ofxTimeMeasurements是一款用于OpenFrameworks 开源C++框架的插件,可以让使用者轻松测量C++代码任何部分的执行时间。其优势在于以图形化的方式显示代码执行时间。效果如下:

只是它必须依赖OpenFrameworks,所以如果你不用这个框架,还是推荐用我之前写的《C++计算打印函数和代码块的执行时间(支持所有类型函数)》,来测量代码执行时间吧,那样更方便。
首先下载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

在 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

拷贝到当前项目目录中

然后运行即可看到效果:

《The setup to use oF with VS 2019》
《Installing openFrameworks on Visual Studio 2019 for Windows》