标签: ios4 高清图 iphone4 retina
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。 http://life173.blog.51cto.com/2035365/384735
iPhone4采用了一个叫做retina的屏幕,尺寸和老的iphone一样大,但是分辨率提高了4倍,看起高清的图来,爽太多了,根本看不到像素点.
对于老的app来说,在iphone4中运行,会自动用4个像素替代原来的一个像素,这样就不用更改代码,使得老app可以自然的在iphone4中运行,但是UI的效果会有些蒙蒙的,不是最佳的效果,要达到最佳,必须为原来的图片资源,重新设计一份640*960的高清版本,这样才能在iphone4内达到最佳的UI效果~
下面就来简单总结下在ios4中怎么样使用高清图,首先要了解一些概念:
Points Versus Pixels:
When using native drawing technologies such as Quartz, UIKit, and Core Animation, you specify coordinate values using a logical coordinate space, which measures distances in points. This logical coordinate system is decoupled from the device coordinate space used by the system frameworks to manage the pixels on the screen.
一般程序中使用到的尺寸都是以point来计算的.
在老的iphone中,point和pixel基本没怎么去分辨,因为都是1:1的,都是320*480.
但是在iphone4或以后的设备中,这个不再是1:1的关系,对于iphone4的retina屏幕来说,1point=2pixels,屏幕的最大point的size仍是320*480.
接下来就说下怎么样使用高清图:
UIImage *image1 = [UIImage imageNamed:@"Default.png"];
UIImage *image2 = [UIImage imageNamed:@"Default"];
上面两行代码,在ios4中,都会自动根据你的手机分辨率,来自动匹配图片:
如果是iphone 3G和3GS,调用上面的结果,image1和image2得到的都是Default.png(320*480)这张图片,在查看image的size,你会发现是320*480的(按point来计),再看image的scale这个property是1.0,表示实际的1个piont对应了一个像素点,所以图片的实际像素是(320*scale)*(480*scale)=320*480.
如果是iphone4,返回的结果两个image都是
[email protected](640*960)这张图,再次查看image的size,你会发现仍然是320*480(points),但是scale是2.0,表示1个point对应图片上面的两个像素点,所以图片的实际像素是(320*scale)*(480*scale)=640*960.
所以,只用给同名的高清图加上@2x这个后缀,用UIImage的imageNamed这个函数调用图片名(未带@2x的),就会自动帮你调用合适的图片,使用起来很方便.
你也可以使用,UIImage的initWithContentsOfFile:(需要图片的完整路径)函数来load图片,但是这个不会帮你自动区分图片,你需要自己根据手机的分辨率来指定调用Default.png还是
[email protected].
可以做如下一些测试,能够加深印象:
举个例子:
但是如果调用DefaultCopy.png,因为它找不到
[email protected]这张高清图,只能用原来小size的图,所以返回还是DefaultCopy.png(320*480),size是320*480,但是scale是1.0,实际图像的像素就是(320*scale)*(480*scale)=320*480,显示效果差,因为图片像素只有高清的1/4.