UIImage总结

imageNamed 与 imageWithContentsOfFile的区别

myImage = [UIImage imageNamed:@"icon.png"];
那么小心了
这种方法在一些图片很少,或者图片很小的程序里是ok的。
但是,在大量加载图片的程序里,请千万不要这样做。
这种方法在application bundle的顶层文件夹寻找由供应的名字的图象 。 如果找到图片,装载到iPhone系统缓存图象。那意味图片是(理论上)放在内存里作为cache的。

试想你图片多了,是什么后果``````
图片cache极有可能不会响应 memory warnings and release its objects

所以,用图片的时候一定要小心的alloc和release
推荐使用
NSString *path = [[NSBundle mainBundle] pathForResource:@”icon” ofType:@”png”];
myImage = [UIImage imageWithContentsOfFile:path];

不过这种方法要注意了,如果有高清图,也就是@2x的,就不能自动获取到了,自己把握吧,做ui可以用imageNamed,要处理的大图就别这样加载了

 

------------------------------------------------------------------------------------

用UIImage加载图像的方法很多,最常用的是下面两种:

   1、用imageNamed函数

[UIImage imageNamed:ImageName];

   2、用NSData的方式加载,例如:

  1. NSString *filePath = [[NSBundle mainBundle] pathForResource:fileName ofType:extension];
  2. NSData *image = [NSData dataWithContentsOfFile:filePath];
  3. [UIImage imageWithData:image];

这两种加载方式都有各自的特点。

   1)用imageNamed的方式加载时,系统会把图像Cache到内存。如果图像比较大,或者图像比较多,用这种方式会消耗很大的内存,而且释放图像的 内存是一件相对来说比较麻烦的事情。例如:如果利用imageNamed的方式加载图像到一个动态数组NSMutableArray,然后将将数组赋予一 个UIView的对象的animationImages进行逐帧动画,那么这将会很有可能造成内存泄露。并且释放图像所占据的内存也不会那么简单。但是利 用imageNamed加载图像也有自己的优势。对于同一个图像系统只会把它Cache到内存一次,这对于图像的重复利用是非常有优势的。例如:你需要在 一个TableView里重复加载同样一个图标,那么用imageNamed加载图像,系统会把那个图标Cache到内存,在Table里每次利用那个图 像的时候,只会把图片指针指向同一块内存。这种情况使用imageNamed加载图像就会变得非常有效。

   2)利用NSData方式加载时,图像会被系统以数据方式加载到程序。当你不需要重用该图像,或者你需要将图像以数据方式存储到数据库,又或者你要通过网络下载一个很大的图像时,请尽量使用imageWithData的方式加载图像。(同步处理方式)

无论用哪种方式加载图像,图像使用结束后,一定要记得显示释放内存。

(http://blog.csdn.net/gf771115/article/details/7728842 http://hi.baidu.com/vim888/item/28a64e96534465db1a49df5f   )

//让一个UIImageView响应点击事件
 
UIImageView *imgView =[[UIImageView alloc] initWithFrame:CGRectMake(0, 0,320, 44)];
imgView.userInteractionEnabled=YES;
UITapGestureRecognizer *singleTap =[[UITapGestureRecognizeralloc]initWithTarget:selfaction:@selector(onClickImage)];
[imgView addGestureRecognizer:singleTap];
[singleTap release];

 

-(void)onClickImage{
  // here, do whatever you wantto do
   NSLog(@"imageview is clicked!");
}

 

首先需要加入这个库以及引用这个头文件:QuartzCore.FrameWork,以及#import<QuartzCore/QuartzCore.h>;

然后在UIImageView 加载图片之后,加入下面的代码即可:

CALayer *l = [cell.imgAvatarImage layer];   //获取ImageView的层
[l setMasksToBounds:YES];
[l setCornerRadius:6.0];

通过上面的设置,在UIImageView就可以看到图片圆角的效果了。

@追风 2012/12/20

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值