iOS-图片的拉伸
来源:互联网 发布:程序员需要会什么 编辑:程序博客网 时间:2024/04/29 17:29
iOS-图片拉伸
概念介绍
直接拉伸图片有时候会导致图片四周变的很模糊
所以要想办法使图片四周的形状不变。于是,端盖(end cap)的概念出来了,用来指定图片中的哪一部分不用拉伸。比如下图中,黑色代表需要被拉伸的矩形区域,上下左右不需要被拉伸的边缘就称为端盖。
具体实现
方法一:
使用UIImage的这个方法,可以通过设置端盖宽度返回一个经过拉伸处理的UIImage对象
- (UIImage *)stretchableImageWithLeftCapWidth:(NSInteger)leftCapWidth topCapHeight:(NSInteger)topCapHeight;
这个方法只有2个参数,leftCapWidth代表左端盖宽度,topCapHeight代表顶端盖高度。系统会自动计算出右端盖宽度(rightCapWidth)和底端盖高度(bottomCapHeight),算法如下(系统自己计算的,不用程序员计算):
rightCapWidth = width - leftCapWidth - 1bottomCapHeight = height - topCapHeight - 1
举例:
UIImage *image1 = [UIImage imageNamed:@"imageName"]; UIImage *image2 = [image1 stretchableImageWithLeftCapWidth:image1.size.width * 0.5 topCapHeight:image1.size.height * 0.5];
方法二:
在iOS 5.0中,UIImage又有一个新方法可以处理图片的拉伸问题
- (UIImage *)resizableImageWithCapInsets:(UIEdgeInsets)capInsets NS_AVAILABLE_IOS(5_0);
这个方法只接收一个UIEdgeInsets类型的参数,可以通过设置UIEdgeInsets的left、right、top、bottom来分别指定左端盖宽度、右端盖宽度、顶端盖高度、底端盖高度
举例:
UIImage *image1 = [UIImage imageNamed:@”imageName”];
UIImage *image2 = [image1 resizableImageWithCapInsets:UIEdgeInsetsMake(5, 5, 5, 5)];
方法三:
在iOS 6.0中,UIImage又有一个新方法可以处理图片的拉伸问题
- (UIImage *)resizableImageWithCapInsets:(UIEdgeInsets)capInsets resizingMode:(UIImageResizingMode)resizingMode NS_AVAILABLE_IOS(6_0);
对比iOS5.0中的方法,只多了一个UIImageResizingMode参数,用来指定拉伸的模式:
UIImageResizingModeStretch:拉伸模式,通过拉伸UIEdgeInsets指定的矩形区域来填充图片
UIImageResizingModeTile:平铺模式,通过重复显示UIEdgeInsets指定的矩形区域来填充图片
举例:
UIImage *image1 = [UIImage imageNamed:@”imageName”];
UIImage *image2 = [image1 resizableImageWithCapInsets:UIEdgeInsetsMake(5, 5, 5, 5) resizingMode:UIImageResizingModeStretch];
方法四:
总结:
使用技巧:
除了以上方法的灵活使用之外,在具体项目中,可以将拉伸的图片的方法封装到UIImage的categary的分类方法中,然后在使用的地方直接引入头文件并调用。
举例:
.h文件中:
/** * 返回一张可以拉伸的图片 * * @param name 图片名 * * @return 可以拉伸的图片 */+ (instancetype)resizableImage:(NSString *)name;
.m文件中:
+ (instancetype)resizableImage:(NSString *)name{ UIImage *image = [self imageNamed:name]; return [image stretchableImageWithLeftCapWidth:image.size.width * 0.5 topCapHeight:image.size.height * 0.5];}
- iOS-图片的拉伸
- iOS图片拉伸的做法
- ios图片拉伸的问题
- ios图片拉伸的问题
- iOS之图片的拉伸
- iOS的图片拉伸方法
- ios 图片拉伸的几种方法
- iOS中图片拉伸的方法
- IOS图片拉伸的几种方法
- ios图片拉伸问题的总结
- iOS中图片的拉伸处理技巧
- iOS中图片拉伸的方法
- iOS 图片拉伸的三种方法
- iOS 图片拉伸的三种方法
- iOS 只拉伸图片的中间部分
- iOS中图片拉伸的方法
- ios中拉伸图片的方法
- iOS中图片拉伸的方法
- nodeJS链接mysql数据库(express框架)
- E: Unable to correct problems, you have held broken packages.
- Ubuntu12.04下WiFi热点配置
- Qt热点
- 加载3D模型时注意事项
- iOS-图片的拉伸
- 直方图均衡化原理之概率论相关知识
- hdu 2680 Choose the best route
- post 传字典
- tomcat - set up username and password
- 法国恢复规划
- 大使馆大使馆
- 条件选代码
- jQuery post数据给php的代码例子