GridView如何适配不同屏幕
来源:互联网 发布:ios编程软件 编辑:程序博客网 时间:2024/05/21 15:00
GridView和ListView一样,都是项目中常用的控件之一,那么本篇文章要讲的是GridView如何适应不同大小的屏幕,首先,我们来看一张效果图,如下:
每行为四个item,上下左右间距大概2dp,而且会根据不同的屏幕大小,每个item中的图片随之缩放或放大以适应屏幕(始终保持正方形的样子),我们大多数在使用GridView的时候可能会把columnWidth设置了一个定值如70dp,然后numColumns为自动适配,这样虽然也可以,但是很影响用户体验,那么像上图这样的效果,应该怎么实现呢?
已经不屑于看这篇文章的大牛们请绕道啦,那么还不会实现这种效果的童鞋们此刻有什么思路呢?如何才能保证每行四个item,且自动适应屏幕大小?我们一步一步来分析:首先保证每行四个item不是很简单的事情嘛,把numColumns="4"不就可以了?然后呢,如何确定每个item的宽高呢?其实同样很简单,要想根据屏幕大小来决定item的宽高,不就得先知道屏幕的宽度吗?
- WindowManager windowManager = getWindowManager();
- Display display = windowManager.getDefaultDisplay();
- wh=display.getWidth();
解:每个item的宽度=(wh-(5*2))/4;
即:行宽-各间距后再除以每行item的个数不就得出每个item应占的宽度了吗,然后高度和宽度相等即可。
但还有一个问题是,我们在xml中定义时,一般都用的dp而非px,这如何解决?那么我们把dp转换为px不就成了吗?
- public static int Dp2Px(Context context, float dp) {
- final float scale = context.getResources().getDisplayMetrics().density;
- return (int) (dp * scale + 0.5f);
- }
- <GridView
- android:layout_width="fill_parent"
- android:layout_height="wrap_content"
- android:fadingEdge="none"
- android:gravity="center_horizontal"
- android:horizontalSpacing="2dp"
- android:listSelector="@null"
- android:numColumns="4"
- android:scrollbars="none"
- android:stretchMode="columnWidth"
- android:verticalSpacing="2dp" >
- </GridView>
然后我们在adapter中的getView方法中动态设置每个item的宽高(注意:item的布局文件不要设置固定宽高,全部fill_parent即可):
- AbsListView.LayoutParams param = new AbsListView.LayoutParams(宽度,高度);
- convertView.setLayoutParams(param);
demo可参考下篇文章: 阻尼回弹效果的ScrollView嵌套GridView
0 0
- GridView如何适配不同屏幕
- 【android】GridView如何适配不同屏幕
- GridView如何适配不同屏幕
- GridView如何适配不同屏幕
- GridView如何适配不同屏幕
- Android GridView如何适配不同屏幕
- android如何处理不同屏幕的适配
- Android应用如何适配不同的屏幕
- 适配不同的屏幕
- bootstrap适配不同屏幕
- 不同屏幕适配图片
- Android适配不同屏幕
- 适配不同分辨率屏幕
- Android适配不同屏幕
- bootStrap适配不同屏幕
- android gridView屏幕适配,以及GridView的各种属性
- Android开发中如何适配不同屏幕大小(1)
- android开发如何更好的解决适配不同屏幕大小移动设备的问题
- android webview js交互, 响应webview中的图片点击事件
- [Hb-XIII] 编写、应用中断例程
- 【BZOJ】【P2631】【tree】【题解】【LCT】
- MFC内嵌web页面
- Oracle E-Business Suite Release 12.2 Information Center - Manage
- GridView如何适配不同屏幕
- Search in Rotated Sorted Array II
- 崩溃恢复(crash recovery)与 AUTORESTART参数
- Emacs学习笔记
- 访问不了共享文件夹的解决问题
- Oracle E-Business Suite Maintenance Guide Release 12.2(Patching Utilities)
- linux学习之(五)-linux文解压、压缩、安装
- Queue
- HDU 2544 最短路【经典题】