iOS 生成二维码带图片
来源:互联网 发布:达内 简历 知乎 编辑:程序博客网 时间:2024/05/01 12:21
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
#import <CoreImage/CoreImage.h>
@interface KMQRCode : NSObject
+ (CIImage *)createQRCodeImage:(NSString *)source;
+ (UIImage *)resizeQRCodeImage:(CIImage *)image withSize:(CGFloat)size;
+ (UIImage *)specialColorImage:(UIImage*)image withRed:(CGFloat)red green:(CGFloat)green blue:(CGFloat)blue;
+ (UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withIconSize:(CGSize)iconSize;
+ (UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withScale:(CGFloat)scale;
@end
#import "KMQRCode.h"
@implementation KMQRCode
#pragma mark - Private Methods
void ProviderReleaseData (void *info,const void *data,size_t size){
free((void*)data);
}
#pragma mark - Public Methods
+ (CIImage *)createQRCodeImage:(NSString *)source {
NSData *data = [sourcedataUsingEncoding:NSUTF8StringEncoding];
CIFilter *filter = [CIFilterfilterWithName:@"CIQRCodeGenerator"];
[filter setValue:dataforKey:@"inputMessage"];
[filter setValue:@"Q"forKey:@"inputCorrectionLevel"];//设置纠错等级越高;即识别越容易,值可设置为L(Low) | M(Medium) | Q | H(High)
return filter.outputImage;
}
+ (UIImage *)resizeQRCodeImage:(CIImage *)image withSize:(CGFloat)size {
CGRect extent =CGRectIntegral(image.extent);
CGFloat scale =MIN(size/CGRectGetWidth(extent), size/CGRectGetHeight(extent));
size_t width =CGRectGetWidth(extent) * scale;
size_t height =CGRectGetHeight(extent) * scale;
CGColorSpaceRef colorSpaceRef =CGColorSpaceCreateDeviceGray();
CGContextRef contextRef =CGBitmapContextCreate(nil, width, height,8, 0, colorSpaceRef, (CGBitmapInfo)kCGImageAlphaNone);
CIContext *context = [CIContextcontextWithOptions:nil];
CGImageRef imageRef = [contextcreateCGImage:image fromRect:extent];
CGContextSetInterpolationQuality(contextRef,kCGInterpolationNone);
CGContextScaleCTM(contextRef, scale, scale);
CGContextDrawImage(contextRef, extent, imageRef);
CGImageRef imageRefResized =CGBitmapContextCreateImage(contextRef);
//Release
CGContextRelease(contextRef);
CGImageRelease(imageRef);
return [UIImageimageWithCGImage:imageRefResized];
}
+ (UIImage *)specialColorImage:(UIImage*)image withRed:(CGFloat)red green:(CGFloat)green blue:(CGFloat)blue {
constint imageWidth = image.size.width;
constint imageHeight = image.size.height;
size_t bytesPerRow = imageWidth *4;
uint32_t* rgbImageBuf = (uint32_t*)malloc(bytesPerRow * imageHeight);
//Create context
CGColorSpaceRef colorSpaceRef =CGColorSpaceCreateDeviceRGB();
CGContextRef contextRef =CGBitmapContextCreate(rgbImageBuf, imageWidth, imageHeight,8, bytesPerRow, colorSpaceRef,kCGBitmapByteOrder32Little |kCGImageAlphaNoneSkipLast);
CGContextDrawImage(contextRef,CGRectMake(0,0, imageWidth, imageHeight), image.CGImage);
//Traverse pixe
int pixelNum = imageWidth * imageHeight;
uint32_t* pCurPtr = rgbImageBuf;
for (int i =0; i < pixelNum; i++, pCurPtr++){
if ((*pCurPtr &0xFFFFFF00) < 0x99999900){
//Change color
uint8_t* ptr = (uint8_t*)pCurPtr;
ptr[3] = red;//0~255
ptr[2] = green;
ptr[1] = blue;
}else{
uint8_t* ptr = (uint8_t*)pCurPtr;
ptr[0] =0;
}
}
//Convert to image
CGDataProviderRef dataProviderRef =CGDataProviderCreateWithData(NULL, rgbImageBuf, bytesPerRow * imageHeight,ProviderReleaseData);
CGImageRef imageRef =CGImageCreate(imageWidth, imageHeight,8, 32, bytesPerRow, colorSpaceRef,
kCGImageAlphaLast |kCGBitmapByteOrder32Little, dataProviderRef,
NULL,true, kCGRenderingIntentDefault);
CGDataProviderRelease(dataProviderRef);
UIImage* img = [UIImageimageWithCGImage:imageRef];
//Release
CGImageRelease(imageRef);
CGContextRelease(contextRef);
CGColorSpaceRelease(colorSpaceRef);
return img;
}
+(UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withIconSize:(CGSize)iconSize {
UIGraphicsBeginImageContext(image.size);
//通过两张图片进行位置和大小的绘制,实现两张图片的合并;其实此原理做法也可以用于多张图片的合并
CGFloat widthOfImage = image.size.width;
CGFloat heightOfImage = image.size.height;
CGFloat widthOfIcon = iconSize.width;
CGFloat heightOfIcon = iconSize.height;
[image drawInRect:CGRectMake(0,0, widthOfImage, heightOfImage)];
[icon drawInRect:CGRectMake((widthOfImage-widthOfIcon)/2, (heightOfImage-heightOfIcon)/2,
widthOfIcon, heightOfIcon)];
UIImage *img =UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return img;
}
+(UIImage *)addIconToQRCodeImage:(UIImage *)image withIcon:(UIImage *)icon withScale:(CGFloat)scale {
UIGraphicsBeginImageContext(image.size);
//通过两张图片进行位置和大小的绘制,实现两张图片的合并;其实此原理做法也可以用于多张图片的合并
CGFloat widthOfImage = image.size.width;
CGFloat heightOfImage = image.size.height;
CGFloat widthOfIcon = widthOfImage/scale;
CGFloat heightOfIcon = heightOfImage/scale;
[image drawInRect:CGRectMake(0,0, widthOfImage, heightOfImage)];
[icon drawInRect:CGRectMake((widthOfImage-widthOfIcon)/2, (heightOfImage-heightOfIcon)/2,
widthOfIcon, heightOfIcon)];
UIImage *img =UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return img;
}
@end
#import <UIKit/UIKit.h>
@interface UIImage (RoundedRectImage)
+ (UIImage *)createRoundedRectImage:(UIImage *)image withSize:(CGSize)size withRadius:(NSInteger)radius;
@end
#import "UIImage+RoundedRectImage.h"
@implementation UIImage (RoundedRectImage)
#pragma mark - Private Methods
static void addRoundedRectToPath(CGContextRef contextRef,CGRect rect, float widthOfRadius,float heightOfRadius) {
float fw, fh;
if (widthOfRadius ==0 || heightOfRadius == 0)
{
CGContextAddRect(contextRef, rect);
return;
}
CGContextSaveGState(contextRef);
CGContextTranslateCTM(contextRef,CGRectGetMinX(rect), CGRectGetMinY(rect));
CGContextScaleCTM(contextRef, widthOfRadius, heightOfRadius);
fw = CGRectGetWidth(rect) / widthOfRadius;
fh = CGRectGetHeight(rect) / heightOfRadius;
CGContextMoveToPoint(contextRef, fw, fh/2); // Start at lower right corner
CGContextAddArcToPoint(contextRef, fw, fh, fw/2, fh,1); // Top right corner
CGContextAddArcToPoint(contextRef,0, fh, 0, fh/2,1); // Top left corner
CGContextAddArcToPoint(contextRef,0, 0, fw/2,0, 1);// Lower left corner
CGContextAddArcToPoint(contextRef, fw,0, fw, fh/2,1); // Back to lower right
CGContextClosePath(contextRef);
CGContextRestoreGState(contextRef);
}
#pragma mark - Public Methods1
+ (UIImage *)createRoundedRectImage:(UIImage *)image withSize:(CGSize)size withRadius:(NSInteger)radius {
int w = size.width;
int h = size.height;
CGColorSpaceRef colorSpaceRef =CGColorSpaceCreateDeviceRGB();
CGContextRef contextRef =CGBitmapContextCreate(NULL, w, h,8, 4 * w, colorSpaceRef, (CGBitmapInfo)kCGImageAlphaPremultipliedFirst);
CGRect rect =CGRectMake(0,0, w, h);
CGContextBeginPath(contextRef);
addRoundedRectToPath(contextRef, rect, radius, radius);
CGContextClosePath(contextRef);
CGContextClip(contextRef);
CGContextDrawImage(contextRef,CGRectMake(0,0, w, h), image.CGImage);
CGImageRef imageMasked =CGBitmapContextCreateImage(contextRef);
UIImage *img = [UIImageimageWithCGImage:imageMasked];
CGContextRelease(contextRef);
CGColorSpaceRelease(colorSpaceRef);
CGImageRelease(imageMasked);
return img;
}
@end
使用
//用于生成二维码的字符串source
NSString *source =@"https://github.com/KenmuHuang";
CIImage *imgQRCode = [KMQRCodecreateQRCodeImage:source];
UIImage *imgAdaptiveQRCode = [KMQRCoderesizeQRCodeImage:imgQRCode
withSize:_imgVQRCode.frame.size.width];
UIImage *imgIcon = [UIImagecreateRoundedRectImage:[UIImageimageNamed:@"logo"]
withSize:CGSizeMake(70,70)
withRadius:10];
imgAdaptiveQRCode = [KMQRCodeaddIconToQRCodeImage:imgAdaptiveQRCode
withIcon:imgIcon
withIconSize:imgIcon.size];
_imgVQRCode.image = imgAdaptiveQRCode;
- iOS 生成二维码带图片
- iOS二维码生成中间带图片Logo
- 带图片二维码生成
- iOS生成二维码图片
- iOS 开发 二维码生成大全(黑白/彩色二维码和带图片的二维码)详解
- 二维码生成中间带 图片
- 普通二维码和带图片二维码生成
- iOS二维码生成(带logo)
- iOS二维码生成(带logo)
- iOS二维码生成(带logo)
- ios 生成二维码图片libqrencode
- IOS 7+ 生成二维码图片
- 【iOS开发】二维码生成 二维码读取 (带Logo的二维码)
- java zxing 生成带图片的二维码
- java代码生成带图片的二维码
- java zxing 生成带图片的二维码
- 生成带logo的二维码图片
- Android生成带图片的二维码
- cc2530 用SmartRFProg烧hex时出错处理记录
- app上传AppStore被拒绝的各种原因
- Linux虚拟机配置上ionic环境
- Xcode8使用出现的问题&iOS10上架出现的一些问题
- 基于selenium登录淘宝
- iOS 生成二维码带图片
- Address already in use: JVM_Bind(端口冲突)
- h5头文件里添加的自适配内容
- Redis和Memcached的区别
- 移动端弹出层弹出 body还能滚动(滚动穿透)
- IP、主机名和域名
- 中文版Google App Engine入门指南
- 在CentOS上安装TCP协议性能评测工具tcpdive
- Android进阶之Cookie的持久化