3

ライブラリを使用して、 8 ビットイメージを DICOM ファイルとして正常に書き込みました。現在、 16 ビットイメージを DICOM ファイルとしてGDCM書き込もうとしています。これが私のコードです。私が欠けているものや何をすべきかを誰でも指摘できますか。

static public void CreateSmallDICOMShort(string fileName, short [] buffer, uint[] dim)
  {
      using (var writer = new gdcm.PixmapWriter())
      {
          gdcm.Pixmap img = writer.GetImage();
          img.SetNumberOfDimensions(3);
          var pixelFormat = new PixelFormat();
          pixelFormat.SetScalarType(PixelFormat.ScalarType.UINT16);
          img.SetDimension(0, dim[0]);
          img.SetDimension(1, dim[1]);
          img.SetDimension(2, 1); // fake a 3d volume
          img.SetPixelFormat(pixelFormat);
          PhotometricInterpretation pi = new PhotometricInterpretation(PhotometricInterpretation.PIType.MONOCHROME1);
          img.SetPhotometricInterpretation(pi);
          gdcm.DataElement pixeldata = new gdcm.DataElement(new gdcm.Tag(0x7fe0, 0x0010));
          //byte[] buffer = new byte[512 * 512 * 2];
          pixeldata.SetArray(buffer,(uint)buffer.Length);
          img.SetDataElement(pixeldata);

          gdcm.File file = writer.GetFile();
          gdcm.DataSet ds = file.GetDataSet();
          gdcm.DataElement ms = new gdcm.DataElement(new gdcm.Tag(0x0008, 0x0016));
          string mediastorage = "1.2.840.10008.5.1.4.1.1.7.2"; // Multi-frame Grayscale Byte Secondary Capture Image Storage
          byte[] val = StrToByteArray(mediastorage);
          ms.SetByteValue(val, new gdcm.VL((uint)val.Length));
          ds.Insert(ms);

          writer.SetFileName(fileName);
          writer.Write();
      }
  }
4

2 に答える 2

1

別の機能を使用する必要がありSetArray()ます。画像バッファに 8 ビットのデータ配列を渡しています。16 ビット配列を渡すだけです。例えば:

unsigned short[] buffer = new unsigned short[512 * 512];
pixeldata.SetArray(buffer,(uint)buffer.Length);
于 2014-04-25T15:43:13.890 に答える