翻譯|使用教程|編輯:胡濤|2022-11-01 11:03:31.740|閱讀 173 次
概述:本教程展示了如何使用 LEADTOOLS SDK 在 C# .NET Core 應用程序中將注釋從外部 XML 文件刻錄到 PDF 文檔。歡迎查閱~
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
LEADTOOLS 是一個綜合工具包的集合,用于將識別、文檔、醫療、成像和多媒體技術整合到桌面、服務器、平板電腦、網絡和移動解決方案中,是一項企業級文檔自動化解決方案,有捕捉,OCR,OMR,表單識別和處理,PDF,打印捕獲,歸檔,注釋和顯示功能。利用業界領先的圖像處理技術,能夠智能識別文件,可以用來識別任何類型的掃描或傳真形式的圖像。
本教程展示了如何使用 LEADTOOLS SDK 在 C# .NET Core 應用程序中將注釋從外部 XML 文件刻錄到 PDF 文檔。
概括 | 本教程介紹了將注釋刻錄到 C# .NET Core 控制臺應用程序中的圖像 |
完成時間 | 30分鐘 |
視覺工作室項目 | |
平臺 | C# .NET Core 控制臺應用程序 |
IDE | Visual Studio 2019、2022 |
開發許可證 | 下載 LEADTOOLS |
在學習從 LEADDocument中添加和刪除頁面 - C# .NET Core 教程之前,通過查看添加引用和設置許可教程來熟悉創建項目的基本步驟。
從添加引用和設置許可證教程中創建的項目的副本開始。如果您沒有該項目,請按照該教程中的步驟創建它。
所需的參考資料取決于項目的目的。可以通過 NuGet 包添加引用。
本教程需要以下 NuGet 包:
有關您的應用程序需要哪些 DLL 文件的完整列表,請參閱您的應用程序中包含的文件。
許可證解鎖項目所需的功能。它必須在調用任何工具包函數之前設置。有關詳細信息,包括針對不同平臺的教程,請參閱設置運行時許可證。
有兩種類型的運行時許可證:
創建項目、添加參考和許可證集后,就可以開始編碼了。
在解決方案資源管理器中,打開Program.cs以下語句并將其添加到using文件頂部的塊中。
【C#】
using System; using System.IO; using Leadtools; using Leadtools.Annotations.Engine; using Leadtools.Annotations.Rendering; using Leadtools.Codecs;
在該Program.cs文件中,添加一個名為的新方法BurnAnnotationsToImage(),并在該方法之后的 Main 方法中調用它SetLicense()。源圖像隨項目一起提供。還有一個包含注釋數據的 XML 文件。這兩個文件的文件名是:
文件名 | 描述 |
---|---|
Burn-Annotations-to-an-Image-Source-Image.jpg | 圖像文件 |
Burn-Annotations-to-an-Image-Annotations-File.xml | LEAD 注釋文件 |
Program.cs這些文件與C# 源文件位于同一目錄中。
添加以下代碼以加載RasterImage,加載AnnContainer ,將AnnContainer映射到圖像,將容器刻錄到圖像,并將新圖像導出到文件。
【C#】
static void BurnAnnotationsToImage() { string imageFile = @"Burn-Annotations-to-an-Image-Source-Image.jpg"; string annFile = @"Burn-Annotations-to-an-Image-Annotations-File.xml"; string outputFile = @"output.jpg"; AnnDrawRenderingEngine _renderingEngine = new AnnDrawRenderingEngine(); using (RasterCodecs codecs = new RasterCodecs()) { AnnCodecs annCodecs = new AnnCodecs(); AnnContainer container = new AnnContainer(); using (RasterImage srcImage = codecs.Load(imageFile)) { // If you would like to use Memory Stream, then use this code: /* byte[] bytes = File.ReadAllBytes(imageFile); using (MemoryStream ms = new MemoryStream(bytes)) { ms.Position = 0; codecs.Load(ms); Console.WriteLine("Image loaded"); } */ container.Mapper.MapResolutions(srcImage.XResolution, srcImage.YResolution, srcImage.XResolution, srcImage.YResolution); container.Size = container.Mapper.SizeToContainerCoordinates(srcImage.ImageSize.ToLeadSizeD()); container = annCodecs.Load(annFile, 1); // Uncomment the below code to use memory stream to handle the files // byte[] outputBytes = File.ReadAllBytes(outputFile); // using (MemoryStream ms = new MemoryStream(outputBytes)) // { using (RasterImage burnImage = _renderingEngine.RenderOnImage(container, srcImage)) { codecs.Save(burnImage, outputFile, RasterImageFormat.Jpeg, 0); string path = Path.GetFullPath(outputFile); Console.WriteLine("Image saved" + path); /* ms.Position = 0; codecs.Save(burnImage, ms, RasterImageFormat.Jpeg, 0); string path = Path.GetFullPath(outputFile); Console.WriteLine("Image saved" + path); */ } // } } } }
要使用內存流加載圖像,請取消注釋BurnAnnotationsToImage()方法中的代碼。
【C#】
// load the image using memory stream byte[] bytes = File.ReadAllBytes(imageFile); using (MemoryStream ms = new MemoryStream(bytes)) { ms.Position = 0; codecs.Load(ms); Console.WriteLine("Image loaded"); } // save the stream of outputFile byte[] outputBytes = File.ReadAllBytes(outputFile); using (MemoryStream ms = new MemoryStream(outputBytes)) { ms.Position = 0; codecs.Save(burnImage, ms, RasterImageFormat.Jpeg, 0); string path = Path.GetFullPath(outputFile); Console.WriteLine("Image saved" + path); }
按F5或選擇Debug -> Start Debugging運行項目。
如果正確執行了這些步驟,則應用程序會加載指定的圖像,加載指定的注釋 XML 文件,然后將這些注釋刻錄到圖像并將該圖像導出到文件中。以下屏幕截圖顯示了預期的輸出:
以上便是將注釋刻錄到圖像上的 C# .NET Core 控制臺應用程序教程 ,如果您還有其他疑問,歡迎咨詢我們或者加入我們官方技術交流群。
歡迎下載|體驗更多LEADTOOL產品
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn