Dicom文件基本操作

官方文档

网址:https://github.com/fo-dicom/fo-dicom
托管在github上。

官方例子

Dicom文件基本操作

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

file中保存了dicomFile信息。

var dataSet =file.Dataset(); // dataSet中保存的是dcm的基本数据,标签信息及piexldata信息。

读取标签var patientid = file.Dataset.Get<string>(DicomTag.PatientID);

添加并修改标签file.Dataset.Add(DicomTag.PatientsName, "DOE^JOHN");

改变TransferSyntax属性,用图像数据的压缩等。file = file.ChangeTransferSyntax(DicomTransferSyntax.JPEGProcess14SV1);

file.Save(@"output.dcm"); // 保存文件到本地file.Dataset.Remove(DicomTag.PixelData); 删除标签

图像操作

图像数据存贮在PixelData中,根据其DicomTag.NumberOfFrames帧数的设置,可知其有多少帧图像数据。获取第一帧图像数据可用var pixel = DicomPixelData.Create(file.Dataset);var frame = pixel.GetFrame(0);得到第一帧数据,可在此数据中进行设置,或者这样idx第几帧var header = DicomPixelData.Create(dataset);var pixelData = PixelDataFactory.Create(header, idx);

图像压缩解决方案

可使用 file = file.ChangeTransferSyntax(DicomTransferSyntax.ExplicitVRLittleEndian);
进行解压缩。
然后在设置 file = file.ChangeTransferSyntax(DicomTransferSyntax.JPEG2000Lossless);进行压缩。

图像显示

1
2
3
4
var image = new DicomImage(@"test.dcm");
image.RenderImage().AsBitmap().Save(@ "test.jpg");
ImageManager.SetImplementation(WPFImageManager.Instance);
(WriteableBitmap) image.RenderImage().AsWriteableBitmap();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值