码迷,mamicode.com
首页 > 移动开发 > 详细

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

时间:2018-02-18 21:29:33      阅读:231      评论:0      收藏:0      [点我收藏+]

标签:宽度   sheet   http   ber   rap   gpo   一般来说   lin   ack   

開始解说这篇博客之前,我想问一下,当布局相似GridView这样的多列布局时,我们该怎么布局,才干更好的去适配呢?

扣张图来展示一下

技术分享图片

比如这样的需求,三张图片均分屏幕

实现方法:

1.切图固定,比如是1080x1920。

在固定分辨率上非常好计算,也非常好适配。但有个问题。换了不同的分辨率,就须要做不同的适配。针对不同的分辨率即可计算。这样也能实现。可是太麻烦了,由于各种分辨率的手机层出不穷,适配不止啊。

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"

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

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

标签:宽度   sheet   http   ber   rap   gpo   一般来说   lin   ack   

原文地址:https://www.cnblogs.com/zhchoutai/p/8453167.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!