美文网首页
屏幕适配方案:缩放Window

屏幕适配方案:缩放Window

作者: xiari1991 | 来源:发表于2020-04-12 22:36 被阅读0次

    背景:

    公司有个项目,是11年开发的,那时的iPad只有1024x768的分辨率,所以没有屏幕适配的问题,frame都是写死的。后来不同尺寸的iPad相继出现,本来应该会出现屏幕不能适配的问题,但是由于该项目没有设置启动图,页面会自动等比例缩放撑满整个屏幕,各分辨率的宽高比相差不多,所以并没有出现太大问题。但是2020年3月4日,苹果要求所有提交至 App Store 的 app 都须使用 Xcode storyboard(故事板) 来提供 app 的启动屏幕,之前的不设置启动图取巧的方式就不能用了。

    最理想的适配方案当然是AutoLayout,但改为AutoLayout改动太大,目前适配周期短,所以这种方案就淘汰了。然后考虑使用AutoResizing,改动小了很多,但是由于项目很大,页面很多,改动时间还是有些长。

    最后考虑了不设置启动图能正常适配的原理。考虑使用缩放Window的方案

    缩放方案需要修改哪些内容

    1、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);
    

    2、屏幕尺寸的分辨率需要自己写死,不能使用screen的bounds

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

    此方案的缺点

    1、如果宽高等比例缩放,iPad Pre 11英寸上下会有一点黑边。
    2、如果是宽高撑满整个屏幕,略微有些变形,不过不太能看出来
    3、会有点模糊,不太明显
    4、如果那天新出一款iPad宽高比和以前的iPad差别比较大,缩放方案就不适用了。

    相关文章

      网友评论

          本文标题:屏幕适配方案:缩放Window

          本文链接:https://www.haomeiwen.com/subject/lnzbmhtx.html