IOS依據(jù)傳入字符串生成二維碼

h文件

import@interface QrCodeGenerateVC : UIViewController

@end

.m文件

import "QrCodeGenerateVC.h"

@interface QrCodeGenerateVC ()
@property(nonatomic,strong) UIImageView *imageview;
@end
@implementation QrCodeGenerateVC
- (void)viewDidLoad {
[super viewDidLoad];
_imageview = [[UIImageView alloc]initWithFrame:CGRectMake(0, 40, SCREENWIDGH, SCREENWIDGH)];

[self.view addSubview:_imageview];

}

 -(void)initErCodeWithString:(NSString *)dataString{

// 1.創(chuàng)建濾鏡

CIFilter *filter = [CIFilter   filterWithName:@"CIQRCodeGenerator"];

// 2.還原濾鏡默認(rèn)屬性

[filter setDefaults];

// 3.設(shè)置需要生成二維碼的數(shù)據(jù)到濾鏡中

// OC中要求設(shè)置的是一個(gè)二進(jìn)制數(shù)據(jù)

NSData *data = [dataString dataUsingEncoding:NSUTF8StringEncoding];

[filter setValue:data forKeyPath:@"InputMessage"];

// 4.從濾鏡從取出生成好的二維碼圖片

CIImage *ciImage = [filter outputImage];

self.imageview.layer.shadowOffset = CGSizeMake(0, 0.5);          // 設(shè)置陰影的偏移量

self.imageview.layer.shadowRadius = 1;  // 設(shè)置陰影的半徑

self.imageview.layer.shadowColor = [UIColor     blackColor].CGColor; // 設(shè)置陰影的顏色為黑色

self.imageview.layer.shadowOpacity = 0.3; // 設(shè)置陰影的不透明度

self.imageview.image = [self     createNonInterpolatedUIImageFormCIImage:ciImage size: SCREENWIDGH-20];

}

//2.生成高清二維碼方法

- (UIImage *)createNonInterpolatedUIImageFormCIImage:(CIImage *)ciImage size:(CGFloat)widthAndHeight
{
CGRect extentRect = CGRectIntegral(ciImage.extent);
CGFloat scale = MIN(widthAndHeight / CGRectGetWidth(extentRect), widthAndHeight / CGRectGetHeight(extentRect));
// 1.創(chuàng)建bitmap;
size_t width = CGRectGetWidth(extentRect) * scale;
size_t height = CGRectGetHeight(extentRect) * scale;
CGColorSpaceRef cs = CGColorSpaceCreateDeviceGray();
CGContextRef bitmapRef = CGBitmapContextCreate(nil, width, height, 8, 0, cs, (CGBitmapInfo)kCGImageAlphaNone);
CIContext *context = [CIContext contextWithOptions:nil];
CGImageRef bitmapImage = [context createCGImage:ciImage fromRect:extentRect];
CGContextSetInterpolationQuality(bitmapRef, kCGInterpolationNone);
CGContextScaleCTM(bitmapRef, scale, scale);
CGContextDrawImage(bitmapRef, extentRect, bitmapImage);
// 保存bitmap到圖片
CGImageRef scaledImage = CGBitmapContextCreateImage(bitmapRef);
CGContextRelease(bitmapRef);
CGImageRelease(bitmapImage);
//return [UIImage imageWithCGImage:scaledImage]; // 黑白圖片
UIImage *newImage = [UIImage imageWithCGImage:scaledImage];
return [self imageBlackToTransparent:newImage withRed:200.0f andGreen:70.0f andBlue:189.0f];
}

//3.設(shè)置圖片透明度

void ProviderReleaseData (void *info, const void *data, size_t size){

free((void*)data);
}

- (UIImage*)imageBlackToTransparent:(UIImage*)image withRed:(CGFloat)red andGreen:(CGFloat)green andBlue:(CGFloat)blue{

 const int imageWidth = image.size.width;

const int imageHeight = image.size.height;

size_t      bytesPerRow = imageWidth * 4;

uint32_t* rgbImageBuf = (uint32_t*)malloc(bytesPerRow * imageHeight);

CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();

 CGContextRef context = CGBitmapContextCreate(rgbImageBuf, imageWidth, imageHeight, 8, bytesPerRow, colorSpace,

 kCGBitmapByteOrder32Little | kCGImageAlphaNoneSkipLast);

CGContextDrawImage(context, CGRectMake(0, 0, imageWidth, imageHeight), image.CGImage);

 // 遍歷像素

int pixelNum = imageWidth * imageHeight;

uint32_t* pCurPtr = rgbImageBuf;

for (int i = 0; i < pixelNum; i++, pCurPtr++){

if ((*pCurPtr & 0xFFFFFF00) < 0x99999900)    // 將白色變成透明

{

 // 改成下面的代碼,會將圖片轉(zhuǎn)成想要的顏色

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;

   }

}

// 輸出圖片

CGDataProviderRef dataProvider = CGDataProviderCreateWithData(NULL, rgbImageBuf, bytesPerRow * imageHeight, ProviderReleaseData);

CGImageRef imageRef = CGImageCreate(imageWidth, imageHeight, 8, 32, bytesPerRow, colorSpace,

kCGImageAlphaLast | kCGBitmapByteOrder32Little, dataProvider,

NULL, true, kCGRenderingIntentDefault);

CGDataProviderRelease(dataProvider);

UIImage* resultUIImage = [UIImage imageWithCGImage:imageRef];

// 清理空間

CGImageRelease(imageRef);

CGContextRelease(context);

 CGColorSpaceRelease(colorSpace);

return resultUIImage;
}

注如果對二維碼的清晰度要求不高可使用下面代碼

    -(UIImage *)generaterSmallErcode{

 // 1.實(shí)例化二維碼濾鏡

 CIFilter *filter = [CIFilter filterWithName:@"CIQRCodeGenerator"];

// 2.恢復(fù)濾鏡的默認(rèn)屬性 (因?yàn)闉V鏡有可能保存上一次的屬性)

 [filter setDefaults];

// 3.將字符串轉(zhuǎn)換成NSdata

 NSData *data  = [@"二維碼數(shù)據(jù)" dataUsingEncoding:NSUTF8StringEncoding];

 // 4.通過KVO設(shè)置濾鏡, 傳入data, 將來濾鏡就知道要通過傳入的數(shù)據(jù)生成二維碼
[filter setValue:data forKey:@"inputMessage"];

// 5.生成二維碼

CIImage *outputImage = [filter outputImage];

UIImage *image = [UIImage imageWithCIImage:outputImage];

 return image;

}

 @end
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 生成二維碼: .h文件 #import@interface NPDFgenerationOfQRCode : NS...
    他好像一條蟲閱讀 504評論 0 1
  • *7月8日上午 N:Block :跟一個(gè)函數(shù)塊差不多,會對里面所有的內(nèi)容的引用計(jì)數(shù)+1,想要解決就用__block...
    炙冰閱讀 2,547評論 1 14
  • 1、為什么使用二維碼? 在手機(jī)客戶端應(yīng)用里,對二維碼的使用也比較多。常見的功能有物品信息查詢,登錄信息驗(yàn)證,掃描登...
    方圓幾度閱讀 554評論 0 0
  • 在iOS中隨處都可以看到絢麗的動畫效果,實(shí)現(xiàn)這些動畫的過程并不復(fù)雜,今天將帶大家一窺iOS動畫全貌。在這里你可以看...
    F麥子閱讀 5,141評論 5 13
  • 一、掃描 1、 ZBar ZBar在掃描的靈敏度上,和內(nèi)存的使用上相對于ZXing上都是較優(yōu)的,但是對于 “圓角二...
    空白Null閱讀 1,090評論 0 2