ZBar与ZXing使用后感觉

[原]ZBar与ZXing使用后感觉(上)

2014-3-18阅读2011 评论1

最近对二维码比较感兴趣,还是那句老话,那么我就对比了一下zxing和zbar

如果对于这两个的背景不了解的话,可以看我以前的文章,介绍了几个比较基础的知识。

首先,现在有个很好用的cocoapods第三方库管理工具,至于如何安装,那么以前分享过一片如何安装cocoapods的介绍。

如果这两点你都满足的话,可以继续这个对比拉,其实为什么不直接从github下载一步步配置编译呢?至少我觉得cocoapods这个工具很方便。而且免去了一些配置编译的缺点。

如果你要深究加入什么库啊,setting里面要配置什么啊,可以去网上搜索一下,也很多。

废话不多说,在podfile里面加入这3个命令:

pod ‘ZBarSDK‘, ‘~> 1.3.1‘
pod ‘ZXingObjC‘, ‘~> 2.2.4‘
pod ‘libqrencode‘, ‘~> 3.4.2‘

这是我目前对于二维码扫瞄,所使用到的一些库,zbar是用的zbar开源库,支持我们常见的条形码以及二维码扫瞄,使用简单,方便,但是不能生成二维码,所以我们要借助libqrencode,这个库很好用,但是一般刚接触可能不是很清楚如何使用。

zbar:

一般里面有个

ZBarReaderViewController * ctrl = [[ZBarReaderViewController alloc] init];

ctrl.readerDelegate = self;

- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info

for (ZBarSymbol * symbol in set){

break;

}

ZBarReaderView

看看怎么使用把,其实他就是一个view,比较方便,也比较好用

ZBarReaderView * view = [[ZBarReaderView alloc] init];

view.frame = CGRectMake(50, 100, 220, 220);

view.readerDelegate = self;

view.torchMode = 0;

view.showsFPS = YES;

[self.view addSubview:view];

[view release];

[view start];

注意哦start,才能正确调用开始扫瞄,至于torchmode是关于闪光灯的,默认2是自动,0是关闭把。这样只要扫瞄到,就是调用代理

didReadSymbols: (ZBarSymbolSet*) symbols

fromImage: (UIImage*) image

你可以在这里处理出结果,有个特殊,就是扫瞄中文的二维码乱码问题,解决很简单,由于zbar是日本人搞的,所以他把中文默认为日文,你用utf8是无法解码的,附上代码

for (ZBarSymbol * symbol in symbols){

if (symbol.type == ZBAR_QRCODE) {

if ([symbol.data canBeConvertedToEncoding:NSShiftJISStringEncoding]) {

NSString  * str = [NSString
stringWithCString:[symbol.data cStringUsingEncoding:
NSShiftJISStringEncoding] encoding:NSUTF8StringEncoding];

}

//            NSString * str = [NSString stringWithCString:[symbol.data UTF8String] encoding:NSUTF8StringEncoding];

}

break;

}

要用日文的格式解码,这样就ok拉,至于项目中使用,可能细节更多,但是这些基础,足够你后面的使用。

[原]ZBar与ZXing使用后感觉(中)

2014-3-18阅读1272 评论6

上一篇文章中,介绍了一些zbar的几本使用,由于zbar本书无法生成二维码,所以我们必须借助另一个库,libqrencode,这个库可以帮 助你生成二维码,但是这个库都是一些。c文件,真正的使用需要额外的两个文件,其实如果实例非凡,不需要这两个文件也可以,贴上源 码:QRCodeGenerator

#import "QRCodeGenerator.h"
#import <qrencode.h>

#if __IPHONE_OS_VERSION_MAX_ALLOWED > __IPHONE_6_1
#define kCGImageAlphaPremultipliedLast  (kCGBitmapByteOrderDefault | kCGImageAlphaPremultipliedLast)
#else
#define kCGImageAlphaPremultipliedLast  kCGImageAlphaPremultipliedLast
#endif

enum {
	qr_margin = 3
};

@implementation QRCodeGenerator

+ (void)drawQRCode:(QRcode *)code context:(CGContextRef)ctx size:(CGFloat)size {
	unsigned char *data = 0;
	int width;
	data = code->data;
	width = code->width;
	float zoom = (double)size / (code->width + 2.0 * qr_margin);
	CGRect rectDraw = CGRectMake(0, 0, zoom, zoom);

	// draw
//	CGContextSetFillColor(ctx, CGColorGetComponents([UIColor greenColor].CGColor));

    int ran;

	for(int i = 0; i < width; ++i) {
		for(int j = 0; j < width; ++j) {
			if(*data & 1) {
                ran = arc4random() % 3;

                CGContextSetFillColorWithColor(ctx, [UIColor colorWithRed:ran/255.f green:255/255.f blue:255/255.f alpha:1.0].CGColor);

				rectDraw.origin = CGPointMake((j + qr_margin) * zoom,(i + qr_margin) * zoom);

//                CGContextDrawImage(ctx, rectDraw, [UIImage imageNamed:@"7745002.jpg"].CGImage);
				CGContextAddRect(ctx, rectDraw);
//                CGContextAddEllipseInRect(ctx, rectDraw);
                CGContextFillPath(ctx);
			}
			++data;
		}
	}

}

+ (UIImage *)qrImageForString:(NSString *)string imageSize:(CGFloat)size {
	if (![string length]) {
		return nil;
	}

	QRcode *code = QRcode_encodeString([string UTF8String], 0, QR_ECLEVEL_L, QR_MODE_8, 1);

	if (!code) {
		return nil;
	}

	// create context
	CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
	CGContextRef ctx = CGBitmapContextCreate(0, size, size, 8, size * 4, colorSpace, kCGImageAlphaPremultipliedLast);

	CGAffineTransform translateTransform = CGAffineTransformMakeTranslation(0, -size);
	CGAffineTransform scaleTransform = CGAffineTransformMakeScale(1, -1);
	CGContextConcatCTM(ctx, CGAffineTransformConcat(translateTransform, scaleTransform));

	// draw QR on this context
	[QRCodeGenerator drawQRCode:code context:ctx size:size];

	// get image
	CGImageRef qrCGImage = CGBitmapContextCreateImage(ctx);
	UIImage * qrImage = [UIImage imageWithCGImage:qrCGImage];

	// some releases
	CGContextRelease(ctx);
	CGImageRelease(qrCGImage);
	CGColorSpaceRelease(colorSpace);
	QRcode_free(code);

	return qrImage;
}

注意到drawcode的那个方法了吗,那个和原本的文件的方法有些出入,主要被我修改了一下

外部使用,只要调用qrimageforstring那个方法就行,将你要生成的string当作入参传入即可。

原理吗?相信大家一看就明白,qrcode将字符串生成了一个data数据,根据这个数据,然后去绘制一个又一个的小黑块,这样就产生了我们看到的
二维码。那么彩色二维码,很酷把,知道了原理,我们才获取到数据在绘制的时候,可以绘制各种颜色的小方块,如何绘制,相信大家看看就知道了,

但是原色过多,可能无法识别,或者识别率很低,测试了一下,对于一种颜色,几本没啥问题。

很多时候,我们看到二维码中间有个图片,其实这里又包含了另一个知识,那就是缺省率,

typedef enum {
	QR_ECLEVEL_L = 0, ///< lowest
	QR_ECLEVEL_M,
	QR_ECLEVEL_Q,
	QR_ECLEVEL_H      ///< highest
} QRecLevel;

这个枚举,很清楚把,最高,缺省率可以高达30%,就是你选择了最高编码等级,所以我们就可以在二维码中间贴上一张 图片也不影响使用,但是如果你选择最低的,那么缺省只能达到5左右,但是越低,扫瞄速度越快,越高,意味着你的二维码也越复杂,增加扫瞄难度,所以如何权 衡,看自己把。

[原]zbar与ZXing使用后感觉(下)

2014-3-18阅读1397 评论2

其实,感觉介绍的有点简单,主要是作为自己的积累的一部分,所以有些属性,自己去试了试,但是并没有在文章中体现,所以最终啥时候用到,某一方面, 再去深究把,我只能把一些基础的介绍出来,前面介绍了zbar,这里就着重介绍一下zxing,其实说实话,zxing更方便,但是不支持条形码,据说可 以修改实现,但是没去研究,又兴趣的可以研究下,zxing本身很庞大,支持各个平台,pod search zxing

以外发现一个其他的开源库

-> ZXing (2.2)
   Multi-format 1D/2D barcode image processing library.
   pod ‘ZXing‘, ‘~> 2.2‘
   - Homepage: http://code.google.com/p/zxing/
   - Source:   http://zxing.googlecode.com/svn/
   - Versions: 2.2, 2.1, 2.0 [master repo]
   - Sub specs:
     - ZXing/ios (2.2)

-> ZXingObjC (2.2.5)
   An Objective-C Port of ZXing.
   pod ‘ZXingObjC‘, ‘~> 2.2.5‘
   - Homepage: https://github.com/TheLevelUp/ZXingObjC
   - Source:   https://github.com/TheLevelUp/ZXingObjC.git
   - Versions: 2.2.5, 2.2.4, 2.2.3, 2.2.2, 2.2.1, 2.2.0, 2.1.0, 2.0.2, 2.0.1,
   1.7, 0.0.1 [master repo]
dhmatoiMac:~ dh$

zxingobjc,看到这个名字再熟悉不过了,去了github上看了一下,维护情况也行,所以决定使用这个,还是两方面介绍,这个库支持扫瞄和生成哦!:

生成:

- (void)crateQRcode
{
    NSError* error = nil;
    ZXMultiFormatWriter* writer = [ZXMultiFormatWriter writer];
    ZXBitMatrix* result = [writer encode:@"A string to encode"
                                  format:kBarcodeFormatQRCode
                                   width:500
                                  height:500
                                   error:&error];
    if (result) {
        CGImageRef image = [[ZXImage imageWithMatrix:result] cgimage];

        imageView.image =[UIImage imageWithCGImage:image];

        // This CGImageRef image can be placed in a UIImage, NSImage, or written to a file.
    } else {
        NSString* errorMessage = [error localizedDescription];
    }
}

简单吧,至于原理,还没看,以后再深究!,因为libqrcode看了,这个估计也是差不多的。

扫瞄就更简单了:

本来想自己写一下,但是发现,github上的介绍也可以:

所以这里直接用demo了,别怪我偷懒啊~哈哈

初始化:

 self.capture = [[ZXCapture alloc] init];
  self.capture.camera = self.capture.back;
  self.capture.focusMode = AVCaptureFocusModeContinuousAutoFocus;
  self.capture.rotation = 90.0f;

  self.capture.layer.frame = self.view.bounds;
  [self.view.layer addSublayer:self.capture.layer];

  [self.view bringSubviewToFront:self.scanRectView];
  [self.view bringSubviewToFront:self.decodedLabel];

结果回调:

- (NSString *)barcodeFormatToString:(ZXBarcodeFormat)format {
  switch (format) {
    case kBarcodeFormatAztec:
      return @"Aztec";

    case kBarcodeFormatCodabar:
      return @"CODABAR";

    case kBarcodeFormatCode39:
      return @"Code 39";

    case kBarcodeFormatCode93:
      return @"Code 93";

    case kBarcodeFormatCode128:
      return @"Code 128";

    case kBarcodeFormatDataMatrix:
      return @"Data Matrix";

    case kBarcodeFormatEan8:
      return @"EAN-8";

    case kBarcodeFormatEan13:
      return @"EAN-13";

    case kBarcodeFormatITF:
      return @"ITF";

    case kBarcodeFormatPDF417:
      return @"PDF417";

    case kBarcodeFormatQRCode:
      return @"QR Code";

    case kBarcodeFormatRSS14:
      return @"RSS 14";

    case kBarcodeFormatRSSExpanded:
      return @"RSS Expanded";

    case kBarcodeFormatUPCA:
      return @"UPCA";

    case kBarcodeFormatUPCE:
      return @"UPCE";

    case kBarcodeFormatUPCEANExtension:
      return @"UPC/EAN extension";

    default:
      return @"Unknown";
  }
}

#pragma mark - ZXCaptureDelegate Methods

- (void)captureResult:(ZXCapture *)capture result:(ZXResult *)result {
  if (!result) return;

  // We got a result. Display information about the result onscreen.
  NSString *formatString = [self barcodeFormatToString:result.barcodeFormat];
  NSString *display = [NSString stringWithFormat:@"Scanned!\n\nFormat: %@\n\nContents:\n%@", formatString, result.text];
  [self.decodedLabel performSelectorOnMainThread:@selector(setText:) withObject:display waitUntilDone:YES];

  // Vibrate
  AudioServicesPlaySystemSound(kSystemSoundID_Vibrate);
}

好了,很简单,所以以后如果有空继续补充吧,主要了解这些,以备以后用起来方便!

原文:http://m.blog.csdn.net/blog/shidongdong2012/21476909

时间: 2024-10-12 05:47:46

ZBar与ZXing使用后感觉的相关文章

二维码开源库zbar、zxing使用心得

首先说明我的测试场景是“识别打印在纸上的二维码”,在扫描结果中寻找二维码并进行识别,而不是直接让摄像头对着二维码扫描. zbar和zxing用的都是自己从github上clone的c++源码/接口编译出来的dll,都是默认参数 再说结论:测了大概几千张图片,两个库的准确率差不多(由于图片场景的多样性,确切的准确率数字也没有什么意义),但是zbar的速度要快很多,大概是zxing的4-5倍.其实两个库的准确率都不太如人意,稍微模糊一点就无法识别,甚至有一些不模糊的图像也识别不出.相比之下,微信的识

哈高科高科技化看后感觉很假

http://passport.baidu.com/?business&un=%E6%8C%89%E6%91%A9%E7%BE%8E%E5%A5%B3%E5%AE%89%E6%BA%AA http://passport.baidu.com/?business&un=%E6%8C%89%E6%91%A9%E7%BE%8E%E5%A5%B3%E5%AE%89%E6%B3%BD http://passport.baidu.com/?business&un=%E6%8C%89%E6%91%

C#使用zxing,zbar,thoughtworkQRcode解析二维码,附源代码

最近做项目需要解析二维码图片,找了一大圈,发现没有人去整理下开源的几个库案例,花了点时间 做了zxing,zbar和thoughtworkqrcode解析二维码案例,希望大家有帮助. zxing是谷歌开源的二维码库,zbar,thoughtworkQRcode也是开源的,三者之间比较各有优劣 下面通过一个案例demo源码,来认识学习下这三者的实际解码效果, 第一次上传demo源码,献丑了 zbar解析关键代码: Image primaryImage = Image.FromFile(fileNa

windows平台python 2.7环境编译安装zbar

最近一个项目需要识别二维码,找来找去找到了zbar和zxing,中间越过无数坑,总算基本上弄明白,分享出来给大家. 一.zbar官方介绍 ZBar 是款桌面电脑用条形码/二维码扫描工具,支持摄像头及图片扫描,支持多平台,例如 iPhone,Andriod 手机,同时 ZBar封装了二维码扫描的 API 开发包. ZBar 目前条码类型有:EAN-13/UPC-A, UPC-E, EAN-8, Code 128, Code 39, Interleaved 2 of 5 and QR Code. 从

ZBar 是款桌面电脑用条形码/二维码扫描工具

windows平台python 2.7环境编译安装zbar 最近一个项目需要识别二维码,找来找去找到了zbar和zxing,中间越过无数坑,总算基本上弄明白,分享出来给大家. 一.zbar官方介绍 ZBar 是款桌面电脑用条形码/二维码扫描工具,支持摄像头及图片扫描,支持多平台,例如 iPhone,Andriod 手机,同时 ZBar封装了二维码扫描的 API 开发包. ZBar 目前条码类型有:EAN-13/UPC-A, UPC-E, EAN-8, Code 128, Code 39, Int

【养生窍门】记住!!!运动后千万别做这9件事

NO.1不要蹲坐休息 这是非常普遍的做法,运动结束后感觉累了,就蹲下或坐下认为能省力和休息,其实,这是一个错误的做法.健身运动后若立即蹲坐下来休息,会阻碍下肢血液回流,影响血液循环,加深肌体疲劳.严重时会产生重力性休克. 因此,每次运动结束后应调整呼吸节奏,进行一些低热量的活动,例如慢步走走,做做几节放松体操,或者简单深呼吸,促使四肢血液回流心脏,以利于还清"氧债",加快恢复体能.消除疲劳. NO.2不要贪吃冷饮 运动往往使人大汗淋漓,尤其是在夏天,随着大量水分的消耗,运动过后总会有口

Ubuntu Kylin 14.04LTS 开机后卡在登陆界面,可以进入字符界面,或者登陆后鼠标不显示但是管用

2014年4月27日,距离中期检查还有七天,基本上什么也没做,特别着急,雨已经下了快一天了,中午用美团外卖定的黄焖排骨,MD,什么玩意,那么一点点就18块钱,一看就不值五块钱,发誓再也不吃,最重要的是订完两个半小时才送到,饿过劲了都 吐槽一下Ubuntu 的谷歌输入法,真是不符合国人习惯 刚刚整好这个毛病,有种致之死地而后生的狂喜 ubuntu今天上午关机去win7,买了个东西回来就没法开机了,开机后卡在登陆界面,鼠标不能动,好不容易鼠标能动了,也能输入密码了,结果进去之后又卡住了,不显示桌面,

最小割模型在信息学竞赛中的应用___读后的收获

在看了Amber的<最小割模型在信息学竞赛中的应用>后感觉到了自己的智障-- 我还是按照目录来,其实第一个子目录中我收获最大的还是01分数规划的内容. 01分数规划:给定n个条件,在其中选取一些条件,使得要求的目标函数达到最值. 通俗一点说:给定两个数组,a[i]表示选取i的收益,b[i]表示选取i的代价.如果选取i,定义x[i]=1否则x[i]=0.每一个物品只有选或者不选两种方案,求一个选择方案使得R=sigma(a[i]*x[i])/sigma(b[i]*x[i])取得最值,即所有选择物

硬盘分区Convert转换为NTFS后使用正常,但DiskGenius显示未格式化的解决方法

有几个旧分区还是Fat32的,因为文件太多一直没清理,近日要用到大文件比较多,所以干脆把所有分区都用Convert转换为NTFS,转换后使用一切正常,但是用DiskGenius后发现同一硬盘不同分区却有不同结果,在DiskGenius有些正常有些显示"未格式化",但"未格式化"的几个分区无论是系统里还是其它硬盘工具里都显示正常,DiskGenius不时要用,体验良好,但是如果分区显示未格式化的话就没办法做任何操作,于是开始了惊险的修复之路... 开始以为是分区表错误