Fellow Oak DICOM: 强大的跨平台DICOM工具包

fo-dicom

Fellow Oak DICOM: 医学影像开发的利器

Fellow Oak DICOM (fo-dicom) 是一个功能强大、跨平台的DICOM工具包,为医学影像软件开发提供了全面的支持。作为开源项目,fo-dicom 不断发展,目前最新版本为5.x,提供了更加丰富的功能和更好的性能。

主要特性

fo-dicom 的主要特性包括:

  • 支持 .NET Standard 2.0,可在所有兼容的平台上运行
  • 使用最新的 DICOM 字典 (2024c 版本)
  • 高性能的全异步 API,充分利用 async/await
  • 支持 JPEG、JPEG-LS、JPEG2000、HTJPEG2000 和 RLE 图像压缩(需额外包)
  • 可处理非常大的数据集,支持按需加载内容
  • 图像可渲染为 System.Drawing.Bitmap 或 SixLabors.ImageSharp 格式
  • 支持 JSON 和 XML 导入/导出
  • 提供匿名化功能
  • 实现 DICOM 服务
  • 可通过 DI 容器自定义组件

这些特性使 fo-dicom 成为医学影像软件开发的理想工具,能够满足从基础到高级的各种需求。

支持的运行时

fo-dicom 官方支持以下运行时:

  • .NET Core 7.0
  • .NET Core 6.0
  • .NET Framework 4.6.2

其他实现了 .NET Standard 2.0 的运行时也可能兼容,但需注意官方 CI 管道仅在 Windows 上测试了上述平台。

安装与使用

fo-dicom 可以通过 NuGet 包管理器轻松安装。主要的 NuGet 包有:

包名描述
fo-dicom核心包,包含解析器、服务和工具
fo-dicom.Imaging.Desktop用于渲染位图的 System.Drawing 引用库
fo-dicom.Imaging.ImageSharp用于跨平台渲染的 ImageSharp 引用库
fo-dicom.Codecs由 Efferent Health 开发的跨平台 DICOM 编解码器

要开始使用 fo-dicom,首先需要在项目中添加相关的 NuGet 包。然后,可以使用 DicomSetupBuilder 来配置 fo-dicom 的内部组件:

new DicomSetupBuilder()
    .RegisterServices(s => s.AddFellowOakDicom())
    .Build();

文件操作示例

fo-dicom 提供了简单直观的 API 来处理 DICOM 文件:

// 打开 DICOM 文件
var file = await DicomFile.OpenAsync(@"test.dcm");

// 读取患者 ID
var patientId = file.Dataset.GetString(DicomTag.PatientID);

// 更新患者姓名
file.Dataset.AddOrUpdate(DicomTag.PatientName, "DOE^JOHN");

// 保存修改后的文件
await file.SaveAsync(@"output.dcm");

图像渲染

fo-dicom 支持将 DICOM 图像渲染为常见的图像格式:

var image = new DicomImage(@"test.dcm");
image.RenderImage().AsBitmap().Save(@"test.jpg");

DICOM 网络服务

fo-dicom 还提供了实现 DICOM 网络服务的功能,例如 C-STORE、C-FIND、C-MOVE 等:

// C-STORE SCU 示例
var client = DicomClientFactory.Create("127.0.0.1", 12345, false, "SCU", "ANY-SCP");
await client.AddRequestAsync(new DicomCStoreRequest(@"test.dcm"));
await client.SendAsync();

// C-ECHO SCU/SCP 示例
var server = DicomServerFactory.Create<DicomCEchoProvider>(12345);

var client = DicomClientFactory.Create("127.0.0.1", 12345, false, "SCU", "ANY-SCP");
client.NegotiateAsyncOps();
for (int i = 0; i < 10; i++)
    await client.AddRequestAsync(new DicomCEchoRequest());
await client.SendAsync();

依赖注入支持

fo-dicom 5.x 版本引入了依赖注入支持,使代码更加模块化和可测试:

var services = new ServiceCollection();
services.AddFellowOakDicom();
var serviceProvider = services.BuildServiceProvider();
DicomSetupBuilder.UseServiceProvider(serviceProvider);

通过依赖注入,可以更灵活地配置和扩展 fo-dicom 的功能。

日志记录

fo-dicom 使用 Microsoft.Extensions.Logging 进行日志记录,可以轻松集成到现有的日志系统中:

services.AddLogging(logging =>
{
    logging.AddConsole();
    logging.SetMinimumLevel(LogLevel.Information);
});

结语

Fellow Oak DICOM 为医学影像软件开发提供了强大而灵活的工具。无论是处理 DICOM 文件、渲染图像,还是实现复杂的 DICOM 网络服务,fo-dicom 都能够胜任。其跨平台支持和开源特性,使其成为医疗影像领域开发者的首选工具之一。

对于那些刚接触 DICOM 的开发者,推荐查看 Saravanan Subramanian 的 DICOM 教程:My DICOM Tutorials。该教程中也使用了 fo-dicom 的一些代码示例,可以帮助你更好地理解和使用这个强大的工具包。

随着医疗影像技术的不断发展,fo-dicom 也在持续更新和改进。开发者可以通过 GitHub 页面关注项目的最新动态,参与讨论,甚至为项目贡献代码。无论你是医疗软件开发新手,还是经验丰富的专家,Fellow Oak DICOM 都将是你在 DICOM 开发领域的得力助手。

文章链接:www.dongaigc.com/a/fellow-oak-dicom-cross-platform-toolkit

https://www.dongaigc.com/a/fellow-oak-dicom-cross-platform-toolkit

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值