個人認為最快的鋪簡單頁面的最快方式
很明顯能看出這三種屏幕的尺寸寬高比是差不多的胎源,因此可以在5的基礎上鲤竹,按比例放大來兼容6和6Plus的屏幕搅方。
繪制的時注意!
1)尺寸
2)取消
viewDidLoad() 函數里面主要負責加載一些配置型的東西并且初始化界面盟蚣。最后會初始化自動布局的約束悦屏。你在界面上設置的frame节沦,雖然viewDidLoad() 里面修改了frame,但是在最后初始化自動布局約束之后你的frame 又回到添加自動布局約束時的值础爬。如果寫在viewDidAppear() 里面會出現一些能看見的變化.這不是我們想要的,我的xcode版本比較高.所以Storyboard的Use Auto Layout 是選中的,那我們就取消這個選項,再把調用方法寫在viewDidLoad,就不會出現能讓你看見的過程.
在帶有xib的viewController 中
定義宏
#define SCREEN_WITH [[UIScreen mainScreen] bounds].size.width
#define SCREEN_HEIGHT [[UIScreen mainScreen] bounds].size.height
及獲取屏幕的寬和高
在viewDidload里調用
[self xibAutoLay:self.view];
方法實現
- (void)xibAutoLay:(UIView *)allView
{
CGFloat autoSizeScaleX, autoSizeScaleY;
/*
因為iPhone4s屏幕的高度是480甫贯,因此當屏幕尺寸大于iPhone4時,autoSizeScaleX和autoSizeScaleY即為當前屏幕和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;
/*? 如果想文字也適應比例
if ([temp isKindOfClass:[UILabel class]]) {? //判斷帶文字的類型的view,例:UILabel
UILabel *labelTemp = (UILabel *)temp; // 轉換類型
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ā)現....
參考博客地址? :http://blog.it985.com/5121.html