Leadtools.Dicom Requires Medical product license | Send comments on this topic. | Back to Introduction - All Topics | Help Version 16.5.9.25
GetModalityLutAttributes() Method
See Also  Example
Leadtools.Dicom Namespace > DicomDataSet Class > GetModalityLutAttributes Method : GetModalityLutAttributes() Method



Retrieves the attributes that describe the Modality LUT.

Syntax

Visual Basic (Declaration) 
Overloads Public Function GetModalityLutAttributes() As DicomModalityLutAttributes
Visual Basic (Usage)Copy Code
Dim instance As DicomDataSet
Dim value As DicomModalityLutAttributes
 
value = instance.GetModalityLutAttributes()
C# 
public DicomModalityLutAttributes GetModalityLutAttributes()
C++/CLI 
public:
DicomModalityLutAttributes^ GetModalityLutAttributes(); 

Return Value

Modality LUT attributes.

Example

This example will extract the modality LUT information from a DICOM dataset.

Visual BasicCopy Code
Public Sub TestGetModalityLutAttributes()
   Dim dicomFileName As String = LeadtoolsExamples.Common.ImagesPath.Path + "IMAGE3.dic"
   'Make sure to initialize the DICOM engine, this needs to be done only once
   'In the whole application
   DicomEngine.Startup()
   Dim ds As DicomDataSet = New DicomDataSet()
   Using (ds)
      'Load DICOM File
      ds.Load(dicomFileName, DicomDataSetLoadFlags.None)
      Dim modalityLutAttributes As DicomModalityLutAttributes = ds.GetModalityLutAttributes()
      If Not modalityLutAttributes Is Nothing AndAlso modalityLutAttributes.IsModalityLutSequence Then
         Dim ModalityLutData As Integer() = ds.GetModalityLutData()
      End If
   End Using

   DicomEngine.Shutdown()
End Sub
C#Copy Code
public void TestGetModalityLutAttributes() 

   string dicomFileName = LeadtoolsExamples.Common.ImagesPath.Path + "IMAGE3.dic"; 
   //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); 
      DicomModalityLutAttributes modalityLutAttributes = ds.GetModalityLutAttributes(); 
      if (modalityLutAttributes != null && modalityLutAttributes.IsModalityLutSequence) 
      { 
         int[] ModalityLutData = ds.GetModalityLutData(); 
      } 
   } 
   DicomEngine.Shutdown(); 
}

Remarks

If the method does not find any of the attributes of the "Modality LUT Module" it will set both DicomModalityLutAttributes.IsModalityLutSequence and DicomModalityLutAttributes.IsRescaleSlopeIntercept to false. In this case, the rest of the members of the DicomModalityLutAttributes class are undefined.

If the method finds the "Rescale Intercept" (0028,1052) and "Rescale Slope" (0028,1053) elements, it will set DicomModalityLutAttributes.IsRescaleSlopeIntercept to true and populate DicomModalityLutAttributes.RescaleIntercept, DicomModalityLutAttributes.RescaleSlope, and DicomModalityLutAttributes.RescaleType with the values retrieved from the DICOM Data Set.

If the method finds "Modality LUT Sequence" (0028,3000), it will set DicomModalityLutAttributes.IsModalityLutSequence to true and populate DicomModalityLutAttributes.FirstStoredPixelValueMapped, DicomModalityLutAttributes.NumberOfEntries, DicomModalityLutAttributes.EntryBits, DicomModalityLutAttributes.LutExplanation, and DicomModalityLutAttributes.LutType with the values retrieved from the DICOM Data Set.

It is prohibited by the DICOM standard for both "Rescale Intercept" and "Modality LUT Sequence" to exist in the same DICOM Data Set. However, if this method encounters such a Data Set, it will ignore "Modality LUT Sequence" and assume that only "Rescale Intercept" exists.

Requirements

Target Platforms: Microsoft .NET Framework 3.0, Windows XP, Windows Server 2003 family, Windows Server 2008 family

See Also

Leadtools.Dicom requires a Medical toolkit server license and unlock key. For more information, refer to: Imaging Pro/Document/Medical Features