public class MedicalViewerMPRCell : MedicalViewerCell             public ref class MedicalViewerMPRCell : public MedicalViewerCell, IAnnAutomationControl, System.ComponentModel.IComponent, System.ComponentModel.INotifyPropertyChanged, System.ComponentModel.ISynchronizeInvoke, System.IDisposable, System.Windows.Forms.IBindableComponent, System.Windows.Forms.IDropTarget, System.Windows.Forms.IWin32Window   For more information, refer to Image Viewer Cells.
using Leadtools;using Leadtools.Dicom;using Leadtools.Medical3D;using Leadtools.Codecs;using Leadtools.MedicalViewer;using Leadtools.ImageProcessing;using Leadtools.ImageProcessing.Core;using Leadtools.ImageProcessing.Color;using Leadtools.Annotations.Engine;using Leadtools.Annotations.Designers;class MedicalViewerMPRForm : Form{private MedicalViewer _medicalViewer;private MedicalViewerSeriesManager _seriesManager;void MedicalViewerMPRForm_SizeChanged(object sender, EventArgs e){_medicalViewer.Size = new Size(this.ClientRectangle.Right, this.ClientRectangle.Bottom);}public MedicalViewerMPRForm(MedicalViewerSeriesManager output){RasterCodecs _codecs = new RasterCodecs();this.SizeChanged += new EventHandler(MedicalViewerMPRForm_SizeChanged);// Create the medical viewer and adjust the size and the location._medicalViewer = new MedicalViewer(2, 2);_medicalViewer.Location = new Point(0, 0);_medicalViewer.Size = new Size(this.ClientRectangle.Right, this.ClientRectangle.Bottom);_seriesManager = output;int index;RasterImage image;int count = output.Stacks[0].Items.Count;CodecsImageInfo codecsInformation;MedicalViewerMPRCell AxialFrame = new MedicalViewerMPRCell();MedicalViewerMPRCell SagittalFrame = new MedicalViewerMPRCell();MedicalViewerMPRCell CoronalFrame = new MedicalViewerMPRCell();codecsInformation = _codecs.GetInformation((string)output.Stacks[0].Items[0].Data, true);int width = codecsInformation.Width;int height = codecsInformation.Height;int depth = 256;// Create a 3D control.Medical3DControl _medical3DControl = new Medical3DControl();_medical3DControl.ObjectsContainer.VolumeType = Medical3DVolumeType.MPR;_medical3DControl.ObjectsContainer.Objects.Add(new Medical3DObject());// Create a 3D object._medical3DControl.ObjectsContainer.Objects[0].MemoryEfficientInit(depth);for (index = 0; index < depth; index++){image = _codecs.Load((string)output.Stacks[0].Items[index].Data, 0, CodecsLoadByteOrder.BgrOrGrayOrRomm, 1, 1);_medical3DControl.ObjectsContainer.Objects[0].MemoryEfficientSetFrame(image, index, true);}string spearator = ("\\");string[] test = output.Stacks[0].Items[0].ImageOrientation.Split(spearator.ToCharArray());float[] orientation = new float[6];int i;for (i = 0; i < 6; i++){orientation[i] = (float)Convert.ToDouble(test[i]);}_medical3DControl.ObjectsContainer.Objects[0].MemoryEfficientEnd(orientation,output.Stacks[0].PixelSpacing);// Create axial frameAxialFrame.ShowMPRCrossHair = true;AxialFrame.DistinguishMPRByColor = true;AxialFrame.SetTag(6, MedicalViewerTagAlignment.TopLeft, MedicalViewerTagType.Frame);AxialFrame.AddAction(MedicalViewerActionType.Stack);AxialFrame.SetAction(MedicalViewerActionType.Stack, MedicalViewerMouseButtons.Wheel, MedicalViewerActionFlags.Active);// Create Sagittal frameSagittalFrame.ShowMPRCrossHair = true;SagittalFrame.DistinguishMPRByColor = true;SagittalFrame.SetTag(6, MedicalViewerTagAlignment.TopLeft, MedicalViewerTagType.Frame);SagittalFrame.AddAction(MedicalViewerActionType.Stack);SagittalFrame.SetAction(MedicalViewerActionType.Stack, MedicalViewerMouseButtons.Wheel, MedicalViewerActionFlags.Active);// Create coronal frameCoronalFrame.ShowMPRCrossHair = true;CoronalFrame.DistinguishMPRByColor = true;CoronalFrame.SetTag(6, MedicalViewerTagAlignment.TopLeft, MedicalViewerTagType.Frame);CoronalFrame.AddAction(MedicalViewerActionType.Stack);CoronalFrame.SetAction(MedicalViewerActionType.Stack, MedicalViewerMouseButtons.Wheel, MedicalViewerActionFlags.Active);// attach the MPR cells to the 3D control_medical3DControl.AxialFrame = AxialFrame;_medical3DControl.SagittalFrame = SagittalFrame;_medical3DControl.CoronalFrame = CoronalFrame;AxialFrame.AxialName = "Axial Cell";SagittalFrame.SagittalName = "Sagittal Cell";CoronalFrame.CoronalName = "Coronal Cell";AxialFrame.SetTag(1, MedicalViewerTagAlignment.TopLeft, MedicalViewerTagType.MPRType);SagittalFrame.SetTag(1, MedicalViewerTagAlignment.TopLeft, MedicalViewerTagType.MPRType);CoronalFrame.SetTag(1, MedicalViewerTagAlignment.TopLeft, MedicalViewerTagType.MPRType);// with this option, you will not be able to select more than one cell at the same time. (selecting multiple cells are done with the pressing and holding the Ctrl and clicking on cell)_medicalViewer.AllowMultipleSelection = false;_medicalViewer.Cells.Add(_medical3DControl);_medicalViewer.Cells.Add(AxialFrame);_medicalViewer.Cells.Add(SagittalFrame);_medicalViewer.Cells.Add(CoronalFrame);Controls.Add(_medicalViewer);_medicalViewer.Dock = DockStyle.Fill;}// This event handles communication between the 3D and the MedicalViewer.void cell_Data3DRequested(object sender, MedicalViewerData3DRequestedEventArgs e){e.Succeed = Medical3DEngine.Provide3DInformation(e);}void cell_FramesRequested(object sender, MedicalViewerRequestedFramesInformationEventArgs e){MedicalViewerMultiCell cell = (MedicalViewerMultiCell)(sender);RasterCodecs _codecs = new RasterCodecs();int i;RasterImage image;string fileName;if (e.RequestedFramesIndexes.Length > 0){fileName = (string)(_seriesManager.Stacks[0].Items[e.RequestedFramesIndexes[0]].Data);image = _codecs.Load(fileName);}elsereturn;for (i = 1; i < e.RequestedFramesIndexes.Length; i++){fileName = (string)(_seriesManager.Stacks[0].Items[e.RequestedFramesIndexes[i]].Data);image.AddPage(_codecs.Load(fileName));}cell.SetRequestedImage(image, e.RequestedFramesIndexes, MedicalViewerSetImageOptions.Insert);}public MedicalViewer Viewer{get { return _medicalViewer; }}}MedicalViewerMPRForm GetMedicalViewerMPRForm(){MedicalViewerSeriesManagerFrom form = new MedicalViewerSeriesManagerFrom();MedicalViewerSeriesManager output = form.LoadJamesHead();return new MedicalViewerMPRForm(output);}// This example changes the default window level value by decrease the width by 100. Then resets the images based on the new value.public void MedicalViewerMPRExample(){MedicalViewerMPRForm myForm = GetMedicalViewerMPRForm();MedicalViewer medicalViewer = myForm.Viewer;myForm.ShowDialog();}
Help Collections
Raster .NET | C API | C++ Class Library | HTML5 JavaScript
Document .NET | C API | C++ Class Library | HTML5 JavaScript
Medical .NET | C API | C++ Class Library | HTML5 JavaScript
Medical Web Viewer .NET
Multimedia
Direct Show .NET | C API | Filters
Media Foundation .NET | C API | Transforms
Supported Platforms
.NET, Java, Android, and iOS/macOS Assemblies
Imaging, Medical, and Document
C API/C++ Class Libraries
Imaging, Medical, and Document
HTML5 JavaScript Libraries
Imaging, Medical, and Document
