首頁 >後端開發 >php教程 >Android UI控制系列:GridView(網格佈局)

Android UI控制系列:GridView(網格佈局)

黄舟
黄舟原創
2017-01-19 09:58:181226瀏覽

GridView依照行列的方式來顯示內容,通常適合顯示圖示、圖片等內容,主要用於設定Adapter

在這裡主要是基礎BaseAdapter類,重寫其中的方法,主要是重寫getView方法設定圖片的顯示格式

實例程式碼如下

GridViewTest.java

/*
* @author hualang
*/
package org.hualang.grid;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;

public class GridViewTest extends Activity {
    /** Called when the activity is first created. */
        private GridView gv;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);

        //通过findViewById方法获得GridView对象
        gv=(GridView)findViewById(R.id.GridView01);
        //设置GridView的行数
        gv.setNumColumns(4);
        gv.setAdapter(new MyAdapter(this));
    }
    //自定义适配器
    class MyAdapter extends BaseAdapter
    {
            //图片id数组
            private Integer[] imgs={
                            R.drawable.img01,
                            R.drawable.img02,
                            R.drawable.img03,
                            R.drawable.img04,
                            R.drawable.img05,
                            R.drawable.img06,
                            R.drawable.img07,
                            R.drawable.img08,

                            R.drawable.img01,
                            R.drawable.img02,
                            R.drawable.img03,
                            R.drawable.img04,
                            R.drawable.img05,
                            R.drawable.img06,
                            R.drawable.img07,
                            R.drawable.img08
            };
            //上下文对象
            Context context;
            //构造方法
            MyAdapter(Context context)
            {
                    this.context=context;
            }
            //获得数量
            public int getCount()
            {
                    return imgs.length;
            }
            //获得当前选项
            public Object getItem(int item)
            {
                    return item;
            }
            //获得当前选项id
            public long getItemId(int id)
            {
                    return id;
            }

            //创建View方法
            public View getView(int position,View convertView,ViewGroup parent)
            {
                    ImageView imageView;
                    if(convertView==null)
                    {
                            //实例化ImageView对象
                            imageView=new ImageView(context);
                            //设置ImageView对象布局
                            imageView.setLayoutParams(new GridView.LayoutParams(45,45));
                            //设置边界对齐
                            imageView.setAdjustViewBounds(false);
                            //设置刻度类型
                            imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
                            //设置间距
                            imageView.setPadding(8,8,8,8);
                    }else
                    {
                            imageView=(ImageView)convertView;
                    }
                    //为ImageView设置图片资源
                    imageView.setImageResource(imgs[position]);
                    return imageView;
            }

    }
}

main.xml

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

運行結果如下

Android UI控制系列:GridView(網格佈局)關注PHP中文網(www.php.cn)!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn