Android:控件GridView的使用实例
程序员文章站
2024-02-26 21:32:16
如果是列表(单列多行形式)的使用listview,如果是多行多列网状形式的优先使用gridview。
如果是列表(单列多行形式)的使用listview,如果是多行多列网状形式的优先使用gridview。
<?xml version="1.0" encoding="utf-8"?> <gridview xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" > </gridview>
girdview的一些属性:
- android:numcolumns="auto_fit" --------列数设置为自动
- android:columnwidth="90dp",----------每列的宽度,也就是item的宽度
- android:stretchmode="columnwidth"------缩放与列宽大小同步
- android:verticalspacing="10dp"----------垂直边距
- android:horizontalspacing="10dp"-------水平边距
1、准备数据源
2、新建适配器
3、加载适配器
gridview(网格视图)是按照行列的方式来显示内容的,一般用于显示图片,图片等内容,比如实现九宫格图,用gridview是首选,也是最简单的,下面来个实例,
实例下载:demo
效果图:
mainactivity.java
package com.example.testgridview; import java.util.arraylist; import java.util.hashmap; import java.util.list; import java.util.map; import android.app.activity; import android.os.bundle; import android.widget.gridview; import android.widget.simpleadapter; public class mainactivity extends activity { private gridview gview; private list<map<string, object>> data_list; private simpleadapter sim_adapter; // 图片封装为一个数组 private int[] icon = { r.drawable.address_book, r.drawable.calendar, r.drawable.camera, r.drawable.clock, r.drawable.games_control, r.drawable.messenger, r.drawable.ringtone, r.drawable.settings, r.drawable.speech_balloon, r.drawable.weather, r.drawable.world, r.drawable.youtube }; private string[] iconname = { "通讯录", "日历", "照相机", "时钟", "游戏", "短信", "铃声", "设置", "语音", "天气", "浏览器", "视频" }; @override protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.test); gview = (gridview) findviewbyid(r.id.gview); //新建list data_list = new arraylist<map<string, object>>(); //获取数据 getdata(); //新建适配器 string [] from ={"image","text"}; int [] to = {r.id.image,r.id.text}; sim_adapter = new simpleadapter(this, data_list, r.layout.item, from, to); //配置适配器 gview.setadapter(sim_adapter); } public list<map<string, object>> getdata(){ //cion和iconname的长度是相同的,这里任选其一都可以 for(int i=0;i<icon.length;i++){ map<string, object> map = new hashmap<string, object>(); map.put("image", icon[i]); map.put("text", iconname[i]); data_list.add(map); } return data_list; } }
test.xml
<?xml version="1.0" encoding="utf-8"?> <linearlayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" android:background="#000" > <gridview android:id="@+id/gview" android:layout_width="match_parent" android:layout_height="wrap_content" android:numcolumns="auto_fit" android:columnwidth="80dp" android:stretchmode="columnwidth" ></gridview> </linearlayout>
item.xml
<?xml version="1.0" encoding="utf-8"?> <linearlayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="wrap_content" android:layout_height="wrap_content" android:orientation="vertical" android:gravity="center" android:padding="10dp" > <imageview android:src="@drawable/ic_launcher" android:id="@+id/image" android:layout_width="60dp" android:layout_height="60dp" /> <textview android:id="@+id/text" android:layout_margintop="5dp" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textcolor="#ffffff" android:text="文字" /> </linearlayout>
监听接口: onitemclicklistener
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。