【Android开发笔记】利用GridView实现网格列表
前言
在android中,常用的listView只是多行一列的表格,但实际中也常用到多行多列的表格,因此,我们可以通过GridView实现一个多行多列的网格列表。
准备
新建一个MainAcivity,包括一个布局文件actvity_layout_main。
1、主要布局
在布局文件中添加GridView组件,设置大小、id等常见属性。为实现多个列,通过numColumns、columnWidth这两个属性设置列数、列宽。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".ui.details.OverViewActivity">
<GridView
android:id="@+id/title_number_view"
android:columnWidth="120dp"
android:numColumns="4"
android:layout_margin="5dp"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
</GridView>
</LinearLayout>
2、主要代码
在代码中,将GridView组件进行绑定并添加数据,具体使用看代码:
注意:这里使用的使listView自带的item样式simple_list_item_2,即每一项有两行,也可以自定义item样式
import androidx.appcompat.app.AppCompatActivity;
import android.graphics.Color;
import android.os.Bundle;
import android.util.TypedValue;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.GridView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import com.example.studentvue.R;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class MainActivity extends AppCompatActivity {
private GridView titleNum;
private SimpleAdapter simpleAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_over_view);
//获取GridView
titleNum = findViewById(R.id.title_number_view);
//设置key和item样式中的组件id
String[] keys = {"num", "score"};
int[] ids = {android.R.id.text1, android.R.id.text2};
//获取样例数据
ArrayList<HashMap<String,String>> list = getNumAndScore();
//设置simpleAdapter容器,为item中的组件绑定数据
simpleAdapter = new SimpleAdapter(this, list, android.R.layout.simple_list_item_2,keys, ids);
//为GridView绑定simpleAdapter容器
titleNum.setAdapter(simpleAdapter);
}
//测试:获取数据
public ArrayList<HashMap<String, String>> getNumAndScore(){
ArrayList<HashMap<String,String>> dataList = new ArrayList<HashMap<String,String>>();
for(int i=1; i<=20; i++){
HashMap<String,String> item = new HashMap<String,String>();
item.put("num", Integer.toString(i));
item.put("score", String.valueOf(i+10));
dataList.add(item);
}
return dataList;
}
}
运行结果
待更新。。。。。