二维码图片生成(扩展知识:创建带圆角效果的图片)

效果如下:

ViewController.h

1 #import <UIKit/UIKit.h>
2 @interface ViewController : UIViewController
3 @property (strong, nonatomic) IBOutlet UIImageView *imgVQRCode;
4
5 @end

ViewController.m

 1 #import "ViewController.h"
 2 #import "KMQRCode.h"
 3 #import "UIImage+RoundedRectImage.h"
 4
 5 @interface ViewController ()
 6 - (void)layoutUI;
 7 @end
 8
 9 @implementation ViewController
10
11 - (void)viewDidLoad {
12     [super viewDidLoad];
13
14     [self layoutUI];
15 }
16
17 - (void)didReceiveMemoryWarning {
18     [super didReceiveMemoryWarning];
19     // Dispose of any resources that can be recreated.
20 }
21
22 - (void)layoutUI {
23     //用于生成二维码的字符串source
24     NSString *source = @"https://github.com/KenmuHuang";
25
26     //使用iOS 7后的CIFilter对象操作,生成二维码图片imgQRCode(会拉伸图片,比较模糊,效果不佳)
27     CIImage *imgQRCode = [KMQRCode createQRCodeImage:source];
28
29     //使用核心绘图框架CG(Core Graphics)对象操作,进一步针对大小生成二维码图片imgAdaptiveQRCode(图片大小适合,清晰,效果好)
30     UIImage *imgAdaptiveQRCode = [KMQRCode resizeQRCodeImage:imgQRCode
31                                                     withSize:_imgVQRCode.frame.size.width];
32
33     //默认产生的黑白色的二维码图片;我们可以让它产生其它颜色的二维码图片,例如:蓝白色的二维码图片
34     imgAdaptiveQRCode = [KMQRCode specialColorImage:imgAdaptiveQRCode
35                                             withRed:33.0
36                                               green:114.0
37                                                blue:237.0]; //0~255
38
39     //使用核心绘图框架CG(Core Graphics)对象操作,创建带圆角效果的图片
40     UIImage *imgIcon = [UIImage createRoundedRectImage:[UIImage imageNamed:@"QRCode"]
41                                               withSize:CGSizeMake(70.0, 93.0)
42                                             withRadius:10];
43     //使用核心绘图框架CG(Core Graphics)对象操作,合并二维码图片和用于中间显示的图标图片
44     imgAdaptiveQRCode = [KMQRCode addIconToQRCodeImage:imgAdaptiveQRCode
45                                               withIcon:imgIcon
46                                           withIconSize:imgIcon.size];
47
48 //    imgAdaptiveQRCode = [KMQRCode addIconToQRCodeImage:imgAdaptiveQRCode
49 //                                              withIcon:imgIcon
50 //                                             withScale:3];
51
52     _imgVQRCode.image = imgAdaptiveQRCode;
53     //设置图片视图的圆角边框效果
54     _imgVQRCode.layer.masksToBounds = YES;
55     _imgVQRCode.layer.cornerRadius = 10.0;
56     _imgVQRCode.layer.borderColor = [UIColor lightGrayColor].CGColor;
57     _imgVQRCode.layer.borderWidth = 4.0;
58 }
59
60 @end

?UIImage+RoundedRectImage.h

1 #import <UIKit/UIKit.h>
2
3 @interface UIImage (RoundedRectImage)
4 + (UIImage *)createRoundedRectImage:(UIImage *)image withSize:(CGSize)size withRadius:(NSInteger)radius;
5
6 @end

UIImage+RoundedRectImage.m

 1 #import "UIImage+RoundedRectImage.h"
 2
 3 @implementation UIImage (RoundedRectImage)
 4
 5 #pragma mark - Private Methods
 6 static void addRoundedRectToPath(CGContextRef contextRef, CGRect rect, float widthOfRadius, float heightOfRadius) {
 7     float fw, fh;
 8     if (widthOfRadius == 0 || heightOfRadius == 0)
 9     {
10         CGContextAddRect(contextRef, rect);
11         return;
12     }
13
14     CGContextSaveGState(contextRef);
15     CGContextTranslateCTM(contextRef, CGRectGetMinX(rect), CGRectGetMinY(rect));
16     CGContextScaleCTM(contextRef, widthOfRadius, heightOfRadius);
17     fw = CGRectGetWidth(rect) / widthOfRadius;
18     fh = CGRectGetHeight(rect) / heightOfRadius;
19
20     CGContextMoveToPoint(contextRef, fw, fh/2);  // Start at lower right corner
21     CGContextAddArcToPoint(contextRef, fw, fh, fw/2, fh, 1);  // Top right corner
22     CGContextAddArcToPoint(contextRef, 0, fh, 0, fh/2, 1); // Top left corner
23     CGContextAddArcToPoint(contextRef, 0, 0, fw/2, 0, 1); // Lower left corner
24     CGContextAddArcToPoint(contextRef, fw, 0, fw, fh/2, 1); // Back to lower right
25
26     CGContextClosePath(contextRef);
27     CGContextRestoreGState(contextRef);
28 }
29
30 #pragma mark - Public Methods
31 + (UIImage *)createRoundedRectImage:(UIImage *)image withSize:(CGSize)size withRadius:(NSInteger)radius {
32     int w = size.width;
33     int h = size.height;
34
35     CGColorSpaceRef colorSpaceRef = CGColorSpaceCreateDeviceRGB();
36     CGContextRef contextRef = CGBitmapContextCreate(NULL, w, h, 8, 4 * w, colorSpaceRef, (CGBitmapInfo)kCGImageAlphaPremultipliedFirst);
37     CGRect rect = CGRectMake(0, 0, w, h);
38
39     CGContextBeginPath(contextRef);
40     addRoundedRectToPath(contextRef, rect, radius, radius);
41     CGContextClosePath(contextRef);
42     CGContextClip(contextRef);
43     CGContextDrawImage(contextRef, CGRectMake(0, 0, w, h), image.CGImage);
44     CGImageRef imageMasked = CGBitmapContextCreateImage(contextRef);
45     UIImage *img = [UIImage imageWithCGImage:imageMasked];
46
47     CGContextRelease(contextRef);
48     CGColorSpaceRelease(colorSpaceRef);
49     CGImageRelease(imageMasked);
50     return img;
51 }
52
53 @end

KMQRCode.h

 1 #import <UIKit/UIKit.h>
 2
 3 @interface KMQRCode : NSObject
 4 + (CIImage *)createQRCodeImage:(NSString *)source;
 5 + (UIImage *)resizeQRCodeImage:(CIImage *)image withSize:(CGFloat)size;
 6 + (UIImage *)specialColorImage:(UIImage*)image withRed:(CGFloat)red green:(CGFloat)green blue:(CGFloat)blue;
 7 + (UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withIconSize:(CGSize)iconSize;
 8 + (UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withScale:(CGFloat)scale;
 9
10 @end

KMQRCode.m

  1 #import "KMQRCode.h"
  2
  3 @implementation KMQRCode
  4
  5 #pragma mark - Private Methods
  6 void ProviderReleaseData (void *info, const void *data, size_t size){
  7     free((void*)data);
  8 }
  9
 10 #pragma mark - Public Methods
 11 + (CIImage *)createQRCodeImage:(NSString *)source {
 12     NSData *data = [source dataUsingEncoding:NSUTF8StringEncoding];
 13
 14     CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"];
 15     [filter setValue:data forKey:@"inputMessage"];
 16     [filter setValue:@"Q" forKey:@"inputCorrectionLevel"]; //设置纠错等级越高;即识别越容易,值可设置为L(Low) |  M(Medium) | Q | H(High)
 17     return filter.outputImage;
 18 }
 19
 20 + (UIImage *)resizeQRCodeImage:(CIImage *)image withSize:(CGFloat)size {
 21     CGRect extent = CGRectIntegral(image.extent);
 22     CGFloat scale = MIN(size/CGRectGetWidth(extent), size/CGRectGetHeight(extent));
 23     size_t width = CGRectGetWidth(extent) * scale;
 24     size_t height = CGRectGetHeight(extent) * scale;
 25     CGColorSpaceRef colorSpaceRef = CGColorSpaceCreateDeviceGray();
 26
 27     CGContextRef contextRef = CGBitmapContextCreate(nil, width, height, 8, 0, colorSpaceRef, (CGBitmapInfo)kCGImageAlphaNone);
 28     CIContext *context = [CIContext contextWithOptions:nil];
 29     CGImageRef imageRef = [context createCGImage:image fromRect:extent];
 30     CGContextSetInterpolationQuality(contextRef, kCGInterpolationNone);
 31     CGContextScaleCTM(contextRef, scale, scale);
 32     CGContextDrawImage(contextRef, extent, imageRef);
 33
 34     CGImageRef imageRefResized = CGBitmapContextCreateImage(contextRef);
 35
 36     //Release
 37     CGContextRelease(contextRef);
 38     CGImageRelease(imageRef);
 39     return [UIImage imageWithCGImage:imageRefResized];
 40 }
 41
 42 + (UIImage *)specialColorImage:(UIImage*)image withRed:(CGFloat)red green:(CGFloat)green blue:(CGFloat)blue {
 43     const int imageWidth = image.size.width;
 44     const int imageHeight = image.size.height;
 45     size_t bytesPerRow = imageWidth * 4;
 46     uint32_t* rgbImageBuf = (uint32_t*)malloc(bytesPerRow * imageHeight);
 47
 48     //Create context
 49     CGColorSpaceRef colorSpaceRef = CGColorSpaceCreateDeviceRGB();
 50     CGContextRef contextRef = CGBitmapContextCreate(rgbImageBuf, imageWidth, imageHeight, 8, bytesPerRow, colorSpaceRef, kCGBitmapByteOrder32Little | kCGImageAlphaNoneSkipLast);
 51     CGContextDrawImage(contextRef, CGRectMake(0, 0, imageWidth, imageHeight), image.CGImage);
 52
 53     //Traverse pixe
 54     int pixelNum = imageWidth * imageHeight;
 55     uint32_t* pCurPtr = rgbImageBuf;
 56     for (int i = 0; i < pixelNum; i++, pCurPtr++){
 57         if ((*pCurPtr & 0xFFFFFF00) < 0x99999900){
 58             //Change color
 59             uint8_t* ptr = (uint8_t*)pCurPtr;
 60             ptr[3] = red; //0~255
 61             ptr[2] = green;
 62             ptr[1] = blue;
 63         }else{
 64             uint8_t* ptr = (uint8_t*)pCurPtr;
 65             ptr[0] = 0;
 66         }
 67     }
 68
 69     //Convert to image
 70     CGDataProviderRef dataProviderRef = CGDataProviderCreateWithData(NULL, rgbImageBuf, bytesPerRow * imageHeight, ProviderReleaseData);
 71     CGImageRef imageRef = CGImageCreate(imageWidth, imageHeight, 8, 32, bytesPerRow, colorSpaceRef,
 72                                         kCGImageAlphaLast | kCGBitmapByteOrder32Little, dataProviderRef,
 73                                         NULL, true, kCGRenderingIntentDefault);
 74     CGDataProviderRelease(dataProviderRef);
 75     UIImage* img = [UIImage imageWithCGImage:imageRef];
 76
 77     //Release
 78     CGImageRelease(imageRef);
 79     CGContextRelease(contextRef);
 80     CGColorSpaceRelease(colorSpaceRef);
 81     return img;
 82 }
 83
 84 +(UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withIconSize:(CGSize)iconSize {
 85     UIGraphicsBeginImageContext(image.size);
 86     //通过两张图片进行位置和大小的绘制,实现两张图片的合并;其实此原理做法也可以用于多张图片的合并
 87     CGFloat widthOfImage = image.size.width;
 88     CGFloat heightOfImage = image.size.height;
 89     CGFloat widthOfIcon = iconSize.width;
 90     CGFloat heightOfIcon = iconSize.height;
 91
 92     [image drawInRect:CGRectMake(0, 0, widthOfImage, heightOfImage)];
 93     [icon drawInRect:CGRectMake((widthOfImage-widthOfIcon)/2, (heightOfImage-heightOfIcon)/2,
 94                                 widthOfIcon, heightOfIcon)];
 95     UIImage *img = UIGraphicsGetImageFromCurrentImageContext();
 96
 97     UIGraphicsEndImageContext();
 98     return img;
 99 }
100
101 +(UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withScale:(CGFloat)scale {
102     UIGraphicsBeginImageContext(image.size);
103
104     //通过两张图片进行位置和大小的绘制,实现两张图片的合并;其实此原理做法也可以用于多张图片的合并
105     CGFloat widthOfImage = image.size.width;
106     CGFloat heightOfImage = image.size.height;
107     CGFloat widthOfIcon = widthOfImage/scale;
108     CGFloat heightOfIcon = heightOfImage/scale;
109
110     [image drawInRect:CGRectMake(0, 0, widthOfImage, heightOfImage)];
111     [icon drawInRect:CGRectMake((widthOfImage-widthOfIcon)/2, (heightOfImage-heightOfIcon)/2,
112                                 widthOfIcon, heightOfIcon)];
113     UIImage *img = UIGraphicsGetImageFromCurrentImageContext();
114
115     UIGraphicsEndImageContext();
116     return img;
117 }
118
119 @end
时间: 2024-09-26 23:26:15

二维码图片生成(扩展知识:创建带圆角效果的图片)的相关文章

.net core 的图片处理及二维码的生成及解析

写代码这事,掐指算来已经十有余年. 从html到css到javascript到vbscript到c#,从兴趣到职业,生活总是失落与惊喜并存. 绝大部分时候,出发并不是因为知道该到哪里去,只是知道不能再逗留下去了,如此而已.受过风吹雨打之后会有很多独有的感受及思考,主见开始生发并在摇摆中坚定,想来这就是成长了,嗯--就算是成长吧,呵呵! 话说微软的 .net core 3.0 即将发布了,作为一个码农,还是要关心一下的.从 .net core 2.0 及MySql官方开始支持 .net core

二维码的生成细节和原理

二维码的生成细节和原理 二维码又称QR Code,QR全称Quick Response,是一个近几年来移动设备上超流行的一种编码方式,它比传统的Bar Code条形码能存更多的信息,也能表示更多的数据类型:比如:字符,数字,日文,中文等等.这两天学习了一下二维码图片生成的相关细节,觉得这个玩意就是一个密码算法,在此写一这篇文章 ,揭露一下.供好学的人一同学习之. 关于QR Code Specification,可参看这个PDF:http://raidenii.net/files/datashee

C# ZXing.Net生成二维码、识别二维码、生成带Logo的二维码(一)

一.ZXing.Net 源代码地址:http://zxingnet.codeplex.com/ 也可以使用Nuget包管理,添加如图: 说明:ZXing是一个开源Java类库用于解析多种格式的1D/2D条形码.目标是能够对QR编码.Data Matrix.UPC的1D条形码进行解码. 其提供了多种平台下的客户端包括:J2ME.J2SE和Android.现在也有了对应的.Net版本 二.生成二维码 将字符编码时可以指定字符格式:默认为ISO-8859-1英文字符集,但一般移动设备常用UTF-8字符

ios-深度解析二维码的生成与使用

利用一个小demo来对二维码进行学习,总共四个界面(主界面,生成二维码界面,识别二维码界面,扫描二维码界面) 一.二维码的介绍 1.什么是二维码? 二维条码/二维码是用某种特定的几何图形按一定规律在平面分布的黑白相间的图形记录数据符号信息的 总结: 用图形记录标记一些信息,方便通过图形识别来获取信息 2 应用场景 信息获取(名片.地图.WIFI密码.资料) 手机电商(用户扫码.手机直接购物下单) 手机支付(扫描商品二维码,通过银行或第三方支付提供的手机端通道完成支付) 微信添加好友 二.二维码界

二维码后台生成方法

二维码后台生成方法1.下载包:http://mvnrepository.com/artifact/com.google.zxing/core/3.1.0core-3.1.0.jarlog4j-1.2.14.jar或者在pom.xml增加:        <!-- log4j -->        <dependency>            <groupId>log4j</groupId>            <artifactId>log4

iOS二维码的生成与扫描

由于近期工作中遇到了个需求:需要将一些固定的字段 在多个移动端进行相互传输,所以就想到了 二维码 这个神奇的东东! 现在的大街上.连个摊煎饼的大妈 都有自己的二维码来让大家进行扫码支付.可见现在的二维码使用率多高, 不光如此,在很多的社交类的APP 基本都有扫一扫加好友这个功能吧,因此决定学一学这个神奇的东西. 查找了一些资料博客啊发现,iOS7之前 对于开发人员来说 熟悉的第三方QRCode库有: ZXingGoogle出品并开源 一直到现在都还有专人维护 是世界上使用最广的二维码库 iOS上

Android 基于google Zxing实现二维码的生成,识别和长按识别的效果

最近项目用到了二维码的生成与识别,之前没有接触这块,然后就上网搜了搜,发现有好多这方面的资源,特别是google Zxing对二维码的封装,实现的已经不错了,可以直接拿过来引用,下载了他们的源码后,只做了少少的改动,就是在Demo中增加了长按识别的功能,网上虽然也有长按识别的Demo,但好多下载下来却无法运行,然后总结了一下,加在了下面的Demo中. 如图所示,引用时直接把用红色圈起来的包放在你项目所对应的文件夹下,当然一些资源文件,比如string.xml里项目的引用你自己添加上就是 当然别忘

java实现二维码的生成与解析

二维码的生成及解析的低层实现并不简单,我们只需要知道怎么使用就可以了,参考博客:https://blog.csdn.net/jam_fanatic/article/details/82818857 1.maven中jar包引用com.google.zxing: 2.创建QRCodeUtil二维码工具类,使用谷歌提供的帮助类BufferedImageLuminanceSource绘制二维码. 生成二维码:QRCodeUtil.encode(编码到二维码中的内容, 嵌入二维码的图片路径, 生成的二维

Android zxing 解析二维码,生成二维码极简demo

zxing 官方的代码很多,看起来很费劲,此demo只抽取了有用的部分,实现了相机预览解码,解析本地二维码,生成二维码三个功能. 简化后的结构如下: 废话少说直接上代码: BaseDecodeHandler: package com.song.zxing.decode; import android.graphics.Bitmap; import android.os.Bundle; import com.google.zxing.BarcodeFormat; import com.google