博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
React native 分辨率适配
阅读量:4086 次
发布时间:2019-05-25

本文共 3595 字,大约阅读时间需要 11 分钟。

中使用的尺寸单位是pt,是一个绝对长度,而设计师使用的是px, 这两种尺寸如何换算呢?官方提供了:

http://www.jianshu.com/p/7836523b4d20?utm_source=tuicool&utm_medium=referral

import {PixelRatio} from 'react-native';const pt2px = pt=>PixelRatio.getPixelSizeForLayoutSize(pt);const px2pt = px=>PixelRatio.roundToNearestPixel(px);

设计师给你一个尺寸,比如100px*200px的View,按照下面的方式可实现设计还原:

这个时候,你或许会说,这也太麻烦了,每个有尺寸的地方我都得转么,能不能我直接用px写,当然可以,不过需要整体加个缩放系数:

import {PixelRatio,Dimensions}} from 'react-native';const pt2px = pt=>PixelRatio.getPixelSizeForLayoutSize(pt);const px2pt = px=>PixelRatio.roundToNearestPixel(px);let pxRatio = PixelRatio.get();let {win_width,win_height} = Dimensions.get("window");let scale = 1/pxRatio;let width = pt2px(win_width);let height = pt2px(win_height);const com = props=>(                
)const styles={ container: { width:width, height:height, backgroundColor: 'transparent', transform:[{translateX:-width*.5}, {translateY:-height*.5}, {
scale:scale}, {translateX:width*.5}, {translateY:height*.5}] },}

这样处理后,在根节点内,你再也不用考虑pt的问题了,直接使用px即可。

不过此时还有另外一个问题,设计尺寸是死的,屏幕大小是活的,得考虑分辨率适配啊,那在不同的分辨率下如何正确的实现设计师的设计呢?

我们将使用一种游戏经常会用到得方案,fixedWidth/fixedHeight.

fixedWidth

fixedWidth 模式是保持原始宽高比缩放应用程序内容,缩放后应用程序内容在水平和垂直方向都填满播放器窗口,但只保持应用程序内容的原始宽度不变,高度可能会改变,简言之宽度固定,高度自适应

fixedHeight

fixedHeight 模式是保持原始宽高比缩放应用程序内容,缩放后应用程序内容在水平和垂直方向都填满播放器窗口,但只保持应用程序内容的原始高度不变,宽度可能会改变,简言之高度固定,宽度自适应

具体如何应用呢,别急,一步步来。
先来看看如何得到屏幕的像素宽高:

import {Dimensions,PixelRatio} from 'react-native';let {width,height} = Dimensions.get("window");let w =pt2px(width);let h = pt2px(height);

假定我们的设计尺寸是

let designSize = {
width:750,height:1336};

按照fixedWidth、fixedHeight的定义,我们计算下新的宽高:

//fixedWidthlet scale = designSize.width/w;let winSize = {
width:designSize.width,height:h*scale};//fixedHeightlet scale = designSize.height/h;let winSize = {
width:designSize.width*scale,height:designSize.height};

这个winsize就是最终实际用来布局的屏幕尺寸,此时我们又会多了一个分辨率适配的缩放系数,还记得我们前一个我们添加的为了使用px的缩放系数么,我们在这里做一个整合:

import {PixelRatio,Dimensions}} from 'react-native';const pt2px = pt=>PixelRatio.getPixelSizeForLayoutSize(pt);const px2pt = px=>PixelRatio.roundToNearestPixel(px);let designSize = {
width:750,height:1336};let pxRatio = PixelRatio.get();let {win_width,win_height} = Dimensions.get("window");let width = pt2px(win_width);let height = pt2px(win_height);let design_scale = designSize.width/width;height = height*design_scalelet scale = 1/pxRatio/design_scale;const com = props=>(
)const styles={ container: { width:width, height:height, backgroundColor: 'transparent', transform:[{translateX:-width*.5}, {translateY:-height*.5}, {
scale:scale}, {translateX:width*.5}, {translateY:height*.5}] },}

在后续的开发中将不必再关注适配的问题,只需要按照设计师给的尺寸实现布局即可。

最后再附上一个工具类 Resolution.js:

import {Dimensions,PixelRatio} from 'react-native';let designSize = {
width:750,height:1336};export default class Resolution { static get(type){ let pxRatio = PixelRatio.get(); let {
width,height} = Dimensions.get("window"); let w = PixelRatio.getPixelSizeForLayoutSize(width); let h = PixelRatio.getPixelSizeForLayoutSize(height); let scale = designSize.width/w; let winSize = {
width:designSize.width,height:h*scale}; return { width:winSize.width, height:winSize.height, scale:(1/scale)/pxRatio } }};

转载地址:http://wkrni.baihongyu.com/

你可能感兴趣的文章
《跟工程师学嵌入式开发》这本书最后的终极项目我反而觉得有说头
查看>>
博士的申请考核制
查看>>
那些硬件的初始化函数主要是在做些上什么?
查看>>
MAVLink学习之路05_MAVLink应用编程接口分析(也有讲STM32下的收发函数)
查看>>
找到了中文版的mavlink手册
查看>>
浅谈飞控开发的仿真功能
查看>>
我觉得在室内弄无人机开发装个防撞机架还是很有必要的,TBUS就做得很好。
查看>>
serial也是见到很多次了,似乎它就是一种串行通信协议
查看>>
TBUS的一些信息
查看>>
PX4+激光雷达在gazebo中仿真实现(古月居)
查看>>
专业和业余的区别就在于你在基础在基本功打磨练习花的时间
查看>>
通过mavlink实现自主航线的过程笔记
查看>>
Ardupilot飞控Mavlink代码学习
查看>>
这些网站有一些嵌入式面试题合集
查看>>
我觉得刷题是有必要的,不然小心实际被问的时候懵逼,我觉得你需要刷个50份面试题。跟考研数学疯狂刷卷子一样!
查看>>
我觉得嵌入式面试三要素:基础吃透+项目+大量刷题,缺一不可。不刷题是不行的。而且得是大量刷,刷出感觉套路,别人做题都做得是固定题型套路条件反射了,你还在那慢慢理解慢慢推是不行的,也是考研的教训。
查看>>
相机标定的目的:获取摄像机的内参和外参矩阵(同时也会得到每一幅标定图像的选择和平移矩阵),内参和外参系数可以对之后相机拍摄的图像就进行矫正,得到畸变相对很小的图像。
查看>>
现在来看,做个普罗米修斯的docker镜像对我而言并不难,对PX4仿真环境配置也熟悉了。
查看>>
删除docker容器和镜像的命令
查看>>
VINS-Fusion Intel® RealSense™ Depth Camera D435i
查看>>