【发布时间】:2014-01-26 21:55:50
【问题描述】:
在前一段时间我问过的上一个问题中,我可以将一个图像写入 Dicom,但现在我需要在 Dicon 文件中以帧的顺序写入两个或多个 jpg 图像。使用 dcm4che3。请有人帮忙吗?
public static void main(String[] args) throws Exception {
Attributes attrs = new Attributes();
String ts = UID.JPEG2000;
Attributes fmi = Attributes.createFileMetaInformation("1.2.3", UID.MRImageStorage , ts);
File f = new File("/tmp/taylor.jpg");
BufferedImage vf = ImageIO.read(f);
attrs.setString(Tag.PatientName, VR.AE, "Test");
attrs.setString(Tag.PatientSex, VR.CS, "M");
attrs.setString(Tag.PatientID, VR.CS, "10");
attrs.setString(Tag.PatientBirthDate, VR.AS, "19861010");
attrs.setString(Tag.StudyDate, VR.AS, "20140126");
attrs.setString(Tag.SeriesDate, VR.AS, "20140126");
attrs.setString(Tag.StudyTime, VR.AS, "101010");
attrs.setString(Tag.SeriesTime, VR.AS, "101010");
attrs.setString(Tag.StudyDescription, VR.AS, "Test #1");
attrs.setString(Tag.SeriesDescription, VR.AS, "Test #2");
attrs.setString(Tag.Modality, VR.CS, "MR");
attrs.setInt(Tag.Columns, VR.US, vf.getWidth());
attrs.setInt(Tag.Rows, VR.US, vf.getHeight());
attrs.setInt(Tag.InstanceNumber, VR.US, 1);
attrs.setInt(Tag.SamplesPerPixel, VR.IS, 3);
attrs.setString(Tag.PhotometricInterpretation, VR.CS, "MONOCHROME2");
attrs.setInt(Tag.BitsAllocated, VR.IS, 8);
attrs.setInt(Tag.BitsStored, VR.IS, 8);
attrs.setInt(Tag.NumberOfFrames, VR.IS, 5);
attrs.setInt(Tag.SeriesNumber, VR.IS, 2);
DataBufferByte buff = (DataBufferByte) vf.getData().getDataBuffer();
Fragments fr = attrs.newFragments(Tag.PixelData, VR.OW, 1);
for (int i = 0; i < 5; i++) {
fr.add(buff.getData(0));
}
attrs.trimToSize();
File fi = new File("/tmp/test.dcm");
System.out.println(fi.getCanonicalPath());
System.out.println(fmi);
System.out.println(attrs);
DicomOutputStream dos = new DicomOutputStream(fi);
dos.writeDataset(fmi, attrs);
dos.finish();
dos.close();
}
此代码用于创建 dcm 文件,但我无法使用 Weasis 查看器打开它。
【问题讨论】: