知识 分享 互助 快乐十分玩法与奖金

    懒人建站专注于网页素材下载,提供网站模板、网页设计、ps素材、图片素材等,服务于【个人站长】【网页设计师】和【web开发从业者】的代码素材与设计素材网站。

    懒人建站提供网页素材下载、网站模板
    知识 分享 互助!

    湖南快乐十分动物开奖:React Native不同设备分辨率适配和设计稿尺寸单位px的适配

    作者:不吃鱼的猫 2018-02-22 人气:
    React Native不同设备分辨率适配和设计稿尺寸单位px的适配,设计师给的稿子都是按照px像素单位设计的,这个时候我们怎么快速还原设计稿那?下面代码实现React Native设计稿尺寸单位px与pt单位的自动转换适配。

    快乐十分玩法与奖金 www.j63d3.cn React Native不同设备分辨率适配和设计稿尺寸单位px的适配,设计师给的稿子都是按照px像素单位设计的,这个时候我们怎么快速还原设计稿那?

    React Native中使用的尺寸单位是dp(一种基于屏幕密度的抽象单位。在每英寸160点的显示器上,1dp = 1px),而设计师使用的是px, 这两种尺寸如何换算呢?

    官方提供了PixelRatio进行pt到px的转换

    import {PixelRatio} from 'react-native';
    const dp2px = dp=>PixelRatio.getPixelSizeForLayoutSize(dp);
    const px2dp = px=>PixelRatio.roundToNearestPixel(px);

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

    View style={{width:px2dp(100),height:px2dp(200),backgroundColor:"red"}}

    如果每个地方都这样写会很麻烦,于是我们就有了下面转换代码

    import {PixelRatio,Dimensions}} from 'react-native';
    const dp2px = dp=>PixelRatio.getPixelSizeForLayoutSize(dp);
    const px2dp = px=>PixelRatio.roundToNearestPixel(px);
    let designSize = {width:720,height:1280}; //假设设计尺寸为:720*1280
    let pxRatio = PixelRatio.get();
    let win_width = Dimensions.get("window").width;
    let win_height = Dimensions.get("window").height;
    let width = dp2px(win_width);
    let height = dp2px(win_height);
    let design_scale = designSize.width/width;
    height = height*design_scale
    let scale = 1/pxRatio/design_scale;

    实际使用:

    要在最外层View上设置如下样式:

    const styles = StyleSheet.create({
        container: {
            width: width,
            height: height,
            transform: [{translateX: -width * .5}, {translateY: -height * .5}, {scale: scale}, {translateX: width * .5}, {translateY: height * .5}]
        }
    });

    在后续的开发中将不必再关注适配的问题,只需要按照设计师给的尺寸实现布局即可,比如设计稿中的图片尺寸是300px*300px,你的样式中就写 width: 300,height: 300,

    这里就写设计稿上的300px 300px,不用带单位
    image: {
            width:300,
            height:300
        }

    原文:https://www.jianshu.com/p/7836523b4d20  详细描述可以查看原文

    ↓ 查看全文

    React Native不同设备分辨率适配和设计稿尺寸单位px的适配由懒人建站收集整理,您可以自由传播,请主动带上本文链接

    快乐十分玩法与奖金就是免费分享,觉得有用就多来支持一下,没有能帮到您,懒人也只能表示遗憾,希望有一天能帮到您。

    React Native不同设备分辨率适配和设计稿尺寸单位px的适配-最新评论

  • 厉害了!如何用数学解构太极图? 2019-04-07
  • “沙雕世界杯”作品亮相舟山 2019-04-07
  • 对外投资连续7个月增长(市场观察) 2019-04-04
  • 董卿白岩松朱广权 看看央视主持人大学就读啥院系 2019-04-03
  • 陈海滢的专栏作者中国国家地理网 2019-03-20
  • 黄坤明:努力开创中国政研会工作新局面 2019-03-16
  • 新型社交软件改变了我们的生活 春城壹网 七彩云南 一网天下 2019-03-15
  • 养生谣言肆虐 微信圈不可全信 2019-03-14
  • 国际在线:向世界报道中国,向中国报道世界 2019-03-14
  • 推动重庆各项事业沿着习近平总书记指引的方向奋力前行——华龙网 2019-03-13
  • 成都寻旧文章中国国家地理网 2019-03-13
  • 世界杯第二日精选 C罗力挽狂澜 伊朗20年首胜 2019-03-12
  • 成龙晒罕见旧照怀念父亲 三代同堂温馨和乐 2019-03-10
  • 北京经开·国际企业大道Ⅲ,北京北京经开·国际企业大道Ⅲ 2019-03-10
  • 学习贯彻党的十九大精神 2019-03-07
  • 505| 114| 266| 352| 318| 172| 986| 835| 5| 148|