前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android开发(2) - 九宫格的实现

Android开发(2) - 九宫格的实现

作者头像
张云飞Vir
发布2020-03-16 15:01:24
8390
发布2020-03-16 15:01:24
举报
文章被收录于专栏:写代码和思考写代码和思考

前言

在程序中经常会遇到九宫格的样式实现,如下图:

下面我们看看实现的步骤。

  1. 一个整体的容器部分。就是上图中包括整个图片项个各个部分,这里我们使用gridView(表格布局)来实现 2.整个界面里需要注意的是 “重复的部分”,就是 各个图片项和,图片下方显示的文字了。那么我们需要描述这个部分。在描述时,要说明图片位于上方,文字位于下方。 3.迭代,或者说重复的将各项 插入(放入)到容器内。

具体怎么实现。

1.新建一个activity,描述放置我们的容器控件

代码语言:javascript
复制
<GridView android:id="@+id/gridView1"
 android:layout_width="fill_parent"
 android:numColumns="auto_fit"
  android:stretchMode="columnWidth" 
  android:columnWidth="90dp"
 android:gravity="center"
  android:layout_height="fill_parent">
</GridView>

在这里需要关注的属性是columnWidth,这里指定了列的宽度,一个列对象,对应一个 “可重复的子项”,这个子项就是我们 的图片项和图片下方文字显示的部分。如果不指定这个宽度的话,默认是每行(展示的行,界面)仅仅只显示一个 “可重复的子项”,而当指定了宽度时,本文指定为90dp,如果每行实际行尺寸大于90,他就会继续将下一个的“可重复的子项”,放置在本行。于是就呈现一种 一行显示多个子项的情况。numColumns属性,指定一个自动填充的值,指示了自动填充行。

2。指定“可重复的子项”,就是需要迭代显示的部分

新建一个布局文件layout_gridview_item.xml

代码语言:javascript
复制
<RelativeLayout android:id="@+id/relativeLayout1" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
xmlns:android="http://schemas.android.com/apk/res/android">
    <ImageView android:id="@+id/imageView_ItemImage" 
    android:layout_width="wrap_content"
     android:src="@drawable/icon" 
     android:layout_height="wrap_content" 
     android:layout_centerHorizontal="true"
     >
     </ImageView>
    <TextView android:id="@+id/textView_ItemText" 
    android:text="TextView" 
    android:layout_width="wrap_content"
     android:layout_height="wrap_content" 
     android:layout_below="@+id/imageView_ItemImage"
     android:layout_centerHorizontal="true"
      >
      </TextView>
</RelativeLayout>

这里使用了一个相对布局,在TextView 里使用属性android:layout_below="@+id/imageView_ItemImage" 指示了文本在图片的下方。

3.剩下的就是数据绑定了。上代码:

代码语言:javascript
复制
   protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);

setContentView(R.layout.layout_main);


_gridView1 = (GridView)findViewById(R.id.gridView1);

ArrayList<HashMap<String,Object>> lst = new ArrayList<HashMap<String,Object>>();
for(int i = 0 ;i < 10; i++)
{
 HashMap<String,Object> map = new HashMap<String,Object>();
 map.put("itemImage", R.drawable.icon);
 map.put("itemText", "item"+i);

 lst.add(map);
  }
    
    SimpleAdapter adpter = new SimpleAdapter(this,
  lst,R.layout.layout_gridview_item,    
new String[]{"itemImage","itemText"},
new int[]{R.id.imageView_ItemImage,R.id.textView_ItemText});

  _gridView1.setAdapter(adpter);

  _gridView1.setOnItemClickListener(new gridView1OnClickListener());
 }

先构建ArrayList作为数据源,在构建SimpleAdapter 作为数据适配器,为gridView指定适配器对象。注意在构建适配器对象的参数,如下:

代码语言:javascript
复制
SimpleAdapter adpter = new SimpleAdapter(this,
lst,R.layout.layout_gridview_item,    //指定 子项的布局文件的ID
new String[]{"itemImage","itemText"}, //指定 数据的列
new int[]{R.id.imageView_ItemImage,R.id.textView_ItemText}); //指定数据的列对应到的 绑定的目标控件

那么如何获得选择的项呢?

就是上面的gridView1OnClickListener的实现内容如下:

代码语言:javascript
复制
class gridView1OnClickListener implements OnItemClickListener
{

    public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
            long arg3) {
        // TODO Auto-generated method stub
        Object obj = _gridView1.getAdapter().getItem(arg2);
        HashMap<String,Object> map  = (HashMap<String,Object>)obj;
        String str = (String) map.get("itemText");
        
        Toast.makeText(getApplicationContext(), ""+str, 0).show();
    }
    
}

至此完成。 代码下载

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 下面我们看看实现的步骤。
  • 具体怎么实现。
  • 那么如何获得选择的项呢?
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档