一、简介
ofxTimeMeasurements是一款用于OpenFrameworks 开源C++框架的插件,可以让使用者轻松测量C++代码任何部分的执行时间。其优势在于以图形化的方式显示代码执行时间。效果如下:
只是它必须依赖OpenFrameworks,所以如果你不用这个框架,还是推荐用我之前写的《C++计算打印函数和代码块的执行时间(支持所有类型函数)》,来测量代码执行时间吧,那样更方便。
二、下载编译OpenFrameworks
首先下载OpenFrameworks。vs2017可以直接在 “拓展”->“管理扩展”->“联机” 中搜索和下载到此插件。但vs2019或更高版本的vs中则不行,必须手动下载安装。我用的是vs2019,下面演示在vs2019中手动安装的方法。
下载 https://openframeworks.cc/versions/v0.10.1/of_v0.10.1_vs2017_release.zip
解压,进入目录libs\openFrameworksCompiled\project\vs,打开openframeworksLib.sln
“生成”
完成后可以看到在libs\openFrameworksCompiled\lib\vs\Win32中生成了openframeworksLib_debug.lib
三、下载编译ofxTimeMeasurements例程
在 https://github.com/armadillu/ofxTimeMeasurements 下载ofxTimeMeasurements源码
新建vs控制台程序。按照如下结构将其头文件和源文件放进去。
“视图”->“属性管理器”
添加新项目属性表
“PropertySheet” -> “属性” -> “用户宏” 将openFrameworksCompiled的根目录路径添加进去
“PropertySheet” -> “属性” -> “C/C++” -> “常规” ->“附加包含目录” ,添加如下路径
$(OF_ROOT)\libs\openFrameworks
$(OF_ROOT)\libs\openFrameworks\graphics
$(OF_ROOT)\libs\openFrameworks\app
$(OF_ROOT)\libs\openFrameworks\sound
$(OF_ROOT)\libs\openFrameworks\utils
$(OF_ROOT)\libs\openFrameworks\communication
$(OF_ROOT)\libs\openFrameworks\video
$(OF_ROOT)\libs\openFrameworks\types
$(OF_ROOT)\libs\openFrameworks\math
$(OF_ROOT)\libs\openFrameworks\3d
$(OF_ROOT)\libs\openFrameworks\gl
$(OF_ROOT)\libs\openFrameworks\events
$(OF_ROOT)\libs\glm\include
$(OF_ROOT)\libs\rtAudio\include
$(OF_ROOT)\libs\quicktime\include
$(OF_ROOT)\libs\freetype\include
$(OF_ROOT)\libs\freetype\include\freetype2
$(OF_ROOT)\libs\freeImage\include
$(OF_ROOT)\libs\fmod\include
$(OF_ROOT)\libs\videoInput\include
$(OF_ROOT)\libs\glew\include\
$(OF_ROOT)\libs\glu\include
$(OF_ROOT)\libs\tess2\include
$(OF_ROOT)\libs\cairo\include\cairo
$(OF_ROOT)\libs\glfw\include
$(OF_ROOT)\libs\openssl\include
$(OF_ROOT)\libs\utf8\include
$(OF_ROOT)\libs\boost\include
$(OF_ROOT)\libs\json\include
$(OF_ROOT)\libs\curl\include
$(OF_ROOT)\libs\uriparser\include
$(OF_ROOT)\libs\pugixml\include
$(OF_ROOT)\addons
“PropertySheet” -> “属性” -> “链接器” -> “常规” -> “附加库目录” ,添加如下路径
$(OF_ROOT)\libs\glfw\lib\vs\Win32
$(OF_ROOT)\libs\rtAudio\lib\vs\Win32
$(OF_ROOT)\libs\FreeImage\lib\vs\Win32
$(OF_ROOT)\libs\freetype\lib\vs\Win32
$(OF_ROOT)\libs\fmod\lib\vs\Win32
$(OF_ROOT)\libs\videoInput\lib\vs\Win32
$(OF_ROOT)\libs\cairo\lib\vs\Win32
$(OF_ROOT)\libs\glew\lib\vs\Win32
$(OF_ROOT)\libs\glu\lib\vs\Win32
$(OF_ROOT)\libs\openssl\lib\vs\Win32
$(OF_ROOT)\libs\curl\lib\vs\Win32
$(OF_ROOT)\libs\tess2\lib\vs\Win32
$(OF_ROOT)\libs\boost\lib\vs\Win32
$(OF_ROOT)\libs\uriparser\lib\vs\Win32
$(OF_ROOT)\libs\pugixml\lib\vs\Win32
$(OF_ROOT)\libs\openFrameworksCompiled\lib\vs\Win32
“PropertySheet” -> “属性” -> “链接器” -> “输入” -> “附加依赖项”,添加如下路径
cairo-static.lib
pixman-1.lib
libpng.lib
zlib.lib
msimg32.lib
OpenGL32.lib
GLu32.lib
kernel32.lib
setupapi.lib
Vfw32.lib
comctl32.lib
rtAudioD.lib
videoInputD.lib
libfreetype.lib
FreeImage.lib
dsound.lib
user32.lib
gdi32.lib
winspool.lib
comdlg32.lib
advapi32.lib
shell32.lib
ole32.lib
oleaut32.lib
uuid.lib
glew32s.lib
fmod_vc.lib
glu32.lib
libssl.lib
libcrypto.lib
crypt32.lib
libcurl.lib
uriparser.lib
pugixmld.lib
Ws2_32.lib
tess2.lib
glfw3.lib
winmm.lib
odbc32.lib
odbccp32.lib
wldap32.lib
openframeworksLib_debug.lib
“解决方案资源管理器”
“属性” -> “C/C++” -> “常规” -> “附加包含目录” ,将ofxTimeMeasurements的头文件和源文件目录包含进去。
“SDL检查” -> 否
“预处理器定义”,添加:_CRT_SECURE_NO_DEPRECATE
_SCL_SECURE_NO_DEPRECATE
BOOST_CONFIG_SUPPRESS_OUTDATED_MESSAGE
“代码生成” -> “运行库” -> “多线程调试 DLL (/MDd)”
“链接器” -> “命令行” -> /NODEFAULTLIB:"libcmt.lib"
编译项目,编译过程中可能还有点小报错,根据提示修改即可。
将of_v0.11.2_vs2017_release\libs\fmod\lib\vs\Win32中的fmod.dll、fmodL.dll
of_v0.11.2_vs2017_release\libs\FreeImage\lib\vs\Win32中的FreeImage.dll
拷贝到当前项目目录中
然后运行即可看到效果:
四、参考文章
《visual studio setup guide》
《The setup to use oF with VS 2019》
《Installing openFrameworks on Visual Studio 2019 for Windows》