Android dip与px转换时的公式加0.5原因

首先转换公式:

	public static int dipToPx(int dip) {
        final DisplayMetrics displayMetrics = application.getResources().getDisplayMetrics();
        return (int) (displayMetrics.density * dip + 0.5f);
    }

    public static int pxToDip(Context context, float pxValue) {
        final float scale = context.getResources().getDisplayMetrics().density;
        return (int) (pxValue / scale + 0.5f);
    }

一般是不加0.5值更精确的,需要加0.5的原因是由于float在强转int类型时会把小数点后面的值直接抹除如:

3.000f-3.9999…f转成int类型后值编变成了3

因此为了使结果比较精确就要进行四舍五入计算了:
3.0-3.49999…+0.5后变成了3.5-3.99999,转int后变成了3,
即3.0-3.49999…->3。

3.5-3.99999…+0.5后变成了4.0-4.49999,转int后变成了4,
即3.5-3.99999…->4。

加0.5是为了小数位大于0.5时个位数的加1,这样就实现了类型转换的时候的四舍五入。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值