UIImage常用的分類

有些時候經常需要對系統本有的類方法進行擴充,於是可能需要對類採用繼承或者分類的方式來實現需要。

最近寫的一個項目用到了一些對圖片進行處理的一些擴充方法。


涉及到的方法:



比較常用的類似於拉伸圖片,拼接圖片名稱或者以顏色生成圖片等。


拼接圖片名稱:

[objc] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. + (UIImage *)imageMatchSizeWithName:(NSString *)imageName  
  2. {  
  3.     if (__Device_Iphone_5__)       //iphone5,5s  
  4.     {  
  5.         NSString *ext = [imageName pathExtension];  
  6.           
  7.         imageName = [imageName stringByDeletingPathExtension];  
  8.         imageName = [imageName stringByAppendingString:@"-568h@2x"];  
  9.         imageName = [imageName stringByAppendingPathExtension:ext];  
  10.     }  
  11.       
  12.     return [UIImage imageNamed:imageName];  
  13. }  

通過宏來給圖片名稱拼接一個4寸標識。


拉伸圖片到指定尺寸:

[objc] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. + (UIImage *)compressImage:(UIImage *)imgSrc toSize:(CGSize)size  
  2. {  
  3.     UIGraphicsBeginImageContext(size);  
  4.     CGRect rect = {{0,0}, size};  
  5.     [imgSrc drawInRect:rect];  
  6.     UIImage *compressedImg = UIGraphicsGetImageFromCurrentImageContext();  
  7.     UIGraphicsEndImageContext();  
  8.     return compressedImg;  
  9. }  

通過上下文來繪製實現將圖片拉伸到指定的尺寸。


指定位置獲取像素點平鋪拉伸圖片

[objc] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. + (UIImage *)strechImageWithName:(NSString *)imageName  
  2. {  
  3.     UIImage *image = [UIImage imageNamed:imageName];  
  4.       
  5.     return [image stretchableImageWithLeftCapWidth:image.size.width*0.5 topCapHeight:image.size.height*0.5];  
  6. }  
  7.   
  8. + (UIImage *)strechImageWithName:(NSString *)imageName posX:(CGFloat)x posY:(CGFloat)y  
  9. {  
  10.     UIImage *image = [UIImage imageNamed:imageName];  
  11.       
  12.     return [image stretchableImageWithLeftCapWidth:image.size.width*x topCapHeight:image.size.height*y];  
  13. }  

這裏涉及到一個端帽,不過如果不清楚只要知道是根據指定的像素位置平鋪來實現拉伸即可。


截屏:

[objc] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. + (UIImage *)screenshot  
  2. {  
  3.     CGSize imageSize = [[UIScreen mainScreen] bounds].size;  
  4.       
  5.     if (NULL != UIGraphicsBeginImageContextWithOptions) {  
  6.         UIGraphicsBeginImageContextWithOptions(imageSize, NO0);  
  7.     } else {  
  8.         UIGraphicsBeginImageContext(imageSize);  
  9.     }  
  10.       
  11.     CGContextRef context = UIGraphicsGetCurrentContext();  
  12.       
  13.     for (UIWindow *window in [[UIApplication sharedApplication] windows]) {  
  14.         if (![window respondsToSelector:@selector(screen)] || [window screen] == [UIScreen mainScreen]) {  
  15.             CGContextSaveGState(context);  
  16.               
  17.             CGContextTranslateCTM(context, [window center].x, [window center].y);  
  18.               
  19.             CGContextConcatCTM(context, [window transform]);  
  20.               
  21.             CGContextTranslateCTM(context,  
  22.                                   -[window bounds].size.width * [[window layer] anchorPoint].x,  
  23.                                   -[window bounds].size.height * [[window layer] anchorPoint].y);  
  24.               
  25.             [[window layer] renderInContext:context];  
  26.               
  27.             CGContextRestoreGState(context);  
  28.         }  
  29.     }  
  30.       
  31.     UIImage *image = UIGraphicsGetImageFromCurrentImageContext();  
  32.       
  33.     UIGraphicsEndImageContext();  
  34.       
  35.     return image;  
  36. }  


增加水印:

[objc] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. + (UIImage *)addImage:(UIImage *)image addMsakImage:(UIImage *)maskImage maskFrame:(CGRect)pos  
  2. {  
  3.     UIGraphicsBeginImageContext(image.size);  
  4.     [image drawInRect:CGRectMake(00, image.size.width, image.size.height)];  
  5.       
  6.     //水印圖片的位置  
  7.     [maskImage drawInRect:pos];  
  8.     UIImage *resultingImage = UIGraphicsGetImageFromCurrentImageContext();  
  9.     UIGraphicsEndImageContext();  
  10.     return resultingImage;  
  11. }  


指定顏色生成圖片:

[objc] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. + (UIImage *)imageWithColor:(UIColor *)color  
  2. {  
  3.     CGRect rect = CGRectMake(0011);  
  4.     UIGraphicsBeginImageContext(rect.size);  
  5.     CGContextRef context = UIGraphicsGetCurrentContext();  
  6.       
  7.     CGContextSetFillColorWithColor(context, [color CGColor]);  
  8.     CGContextFillRect(context, rect);  
  9.       
  10.     UIImage *image = UIGraphicsGetImageFromCurrentImageContext();  
  11.     UIGraphicsEndImageContext();  
  12.       
  13.     return image;  
  14. }  

以上三個方法其實均有些類似,都是通過圖片上下文來進行操作。


相對於上述方法,進行模糊稍微麻煩一些,也可以使用CoreImage中的高斯模糊濾鏡,CoreImage的簡單使用可以參照之前的博客:

CoreImage的使用及常見濾鏡工具(一)

[objc] view plaincopy在CODE上查看代碼片派生到我的代碼片
  1. + (UIImage *)blurImage:(UIImage *)src amount:(CGFloat)amount  
  2. {  
  3.     if (amount < 0.0 || amount > 1.0) {  
  4.         amount = 0.5;  
  5.     }  
  6.       
  7.     int boxSize = (int)(amount * 40);  
  8.     boxSize = boxSize - (boxSize % 2) + 1;  
  9.       
  10.     CGImageRef img = src.CGImage;  
  11.       
  12.     vImage_Buffer inBuffer, outBuffer;  
  13.     vImage_Error error;  
  14.       
  15.     voidvoid *pixelBuffer;  
  16.       
  17.     CGDataProviderRef inProvider = CGImageGetDataProvider(img);  
  18.     CFDataRef inBitmapData = CGDataProviderCopyData(inProvider);  
  19.       
  20.     inBuffer.width = CGImageGetWidth(img);  
  21.     inBuffer.height = CGImageGetHeight(img);  
  22.     inBuffer.rowBytes = CGImageGetBytesPerRow(img);  
  23.       
  24.     inBuffer.data = (void*)CFDataGetBytePtr(inBitmapData);  
  25.       
  26.     pixelBuffer = malloc(CGImageGetBytesPerRow(img) * CGImageGetHeight(img));  
  27.       
  28.     outBuffer.data = pixelBuffer;  
  29.     outBuffer.width = CGImageGetWidth(img);  
  30.     outBuffer.height = CGImageGetHeight(img);  
  31.     outBuffer.rowBytes = CGImageGetBytesPerRow(img);  
  32.       
  33.     error = vImageBoxConvolve_ARGB8888(&inBuffer, &outBuffer, NULL00, boxSize, boxSize, NULL, kvImageEdgeExtend);  
  34.       
  35.     if (!error) {  
  36.         error = vImageBoxConvolve_ARGB8888(&outBuffer, &inBuffer, NULL00, boxSize, boxSize, NULL, kvImageEdgeExtend);  
  37.           
  38.         if (!error) {  
  39.             error = vImageBoxConvolve_ARGB8888(&inBuffer, &outBuffer, NULL00, boxSize, boxSize, NULL, kvImageEdgeExtend);  
  40.         }  
  41.     }  
  42.       
  43.     CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();  
  44.       
  45.     CGContextRef ctx = CGBitmapContextCreate(outBuffer.data,  
  46.                                              outBuffer.width,  
  47.                                              outBuffer.height,  
  48.                                              8,  
  49.                                              outBuffer.rowBytes,  
  50.                                              colorSpace,  
  51.                                              (CGBitmapInfo)kCGImageAlphaNoneSkipLast);  
  52.       
  53.     CGImageRef imageRef = CGBitmapContextCreateImage (ctx);  
  54.       
  55.     UIImage *returnImage = [UIImage imageWithCGImage:imageRef];  
  56.       
  57.     CGContextRelease(ctx);  
  58.     CGColorSpaceRelease(colorSpace);  
  59.       
  60.     free(pixelBuffer);  
  61.     CFRelease(inBitmapData);  
  62.       
  63.     CGColorSpaceRelease(colorSpace);  
  64.     CGImageRelease(imageRef);  
  65.       
  66.     return returnImage;  
  67. }  
需要注意的是,這個方法需要導入系統庫:<Accelerate/Accelerate.h>


實現即使不是太清楚,也可以直接拿來用就行。

資源位置

GitHub:UIImage-HR

CSDN:iOS圖片分類



以上就是本篇博客全部內容,歡迎指正和交流。轉載註明出處~http://blog.csdn.net/cocoarannie/article/details/18566043

發佈了11 篇原創文章 · 獲贊 3 · 訪問量 5萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章