翻譯|使用教程|編輯:胡濤|2022-11-01 11:03:31.740|閱讀 188 次
概述:本教程展示了如何使用 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@ke049m.cn