vscode 配置opengl (glut), lib链接可参考

2024-03-08 19:44

本文主要是介绍vscode 配置opengl (glut), lib链接可参考,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这里假定你已经配置好基础的vscode c++环境

json介绍

这里其实主要配置的3种json, vscode其实就是通过launch.json和tasks.json来自动生成指令的

  • launch.json

这个用于启动程序用的,但是由于其可以指定preLaunchTask-即在启动之前需要做什么事情,所以这里用来启动编译-链接到最后启动程序等一系列过程
我们可以看到图中左上角,每一个启动方式(c/c++ Runner:Debug Session和c/c++ glut)其实都对应"configurations"数组中的一个json的name属性
在这里插入图片描述

而在这里,我们启动了cmd(program),让cmd去调用我们生成好的程序(args),并且调用完成后再调用pause指令,我们通过preLaunchTask所指向的task完成程序的编译等操作

  • tasks.json

本json中就存放了各种task,每个task都对应一个json,而preLaunchTask就是通过这里每个json的label属性来找是哪个task,这里我们就让task去做3件事情:1.编译,2.链接,3.复制dll

  • c_cpp_properties.json

这个json和程序生成与运行无关,他是用来配置intellisense,这个配置错了,你写代码会有报错,但是编译和生成这些还是正常的,一般就需要注意一下standard和includePath就行
在这里插入图片描述

配置freeglut

  • 下载地址:https://www.transmissionzero.co.uk/software/freeglut-devel/

  • 注意选择mingw

在这里插入图片描述

  • 下载完毕选择一个地方安装解压即可

其中
bin中的dll是运行时需要的
include是编译时需要的,包含目录
lib是连接是需要的,库目录

修改task.json

  • 这里主要通过command后面的指令+args中的参数组成一整个命令行语句然后调用
  • 此外,通过dependsOn 来构成task之间的依赖

创建编译任务 compile

  • 这里command为你的g++.exe的路径,若你将g++的目录添加到了环境变量中,则可以直接使用g++
  • 而args就是各个编译参数:

-I<Include_path>引入包含文件夹,用于编译
-c 指定编译源文件,-o 指定输出的文件,这里生成中间文件.o

  • 可参考代码如下
 {"type": "cppbuild","label": "glut compile","command": "E:/MinGW/bin/g++.exe","args": ["-IE:\\CPP\\OpenGL\\freeglut-MinGW-3.0.0-1.mp\\freeglut\\include","-fdiagnostics-color=always","-g3","-c","${file}","-o","${fileDirname}\\${fileBasenameNoExtension}.o","--std","c++17",],"options": {"cwd": "E:/MinGW/bin"},"problemMatcher": ["$gcc"],"group": {"kind": "build","isDefault": true},"detail": "调试器生成的任务。"},

创建连接任务 link

  • 类似编译,这里同样command为g++,只是args变成链接的参数了,具体为g++ x.o -o y.exe,将x.o链接生成y.exe
  • 那这里既然要链接,就要引入库目录,对应lib目录,指令:-L<lib_path>, 同时要引入库, 指令: -l<lib_name>, 这里lib_name注意不要前面的lib
  • 同时这里本人踩了大坑,g++编译时, -l<lib_name> 必须要放在源文件后面,推荐直接放最后面,不然它还是链接不上
  • 同时你链接需要.o,所以该task, “dependsOn”: [“glut compile”] (上一节的名字)
  • 可参考代码如下:
{"type": "process","label": "glut link","command": "E:/MinGW/bin/g++.exe","args": ["-fdiagnostics-color=always","-g3","${fileDirname}\\${fileBasenameNoExtension}.o","-o","${fileDirname}\\${fileBasenameNoExtension}.exe","--std","c++17","-LE:\\CPP\\OpenGL\\freeglut-MinGW-3.0.0-1.mp\\freeglut\\lib\\","-lopengl32", "-lglu32", "-lfreeglut",],"options": {"cwd": "E:/MinGW/bin"},"problemMatcher": ["$gcc"],"group": {"kind": "build","isDefault": true},"detail": "调试器生成的任务。","dependsOn": ["glut compile"]},

创建移动lib任务 setup

  • 最后要将dll移动到你生成exe的目录下
  • 这里我们使用xcopy指令,注意command
  • 同时"dependsOn": [“glut link”]
  • 参考代码如下:
{"type": "process","label": "glut setup","command": "xcopy","args": ["/y","/d","E:\\CPP\\OpenGL\\freeglut-MinGW-3.0.0-1.mp\\freeglut\\bin\\freeglut.dll","${fileDirname}\\"],"options": {"cwd": "E:/MinGW/bin"},"problemMatcher": ["$gcc"],"group": {"kind": "build","isDefault": true},"detail": "调试器生成的任务。","dependsOn": ["glut link"]},

修改launch.json

  • 最后在launch.json 添加我们的启动json即可
  • 启动的程序为cmd.exe
  • 然后args, 通过cmd调用我们生成的exe,并最后pause
  • 通过 “preLaunchTask”: “glut setup” 来调用我们的task链条
  • 参考代码:
 {"name": "C/C++ glut","type": "cppdbg","request": "launch","stopAtEntry": false,"externalConsole": true,"cwd": "e:/CPP/testVsCode","program": "C:\\Windows\\System32\\cmd.exe","args":["/C", "${fileDirname}\\${fileBasenameNoExtension}.exe", "&","pause"],"MIMode": "gdb","miDebuggerPath": "gdb","setupCommands": [{"description": "Enable pretty-printing for gdb","text": "-enable-pretty-printing","ignoreFailures": true}],"preLaunchTask": "glut setup"}
  • 最后找到对应位置即可编译生成啦
    在这里插入图片描述

补充

  • vscode运行c++时,若想运行在独立控制窗口,那么为了避免窗口瞬间关闭看不到输出,可以使用cmd来调用程序,但是这样会命中不了断点。若想命中断点,且能看到输出,要不用内置控制台,要不在代码末尾补个getchar()

这篇关于vscode 配置opengl (glut), lib链接可参考的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/788189

相关文章

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

hadoop开启回收站配置

开启回收站功能,可以将删除的文件在不超时的情况下,恢复原数据,起到防止误删除、备份等作用。 开启回收站功能参数说明 (1)默认值fs.trash.interval = 0,0表示禁用回收站;其他值表示设置文件的存活时间。 (2)默认值fs.trash.checkpoint.interval = 0,检查回收站的间隔时间。如果该值为0,则该值设置和fs.trash.interval的参数值相等。

NameNode内存生产配置

Hadoop2.x 系列,配置 NameNode 内存 NameNode 内存默认 2000m ,如果服务器内存 4G , NameNode 内存可以配置 3g 。在 hadoop-env.sh 文件中配置如下。 HADOOP_NAMENODE_OPTS=-Xmx3072m Hadoop3.x 系列,配置 Nam

wolfSSL参数设置或配置项解释

1. wolfCrypt Only 解释:wolfCrypt是一个开源的、轻量级的、可移植的加密库,支持多种加密算法和协议。选择“wolfCrypt Only”意味着系统或应用将仅使用wolfCrypt库进行加密操作,而不依赖其他加密库。 2. DTLS Support 解释:DTLS(Datagram Transport Layer Security)是一种基于UDP的安全协议,提供类似于

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

vscode中文乱码问题,注释,终端,调试乱码一劳永逸版

忘记咋回事突然出现了乱码问题,很多方法都试了,注释乱码解决了,终端又乱码,调试窗口也乱码,最后经过本人不懈努力,终于全部解决了,现在分享给大家我的方法。 乱码的原因是各个地方用的编码格式不统一,所以把他们设成统一的utf8. 1.电脑的编码格式 开始-设置-时间和语言-语言和区域 管理语言设置-更改系统区域设置-勾选Bata版:使用utf8-确定-然后按指示重启 2.vscode

沁恒CH32在MounRiver Studio上环境配置以及使用详细教程

目录 1.  RISC-V简介 2.  CPU架构现状 3.  MounRiver Studio软件下载 4.  MounRiver Studio软件安装 5.  MounRiver Studio软件介绍 6.  创建工程 7.  编译代码 1.  RISC-V简介         RISC就是精简指令集计算机(Reduced Instruction SetCom

log4j2相关配置说明以及${sys:catalina.home}应用

${sys:catalina.home} 等价于 System.getProperty("catalina.home") 就是Tomcat的根目录:  C:\apache-tomcat-7.0.77 <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss} [%t] %-5p %c{1}:%L - %msg%n" /> 2017-08-10