更新:Imebra 4.2 包含一整套 ObjectiveC 包装器,它们也适用于 Swift。
原答案:
Imebra 允许在 iOS 上读取和生成 DICOM 文件。
它也可以为 iOS 和 OS-X 编译,它是用 C++ 编写的,但如果文件的扩展名是 .mm 而不是 .m,它可以与 ObjectiveC 方法一起使用
从 4.0.8.1 版开始,Imebra 还包含少量 objectiveC helpers,可将 C++ 字符串转换为 NSString(反之亦然)并从 Imebra 图像中提取 UIImage(或 NSImage)
如何在 Imebra (detailed instructions) 中生成 DICOM 文件:
创建一个空数据集:
// We specify the transfer syntax and the charset
std::string transferSyntax(imebra::NSStringToString(@"1.2.840.10008.1.2.1"));
std::string encoding(imebra::NSStringToString(@"ISO 2022 IR 6"));
imebra::DataSet dataSet(transferSyntax, encoding);
创建一张图片,放入数据集中:
// Create a 300 by 200 pixel image, 15 bits per color channel, RGB
std::string colorSpace(imebra::NSStringToString(@"RGB"));
imebra::Image image(300, 200, imebra::bitDepth_t::depthU16, colorSpace, 15);
{
std::unique_ptr<WritingDataHandlerNumeric> dataHandler(image.getWritingDataHandler());
// Set all the pixels to red
for(std::uint32_t scanY(0); scanY != 200; ++scanY)
{
for(std::uint32_t scanX(0); scanX != 300; ++scanX)
{
dataHandler->setUnsignedLong((scanY * 300 + scanX) * 3, 65535);
dataHandler->setUnsignedLong((scanY * 300 + scanX) * 3 + 1, 0);
dataHandler->setUnsignedLong((scanY * 300 + scanX) * 3 + 2, 0);
}
}
// dataHandler will go out of scope and will commit the data into the image
}
dataSet.setImage(0, image);
保存数据集
std::string fileName(NSStringToString(@"path/to/file.dcm"));
imebra::CodecFactory::save(dataSet, fileName, imebra::codecType_t::dicom);
(声明:我是 Imebra 的作者)