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();


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM