背景:
公司有个iPad项目(只支持横屏),是11年开发的,那时的iPad只有1024×768的分辨率,所以没有屏幕适配的问题,frame都是写死的。后来不同尺寸的iPad相继出现,本来应该会出现屏幕不能适配的问题,但是由于该项目没有设置启动图,页面会自动等比例缩放撑满整个屏幕,各分辨率的宽高比相差不多,所以并没有出现太大问题。但是2020年3月4日,苹果要求所有提交至 App Store 的 app 都须使用 Xcode storyboard(故事板) 来提供 app 的启动屏幕,之前的不设置启动图取巧的方式就不能用了。
最理想的适配方案当然是AutoLayout,但改为AutoLayout改动太大,目前适配周期短,所以这种方案就淘汰了。然后考虑使用AutoResizing,改动小了很多,但是由于项目很大,页面很多,改动时间还是有些长。
最后考虑了不设置启动图能正常适配的原理。考虑使用缩放Window的方案
缩放方案
1、window缩放
|
1
2
3
4
5
6
|
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
|
1
2
3
4
|
#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)了。
|
1
|
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内容请搜索快网idc以前的文章或继续浏览下面的相关文章希望大家以后多多支持快网idc!
相关文章
- 个人网站服务器域名解析设置指南:从购买到绑定全流程 2025-06-10
- 个人网站搭建:如何挑选具有弹性扩展能力的服务器? 2025-06-10
- 个人服务器网站搭建:如何选择适合自己的建站程序或框架? 2025-06-10
- 64M VPS建站:能否支持高流量网站运行? 2025-06-10
- 64M VPS建站:怎样选择合适的域名和SSL证书? 2025-06-10
- 2025-07-10 怎样使用阿里云的安全工具进行服务器漏洞扫描和修复?
- 2025-07-10 怎样使用命令行工具优化Linux云服务器的Ping性能?
- 2025-07-10 怎样使用Xshell连接华为云服务器,实现高效远程管理?
- 2025-07-10 怎样利用云服务器D盘搭建稳定、高效的网站托管环境?
- 2025-07-10 怎样使用阿里云的安全组功能来增强服务器防火墙的安全性?
快网idc优惠网
QQ交流群
-
2025-05-27 79
-
2025-05-27 36
-
2025-05-27 101
-
2025-05-25 31
-
2025-05-29 82

