zoukankan      html  css  js  c++  java
  • Android新手入门2016(10)--GridView

    本文来自肥宝传说之路。引用必须注明出处!

    GridView跟ListView一样是多控件布局。实现九宫图是最方便的。

    还是先看看图,没图说个鸡鸡是不是


    如上图。是一种应用方式。在每一个格子里面。放入应用图标,和显示应用的名字在下方。

    以下先看看布局文件:

    activity_hello_world.xml 

    <?

    xml version="1.0" encoding="utf-8"?> <GridView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/gridview" android:layout_width="fill_parent" android:layout_height="fill_parent" android:numColumns="auto_fit" android:verticalSpacing="10dp" android:horizontalSpacing="10dp" android:columnWidth="90dp" android:stretchMode="columnWidth" android:gravity="center" />

    如今说说一些新的属性: 

    这里dp相关知识能够看看Android长度相关

     android:numColumns="auto_fit"   设置为自己主动适应屏幕宽度,上图仅仅能摆放3个
     android:verticalSpacing="10dp"   两行之间的间距是10像素
     android:horizontalSpacing="10dp"   两列之间的间距为10像素
     android:columnWidth="90dp"   每一列的宽度
     android:stretchMode="columnWidth"  缩放与列宽的大小同步
     android:gravity="center"  空间显示的位置是中间

    我们再来看看代码:

    HelloWorldActivity.java

    package com.fable.helloworld;
     
    import android.app.Activity;  
    import android.os.Bundle;   
    import android.widget.GridView;
    import android.widget.SimpleAdapter; 
    import java.util.*;
    
    public class HelloWorldActivity extends Activity {  
        @Override  
        public void onCreate(Bundle savedInstanceState) {   
        	super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_hello_world);  //设置主布局文件
            GridView gridview = (GridView) findViewById(R.id.gridview);  
            
            //创造数据来源
            ArrayList<HashMap<String, Object>> images = new ArrayList<HashMap<String, Object>>();  
            for(int i=1;i<10;i++)  
            {  
            	HashMap<String, Object> map = new HashMap<String, Object>();  
            	map.put("ItemImage", R.drawable.ic_launcher);//加入图像资源的ID,标识符,值
            	map.put("ItemText", "应用"+String.valueOf(i));//按序号做ItemText。标识符,值  
            	images.add(map);  
            }  
            //把数据传入适配器,转换成布局须要的数据
            SimpleAdapter simpleAdapter = new SimpleAdapter(this, //上下文为当前Activity
            	images,//数据来源   
    	        R.layout.my_list_item,//每一项的布局的XML实现    
    	        new String[] {"ItemImage","ItemText"},//动态数组与ImageItem相应的子项 
    	        new int[] {R.id.ItemImage,R.id.ItemText});  //ImageItem的XML文件中面的一个ImageView,两个TextView ID  
            //加入而且显示  
            gridview.setAdapter(simpleAdapter);   
        }   
      
    }
    
    能够这里使用了SimpleAdapter,使用方法跟ListView一样。对于ListView中SimpleAdapter的使用方法,能够看这里

    事实上过程是非常easy,就是把源数据,转换成适配器的数据,然后把适配器设置到gridView即可了。

    跟ListView一样,每一项的布局内也是要一个布局文件的。

    my_list_item.xml

    <?xml version="1.0" encoding="utf-8"?>  
    <RelativeLayout   
             xmlns:android="http://schemas.android.com/apk/res/android"   
             android:layout_height="wrap_content"   
             android:paddingBottom="4dip" android:layout_width="fill_parent">  
             <ImageView   
                   android:layout_height="wrap_content"   
                   android:id="@+id/ItemImage"   
                   android:layout_width="wrap_content"   
                   android:layout_centerHorizontal="true">   
             </ImageView>  
             <TextView   
                   android:layout_width="wrap_content"   
                   android:layout_below="@+id/ItemImage"   
                   android:layout_height="wrap_content"   
                   android:text="TextView01"   
                   android:layout_centerHorizontal="true"   
                   android:id="@+id/ItemText">  
             </TextView>  
    </RelativeLayout>  
    这里ItemText设置在ItemImage以下,两个都是垂直居中。








  • 相关阅读:
    Python 绘制图表之我见 ---一个java程序员的看法
    机器学习系统设计--1.4
    XUtils3 的 环境搭建与简单使用
    关于SAX
    TensorFlow之Varibale 使用方法
    安装Nvidia k80驱动步骤
    TensorFlow 在android上的Demo(1)
    Python 去剑式
    python编程技巧2
    python语言技巧
  • 原文地址:https://www.cnblogs.com/yutingliuyl/p/7285482.html
Copyright © 2011-2022 走看看