欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

IOS 屏幕适配方案实现缩放window的示例代码

程序员文章站 2022-11-23 18:14:21
背景:公司有个ipad项目(只支持横屏),是11年开发的,那时的ipad只有1024x768的分辨率,所以没有屏幕适配的问题,frame都是写死的。后来不同尺寸的ipad相继出现,本来应该会出现屏幕不...

背景:

公司有个ipad项目(只支持横屏),是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_height [uiscreen mainscreen].bounds.size.height 
改为 #define screen_height 768

3、在window上添加视图,不要使用window.center来让视图居中。因为window.frame.origin 已经不是(0,0)了。

alertview.center = cgrectmake(1024 * 0.5, 768 * 0.5)

此方案的缺点

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

到此这篇关于ios 屏幕适配方案实现缩放window的示例代码的文章就介绍到这了,更多相关ios 缩放window内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!