React Native 中使用的尺寸单位是pt,是一个绝对长度,而设计师使用的是px, 这两种尺寸如何换算呢?官方提供了 PixelRatio:
1 | import {PixelRatio} from 'react-native'; |
设计师给你一个尺寸,比如100px*200px的View,按照下面的方式可实现设计还原:
1 | <View style={{width:px2pt(100),height:px2pt(200),backgroundColor:"red"}}/> |
这个时候,你或许会说,这也太麻烦了,每个有尺寸的地方我都得转么,能不能我直接用px写,当然可以,不过需要整体加个缩放系数:
1 | import {PixelRatio,Dimensions}} from 'react-native'; |
这样处理后,在根节点内,你再也不用考虑pt的问题了,直接使用px即可。
不过此时还有另外一个问题,设计尺寸是死的,屏幕大小是活的,得考虑分辨率适配啊,那在不同的分辨率下如何正确的实现设计师的设计呢?
我们将使用一种游戏经常会用到得方案,fixedWidth/fixedHeight.
fixedWidth 模式是保持原始宽高比缩放应用程序内容,缩放后应用程序内容在水平和垂直方向都填满播放器窗口,但只保持应用程序内容的原始宽度不变,高度可能会改变,简言之 宽度固定,高度自适应 。
fixedHeight
fixedHeight 模式是保持原始宽高比缩放应用程序内容,缩放后应用程序内容在水平和垂直方向都填满播放器窗口,但只保持应用程序内容的原始高度不变,宽度可能会改变,简言之 高度固定,宽度自适应 。
具体如何应用呢,别急,一步步来。
先来看看如何得到屏幕的像素宽高:
1 | import {Dimensions,PixelRatio} from 'react-native'; let {width,height} = Dimensions.get("window"); |
假定我们的设计尺寸是
1 | let designSize = {width:750,height:1336}; |
按照fixedWidth、fixedHeight的定义,我们计算下新的宽高:
1 | //fixedWidth |
这个winsize就是最终实际用来布局的屏幕尺寸,此时我们又会多了一个分辨率适配的缩放系数,还记得我们前一个我们添加的为了使用px的缩放系数么,我们在这里做一个整合:
1 | import {PixelRatio,Dimensions}} from 'react-native'; |
在后续的开发中将不必再关注适配的问题,只需要按照设计师给的尺寸实现布局即可。
最后再附上一个工具类 Resolution.js:
1 | import React, {Component, PropTypes} from 'react'; |
How to use:
1 | import React, { Component } from 'react'; |
bg_day.jpg的尺寸是750*1500,上面的程序在所有的分辨率下图片都能正确显示。
这里有个demo: Github ,如果解决你的问题了,记得给我加星哦~~
另外:不同分辨率下背景图片尺寸如何选择,移步另一篇博文: 《分辨率适配的取值范围》