Products | Support | Email a link to this topic. | Send comments on this topic. | Back to Introduction - All Topics | Help Version 19.0.3.25
|
Leadtools.Dicom Namespace > DicomDataSet Class > GetModalityLutAttributes Method : GetModalityLutAttributes() Method |
public DicomModalityLutAttributes GetModalityLutAttributes()
'Declaration
Public Overloads Function GetModalityLutAttributes() As DicomModalityLutAttributes
'Usage
Dim instance As DicomDataSet Dim value As DicomModalityLutAttributes value = instance.GetModalityLutAttributes()
public DicomModalityLutAttributes GetModalityLutAttributes()
public DicomModalityLutAttributes getModalityLutAttributes()
function Leadtools.Dicom.DicomDataSet.GetModalityLutAttributes()()
public: DicomModalityLutAttributes^ GetModalityLutAttributes();
If the method finds the "Rescale Intercept" (0028,1052) and "Rescale Slope" (0028,1053) elements, it will set IsRescaleSlopeIntercept to true and populate RescaleIntercept, RescaleSlope, and RescaleType with the values retrieved from the DICOM Data Set.
If the method finds "Modality LUT Sequence" (0028,3000), it will set IsModalityLutSequence to true and populate FirstStoredPixelValueMapped, NumberOfEntries, EntryBits, LutExplanation, and 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.
This example will extract the modality LUT information from a DICOM dataset.
Imports Leadtools Imports Leadtools.Dicom <TestMethod()> _ Public Sub TestGetModalityLutAttributes() Dim dicomFileName As String = Path.Combine(LEAD_VARS.ImagesDir, "IMAGE3.dcm") '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 Public NotInheritable Class LEAD_VARS Public Const ImagesDir As String = "C:\Users\Public\Documents\LEADTOOLS Images" End Class
using Leadtools; using Leadtools.Dicom; [TestMethod] public void TestGetModalityLutAttributes() { string dicomFileName = Path.Combine(LEAD_VARS.ImagesDir, "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); DicomModalityLutAttributes modalityLutAttributes = ds.GetModalityLutAttributes(); if (modalityLutAttributes != null && modalityLutAttributes.IsModalityLutSequence) { int[] ModalityLutData = ds.GetModalityLutData(); } } DicomEngine.Shutdown(); } static class LEAD_VARS { public const string ImagesDir = @"C:\Users\Public\Documents\LEADTOOLS Images"; }
using Leadtools.Dicom.Constants; using Leadtools; using Leadtools.Dicom; [TestMethod] public async Task TestGetModalityLutAttributes() { //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 string filePath = @"Assets\IMAGE3.dcm"; StorageFile file = await Tools.AppInstallFolder.GetFileAsync(filePath); ILeadStream stream = LeadStreamFactory.Create(file); bool success = await ds.LoadAsync(stream, DicomDataSetLoadFlags.None); Debug.Assert(success); DicomModalityLutAttributes modalityLutAttributes = ds.GetModalityLutAttributes(); if (modalityLutAttributes != null && modalityLutAttributes.IsModalityLutSequence) { int[] ModalityLutData = ds.GetModalityLutData(); } } DicomEngine.Shutdown(); }
using Leadtools; using Leadtools.Dicom; using Leadtools.Examples; public void TestGetModalityLutAttributes(Stream dicomStream) { //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(dicomStream, DicomDataSetLoadFlags.None); DicomModalityLutAttributes modalityLutAttributes = ds.GetModalityLutAttributes(); if (modalityLutAttributes != null && modalityLutAttributes.IsModalityLutSequence) { int[] ModalityLutData = ds.GetModalityLutData(); } } DicomEngine.Shutdown(); }
Imports Leadtools Imports Leadtools.Dicom Public Sub TestGetModalityLutAttributes(ByVal dicomStream As Stream) 'Make sure to initialize the DICOM engine, this needs to be done only once 'In the whole application DicomEngine.Startup() Using ds As DicomDataSet = New DicomDataSet() 'Load DICOM File ds.Load(dicomStream, 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