個人認(rèn)為最快的鋪簡單頁面的最快方式

很明顯能看出這三種屏幕的尺寸寬高比是差不多的,因此可以在5的基礎(chǔ)上,按比例放大來兼容6和6Plus的屏幕。

繪制的時注意!
1)尺寸

2)取消

viewDidLoad() 函數(shù)里面主要負(fù)責(zé)加載一些配置型的東西并且初始化界面。最后會初始化自動布局的約束。你在界面上設(shè)置的frame,雖然viewDidLoad() 里面修改了frame,但是在最后初始化自動布局約束之后你的frame 又回到添加自動布局約束時的值。如果寫在viewDidAppear() 里面會出現(xiàn)一些能看見的變化.這不是我們想要的,我的xcode版本比較高.所以Storyboard的Use Auto Layout 是選中的,那我們就取消這個選項,再把調(diào)用方法寫在viewDidLoad,就不會出現(xiàn)能讓你看見的過程.
在帶有xib的viewController 中
定義宏
#define SCREEN_WITH [[UIScreen mainScreen] bounds].size.width
#define SCREEN_HEIGHT [[UIScreen mainScreen] bounds].size.height
及獲取屏幕的寬和高
在viewDidload里調(diào)用
[self xibAutoLay:self.view];
方法實現(xiàn)
- (void)xibAutoLay:(UIView *)allView
{
CGFloat autoSizeScaleX, autoSizeScaleY;
/*
因為iPhone4s屏幕的高度是480,因此當(dāng)屏幕尺寸大于iPhone4時,autoSizeScaleX和autoSizeScaleY即為當(dāng)前屏幕和iPhone5尺寸的寬高比。
比如如果是5,autoSizeScaleX=1,autoSizeScaleY=1;
如果是6,autoSizeScaleX=1.171875,autoSizeScaleY=1.17429577;
如果是6Plus,autoSizeScaleX=1.29375,autoSizeScaleY=1.2957;
*/
if(SCREEN_HEIGHT > 480){
autoSizeScaleX = SCREEN_WITH/320;
autoSizeScaleY = SCREEN_HEIGHT/568;
}else{
autoSizeScaleX = 1.0;
autoSizeScaleY = 1.0;
}
for (UIView *temp in allView.subviews) {
CGRect rect;
rect.origin.x = temp.frame.origin.x * autoSizeScaleX;
rect.origin.y = temp.frame.origin.y * autoSizeScaleY;
rect.size.width = temp.frame.size.width * autoSizeScaleX;
rect.size.height = temp.frame.size.height * autoSizeScaleY;
temp.frame = rect;
/*? 如果想文字也適應(yīng)比例
if ([temp isKindOfClass:[UILabel class]]) {? //判斷帶文字的類型的view,例:UILabel
UILabel *labelTemp = (UILabel *)temp; // 轉(zhuǎn)換類型
labelTemp.font? = [UIFont systemFontOfSize:17/(320*568/(SCREEN_WITH * SCREEN_HEIGHT))];
[labelTemp sizeToFit];
}
*/
// ? ? 因為有可能你在某個view的子類上嵌套了其他的view所以 有幾層嵌套就嵌套幾層for in
/*
for (UIView *tempTwo in temp.subviews) {
rect.origin.x = tempTwo.frame.origin.x * autoSizeScaleX;
rect.origin.y = tempTwo.frame.origin.y * autoSizeScaleY;
rect.size.width = tempTwo.frame.size.width * autoSizeScaleX;
rect.size.height = tempTwo.frame.size.height * autoSizeScaleY;
tempTwo.frame = rect;
}
*/
}
}
此文章新手向..本文方法可能存在某些bug,請不要介意,因為,我還沒發(fā)現(xiàn)....
作者:L_Glenn
鏈接:http://www.itdecent.cn/p/093297882f0c
來源:簡書
參考博客地址? :http://blog.it985.com/5121.html
著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請注明出處。