public Dictionary<string, string> Attributes { get; set; }
public:
property Dictionary<String^,String^>^ Attributes {
Dictionary<String^,String^>^ get();
void set ( Dictionary<String^,String^>^ );
}
The dictionary of string pairs that correspond to each attribute in the XML input file.
This is for informational purposes only. Modifying this has no effect.
using Leadtools.Dicom;
using Leadtools.Dicom.Common;
using Leadtools.Dicom.Common.Extensions;
using Leadtools;
using Leadtools.Dicom.Common.Linq.BasicDirectory;
using Leadtools.Dicom.Common.DataTypes;
using Leadtools.Codecs;
public void SaveXmlCallbackExample()
{
string dicomFileNameIn = Path.Combine(LEAD_VARS.ImagesDir, "DICOM", "image3.dcm");
string xmlFileNameOut = Path.Combine(LEAD_VARS.ImagesDir, "test.xml");
string dicomFileNameOut = Path.Combine(LEAD_VARS.ImagesDir, "test.dcm");
// Initialize DICOM engine
DicomEngine.Startup();
DicomDataSet ds = new DicomDataSet();
// Load an existing DICOM file
ds.Load(dicomFileNameIn, DicomDataSetLoadFlags.None);
// Save as XML to a file with no binary data
// For the demo, keep the XML output file size small by skipping the pixel data
// Use the SaveXmlCallback delegate to customize the XML file
DicomDataSetSaveXmlFlags xmlFlags =
DicomDataSetSaveXmlFlags.IgnoreBinaryData |
DicomDataSetSaveXmlFlags.TrimWhiteSpace |
DicomDataSetSaveXmlFlags.TagWithCommas;
ds.SaveXml(xmlFileNameOut, xmlFlags, new SaveXmlCallback(MySaveXmlCallback));
// Use a LoadmlCallback to read the customized XML file
ds.LoadXml(xmlFileNameOut, DicomDataSetLoadXmlFlags.None, new LoadXmlBeforeElementCallback(MyLoadXmlBeforeElementCallback), new LoadXmlAfterElementCallback(MyLoadXmlAfterElementCallback));
// Save the result -- there will be no pixel data
ds.Save(dicomFileNameOut, DicomDataSetSaveFlags.None);
DicomEngine.Shutdown();
}
private static bool MySaveXmlCallback(SaveXmlData data)
{
//string sTag = data.attributes["tag"];
//if (sTag.StartsWith("0008"))
// return false;
if (data.NodeType == DicomXmlNodeType.Comment)
{
data.Comment = "COMMENT: customized xml file using the SaveXmlCallback";
return false;
}
if (data.ElementName == "dataset")
{
data.Attributes.Add("new_attribute", "some_value");
}
else if (data.ElementName == "element")
{
data.ElementName = "element_newname";
string sTagValue = data.Attributes["tag"];
data.Attributes.Remove("tag");
data.Attributes.Add("tag_newname", sTagValue);
}
return true;
}
private static bool MyLoadXmlBeforeElementCallback(LoadXmlBeforeElementData data)
{
string sTagValue = data.Attributes["tag_newname"];
long tag = 0;
sTagValue = sTagValue.Replace(",", string.Empty);
if (long.TryParse(sTagValue, System.Globalization.NumberStyles.HexNumber, null, out tag))
data.Tag = tag;
return true;
}
private static void MyLoadXmlAfterElementCallback(LoadXmlAfterElementData data)
{
if (data.DicomElement.Tag == DicomTag.PixelData)
{
// here you could call one of the following to set the pixel data
// data.DicomDataSet.SetBinaryValue
// data.DicomDataSet.SetImage()
}
}
static class LEAD_VARS
{
public const string ImagesDir = @"C:\LEADTOOLS23\Resources\Images";
}
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