Android学习之GridView图片布局适配经验

幽沉谢世事,俯默窥唐虞。这篇文章主要讲述Android学习之GridView图片布局适配经验相关的知识,希望能为你提供帮助。
開始解说这篇博客之前,我想问一下,当布局相似GridView这样的多列布局时,我们该怎么布局,才干更好的去适配呢?
扣张图来展示一下

Android学习之GridView图片布局适配经验

文章图片

比如这样的需求,三张图片均分屏幕
实现方法:
1.切图固定,比如是1080x1920。
【Android学习之GridView图片布局适配经验】在固定分辨率上非常好计算,也非常好适配。但有个问题。换了不同的分辨率,就须要做不同的适配。针对不同的分辨率即可计算。这样也能实现。可是太麻烦了,由于各种分辨率的手机层出不穷,适配不止啊。
2.就是本篇博客记叙的重点实现方式。
不用通过固定的大小来设置图片大小。那么怎么做呢?上面已经说过。这样的需求是将屏幕三分。那么获取屏幕宽度。在动态设置图片宽度为0.3屏幕宽度就能非常好的解决这个适配的问题。那么宽度攻克了,高度怎么解决呢?
一般来说。是依据宽高比来确定的,要么是1:1,要么是16:9等。宽高比能够让设计来确定,这样就能够依据获得的宽度来确定高度,哈哈,这样不就是全然解决适配问题了么。
说了这么多,也该上代码了
//获取屏幕宽度 int width = ((Activity) ivImage2.getContext()).getWindowManager().getDefaultDisplay().getWidth(); ViewGroup.LayoutParams params = ivImage2.getLayoutParams(); //设置图片的相对于屏幕的宽高比 params.width = width/2; params.height = width/3 ; ivImage2.setLayoutParams(params);

非常easy吧。在adapter中,实例化ImageView后,调用这几句代码,当然宽高比依据详细需求来说。
另外。xml中ImageView设置宽高都应该为
android:layout_width="wrap_content" android:layout_height="wrap_content"

这样整个适配就完毕了,记录工作中的小成长。谢谢。

    推荐阅读