android平板 多列显示GridView

  次阅读 来源:互联网(转载协议) 2015-10-03 10:52 我要评论(0)

大家可能遇到过这样的情况,一个应用要开发手机版和 Pad 版,在手机中一个ListView就可以搞定,并且是一列显示的,但运行在Pad上时,发现界面太长,需要在Pad上进行多列显示,这时候就希望实现多列 的效果,这里我简单实现了个Demo,供大家参考(我也是遇到这样的情况才有这样的需求,大家共勉),对于高手来说这些都是小意思,请高台贵手,勿拍! (最下方附有源码)

1.效果类似Hiapk的安卓市场,如下:

2.界面布局

main.xml

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > < GridView android:id="@+id/list_gridView" android:layout_width="fill_parent" android:layout_height="wrap_content" android:columnWidth="100dp" android:numColumns="5"/> </LinearLayout>

Tips:上面的 android:numColumns="5" 表示显示的列数

item_main.xml 在这里布局需要显示的元素

<?xml version="1.0" encoding="utf-8"?> <TableLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="10dp" android:scrollbars="vertical" > <TableRow > < TextView android:id="@+id/key" android:ellipsize="end" android:gravity="left"/> </TableRow> <TableRow android:paddingTop="5dp" > < TextView android:id="@+id/title_1" android:ellipsize="end" android:gravity="left" /> </TableRow> <TableRow android:paddingTop="5dp" > < TextView android:id="@+id/title_2" android:ellipsize="end" android:gravity="left"/> < ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:src="@drawable/item_more" /> </TableRow> <TableRow android:paddingTop="5dp" > < TextView android:id="@+id/title_3" android:ellipsize="endandroid:gravity="left"/> </TableRow> <TableRow android:paddingTop="5dp" > < TextView android:id="@+id/title_4" android:ellipsize="end" android:gravity="left" /> </TableRow> </TableLayout>

3.Activity处理

其实与使用ListView和GirdView没什么区别

package org.hanely.towne.activity; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import android.app.Activity; import android.os.Bundle; import android.widget.GridView; import android.widget.SimpleAdapter; public class GirdviewActivity extends Activity { private GridView gridListView; private List<HashMap<String,String>> data; private String test ="多列显示Test" ; @Override public void onCreate(Bundle savedInstanceState) { super .onCreate(savedInstanceState); setContentView(R.layout.main); findVidwByIds(); fillData(); SimpleAdapter sa = new SimpleAdapter( this, data, R.layout.item_main, new String[]{"key","title_1","title_2","title_3","title_4"}, new int []{R.id.key,R.id.title_1,R.id.title_2,R.id.title_3,R.id.title_4}); gridListView.setAdapter(sa); } public void findVidwByIds(){ gridListView = (GridView) findViewById(R.id.list_gridView); } public void fillData(){ data = new ArrayList<HashMap<String,String>> (); for( int i=0; i<10; i++ ){ HashMap<String,String> map = new HashMap<String,String> (); map.put("key", test+ i); map.put("title_1", test+ i); map.put("title_2", test+ i); map.put("title_3", test+ i); map.put("title_4", test+ i); data.add(map); } }}

本站文章信息来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • 汤晓鸥:人工智能的中国式文艺复兴

    汤晓鸥:人工智能的中国式文艺复兴

  • 全球陷入"区块链狂热"潮,大规模应用还需等待

    全球陷入"区块链狂热"潮,大规模应用还需等待

  • 区块链最近太火,但A股多家公司明确表态不考虑涉足

    区块链最近太火,但A股多家公司明确表态不考虑涉足

  • 马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

    马云的新零售?张近东的智慧零售?抑或是刘强东的第四次零售革命?

网友点评网友点评
阅读推荐阅读推荐

算法 任何一个入门的软件开发人员都会听到这句话:算法是软件的灵魂!近年来大火的机器学习即是在算法在人工智能上的集中体现。今日头条通...

据《日本经济新闻》报道,日本东京大学教授稻叶雅幸等人开发出再现日本人骨骼肌肉构造的机器人。机器人各部位的肌肉和骨骼长度与日本人的平...

以奥黛丽-赫本为原型打造的人形机器人索菲娅首次拜访了印度。索菲娅是世界上首位获得公民身份的机器人,她在12月30日出现在了印度理工学院...

在查获现场,代售点电脑旁的一台机器人通过敲击电脑键盘抢票。 广州日报惠州讯 (全媒体记者秦仲阳 通讯员张中铃摄影报道)2018年春运售票已...