Gets the number of items under the VOI LUT Sequence (0028,3010).
public int VoiLutCount {get;} Public ReadOnly Property VoiLutCount As Integer public int VoiLutCount {get;} get_VoiLutCount(); public:property int VoiLutCount {int get();}
The number of items under the VOI LUT Sequence.
This property gets the number of items under the VOI LUT Sequence (0028,3010). If this Sequence does not exist in the Data Set, the property specifies 0.
This example will load a DICOM dataset, update its VOI LUT and then verify that it was updated properly.
using Leadtools;using Leadtools.Dicom;public void TestVoiLut(){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 applicationDicomEngine.Startup();using (DicomDataSet ds = new DicomDataSet()){int VoiLutSize = 65536;//Load DICOM Fileds.Load(dicomFileName, DicomDataSetLoadFlags.None);ds.DeleteVoiLut();DicomVoiLutAttributes VoiLutAttributes = new DicomVoiLutAttributes();VoiLutAttributes.FirstStoredPixelValueMapped = 0;VoiLutAttributes.EntryBits = 16;VoiLutAttributes.NumberOfEntries = VoiLutSize;int[] LutData = new int[VoiLutSize];for (int i = 0; i < VoiLutSize; i++){LutData[i] = i;}ds.SetVoiLut(0, VoiLutAttributes, LutData);DicomVoiLutAttributes attributes = ds.GetVoiLut(0);if (attributes != null){Debug.Assert(attributes.FirstStoredPixelValueMapped == 0);Debug.Assert(attributes.EntryBits == 16);Debug.Assert(attributes.NumberOfEntries == VoiLutSize);int[] data = ds.GetVoiLutData(0);// Do something with the data}ds.Save(Path.Combine(LEAD_VARS.ImagesDir, "VOILut.dcm"), DicomDataSetSaveFlags.None);}DicomEngine.Shutdown();}static class LEAD_VARS{public const string ImagesDir = @"C:\Users\Public\Documents\LEADTOOLS Images";}
Imports LeadtoolsImports Leadtools.DicomPublic Sub TestVoiLut()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 applicationDicomEngine.Startup()Dim ds As DicomDataSet = New DicomDataSet()Using (ds)Dim VoiLutSize As Integer = 65536'Load DICOM Fileds.Load(dicomFileName, DicomDataSetLoadFlags.None)ds.DeleteVoiLut()Dim VoiLutAttributes As DicomVoiLutAttributes = New DicomVoiLutAttributes()VoiLutAttributes.FirstStoredPixelValueMapped = 0VoiLutAttributes.EntryBits = 16VoiLutAttributes.NumberOfEntries = VoiLutSizeDim LutData As Integer() = New Integer(VoiLutSize - 1) {}Dim i As Integer = 0Do While i < VoiLutSizeLutData(i) = ii += 1Loopds.SetVoiLut(0, VoiLutAttributes, LutData)Dim attributes As DicomVoiLutAttributes = ds.GetVoiLut(0)If Not attributes Is Nothing ThenDebug.Assert(attributes.FirstStoredPixelValueMapped = 0)Debug.Assert(attributes.EntryBits = 16)Debug.Assert(attributes.NumberOfEntries = VoiLutSize)Dim data As Integer() = ds.GetVoiLutData(0)' Do something with the dataEnd Ifds.Save(Path.Combine(LEAD_VARS.ImagesDir, "VOILut.dcm"), DicomDataSetSaveFlags.None)End UsingDicomEngine.Shutdown()End SubPublic NotInheritable Class LEAD_VARSPublic Const ImagesDir As String = "C:\Users\Public\Documents\LEADTOOLS Images"End Class
using Leadtools;using Leadtools.Dicom;using Leadtools.Examples;public void TestVoiLut(Stream dicomStream, Stream outputStream){//Make sure to initialize the DICOM engine, this needs to be done only once//In the whole applicationDicomEngine.Startup();using (DicomDataSet ds = new DicomDataSet()){int VoiLutSize = 65536;//Load DICOM Fileds.Load(dicomStream, DicomDataSetLoadFlags.None);ds.DeleteVoiLut();DicomVoiLutAttributes VoiLutAttributes = new DicomVoiLutAttributes();VoiLutAttributes.FirstStoredPixelValueMapped = 0;VoiLutAttributes.EntryBits = 16;VoiLutAttributes.NumberOfEntries = VoiLutSize;int[] LutData = new int[VoiLutSize];for (int i = 0; i < VoiLutSize; i++){LutData[i] = i;}ds.SetVoiLut(0, VoiLutAttributes, LutData);DicomVoiLutAttributes attributes = ds.GetVoiLut(0);if (attributes != null){Debug.Assert(attributes.FirstStoredPixelValueMapped == 0);Debug.Assert(attributes.EntryBits == 16);Debug.Assert(attributes.NumberOfEntries == VoiLutSize);int[] data = ds.GetVoiLutData(0);// Do something with the data}ds.Save(outputStream, DicomDataSetSaveFlags.None);}DicomEngine.Shutdown();}
Imports LeadtoolsImports Leadtools.DicomPublic Sub TestVoiLut(ByVal dicomStream As Stream, ByVal outputStream As Stream)'Make sure to initialize the DICOM engine, this needs to be done only once'In the whole applicationDicomEngine.Startup()Using ds As DicomDataSet = New DicomDataSet()Dim VoiLutSize As Integer = 65536'Load DICOM Fileds.Load(dicomStream, DicomDataSetLoadFlags.None)ds.DeleteVoiLut()Dim VoiLutAttributes As DicomVoiLutAttributes = New DicomVoiLutAttributes()VoiLutAttributes.FirstStoredPixelValueMapped = 0VoiLutAttributes.EntryBits = 16VoiLutAttributes.NumberOfEntries = VoiLutSizeDim LutData As Integer() = New Integer(VoiLutSize - 1) {}Dim i As Integer = 0Do While i < VoiLutSizeLutData(i) = ii += 1Loopds.SetVoiLut(0, VoiLutAttributes, LutData)Dim attributes As DicomVoiLutAttributes = ds.GetVoiLut(0)If Not attributes Is Nothing ThenDebug.Assert(attributes.FirstStoredPixelValueMapped = 0)Debug.Assert(attributes.EntryBits = 16)Debug.Assert(attributes.NumberOfEntries = VoiLutSize)Dim data As Integer() = ds.GetVoiLutData(0)' Do something with the dataEnd Ifds.Save(outputStream, DicomDataSetSaveFlags.None)End UsingDicomEngine.Shutdown()End Sub
|
Products |
Support |
Feedback: VoiLutCount Property - Leadtools.Dicom |
Introduction |
Help Version 19.0.2017.6.16
|

Raster .NET | C API | C++ Class Library | JavaScript HTML5
Document .NET | C API | C++ Class Library | JavaScript HTML5
Medical .NET | C API | C++ Class Library | JavaScript HTML5
Medical Web Viewer .NET
Your email has been sent to support! Someone should be in touch! If your matter is urgent please come back into chat.
Chat Hours:
Monday - Friday, 8:30am to 6pm ET
Thank you for your feedback!
Please fill out the form again to start a new chat.
All agents are currently offline.
Chat Hours:
Monday - Friday
8:30AM - 6PM EST
To contact us please fill out this form and we will contact you via email.