ios图片圆角处理
2015-04-01 22:27
225 查看
UIImage+wiRoundedRectImage.h
调用方法:
UIImage * image = [UIImageimageNamed:@"123.jpg"]; // 设置原图
CGSize size = CGSizeMake(100,100); // 设置尺寸
_pImgV.image = [UIImagecreateRoundedRectImage:image size:size radius:10]; // 设置radius
#import <UIKit/UIKit.h> @interface UIImage (wiRoundedRectImage) + (id)createRoundedRectImage:(UIImage*)image size:(CGSize)size radius:(NSInteger)r; @end
#import "UIImage+wiRoundedRectImage.h"
@implementation UIImage (wiRoundedRectImage) static void addRoundedRectToPath(CGContextRef context, CGRect rect, float ovalWidth, float ovalHeight) { float fw, fh; if (ovalWidth == 0 || ovalHeight == 0) { CGContextAddRect(context, rect); return; } CGContextSaveGState(context); CGContextTranslateCTM(context, CGRectGetMinX(rect), CGRectGetMinY(rect)); CGContextScaleCTM(context, ovalWidth, ovalHeight); fw = CGRectGetWidth(rect) / ovalWidth; fh = CGRectGetHeight(rect) / ovalHeight; CGContextMoveToPoint(context, fw, fh/2); // Start at lower right corner CGContextAddArcToPoint(context, fw, fh, fw/2, fh, 1); // Top right corner CGContextAddArcToPoint(context, 0, fh, 0, fh/2, 1); // Top left corner CGContextAddArcToPoint(context, 0, 0, fw/2, 0, 1); // Lower left corner CGContextAddArcToPoint(context, fw, 0, fw, fh/2, 1); // Back to lower right CGContextClosePath(context); CGContextRestoreGState(context); } + (id)createRoundedRectImage:(UIImage*)image size:(CGSize)size radius:(NSInteger)r { // the size of CGContextRef int w = size.width; int h = size.height; UIImage *img = image; CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); CGContextRef context = CGBitmapContextCreate(NULL, w, h, 8, 4 * w, colorSpace, kCGImageAlphaPremultipliedFirst); CGRect rect = CGRectMake(0, 0, w, h); CGContextBeginPath(context); addRoundedRectToPath(context, rect, r, r); CGContextClosePath(context); CGContextClip(context); CGContextDrawImage(context, CGRectMake(0, 0, w, h), img.CGImage); CGImageRef imageMasked = CGBitmapContextCreateImage(context); img = [UIImage imageWithCGImage:imageMasked]; CGContextRelease(context); CGColorSpaceRelease(colorSpace); CGImageRelease(imageMasked); return img; } @end
调用方法:
UIImage * image = [UIImageimageNamed:@"123.jpg"]; // 设置原图
CGSize size = CGSizeMake(100,100); // 设置尺寸
_pImgV.image = [UIImagecreateRoundedRectImage:image size:size radius:10]; // 设置radius
相关文章推荐
- IOS 图片阴影,圆角等处理
- [iOS] 图像处理 - 一种高效裁剪图片圆角的算法
- iOS开发笔记-将图片处理成圆形或者说特定圆角
- IOS 图片阴影,圆角等处理
- iOS 开发--开源图片处理圆角
- ios 图片圆角或圆形处理
- iOS开发小技巧--图片的圆角处理
- iOS每日一记之———————————————图片圆角的处理
- IOS拉伸圆角图片
- Android中几种图像特效处理的小技巧,比如圆角,倒影,还有就是图片缩放,Drawable转化为Bitmap,Bitmap转化为Drawable等等
- 图片的圆角的处理
- Android之图片处理(图片合成、图片圆角、图片翻转、图片缩放)
- iPhone开发:iPhone iOS 3.x 与 iOS 4.x 的图片兼容处理
- ios图片处理
- Android图片缩放、圆角处理以及倒影特效代码
- Android腾讯微薄客户端开发七:图片加圆角以及时间处理工具类
- IOS图片大小处理
- Android图片缩放、圆角处理以及倒影特效代码
- Android腾讯微薄客户端开发七:图片加圆角以及时间处理工具类
- Phone中图片的拉伸/圆角处理(Image round corner, aspect fit)