←Select platform

DicomSetImageFlags Enumeration

Summary
Represents the values that control the behavior of the InsertImage and SetImage methods.
Syntax
C#
C++/CLI
Java
[FlagsAttribute()] 
public enum DicomSetImageFlags   
public class DicomSetImageFlags 
[FlagsAttribute()] 
public enum class DicomSetImageFlags   
Members
ValueMemberDescription
0x00000000None None.
0x00000001AutoSaveOverlays The method will automatically insert the overlays associated with the input image into the dataset.
0x00000002AutoSetVoiLut The method will automatically add a VOI LUT to the dataset.
0x00000004MinimizeJpegSize and the nCompression parameter is IMAGE_COMPRESSION_JPEG_LOSSLESS or IMAGE_COMPRESSION_JPEG_LOSSY, the JPEG compression engine will use optimized Huffman tables, which results in better compression, but slower speed
0x00000008MfgOverwriteShared For SetImage and SetImageList: This flag is ignored.
For all other methods: Existing elements under the Shared Functional Groups Sequence will be overwritten. If this flag is not included, Shared Functional Groups Sequence elements are unchanged.
0x00000010MfgVoiLutPerFrame For SetImage and SetImageList: The Frame VOI LUT Sequence is added under the Per-frame Functional Groups Sequence.

For all other methods:
If the Frame VOI LUT Sequence does not already exist, it is added under the Per-frame Functional Groups Sequence.
If the Frame VOI LUT Sequencealready exists under the Shared Functional Groups Sequence, this flag is ignored.

0x00000020MfgVoiLutShared For SetImage and SetImageList: The Frame VOI LUT Sequence is added under the Shared Functional Groups Sequence.

For all other methods:
If the Frame VOI LUT Sequence does not already exist, it is added under the Shared Functional Groups Sequence.
If the Frame VOI LUT Sequencealready exists under the Per-frame Functional Groups Sequence, this flag is ignored.

0x00000040MfgModalityLutPerFrame For SetImage and SetImageList: The Pixel Value Transformation Sequence is added under the Per-frame Functional Groups Sequence.

For all other methods:
If the Pixel Value Transformation Sequence does not already exist, it is added under the Per-frame Functional Groups Sequence.
If the Pixel Value Transformation Sequencealready exists under the Shared Functional Groups Sequence, this flag is ignored.

0x00000080MfgModalityLutShared For SetImage and SetImageList: The Pixel Value Transformation Sequence is added under the Shared Functional Groups Sequence.

For all other methods:
If the Pixel Value Transformation Sequence does not already exist, it is added under the Shared Functional Groups Sequence.
If the Pixel Value Transformation Sequencealready exists under the Per-frame Functional Groups Sequence, this flag is ignored.

0x00000200OptimizedMemory Enables the method to minimize memory usage by utilizing the disk. The method optimizes memory to the minimum possible.
0x20000000KeepLutsIntact For internal use by LEADTOOLS.
For all other methods: If the *Frame VOI LUT Sequence* does **not** already exist, it is added under the *Per-frame Functional Groups Sequence*. If the *Frame VOI LUT Sequence***already** exists under the *Shared Functional Groups Sequence*, this flag is ignored. | | **0x00000020** | **MfgVoiLutShared** | For SetImage and SetImageList: The *Frame VOI LUT Sequence* is added under the *Shared Functional Groups Sequence*. For all other methods: If the *Frame VOI LUT Sequence* does **not** already exist, it is added under the *Shared Functional Groups Sequence*. If the *Frame VOI LUT Sequence***already** exists under the *Per-frame Functional Groups Sequence*, this flag is ignored. | | **0x00000040** | **MfgModalityLutPerFrame** | For SetImage and SetImageList: The *Pixel Value Transformation Sequence* is added under the *Per-frame Functional Groups Sequence*. For all other methods: If the *Pixel Value Transformation Sequence* does **not** already exist, it is added under the *Per-frame Functional Groups Sequence*. If the *Pixel Value Transformation Sequence***already** exists under the *Shared Functional Groups Sequence*, this flag is ignored. | | **0x00000080** | **MfgModalityLutShared** | For SetImage and SetImageList: The *Pixel Value Transformation Sequence* is added under the *Shared Functional Groups Sequence*. For all other methods: If the *Pixel Value Transformation Sequence* does **not** already exist, it is added under the *Shared Functional Groups Sequence*. If the *Pixel Value Transformation Sequence***already** exists under the *Per-frame Functional Groups Sequence*, this flag is ignored. | | **0x00000200** | **OptimizedMemory** | Enables the method to minimize memory usage by utilizing the disk. The method optimizes memory to the minimum possible. | | **0x20000000** | **KeepLutsIntact** | For internal use by LEADTOOLS. |
Remarks

For Android/Java users: The constant members of this class are defined using all capital letters with underscores between words.

Example
C#
using Leadtools; 
using Leadtools.Dicom; 
 
 
public void TestDicomImage() 
{ 
   string dicomFileName = Path.Combine(LEAD_VARS.ImagesDir, "DICOM", "image3.dcm"); 
   //Make sure to initialize the DICOM engine, this needs to be done only once  
   //In the whole application 
   DicomEngine.Startup(); 
   using (DicomDataSet ds = new DicomDataSet()) 
   { 
      //Load DICOM File 
      ds.Load(dicomFileName, DicomDataSetLoadFlags.None); 
 
      DicomElement pixelDataElement = ds.FindFirstElement(null, DicomTag.PixelData, true); 
      if (pixelDataElement == null) 
      { 
         Console.WriteLine("This dataset is missing the pixel data element", "Sample"); 
         return; 
      } 
 
      if (ds.GetImageCount(pixelDataElement) == 0) 
      { 
         Console.WriteLine("Sample: This dataset has no images"); 
         return; 
      } 
 
      DicomImageInformation imageInformation = ds.GetImageInformation(pixelDataElement, 0); 
      if (imageInformation == null) 
      { 
         Console.WriteLine("Sample: Can't retrieve image information"); 
         return; 
      } 
      // Over here we can access the different properties of the DicomImageInformation class to get some 
      // of the image attributes such as bits allocated (DicomImageInformation. BitsAllocated) 
      RasterImage image = ds.GetImage(pixelDataElement, 
         0, 
         0, 
         RasterByteOrder.Gray, 
         DicomGetImageFlags.AllowRangeExpansion | DicomGetImageFlags.AutoApplyModalityLut | DicomGetImageFlags.AutoApplyVoiLut); 
 
      if (image == null) 
      { 
         Console.WriteLine("Sample: Can't retrieve image"); 
         return; 
      } 
 
      //If the image has more than one frame then we can call DicomDataSet.GetImages to get all the frames 
      using (DicomDataSet ds1 = new DicomDataSet()) 
      { 
         ds1.Initialize(DicomClassType.DXImageStoragePresentation, DicomDataSetInitializeType.ExplicitVRLittleEndian); 
         DicomElement pixelDataElement1 = ds1.FindFirstElement(null, DicomTag.PixelData, true); 
         if (pixelDataElement1 != null) 
         { 
            ds1.SetImage(pixelDataElement1, 
               image, 
               DicomImageCompressionType.None, 
               DicomImagePhotometricInterpretationType.Monochrome2, 
               16, 
               2, 
               DicomSetImageFlags.AutoSetVoiLut); 
            //If we have more than one frame then we can call DicomDataSet.SetImages 
 
            //This is an alternative way to set the image, I will first delete the 
            //existing image and then call DicomDataSet.InsertImage 
            ds1.DeleteElement(pixelDataElement1); 
            pixelDataElement1 = ds1.InsertElement(null, false, DicomTag.PixelData, DicomVRType.UN, false, 0); 
            ds1.InsertImage(pixelDataElement1, 
               image, 
               0, 
               DicomImageCompressionType.None, 
               DicomImagePhotometricInterpretationType.Monochrome2, 
               16, 
               2, 
               DicomSetImageFlags.AutoSetVoiLut); 
            //If we have more than one frame then we can call DicomDataSet.InsertImages 
 
            ds1.Save(Path.Combine(LEAD_VARS.ImagesDir, "DICOM", "Test.dcm"), DicomDataSetSaveFlags.None); 
 
         } 
      } 
      //Load DICOM File 
      ds.Load(dicomFileName, DicomDataSetLoadFlags.None); 
   } 
   DicomEngine.Shutdown(); 
} 
 
static class LEAD_VARS 
{ 
   public const string ImagesDir = @"C:\LEADTOOLS22\Resources\Images"; 
} 
Requirements

Target Platforms

See Also

Reference

Leadtools.Dicom Namespace

Help Version 22.0.2023.1.29
Products | Support | Contact Us | Intellectual Property Notices
© 1991-2023 LEAD Technologies, Inc. All Rights Reserved.

Leadtools.Dicom Assembly
Products | Support | Contact Us | Intellectual Property Notices
© 1991-2023 LEAD Technologies, Inc. All Rights Reserved.