图像处理包LEADTOOLS v18示例:iOS OCR 和 Barcode识别

图像处理包LEADTOOLS v18示例:iOS OCR 和 Barcode识别

移动图像开发包LEADTOOLS iOS and OS X imaging SDK提供了创建跨平台移动图像应用的所有功能,如查看器、注释、标记、OCR、条形码、PDF、图像格式、压缩和图像处理等。 本文主要展示如何利用LEADTOOLS iOS库的OCR功能识别文本并从图像中读取条码。

获得LEADTOOLS图像

LEADTOOLS iOS库通过 LTRasterImage对象显示和处理图像。幸运的是,LEADTOOLS只需要几行代码便可轻松地实现与iOS的互操作。

// Obtain the image from bundle, photo library or live capture
UIImage* uiImage = ...
// Convert UIImage to LTRasterImage using default options
LTRasterImage* rasterImage = [LTRasterImageConverter convertFromImage:uiImage
options:LTConvertFromImageOptions_None
error:nil];

获取图像后,接下使用LEADTOOLS 所提供的先进的OCR和Barcode成像技术。

OCR示例

首先,创建一个LEADTOOLS OCR引擎实例。

// Create an instance of LEADTOOLS OCR engine
LTOcrEngine* ocrEngine = [LTOcrEngineManager createEngine:LTOcrEngineType_Advantage];

// Start up the engine with default parameters...
// We already added the OCR engine required language data files to the main bundle
NSString* bundlePath = [[NSBundle mainBundle] bundlePath];
[ocrEngine startup:nil workDirectory:nil startupParameters:bundlePath];

// Optionally, modify the settings for the OCR engine
// here (through ocrEngine.settingsManager)

接下来,我们创建一个新的OCR文档并添加图像:

// First create a document
LTOcrDocument* ocrDocument = [ocrEngine.documentManager createDocument];

// Add the image as a page into the document pages collection
LTOcrPage* ocrPage = [ocrDocument.pages addPageWithImage:rasterImage
target:nil
selector:nil
error:nil];

// You can add manual zones (text or graphics area)
// to the page at this point through the ocrPage.zones collection.
// In this example we will let the engine auto-zone the page for us.

最后,识别页面获取文本。

// Recognize it and print the results to the console
NSString* result = [ocrPage recognizeText:nil
selector:nil
error:nil];
printf("%s\n", result.UTF8String);

Barcode示例

首先,创建一个LEADTOOLS Barcode引擎实例。

// Create an instance of LEADTOOLS barcode engine
LTBarcodeEngine* barcodeEngine = [LTBarcodeEngine new];

// Get the barcode reader object
LTBarcodeReader* barcodeReader = barcodeEngine.reader;

// At this point, you can modify the barcode reading
// options (such as search direction, error checking, etc.)
// through the barcodeReader members. In this example we
// will leave everything as default.

接下来,我们将设置一些搜索选项,然后从图像中读取条形码。

// Read the barcode in the image, first lets setup the options:
// The search location and size in the image, all of it
LeadRect searchBounds = LeadRect_Empty();

// Symbologies (barcode types such as UPC-A, UPC-E,
// QR, etc.) we are interested in, all of them
LTBarcodeSymbology* symbologies = nil;

// Call readBarcode
LTBarcodeData* barcodeData = [barcodeReader readBarcode:rasterImage
searchBounds:searchBounds
symbologies:symbologies
symbologiesCount:0
error:nil];

LTBarcodeData对象包含条码信息,如类型,价值和位置等。有了这些信息,你可以实现在线搜索价格或者访问条码中所嵌入的Web页面。

if (barcodeData != nil)
{
// We have a barcode
// Get the name of the symbology (type) such as UPC-A,
// UPC-E, QR, EAN, etc.
NSString* symbology = [LTBarcodeEngine getSymbologyFriendlyName:barcodeData.symbology];
// Get the location in the image
LeadRect bounds = barcodeData.bounds;
// Get a text representation of the data
NSString* value = barcodeData.value;

// Print the result to the console
NSString* result = [NSString stringWithFormat:
@"Found %@ barcode at %d,%d,%d,%d\nData: %@",
symbology,
bounds.x, bounds.y,
bounds.x + bounds.width,
bounds.y + bounds.height,
value];
printf("%s\n", result.UTF8String);
}
else
{
printf("No barcode found\n");
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
LEADTOOLS Imaging Pro SDK是一个支持150多种光栅图像格式(JPEG,GIF,TIFF...)的应用程序接口(API) 、C++类库、 ActiveX与VCL的工具箱;拥有超过2000种图像处理效果、图像变换及过滤、多种加载与观察选项、TWAIN扫描、打印、微型浏览器、Internet及数据库成像功能、压缩、屏幕捕获、绘图、颜色转换、Internet/intranet成像、图形转换、共用对话框等;同时也括开发者所需要的集成绘图功能以及应用中的数字绘图功能。 0 特征综述 About Feature 声明:本产品中文介绍为慧都控件网版权所有,未经慧都公司书面许可,严禁拷贝、转载! 文件格式支持 采用工业标准和专有压缩技术,可同时支持150多种图像文件格式以及sub-格式的加载、保存和转换。另外,采用LEADTOOLS能添加更多的格式支持,例如采用LEADTOOLS PDF插件,即能实现对PDF文件的加载、保存和转换支持。 压缩支持 支持多种工业标准的压缩技术,括JPEG、CCITT、LZW (使用于GIF及某些TIFF文件)、ZIPLIB (使用于PNG文件)、Huffman算法、RLE及紧缩位压缩算法(Packbits)。另外,采用LEADTOOLS JPEG2000 插件和 LEADTOOLS CMW 插件可添加JPEG2000 及先进的CMW压缩技术。 TWAIN扫描支持 TWAIN 驱动几乎含在所有的扫描仪及其它图像采集设备中,同时随着最新的发展技术,TWAIN 也是性能良好与高可靠性驱动的最佳选择。当前LEADTOOLS 的光栅图像产品支持所有括在TWAIN v1.9 规范中的功能。 屏幕捕获 具有强大的屏幕捕获功能,能从文件、菜单、窗口、不同形状的屏幕客户区域等捕获资源。屏幕捕获工具是极其有用的,特别是在文档编辑及需提供其它图像输入方式的时显得更为重要。 数据库支持 同时提供高端或低端的数据库支持,其中括绑定VB数据控件功能、OLEDB 接口、ODBC 接口以及低端加载和保存图像到内存的功能。 Internet 支持 提供几种不同级别Internet支持,括:可封装到CAB文件的对象、能在web服务器端构造的对象、从URL或存储器装载图像的功能、支持HTTP 和FTP的控件、解析并加载到web服务器端的文件控件,以及用来构造功能强大、通过TCP/IP发送远程过程调用的客户服务器应用程序控件。 图像优化 基于具体优化选项,LEADTOOLS 提供了某些优化图像文件格式以及通过保存图像时使用合适的每个像素所占用的位来减小图像文件大小的功能。 显示与显示效果 对图像如何被显示进行完全地控制,括缩放、展开、图像显示的区域控制以及超过2000种的特效效果。LEADTOOLS 甚至含了一个平铺窗口,这样你能方便地显示图像概要及选用适合最终用户的卷起、平铺方案。 打印支持 由于能使用与显示图像同样的代码来进行打印,所以打印图像与显示图像同样容易。你能控制图像打印的尺寸和位置;另外,能结合Windows GDI函数同LEADTOOLS打印一起使用,提供在同一页上打印文本和多个图像的灵活性。 图像处理 超过200种图象处理功能,分为四个基本类别:过滤、变换、色彩转换及绘图。在LEADTOOLS中的大多数图像处理功能支持不同着重区域,允许图像的某一部份被处理。通过添加更多用于数字绘图的功能,LEAD在LEADTOOLS Raster Imaging Pro中提供了含大量用于数字绘图功能,括笔刷、形状、纹理的创建与使用以及更多。 色彩转换 为确保你能把图像从一种格式转换到另一种格式,或是在任何其它显示设备上显示图象,LEADTOOLS 含了强大的色彩转换功能。该色彩转换功能括:支持8 种以上色彩平滑过渡算法、多种调色板选项以及把图像数据从任何支持的每个像素所占用的位转换到其他支持的每个像素所占用的位功能。支持的数值有1-8位色或灰度、16位色、24 位色和32 位色。如果你需要12或16位灰度或48与64位色支持。 图像公共对话框 LEADTOOLS 图像公共对话框通过扩展Windows公共对话框以提供具体的图像处理功能,节省了大量的繁琐编程时间,同时能给最终用户提供一个一致的外观和感觉。这个公共对话框针对图像处理、变换及特效提供专业的图像公共对话框功能。 数字绘图 数字绘图是任何想给应用程序增加数字绘图功能所必须的。使用 LEADTOOLS 的数字绘图特性,开发者可以创建一个完整的图像编辑或设计应用程序,也可简单地添加这些功能的一部分到现有的应用程序中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值