Provides support for loading and saving objects to annotation files.
function lt.Annotations.Engine.AnnCodecs class lt.Annotations.Engine.AnnCodecs() This class supports loading and saving annotation objects from/to an XML string as well as getting information about previously saved annotations data.
This class also supports saving and loading multipage annotation data where each page contains a full Annotation Container.
Use the Save and SaveAll methods to save an annotation container as XML data. You can then use the browser capabilities to save this XML data to disk or use a Web Service to store it on a server. Use the SerializeOptions property to set save options and monitor the objects being saved.
Use the Load and LoadAll methods to load an annotation container from XML data. The XML data must have been previously loaded from disk using the browser capabilities or obtained from a server using a Web Service. The DeserializeOptions property can be used to set loading options, monitor the objects being loaded and handle errors.
Use the GetInfo or GetInfoFromXmlDocument to determine whether an XML data contains valid annotations data such as the format and number of pages.
LEADTOOLS supports saving multiple annotations to the same dataset. This can be used to save the annotations of a multipage document in the same data.
Use SaveLayer to save individual annotation layers.
This example creates a container, and then adds a line and rectangle objects to it. Then it saves it, obtains its information and loads it back.
import { EngineHelper } from "../utilities/EngineHelper";export class AnnEngine_AnnCodecsExample {constructor() {const helper = new EngineHelper();helper.run(this.run);}run = () => {// Create a new annotation container, 8.5 by 11 incheslet container: lt.Annotations.Engine.AnnContainer = new lt.Annotations.Engine.AnnContainer();// Size must be in annotation units (1/720 of an inch)container.size = lt.LeadSizeD.create(8.5 * 720, 11 * 720);const showContainer = (message, container) => {let str: string = message + "\nContainer size: ";// Add the sizeconst inch: number = 720;const width: number = container.size.width / inch;const height: number = container.size.height / inch;str += width + " by " + height + " inches" + "\n";// Add the objectsstr += "Contains " + container.children.count + " objects(s)\n";for (let i = 0; i < container.children.count; i++) {const annObj: lt.Annotations.Engine.AnnObject = container.children.item(i);str += "Object: " + annObj.friendlyName + " at ";for (let j = 0; j < annObj.points.count; j++) {const pt: lt.LeadPointD = annObj.points.item(j);const x: number = pt.x / inch;const y: number = pt.y / inch;str += "(" + x + ", " + y + ") ";}str += "\n";}alert(str);};const inch: number = 720.0;// Add a red line object, from 1in 1in to 2in 2inconst lineObj: lt.Annotations.Engine.AnnPolylineObject = new lt.Annotations.Engine.AnnPolylineObject();lineObj.points.add(lt.LeadPointD.create(1 * inch, 1 * inch));lineObj.points.add(lt.LeadPointD.create(2 * inch, 2 * inch));lineObj.stroke = lt.Annotations.Engine.AnnStroke.create(lt.Annotations.Engine.AnnSolidColorBrush.create("red"), lt.LeadLengthD.create(1));container.children.add(lineObj);// Add a blue on yellow rectangle from 3in 3in to 4in 4inconst rectObj: lt.Annotations.Engine.AnnRectangleObject = new lt.Annotations.Engine.AnnRectangleObject();rectObj.rect = lt.LeadRectD.create(3 * inch, 3 * inch, 1 * inch, 1 * inch);rectObj.stroke = lt.Annotations.Engine.AnnStroke.create(lt.Annotations.Engine.AnnSolidColorBrush.create("blue"), lt.LeadLengthD.create(1));rectObj.fill = lt.Annotations.Engine.AnnSolidColorBrush.create("yellow");container.children.add(rectObj);// Show the containershowContainer("Before save", container);// Create the codecs object to save and load annotationsconst codecs: lt.Annotations.Engine.AnnCodecs = new lt.Annotations.Engine.AnnCodecs();// Save the containerconst xmlData: string = codecs.save(container, lt.Annotations.Engine.AnnFormat.annotations, null, 1);// delete the containercontainer = null;// Show information about the data we just savedconst info: lt.Annotations.Engine.AnnCodecsInfo = codecs.getInfo(xmlData);let message: string;if (info.format == lt.Annotations.Engine.AnnFormat.annotations) {message = "Version: ";message += info.version;message += " No. of pages: ";message += info.pages.length;message += " page nos: ";for (let i = 0; i < info.pages.length; i++) {message += info.pages[i] + " ";}}else {message = "Invalid annotations data";}alert(message);// Load the container we just savedcontainer = codecs.load(xmlData, 1);// Show itshowContainer("After load", container);}}
import { EngineHelper } from "../utilities/EngineHelper";export class AnnEngine_AnnCodecsExample {constructor() {const helper = new EngineHelper();helper.run(this.run);}run = () => {// Create a new annotation container, 8.5 by 11 incheslet container = new lt.Annotations.Engine.AnnContainer();// Size must be in annotation units (1/720 of an inch)container.size = lt.LeadSizeD.create(8.5 * 720, 11 * 720);const showContainer = (message, container) => {let str = message + "\nContainer size: ";// Add the sizeconst inch = 720;const width = container.size.width / inch;const height = container.size.height / inch;str += width + " by " + height + " inches" + "\n";// Add the objectsstr += "Contains " + container.children.count + " objects(s)\n";for (let i = 0; i < container.children.count; i++) {const annObj = container.children.item(i);str += "Object: " + annObj.friendlyName + " at ";for (let j = 0; j < annObj.points.count; j++) {const pt = annObj.points.item(j);const x = pt.x / inch;const y = pt.y / inch;str += "(" + x + ", " + y + ") ";}str += "\n";}alert(str);};const inch = 720.0;// Add a red line object, from 1in 1in to 2in 2inconst lineObj = new lt.Annotations.Engine.AnnPolylineObject();lineObj.points.add(lt.LeadPointD.create(1 * inch, 1 * inch));lineObj.points.add(lt.LeadPointD.create(2 * inch, 2 * inch));lineObj.stroke = lt.Annotations.Engine.AnnStroke.create(lt.Annotations.Engine.AnnSolidColorBrush.create("red"), lt.LeadLengthD.create(1));container.children.add(lineObj);// Add a blue on yellow rectangle from 3in 3in to 4in 4inconst rectObj = new lt.Annotations.Engine.AnnRectangleObject();rectObj.rect = lt.LeadRectD.create(3 * inch, 3 * inch, 1 * inch, 1 * inch);rectObj.stroke = lt.Annotations.Engine.AnnStroke.create(lt.Annotations.Engine.AnnSolidColorBrush.create("blue"), lt.LeadLengthD.create(1));rectObj.fill = lt.Annotations.Engine.AnnSolidColorBrush.create("yellow");container.children.add(rectObj);// Show the containershowContainer("Before save", container);// Create the codecs object to save and load annotationsconst codecs = new lt.Annotations.Engine.AnnCodecs();// Save the containerconst xmlData = codecs.save(container, lt.Annotations.Engine.AnnFormat.annotations, null, 1);// delete the containercontainer = null;// Show information about the data we just savedconst info = codecs.getInfo(xmlData);let message;if (info.format == lt.Annotations.Engine.AnnFormat.annotations) {message = "Version: ";message += info.version;message += " No. of pages: ";message += info.pages.length;message += " page nos: ";for (let i = 0; i < info.pages.length; i++) {message += info.pages[i] + " ";}}else {message = "Invalid annotations data";}alert(message);// Load the container we just savedcontainer = codecs.load(xmlData, 1);// Show itshowContainer("After load", container);}}
<!doctype html><html lang="en"><title>AnnEngine Example | AnnCodecs</title><head><script src="https://code.jquery.com/jquery-2.2.4.min.js"integrity="sha256-BbhdlvQf/xTY9gja0Dq3HiwQF8LaCRTXxZKRutelT44=" crossorigin="anonymous"></script><script src="../LT/Leadtools.js"></script><script src="../LT/Leadtools.Controls.js"></script><script src="../LT/Leadtools.Annotations.Engine.js"></script><script src="../LT/Leadtools.Annotations.Designers.js"></script><script src="../LT/Leadtools.Annotations.Rendering.Javascript.js"></script><script src="../LT/Leadtools.Annotations.Automation.js"></script><script src="../LT/Leadtools.Annotations.BatesStamp.js"></script><script src="../LT/Leadtools.Demos.js"></script><script src="../LT/Leadtools.Demos.Annotations.js"></script><style>#imageViewerDiv {border: 1px solid #000000;width: 800px;height: 800px;background-color: #7F7F7F;}</style><!-- All demo files are bundled and appended to the window --><script src="../../bundle.js" type="text/javascript"></script></head><body><p>Either Pan/Zoom or Annotations mode. In annotations mode, draw new objects or edit them.</p><div><select id="currentObjectIdSelect"></select></div><div><input type="button" id="exampleButton" value="Example" /><label id="exampleLabel" /></div><div id="imageViewerDiv" /></body><script>window.onload = () => new window.examples.AnnEngine.AnnCodecs();</script></html>
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
