くそー、私は非常にイライラしています...
このページhttp://support.dcmtk.org/docs/mod_dcmjpeg.htmlの例に従って、 JPEG 圧縮された DICOM 画像ファイルを解凍する C++ プログラムを作成しました。
ここで、圧縮されていないものから圧縮されたものへと逆にしたいと思います。同じページで他の例を使用すると、同じ(または他のファイル)コードをコンパイルして実行できますが、ファイルを圧縮できません...
次のコードの後、元の Xfer と Current は同じであることがわかりました。異なる必要があるため、これは良くありません
dataset->chooseRepresentation(EXS_JPEGProcess14SV1, ¶ms);
chooseRepresentation
メソッドが失敗したようなものです....
より多くの行
dataset->canWriteXfer(EXS_JPEGProcess14SV1)
false を返す
dcpixel.cc ファイルで、コードのデバッグを行っていることを確認しました。
DcmPixelData::canChooseRepresentation(.........
....
....
// representation not found, check if we have a codec that can create the
// desired representation.
if (original == repListEnd)
{
result = DcmCodecList::canChangeCoding(EXS_LittleEndianExplicit, toType.getXfer());
}
結果はFALSEです....
どうすれば修正できますか?DCMTK または別のライブラリを使用して DICOM 画像を圧縮するコードを誰かが持っている
これは完全なコードです:
int main()
{
//dcxfer.h
DJDecoderRegistration::registerCodecs(); // register JPEG codecs
DcmFileFormat fileformat;
/**** MONO FILE ******/
if (fileformat.loadFile("Files/cnv3DSlice (1)_cnv.dcm").good())
{
DcmDataset *dataset = fileformat.getDataset();
DcmItem *metaInfo = fileformat.getMetaInfo();
DJ_RPLossless params; // codec parameters, we use the defaults
// this causes the lossless JPEG version of the dataset to be created
dataset->chooseRepresentation(EXS_JPEGProcess14SV1, ¶ms);
// check if everything went well
if (dataset->canWriteXfer(EXS_JPEGProcess14SV1))
{
// force the meta-header UIDs to be re-generated when storing the file
// since the UIDs in the data set may have changed
delete metaInfo->remove(DCM_MediaStorageSOPClassUID);
delete metaInfo->remove(DCM_MediaStorageSOPInstanceUID);
// store in lossless JPEG format
fileformat.saveFile("Files/test_jpeg_compresso.dcm", EXS_JPEGProcess14SV1);
}
}
DJDecoderRegistration::cleanup(); // deregister JPEG codecs
return 0;
}