UI_RD协作开发流程
1. 背景
由于android端需要进行多屏幕适配,这就给UI&RD之间的沟通产生了一些困难。我下面将会对这两种角色的沟通,说明了一下我们项目中沟通的方式和规则。
原则:客户端跟UI约定了各种库(字体、距离、颜色),库的实际值根据各种屏幕等信息提前适配,但名字跟UI给的标注图保持一致。
后文分别对字体、距离和颜色进行解释:
2. 字体库和距离库
UI给出的效果图&标注均在720下面标注的。客户端针对720的标注来生成代码。如图:
为什么需用720下进行标注呢?
android官方文档建议选用320的屏幕作为标准屏幕进行适配,但当前主流机型的屏幕已经升级为720。且UI同学做的效果图就为720下的效果,综上所述,我们采用720的标注。
2.1 距离
针对所有距离,直接使用字体距离库font_distance_pool.xml中的dsxx, 比如:@dimen/ds50。
如何适配的?
针对ds50,分别在xh和h下对应不同的大小,分别为25dip和22dip。
为什么在xh下是25dip?
xh下的密度为2,所以设置为25dip,刚好为25*2=50
为什么在h下是22dip?
这是UI单独设置的规则。h的文件夹一般对应480的屏幕,720与480屏幕等比换算后,50px应该折算成33px,那33px在h下对应的值就大约为22dip了。
一共多少距离?
根据这个规则,已经把100px以下的距离都已经换算好,生成了xh和h的font_distance_pool.xml文件。超过100px的距离为不常用距离,当需要使用时,按照上面的规则,自行添加到距离库中。
2.2 字号
针对所有字号,直接使用字体距离库font_distance_pool.xml中的fontsizexx,比如:@dimen/fontsize22。
一共多少字号大小?
由于跟UI同学的规划,我们把整个应用的所有字号都进行了收敛,控制到7个字号。如上图。
为什么字号的单位的dp而不是sp?
由于android系统可以在设置中更改字体大小。比如在10sp的大小,如果选择大号字体,该字体大小就可能达到了15px。用户随意更改了字体大小,就跟UI设计图中的字体大小发生了差距。这样就很难保证效果图了。所以我们采用了dip,使用了dip就使得系统设置字号大小对本应用无效了。同时,我们本地应用提供了更改字号的功能,这样使得字号的变化处于可控状态。
如何适配不通屏幕?
同样的,字号也会针对xh和h下有适配关系,跟距离的一致。 同样参考:font_distance_pool.xml文件
4. 颜色库
对于颜色,我们做了相应的努力,也跟UI同学一起收敛了一下UI的使用,生成了颜色库,控制整个应用的颜色在30种以内。所有在应用中的颜色都能从该库中找到。
对应颜色,我们有存在日间和夜间模式,但我们只需要日间标注,就知道了夜间的信息,如何做到?
首先,定义了规则:所有日间和夜间的颜色对应关系全部在颜色库colors_pool.xml 里面,并且根据名字的微笑变化来进行匹配。比如: 日间是color,那夜间是color_1。 用_1来区分是否为夜间资源。并且通过代码,根据当前状态自动寻找对应资源。
其次,在日间标注上面,颜色使用颜色库里面的名字。
这样做有什么优势?
RD看见标注很清晰,并且不需要关心夜间信息。更加专心的处理业务功能。
UI只需要一次投入来规划颜色库,以后不需要再做夜间效果图。减少工作量。
5.后续
通过以上努力我们把字号、距离、颜色搞定了。针对android的适配,我们前进了一大步,也方便了一大步。后续,我们可以考虑在布局上做些文章。由于UI和RD在布局上的理解不一致,我们需要通过一些手段来化解理解上的鸿沟。期待后面的探索。
UI_RD协作开发流程的更多相关文章
- Gitblit搭建及Git协作开发流程
1. 概述 目前主流的是git作为自己代码管理,但是采用github需要付费才能够使用,如果不付费,代码需要公开.创业团队及小型开发团队都有必要搭建自己的代码服务器,自己摸索需要一定的时间,会赶不及项 ...
- 前端项目git操作命名规范和协作开发流程
前言 一个项目的分支,一般包括主干 master 和 开发分支 dev,以及若干临时分支 分支命名规范 分支: 命名: 说明: 主分支 master 主分支,所有提供给用户使用的正式版本,都在这个主分 ...
- 20个可以帮你简化iOS app开发流程的工具
这里推荐20个可以帮你简化iOS app开发流程的工具.很多开发者都使用过这些工具,涉及原型和设计.编程.测试以及最后的营销,基本上涵盖了整个开发过程. 原型和设计 有了一个很好的创意后,你要做的不是 ...
- 实例讲解基于 React+Redux 的前端开发流程
原文地址:https://segmentfault.com/a/1190000005356568 前言:在当下的前端界,react 和 redux 发展得如火如荼,react 在 github 的 s ...
- python 面向对象终极进阶之开发流程
好了,你现在会了面向对象的各种语法了, 但是你会发现很多同学都是学会了面向对象的语法,却依然写不出面向对象的程序,原因是什么呢?原因就是因为你还没掌握一门面向对象设计利器, 此刻有经验的人可能会想到 ...
- GitHub Flow & Git Flow 基于Git 的两种协作开发模式
介绍基于Git 两种协作开发模式,GitHub Flow & Git Flow 对于Github 一些好用的特殊操作技巧 ,可以见GitHub 特殊操作技巧 和Git的基本操作 一 GitHu ...
- 利用git 进行多人协作开发
现在,大部分项目都是用 git 来管理代码的,但当项目变大.多人协作时,git 的使用就变得复杂了,这时就需要在 git 使用的流程上来思考如何更优的使用 git. 对于大部分 web 项目而言,并不 ...
- 分享一篇 Git Web 开发流程
分享一篇 Git Web 开发流程 web 项目如何进行 git 多人协作开发 https://segmentfault.com/a/1190000018165757
- git的团队协作开发
title: git的团队协作开发 date: 2018-04-24 14:00:03 tags: [git] --- 项目负责人创建组织架构 在控制面板中点击组织按钮,添加组织,在这里可以把组织理解 ...
随机推荐
- tengine安装
下载地址: http://tengine.taobao.org/download_cn.html $tar -xvzf tengine-2.1.2.tar.gz $./configure$ make$ ...
- hibernate 自生双向一对多 多对一管理 (树)
<span style="font-size: large;">package com.javacrazyer.test; import java.io.Seriali ...
- LINQ To SQL 语法及实例大全
http://blog.csdn.net/pan_junbiao/article/details/7015633 http://blog.csdn.net/pan_junbiao/article/de ...
- BouncyCastle产生一个PKCS#12规范的PFX/p12证书
RT,在C#中实现,依赖.netFramework2.0 BouncyCastle中提供了PKCS12Store,Pkcs12StoreBuilder,AsymmetricKeyEntry,X509C ...
- UIview定义背景图片
UIImage *image = [UIImage imageNamed:@"bgimagename"]; UIView *view = [[UIView alloc]ini ...
- IsolatedStorageException for Silverlight Application
if you are using the IsolatedStorage for application configuration storage, and when you get the Iso ...
- 【转】java int与integer的区别
java int与integer的区别 int与integer的区别从大的方面来说就是基本数据类型与其包装类的区别: int 是基本类型,直接存数值,而integer是对象,用一个引用指向这个对象 1 ...
- jQurey基础简介
随着WEB2.0及ajax思想在互联网上的快速发展传播,陆续出现了一些优秀的Js框架,其中比较著名的有Prototype.YUI.jQuery. mootools.Bindows以及国内的JSVM框架 ...
- 【SQL Server】系统学习之三:逻辑查询处理阶段-六段式
一.From阶段 针对连接说明: 1.笛卡尔积 2.on筛选器 插播:unknown=not unknuwn 缺失的值: 筛选器(on where having)把unknown当做FALSE处理,排 ...
- web提前做好测试
1.压力测试,找到极限点和瓶颈,最小化扩容2.消息队列应对高并发的写操作 根据数据大小分成不同队列,保证效率 堵塞队列,压队列机极限处理能力3.主要业务和次要业务分开,当出现异常时保障主要业务,保证系 ...