Module: $RCSfile: gdcmFileHelper.cxx,v $
Language: C++
- Date: $Date: 2005/10/18 12:49:55 $
- Version: $Revision: 1.61 $
+ Date: $Date: 2005/10/21 12:06:06 $
+ Version: $Revision: 1.67 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
SetWriteFileTypeToACR();
// SetWriteFileTypeToImplicitVR(); // ACR IS implicit VR !
break;
+ case JPEG:
+ SetWriteFileTypeToJPEG();
+ std::cerr << "Writting as JPEG" << std::endl;
+ break;
}
CheckMandatoryElements();
}
bool check = CheckWriteIntegrity(); // verifies length
+ if (WriteType == JPEG ) check = true;
if (check)
{
check = FileInternal->Write(fileName,WriteType);
/**
* \brief Sets in the File the TransferSyntax to 'Explicit VR Little Endian"
*/
+void FileHelper::SetWriteFileTypeToJPEG()
+{
+ std::string ts = Util::DicomString(
+ Global::GetTS()->GetSpecialTransferSyntax(TS::JPEGBaselineProcess1) );
+
+ DataEntry *tss = CopyDataEntry(0x0002,0x0010);
+ tss->SetString(ts);
+
+ Archive->Push(tss);
+}
+
void FileHelper::SetWriteFileTypeToExplicitVR()
{
std::string ts = Util::DicomString(
DocEntry *oldE = FileInternal->GetDocEntry(group, elem);
DataEntry *newE;
- if ( oldE && vr != GDCM_UNKNOWN )
- if ( oldE->GetVR()!=vr )
+ if ( oldE && vr != GDCM_VRUNKNOWN )
+ if ( oldE->GetVR() != vr )
oldE = NULL;
if ( oldE )
void FileHelper::CheckMandatoryElements()
{
+ std::string sop = Util::CreateUniqueUID();
+
// just to remember : 'official' 0002 group
if ( WriteType != ACR && WriteType != ACR_LIBIDO )
{
e_0002_0001->SetLength(2);
Archive->Push(e_0002_0001);
- // 'Media Stored SOP Class UID'
- // [Secondary Capture Image Storage]
- CopyMandatoryEntry(0x0002,0x0002,"1.2.840.10008.5.1.4.1.1.7");
+ // Potentialy post-processed image --> [Secondary Capture Image Storage]
+ // 'Media Storage SOP Class UID'
+ CopyMandatoryEntry(0x0002,0x0002,"1.2.840.10008.5.1.4.1.1.7");
- // 'Media Stored SOP Instance UID'
- CopyMandatoryEntry(0x0002,0x0003,Util::CreateUniqueUID());
-
+ // 'Media Storage SOP Instance UID'
+ CopyMandatoryEntry(0x0002,0x0003,sop);
+
// 'Implementation Class UID'
CopyMandatoryEntry(0x0002,0x0012,Util::CreateUniqueUID());
// 'Image Type' (The written image is no longer an 'ORIGINAL' one)
CopyMandatoryEntry(0x0008,0x0008,"DERIVED\\PRIMARY");
- }
- else
- {
- // There was no 'SOP Class UID'.
- // the source image was NOT a true Dicom one.
- // We consider the image is a 'Secondary Capture' one
- // SOP Class UID
- // [Secondary Capture Image Storage]
- SetMandatoryEntry(0x0008,0x0016,"1.2.840.10008.5.1.4.1.1.7");
}
+ // At the end, not to overwrite the original ones,
+ // needed by 'Referenced SOP Instance UID', 'Referenced SOP Class UID'
+ // 'SOP Instance UID'
+ CopyMandatoryEntry(0x0008,0x0018,sop);
+
+ // whether a 'SOP Class UID' already exists or not in the original image
+ // the gdcm written image *is* a [Secondary Capture Image Storage] !
+ // 'SOP Class UID' : [Secondary Capture Image Storage]
+ CopyMandatoryEntry(0x0008,0x0016,"1.2.840.10008.5.1.4.1.1.7");
+
// ---- The user will never have to take any action on the following ----.
// new value for 'SOP Instance UID'
- SetMandatoryEntry(0x0008,0x0018,Util::CreateUniqueUID());
+ //SetMandatoryEntry(0x0008,0x0018,Util::CreateUniqueUID());
// Instance Creation Date
CopyMandatoryEntry(0x0008,0x0012,Util::GetCurrentDate().c_str());
// Entries whose type is 2c are mandatory-inside-a-Sequence
// Entries whose type is 3 are optional
- // 'Serie Instance UID'
- // Keep the value if exists
- // The user is allowed to create his own Series,
- // keeping the same 'Serie Instance UID' for various images
- // The user shouldn't add any image to a 'Manufacturer Serie'
- // but there is no way no to allowed him to do that
- CheckMandatoryEntry(0x0020,0x000e,Util::CreateUniqueUID());
-
// 'Study Instance UID'
// Keep the value if exists
// The user is allowed to create his own Study,
// adding new series to an already existing Study
CheckMandatoryEntry(0x0020,0x000d,Util::CreateUniqueUID());
+ // 'Serie Instance UID'
+ // Keep the value if exists
+ // The user is allowed to create his own Series,
+ // keeping the same 'Serie Instance UID' for various images
+ // The user shouldn't add any image to a 'Manufacturer Serie'
+ // but there is no way no to allowed him to do that
+ CheckMandatoryEntry(0x0020,0x000e,Util::CreateUniqueUID());
+
// Modality : if missing we set it to 'OTher'
CheckMandatoryEntry(0x0008,0x0060,"OT");