





有没有试过给安卓做完适配,转头发现iOS布局全崩了?图标糊成马赛克、文字挤成一团——双端适配简直是开发者的“双倍痛苦”!今天小编就手把手拆解资源包的制作门道,保你省时省力不秃头!
问题:平板上布局拉伸像橡皮筋?
答案:用对目录名,系统自动匹配!
按尺寸分:
res/layout/→ 默认手机竖屏
res/layout-sw600dp/→ 7英寸平板竖屏
res/layout-sw720dp/→ 10英寸平板
按方向分:
res/layout-land/→ 横屏通用
res/layout-sw600dp-land/→ 平板横屏分栏布局
血泪经验:别再用
layout-large这种过时目录!安卓3.2后最小宽度限定符(sw) 才是王道。
痛点:iOS图标为啥总模糊?
真相:苹果把图片压进Assets.car了!
提取资源:
用iTools导出ipa → 改后缀.zip解压
找到Payload/应用名.app/Assets.car
破解工具:
GitHub下载cartool
终端命令:./cartool Assets.car 输出文件夹
瞬间解出所有高清图!
避坑提示:iOS 15+的深色模式图藏在Assets.car/dark里,别漏了!
安卓→iOS:
把drawable-xxhdpi的图扔进Xcode
勾选Preserve Vector Data(矢量图永不糊)
iOS→安卓:
从Assets.car解压的图改名ic_xxx.png
按密度塞进drawable-mdpi、drawable-xhdpi等目录
场景 | 安卓操作 | iOS操作 |
|---|---|---|
文字大小 |
| 用 |
边距定义 |
|
|
横屏适配 |
|
|
小编翻车史:曾把安卓的
dp直接当iOSpt用,结果iPad上文字溢出屏幕…切记单位不同!(1dp≈1pt但非绝对等价)
高频翻车现场1:安卓横屏布局在iOS折叠屏错位
解法:
安卓端用ConstraintLayout链式约束
iOS端用UILayoutGuide占位隔离
高频翻车现场2:双端深色模式不同步
急救包:
安卓:res/values-night/colors.xml
iOS:Assets.car里追加dark版图片 + UIColor(dynamicProvider)
别追求100%复用率!双端差异是天然存在的:
安卓专属:
碎片化严重 → 备齐drawable-hdpi到drawable-xxxhdpi
折叠屏用res/layout-w600dp-land/特殊优化
iOS专属:
灵动岛挖孔区留出44pt安全边距
用UIAccessibility动态放大字体
最后的大实话:我见过有人强求双端布局一致,结果安卓平板控件小到点不中!适配的真谛是“各美其美” ——安卓分栏用Fragment组合,iOS靠AutoLayout拉伸,能跑顺就是胜利!