DCMTK编译

本文介绍了在编译DCMTK时遇到的Unicode支持问题。由于DCMTK的OFString使用char*接口,强行添加UNICODE定义会导致编译错误。DCMTK的内部日志系统OFLog依赖于log4cplus,但又进行了自定义实现,不支持Unicode编码。若要构建动态库,需开启BUILD_SHARED_LIBS选项,同时为了与宽字节库如QT、LOG4CPLUS兼容,需要手动在接口处进行字符编码转换,避免使用宽字节功能。

VTK/ITK文章列表

dcmtk-3.6.4

使用Unicode?dcmtk的编译选项里没有关于Unicode的选项,OFString的接口里明确使用了OFString(char*)作为构造函数参数,所以,我们可以假设不能够自己擅自在CMakeList.txt里增加一行

add_definitions(-DUNICODE -D_UNICODE)

来强制使用Unicode编码。

亲测:加了之后编译不过

void dcmtk::log4cplus::Logger::forcedLog(const dcmtk::log4cplus::spi::InternalLoggingEvent &) const”: 无法将参数 3 从“int”转换为“const char *”

在dcmtk的源码里是这样的:

OFLogger OFLog::getLogger(const char *loggerName)
{
    OFLog_init();
    // logger objects have a reference counting copy-constructor, so returning by-value is cheap
    return dcmtk::log4cplus::Logger::getInstance(loggerNa
编译 DCMTK(DICOM Toolkit)库通常涉及使用 CMake 工具生成构建配置,并在特定平台上进行编译。以下是适用于 Windows 系统的编译步骤,基于使用 Visual Studio 和 CMake 的常见流程: ### 准备工作 - 下载 DCMTK 源代码:可以从官网 https://dcmtk.org 获取最新的源码包。 - 安装 CMake:建议使用最新版本的 CMake(https://cmake.org/download/)。 - 安装 Visual Studio:支持的版本包括 VS2015、VS2017、VS2019 和 VS2022。[^3] ### 编译流程 #### 1. 使用 CMake 生成构建文件 打开 CMake GUI 工具,设置源码目录和构建目录: - **Where is the source code**: 选择解压后的 DCMTK 源码目录。 - **Where to build the binaries**: 新建一个构建目录,例如 `build_dcmtk`。 点击 `Configure` 按钮,选择合适的 Visual Studio 版本和目标平台(例如 Win64)。配置完成后,点击 `Generate` 生成 Visual Studio 项目文件。 #### 2. 打开并编译 Visual Studio 工程 生成完成后,打开 `build_dcmtk` 目录下的 `.sln` 文件: - 在 Visual Studio 中,选择 `Build > Build Solution` 编译整个解决方案。 - 如果需要调试,可以切换至 `Debug` 模式;如果用于发布,选择 `Release` 模式。 - 编译完成后,生成的库文件(`.lib` 或 `.dll`)将位于 `build_dcmtk/bin` 和 `build_dcmtk/lib` 目录下。[^3] #### 3. 设置环境变量(可选) 为了方便开发和运行,可以将生成的 `.dll` 文件所在目录添加到系统 `PATH` 环境变量中。 #### 4. 集成到项目中 将 DCMTK 的头文件路径(`include` 目录)添加到项目的 `C/C++ -> Additional Include Directories` 中,并在链接器设置中添加对应的 `.lib` 文件路径。 ### 注意事项 - 如果使用较新版本的 Visual Studio(如 VS2019 或 VS2022),需要确保 CMake 支持该版本,否则可能需要更新 CMake 或调整配置。 - 对于旧版本的 Visual Studio(如 VS2005 或 VS2010),建议使用兼容的 CMake 配置以避免兼容性问题 [^2]。 - 若编译过程中遇到错误,建议参考官方文档或社区资源(如 优快云、简书等)获取帮助 [^4]。 ### 示例代码:测试 DCMTK 是否可用 以下是一个简单的代码片段,用于验证 DCMTK 是否成功编译并集成到项目中: ```cpp #include <dcmtk/dcmdata/dctk.h> #include <iostream> int main() { DcmFileFormat fileFormat; OFCondition condition = fileFormat.loadFile("test.dcm"); if (condition.good()) { std::cout << "DICOM 文件加载成功!" << std::endl; } else { std::cout << "无法加载 DICOM 文件。" << std::endl; } return 0; } ``` 确保项目链接了 `dcmdata` 和其他相关库(如 `ofstd`、`dcmimgle` 等),否则会遇到链接错误。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

C++程序员Carea

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值