IOS 創(chuàng)建彩色二維碼實(shí)例詳解
IOS 創(chuàng)建彩色二維碼
因?yàn)橄到y(tǒng)創(chuàng)建的二維碼默認(rèn)都是黑色的,所以突然想改變一下二維碼顏色,具體操作有點(diǎn)復(fù)雜,而且其中用到了好多C語(yǔ)言的語(yǔ)法,Swift不好寫,所以默認(rèn)用了OC。只貼了.m文件的代碼,.h文件就是幾個(gè)類函數(shù)的聲明。
#import "UIImage+CreateQRCode.h" @implementation UIImage (CreateQRCode) + (UIImage *)createQRCode:(NSString *)string andSize:(CGSize)size andColor:(UIColor *)color { UIImage *qrcode = [self createNonInterpolatedUIImageFormCIImage:[self createQRForString:string] withSize:size]; const CGFloat *_components = CGColorGetComponents(color.CGColor); CGFloat red = _components[0] * 255.f; CGFloat green = _components[1] * 255.f; CGFloat blue = _components[2] * 255.f; return [self imageBlackToTransparent:qrcode withRed:red andGreen:green andBlue:blue]; } + (void)setImageViewShadow:(UIImageView *)view { view.layer.shadowOffset = CGSizeMake(0, 2); view.layer.shadowRadius = 2; view.layer.shadowColor = [UIColor blackColor].CGColor; view.layer.shadowOpacity = 0.5; view.backgroundColor = [UIColor clearColor]; } #pragma mark - 創(chuàng)建灰度圖,只有灰度圖才能改變顏色 + (UIImage *)createNonInterpolatedUIImageFormCIImage:(CIImage *)image withSize:(CGSize)size { CGRect extent = CGRectIntegral(image.extent); CGFloat scale = MIN(size.width/CGRectGetWidth(extent), size.height/CGRectGetHeight(extent)); size_t width = CGRectGetWidth(extent) * scale; size_t height = CGRectGetHeight(extent) * scale; // iOS不支持設(shè)備依賴顏色空間或通用顏色空間。iOS應(yīng)用程序必須使用設(shè)備顏色空間 // 設(shè)備顏色空間主要用于IOS應(yīng)用程序,因?yàn)槠渌伾臻g無(wú)法在IOS上使用。大多數(shù)情況下,Mac OS X應(yīng)用程序應(yīng)使用通用顏色空間,而不使用設(shè)備顏色空間。 // CGColorSpaceCreateDeviceGray:創(chuàng)建設(shè)備依賴灰度顏色空間 // CGColorSpaceCreateDeviceRGB:創(chuàng)建設(shè)備依賴RGB顏色空間 // CGColorSpaceCreateDeviceCMYK:創(chuàng)建設(shè)備依賴CMYK顏色空間 CGColorSpaceRef cs = CGColorSpaceCreateDeviceGray();//這個(gè)是改變二維碼顏色的主要屬性,必須是灰度空間,作用是將UIImage轉(zhuǎn)變成了灰度圖 CGContextRef bitmapRef = CGBitmapContextCreate(NULL, width, height, 8, 0, cs, kCGImageAlphaNone); CIContext * context = [CIContext contextWithOptions:NULL]; CGImageRef bitmapImage = [context createCGImage:image fromRect:extent]; CGContextSetInterpolationQuality(bitmapRef, kCGInterpolationHigh); CGContextScaleCTM(bitmapRef, scale, scale); CGContextDrawImage(bitmapRef, extent, bitmapImage); CGImageRef scaledImage = CGBitmapContextCreateImage(bitmapRef); CGContextRelease(bitmapRef); CGImageRelease(bitmapImage); return [UIImage imageWithCGImage:scaledImage]; } #pragma mark - 創(chuàng)建二維碼的主要代碼 + (CIImage *)createQRForString:(NSString *)qrString { NSData *stringData = [qrString dataUsingEncoding:NSUTF8StringEncoding]; CIFilter *qrFilter = [CIFilter filterWithName:@"CIQRCodeGenerator"]; [qrFilter setValue:stringData forKey:@"inputMessage"]; [qrFilter setValue:@"M" forKey:@"inputCorrectionLevel"]; return qrFilter.outputImage; } #pragma mark - 改變二維碼的顏色 void ProviderReleaseData (voidvoid *info, const voidvoid *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){ 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; } @end
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
詳解iOS開發(fā)中UIPickerView控件的使用方法
這篇文章主要介紹了詳解iOS開發(fā)中UIPickerView控件的使用方法,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-11-11詳解適配iOS10 的相關(guān)權(quán)限設(shè)置
在最新版本的iOS10系統(tǒng)中,如果你的項(xiàng)目中訪問(wèn)了隱私數(shù)據(jù),比如:相機(jī)、相冊(cè)、錄音、定位、聯(lián)系人等等。涉及到權(quán)限問(wèn)題,本篇文章主要介紹了適配iOS10 的相關(guān)權(quán)限設(shè)置,有興趣的可以了解一下。2016-12-12iOS App開發(fā)中Objective-C使用正則表達(dá)式進(jìn)行匹配的方法
這篇文章主要介紹了iOS App開發(fā)中Objective-C使用正則表達(dá)式進(jìn)行匹配的方法,文中舉了在iOS中驗(yàn)證用戶郵箱與手機(jī)號(hào)的例子,非常實(shí)用,匹配需要的朋友可以參考下2016-05-05iOS 設(shè)置UILabel的行間距并自適應(yīng)高度的方法
下面小編就為大家?guī)?lái)一篇iOS 設(shè)置UILabel的行間距并自適應(yīng)高度的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04iOS基于CATransition實(shí)現(xiàn)翻頁(yè)、旋轉(zhuǎn)等動(dòng)畫效果
這篇文章主要為大家詳細(xì)介紹了iOS基于CATransition實(shí)現(xiàn)翻頁(yè)、旋轉(zhuǎn)等動(dòng)畫效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-04-04iOS仿網(wǎng)易新聞滾動(dòng)導(dǎo)航條效果
這篇文章主要為大家詳細(xì)介紹了iOS仿網(wǎng)易新聞滾動(dòng)導(dǎo)航條效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05iOS AVCaptureSession實(shí)現(xiàn)視頻錄制功能
這篇文章主要為大家詳細(xì)介紹了iOS AVCaptureSession實(shí)現(xiàn)視頻錄制功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05iOS手勢(shì)識(shí)別的詳細(xì)使用方法(拖動(dòng),縮放,旋轉(zhuǎn),點(diǎn)擊,手勢(shì)依賴,自定義手勢(shì))
這篇文章主要介紹了iOS手勢(shì)識(shí)別的詳細(xì)使用方法(拖動(dòng),縮放,旋轉(zhuǎn),點(diǎn)擊,手勢(shì)依賴,自定義手勢(shì)),具有一定的參考價(jià)值,有需要的可以參考一下。2016-11-11