屏幕適配方案:縮放window

背景:


公司有個iPad項目(只支持橫屏),是11年開發的,那時的iPad只有1024x768的分辨率,因此沒有屏幕適配的問題,frame都是寫死的。後來不一樣尺寸的iPad相繼出現,原本應該會出現屏幕不能適配的問題,可是因爲該項目沒有設置啓動圖,頁面會自動等比例縮放撐滿整個屏幕,各分辨率的寬高比相差很少,因此並無出現太大問題。可是2020年3月4日,蘋果要求全部提交至 App Store 的 app 都須使用 Xcode storyboard(故事板) 來提供 app 的啓動屏幕,以前的不設置啓動圖取巧的方式就不能用了。app

最理想的適配方案固然是AutoLayout,但改成AutoLayout改動太大,目前適配週期短,因此這種方案就淘汰了。而後考慮使用AutoResizing,改動小了不少,可是因爲項目很大,頁面不少,改動時間仍是有些長。code

最後考慮了不設置啓動圖能正常適配的原理。考慮使用縮放Window的方案orm

縮放方案


一、window縮放開發

self.window = [[UIWindow alloc] initWithFrame:CGRectMake(0, 0, 1024, 768)];
    CGFloat scaleX = [UIScreen mainScreen].bounds.size.width / 1024;
    CGFloat scaleY = [UIScreen mainScreen].bounds.size.height / 768;
    self.window.transform = CGAffineTransformMakeScale(scaleX, scaleY);
    CGRect rect = self.window.frame;
    self.window.frame = CGRectMake(0, 0, rect.size.width, rect.size.height);

二、屏幕尺寸的分辨率須要本身寫死,不能使用screen的boundsit

#define SCREEN_WIDTH [UIScreen mainScreen].bounds.size.width 
改成 #define SCREEN_WIDTH 1024
#define SCREEN_HEIGHT [UIScreen mainScreen].bounds.size.height 
改成 #define SCREEN_HEIGHT 768

三、在window上添加視圖,不要使用window.center來讓視圖居中。由於window.frame.origin 已經不是(0,0)了。form

alertView.center = CGRectMake(1024 * 0.5, 768 * 0.5)

此方案的缺點


一、若是使window等比例縮放,iPad Pro 11英寸上下會有一點黑邊。
二、若是使window寬高縮放撐滿整個屏幕,iPad Pro 11英寸會略微有些變形,不明顯
三、會有點模糊,不明顯
四、若是哪天新出一款iPad寬高比和之前的iPad差異比較大,縮放方案就不適用了。原理

相關文章
相關標籤/搜索