微信iOS多设备多字体适配方案总结
一、背景
2014下半年,微信iOS版先后适配iPad, iPhone6/6plus。随着这些大屏设备的登场,部分用户觉得微信的字体太小,但也有很多用户不喜欢太大的字体。为了满足不同用户的需求,我们做了全局字体设置功能,在【设置-通用-字体大小】这里修改设置后,微信大部分界面都会随之缩放。
二、多设备适配
1、各设备的逻辑分辨率:
关于iphone6/6plus的物理分辨率、逻辑分辨率、屏幕物理尺寸、PPI等资料,很多文章已经有详细说明了,这里就不再累赘。对于终端开发人员来说,其实我们需要关心的,主要是各设备的逻辑分辨率和scaleFactor:
需要注意的是,iphone6和6plus可以设置标准模式和放大模式。在放大模式下,6plus会退化为375x667,此时应该当成iphone6来做适配。而iphone6会退化为320x568,应该当作iphone5来适配。
从表中可以看出,适配iphone6/6plus、ipad带来最大的变化是,屏幕宽度不再是320。以往我们可能一直习惯320宽的屏幕,所以写界面的时候容易hardcode,例如,如下图所示,有个按钮离屏幕左右边距分别为20,我们可能会把按钮宽度写死为280:
UIButton *btn = [[UIButton alloc] initWithFrame:CGRectMake(20, 15, 280, 46)];
但到了iphone6 plus上,屏幕宽度变成414,按钮的左右边距就变成20和114,显得不对称。在适配时,根据UI需要,此时可能会增加按钮宽度,改成20+374+20;也可能增加左右边距,改成67+280+67;也可能两者都增加,例如改成26+362+26,使得按钮宽度保持屏幕宽度的7/8。
为了实现这些适配需求,我们的解决方案是,使用配置文件,把界面参数从代码中分离开来,便于参数的适配。
2. 配置文件介绍
配置文件分为两部分:
第一部分是UI规范配置,把需要统一风格的UI元素定义下来。例如对于链接字体颜色,定义LINK_COLOR = rgba(87,107,149,1),所有界面包含链接时,链接的字体颜色都直接取LINK_COLOR,不单独harcode,这样有利于微信的整体UI风格统一、UI规范化,也方便以后UI调整时对链接字体颜色做统一修改。
// UI规范化 @colors{/* 普通列表(PlainStyle)的背景色 */DEFAULT_TABLE_BACKGROUND_COLOR: #2E3132;/* 链接字体颜色 */LINK_COLOR: rgba(87,107,149,1); }
第二部分是各界面的配置,可以对颜色、字体、切片、数值、坐标、尺寸、frame等进行配置,并根据设备适配的需求定义了一些扩展属性。
#test_view{/* 数值 */button_margin1: 20;button_margin2: 20 EqualRatio 320;button_margin3: 200 EqualDifference 320;/* frame、尺寸、坐标 */logo_frame: 0 0 200 200; /* frame */logo_size: 200 200; /* size */logo_origin: 0 0; /* origin *//* 颜色相关 */table_bkg_color: DEFAULT_TABLE_BACKGROUND_COLOR;button_bkg_color1: #00C000;button_bkg_color2: rbga(255,255,255,0.8);button_bkg_color3: clear;logo_image: “btn_bkg.png” 40 40; /* 切片 */label_font: 16 bold; /* 字体 */ }
下面对其中一些配置加以说明:
button_margin2: 20 EqualRatio 320;
表示在不同设备下做等比缩放,在320宽的屏幕下是20,在iphone6 plus屏幕上就是20 / 320 * 414=26
button_margin3: 20 EqualDifference 320;
表示在不同设备下做等差缩放,在320宽的屏幕下是200,在iphone6 plus屏幕上就是200 + (414-320) = 294
table_bkg_color: DEFAULT_TABLE_BACKGROUND_COLOR;
这里使用了UI规范配置里面的定义值
logo_image: “btn_bkg.png” 40 40;
指定了切片的文件,并指定其尺寸(不指定则默认按切片本身的尺寸)。
label_font: 16 bold;
指定字体大小,并为粗体。
EqualRatio,EqualDifference这两个关键词使界面的配置能够尽量做到一个设计稿适配多种设备。但有时候,我们需要在分设备进行单独配置,而等差和等比原则又无法满足。为了解决这个问题,每种设备单独一个配置文件,目前一共五种设备:默认(iphone5)、iphone4/4s、iphone6、iphone6plus、ipad。读取配置文件时,先读默认配置(iphone5),然后根据当前机型再读取单独的配置(如果是ipad就读ipad的配置,如果是iphone5就不用再读了)。这样取值时会优先取到单独的配置,如果没有单独配置就取到默认配置。
例如,默认配置中定义:
button_margin1: 20;button_margin2: 20 EqualRatio 320;button_margin3: 20;
iphone6plus的配置中定义
button_margin1: 30;
则在iphone6plus中,取到的值分别为button_margin1为30(取6plus配置的值),button_margin2为26(取默认配置的等比原则),button_margin3为20(取默认配置的值)
三、界面放大
全局字体设置不是简单地修改所有字体的大小,以主界面的会话cell为例,如下图a所示,如果所有字体改大,界面会变成图b所示,很不协调,两个label的上下间距也显得太小,甚至当字体再改大时会出现重叠问题。
为了保证两个label有足够的上下边距,cell的高度需要随之增加,如图c所示。这样会导致左侧头像在cell中显得太小,于是头像的宽高也要随之放大,头像上的红点也要跟着放大,……,最终整个界面很多元素(字体、宽高、边距等)都需要放大。
图a
图b
图c
图d
至于各元素要放大多少,一开始是想只推出一个大字体版本,由设计师出一套方案。但仔细想想工作量太大了,所有界面都要再出一套设计稿,而且不够灵活,不同设备上的大字体版都只能按照这套设计稿来。最后我们决定用等比放大的原则,所有元素按照统一一个比例进行放大,这样出来的效果还不错,重要的是大大减少了设计和开发的工作量。具体操作是:每个机型设五档字体,设计师确定各机型上每档字体的放大比例,开发写界面时,把字号大小、宽高、边距等值写到配置文件里,并指定这些值是否要随字体设置等比缩放。
在配置文件中,我们增加了关键词dynamic,使得界面能够支持根据字体设置缩放。例如:
button_height: 42 dynamic;
表示在不同字体大小设置下,动态缩放。标准字体下高度是42,字体放大50%后高度就是63
logo_image: “btn_bkg.png” 40 40 dynamic;
指定了切片的文件,并指定其尺寸(不指定则默认按切片本身的尺寸),并且在不同字体大小设置下,动态缩放。
label_font: 16 bold dynamic;
指定字体大小,并为粗体,同样根据字体设置动态放大。
需要注意的是,在对界面参数等比放大时,放大后的长度值要向上取整。这是因为UIView setFrame传入的CGRect,如果坐标或宽高值为小数,可能导致文字出现模糊(不锐利)、view出现黑边等现象。
四、webview字体放大
iOS上,可以在webview页面load完后,设置页面body的style.webkitTextSizeAdjust属性,对页面进行放大。例如:
document.getElementsByTagName("body")[0].style.webkitTextSizeAdjust=“150%”;
这种方法实现简单,但有两个问题:
1、对于复杂的图文页面,放大后的页面很难看。例如腾讯新闻页面的底部,放大后如下图所示。这是因为字体放大了,但图片、宽高等其它元素没有放大。
2、由于要等页面load完才能重写webkitTextSizeAdjust属性,导致页面load完后还会再刷新一下。
幸好微信里的webview阅读90%都是公众号文章,这些页面样式相对统一,而且是微信团队可控的。针对公众号文章,我们做了以下优化:
1、把用户的字体设置作为参数传给公众号平台,由他们调整页面样式后再出页面,这样load出来的页面style就是已经放大的了,不需要客户端重写style导致页面刷新一次。
<html style="-webkit-text-size-adjust: 160%;line-height:1”>
2、如果用户手动修改webview的字体大小,客户端会触发一个jsapi,公众号页面监听并实现这个jsapi,对页面样式进行调整。这样把字体修改的实现方法交给页面本身,而不是简单用webkitTextSizeAdjust,可以达到更好的放大效果。
WeixinJSBridge.on(‘menu:setfont’,function(res){// use fontScale, then set -webkit-text-size-adjust and line-height});
对于非公众号文章,目前默认不随全局字体设置做放大,如果用户手动修改webview的字体大小,会用webkitTextSizeAdjust修改。后续可以把这个jsapi推广到腾讯新闻插件,甚至开放出去,尽量把字体修改的实现方式交给页面。
五、iOS9 iPad分屏多任务
WWDC2015上推出了iPad分屏多任务功能,使得iOS设备的逻辑分辨率又多了五种:
分屏类型 | 分辨率 |
竖屏-小屏 | 320*1024 |
竖屏-大屏 | 438*1024 |
横屏-小屏 | 320*768 |
横屏-半屏 | 507*768 |
横屏-大屏 | 694*768 |
使用目前的适配方案,能够很快地适配iPad分屏。具体方法是:
1、对于320*768和320*1024的屏幕大小,用iphone5的配置参数;
2、对于其它屏幕大小,使用ipad的配置参数,并对必要的参数根据屏幕大小指定等差/等比缩放。
六、总结
界面参数写在配置文件有几个好处:
1、能够很快适配不同机型:对必要的参数指定等差缩放或等比缩放,就可以做到一个设计稿适配多种设备。
2、方便对不同机型做特殊处理:有时候个别参数在不同设备上有差异,而等差/等比原则又无法满足需求。如果参数写在代码里面,就有一堆机型的if判断:
if (isIpad) …;else if (isIphone6) …;else …
而写在配置文件里,只需要根据不同机型读相应配置文件即可。
3、能够很快适配不同字体大小:配置文件里指定哪些参数需要等比缩放,哪些是固定值,读参数的时候做一下处理,就可以实现界面缩放,不需要修改代码。
4、方便界面参数调整:设计师做界面微调时,可以自己修改配置文件,快速确认效果,不需要先跟开发沟通,等开发修改完代码后再确认。一方面减少了沟通成本,另一方面也减轻了开发的负担。
转载于:https://www.cnblogs.com/yulang314/p/5077270.html
微信iOS多设备多字体适配方案总结相关推荐
- IOS项目新手引导页图片适配方案
http://www.jianshu.com/p/6b379ce91d67 1. 背景 基本上每个IOS APP都会有新手引导页面这个功能,常规的就是几张静态图片,可以左右滚动.既然涉及到图片,就肯定 ...
- 关于字体适配的那些事
前言 之前做过很多项目都没考虑过字体适配问题.相信绝大多数人在做项目时,都没仔细去考虑这件事.一般都是根据UI出的图做个估算,有耐心的估计会自己拿工具测量下.如今,考虑到iPhone机型的多样性,UI ...
- iOS 关于全面屏适配的方案及UI在不同尺寸下适配方案
前言 全面屏刚出时,网上有说反人类.但过去这么久了,趋于技术的进步或看久了,大家也都慢慢习惯了(只是笔者还是买不起全面屏).官方适配中文版文档也出来了. 图源:( baijiahao.baidu.co ...
- 微信小程序填坑之路(三):布局适配方案(rpx、px、vw、vh)
因为小程序是以微信为平台运行的,可以同时运行在android与ios的设备上,所以不可避免的会遇到布局适配问题,特别是在iphone5上,因为屏幕尺寸小的缘故,也是适配问题最多的机型,下面就简单介绍几 ...
- Axure经典实例高保真交互下载(微信元件高保真交互库+微信原型交互+安卓设备模板含登录注册引导欢迎流程+ios苹果设备模板)
作品介绍:原型内容包括:微信小程序原件库.视觉规范.基础组件.操作反馈.导航搜索.ios机型设备模板.常用元素.安卓手机设备模板包含注册登录.欢迎引导页等 Axure兼容版本:8.0 和9.0 Axu ...
- iOS转前端之如何适配不同屏幕尺寸方案
今天抽空再写一篇~之前已经做了两个Demo,主要是运用CSS+Html完成的,今天还是来完成一个Demo,搭建一个关于宠物的网站.在开始之前我们先介绍一个知识点,关于适配的. 其实对于学习前端来说,H ...
- 微信小游戏屏幕适配方案
首发于我的个人博客-微信小游戏屏幕适配 很久没有发文了,最近一直在研究微信小游戏,屏幕适配问题真的是哪里都存在. 无奈论坛资料及可行的解决方案还是太少,还是得靠自己. 且来看一看在微信上如何达到适配多 ...
- 适配iOS 13 tabbar 标题字体不显示以及返回变蓝色的为问题
// 适配iOS 13 tabbar 标题字体不显示以及返回变蓝色的为问题 if (@available(iOS 13.0, *)) {//[[UITabBar appearance] setUnse ...
- 微信iOS WKWebview 网页开发适配指南
微信2017.1.6日推送一条消息: 微信iOS客户端 将于2017年3月1日前逐步升级为WKWebview内核,需要网页开发者提前做好网站的兼容检查和适配. 背景 WKWebView 是苹果在iOS ...
最新文章
- 华南理工大学计算机操作系统课程设计大作业银行家死锁避免算法模拟,2016春操作系统大作业银行家死锁避免算法模拟.doc...
- cookie完全跨域
- effective C++ 条款 47:使用traits classes表现类型信息
- php100并发cpu告警,多线程并发导致CPU100%的一种原因和解决办法
- HTML/CSS进阶
- 小白打基础一定要吃透的11类 Python 内置函数
- hexbin_Power BI Desktop中的Hexbin散点图
- 【实习】T100开发学习笔记
- HTML5 Canvas JavaScript库 Fabric.js 使用经验
- macOS完整项目源码之macOS动态壁纸创建工具(教程含源码)
- bch编码c语言有库么,BCH码的译码方法与流程
- 手机短信小额支付接口.Net实现
- 表格操作系列——字段名与字段别名的获取
- selenium上传附件的两种方式(普通上传和借助AutoIt识别Windows上传窗口)
- 图像特征之傅里叶描述子
- php sapi模式,PHP SAPI介绍
- mysql学习记录之创建数据库指定编码
- 什么是 .com 域名?含义和用途又是什么?
- ubuntu 双显卡安装n卡 Quadro K620 Tesla K80*8 显卡驱动的卸载 (已解决)没有图形界面。黑屏
- MATLAB 设置纵轴显示范围、科学记数法
热门文章
- asyncio oracle 异步,带有asyncio futures和RuntimeError的InvalidStateError与aiohttp时使用期货回调...
- arraylist扩容是创建新数组吗 java_arraylist扩容机制要怎么实现?arraylist怎么扩容...
- oracle中存储过程和函数有什么区别,Oracle中存储过程和函数的区别
- php 精度运算,PHP BC 库(任意精度数字运算) | 网游世界
- linux下安装mysql5.7.19,Linux下MySQL5.1升级到高版本MySQL5.7.19详解 | zifangsky的个人博客...
- openshift 3 mysql_最新OpenShift免费空间申请与使用教程-1G内存1G空间支持PHP和MysqL
- Springmvc借助SimpleUrlHandlerMapping实现接口开关功能
- dev c++ Boost库的安装
- codeforces B. Design Tutorial: Learn from Life
- 使用未初始化的内存是什么意思_他们都说JVM能实际使用的内存比-Xmx指定的少?这是为什么呢...