今天做项目遇到了一个问题,一开始把RecycerView中每一Item的ImageView的高度写了一个固定的dp值,一个屏幕中出现四个,换了手机测试之后,一个屏幕出现了4个半,有的是5个,犯了新手最容易犯的错误,对dp和px的概念还是不清楚,后来想下通过获取屏幕宽度的方式来适配吧。
需要用到的工具类方法:
public class ScreenUtils {
public static int getScreenWidth(Context context) {
if (context == null){
return 0;
}
WindowManager wm = (WindowManager) (Context.WINDOW_SERVICE);
DisplayMetrics outMetrics = new DisplayMetrics();
().getMetrics(outMetrics);
return ;
}
public static int dp2px(Context context, float dpValue) {
final float scale = ().getDisplayMetrics().density;
return (int) (dpValue * scale + 0.5f);
}
}
于是乎我有了获取ImageView宽度的方法:
//130是在xml文件中那一排recyclerview之间的间距加上recyclerview和父控件的间距的和
int totalWidth = (context) - ScreenUtils.dp2px(context, 130);
int imageWidth = totalWidth / 4;
那么再设置ImageView的长宽,因为需求的ImageView是一个正方形,所以:
params = ()();
= imageWidth;
= imageWidth;
遇到一个坑,如果写成这样:
params = new (imageWidth, imageWidth);
(params);
那么xml布局文件中的margin属性将全部失效,其实很好理解,new了一个新的出来,之前的属性都不管用了,很简单的对象引用问题,一个是get旧的,一个是set新的,但是意义很不同,自行体会吧。
<ImageView
android:
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="8dp"
android:layout_marginLeft="13dp"
android:layout_marginRight="13dp"/>
总结
更加深刻理解了dp 和 px 的区别和含义,以及开发中遇到的一些小坑,记录下来,方便查阅。
------分割线 2020年
我现在又回来编辑这篇文章了,觉得那时候怎么那么弱智。。。简直无语了。。。这种简单的问题都要记录下来,而且连px和dp还有引用问题都没整明白,真是。。。
这篇文章居然还有一万多的访问量,我也是醉了。。。