Android 为什么 dp2px 或 px2dp 公式需要加 0.5f
2016-09-05 15:32
519 查看
网上 dp2px 和 px2dp 公式:
这两个公式网上很多,但为什么 最后都要加上0.5f 呢?
按正常的推理应该是 dip = pxValue / scale 和 px = dipValue * scale ,
实际上准确的值就应该是 咱们推理出来的,之所以后面加上0.5f是因为 咱们要的只不是那么精准,根据推理算出来的是个浮点数,而咱们程序中一般使用int类型就够了,这里涉及到一个类型转换精准度问题,熟悉java特效的同学应该知道
float 类型的 4.1 和4.9 强转成int类型后,会失去精准度变成 int类型的4, 而如果咱们想四舍五入的话,把他们都加上0.5f,这样转换出来的结果就是:
4.4 + 0.5 = 4.9 转为int 还是4,而4.5 + 0.5 = 5.0 转换成int后就是5,正好是四舍五入,这样就保证了咱们算出来的值相对精准。
public static int px2dip(Context context, float pxValue) { final float scale = context.getResources().getDisplayMetrics().density; return (int) (pxValue / scale + 0.5f); } public static int dip2px(Context context, float dipValue) { final float scale = context.getResources().getDisplayMetrics().density; return (int) (dipValue * scale + 0.5f); }
这两个公式网上很多,但为什么 最后都要加上0.5f 呢?
按正常的推理应该是 dip = pxValue / scale 和 px = dipValue * scale ,
实际上准确的值就应该是 咱们推理出来的,之所以后面加上0.5f是因为 咱们要的只不是那么精准,根据推理算出来的是个浮点数,而咱们程序中一般使用int类型就够了,这里涉及到一个类型转换精准度问题,熟悉java特效的同学应该知道
float 类型的 4.1 和4.9 强转成int类型后,会失去精准度变成 int类型的4, 而如果咱们想四舍五入的话,把他们都加上0.5f,这样转换出来的结果就是:
4.4 + 0.5 = 4.9 转为int 还是4,而4.5 + 0.5 = 5.0 转换成int后就是5,正好是四舍五入,这样就保证了咱们算出来的值相对精准。
相关文章推荐
- Android 为什么 dp2px 或 px2dp 公式需要加 0.5f
- 【转】Android 为什么 dp2px 或 px2dp 公式需要加 0.5f
- 编译android代码时为什么需要“交叉编译环境”
- Android开发环境为什么需要依赖jvm
- (一)android为什么需要recovery升级?
- Android中为什么需要服务?
- android 为什么需要签名
- Android解惑之Handler为什么需要是static的
- Android Handler : Handler为什么需要是static的 (二)
- Android Handler : Handler为什么需要是static的 (一)
- Android为什么需要广播Broadcast
- Android之TypedArray 为什么需要调用recycle()
- Android之TypedArray 为什么需要调用recycle()
- Android初学-----px2dp,dp2px
- Android解惑之Handler为什么需要是static的
- android为什么需要签名与数据共享
- 为什么Android系统需要使用C、C++和Java语言共同开发
- 为什么android中parcelable的实现需要CREATOR
- 配置Android应用开发环境为什么需要安装配置JDK、SDK、ADT
- Android安全输入设计与思考,android设计思考 为什么使用安全键盘? 安全的输入 各大公司的安全键盘设计 开始自定义安全键盘 安全键盘还需要注意的