zoukankan      html  css  js  c++  java
  • Android API 中文 (15) —— GridView


    前言

      关键字: android.widget.GridView
      本章翻译来自0_1 ,版本为2.2 r1,这是翻译组成员至今翻译得最好最用心的一篇,除了章节的基本翻译外,附加了完善的截图和代码,再次感谢0_1为大家带来优质的翻译稿。期待你一起参与Android API 的中文翻译行动,联系我over140@gmail.com。

    声明

      欢迎转载,但请保留文章原始出处:)

        博客园:http://www.cnblogs.com

        Android中文翻译组:http://androidbox.sinaapp.com/

    正文

      一、结构

        public final class GridView extends AbsListView

        java.lang.Object
          android.view.View
            android.view.ViewGroup
              android.widget.AdapterView<T extends android.widget.Adapter>
                android.widget.AbsListView
                  android.widget.GridView

      二、类概述

        一个在平面上可显示多个条目的可滚动的视图组件,该组件中的条目通过一个ListAdapter和该组件进行关联。比如android手机中显示的应用:

        

        比如实现九宫格图,用GridView是首选,也是最简单的。

      三、构造函数

        public GridView (Context context)
        创建一个默认属性的GridView实例

        public GridView (Context context, AttributeSet attrs)

        创建一个带有attrs属性的GridView实例

        public GridView (Context context, AttributeSet attrs, int defStyle)

        创建一个带有attrs属性,并且指定其默认样式的GridView实例

      四、XML属性

    属性名称

    描述

    android:columnWidth

    设置列的宽度。关联的方法为:setColumnWidth(int)

    android:gravity

    设置此组件中的内容在组件中的位置。可选的值有:topbottomleftrightcenter_verticalfill_verticalcenter_horizontalfill_horizontalcenterfillclip_vertical 可以多选,用“|”分开。关联方法:setGravity (int gravity)

    android:horizontalSpacing

    两列之间的间距。关联方法:setHorizontalSpacing(int)

    android:numColumns

    列数。关联方法:setNumColumns(int)

    android:stretchMode

    缩放模式。关联方法:setStretchMode(int)

    android:verticalSpacing

    两行之间的间距。关联方法:setVerticalSpacing(int)

      五、公共方法

             public ListAdapter getAdapter ()

       获得与此组件相关的适配器..

    返回值

        ListAdapter适配器实例

            

             public int getStretchMode ()

      获得GridView的缩放模式..

     

             public boolean onKeyDown (int keyCode, KeyEvent event)

      默认由KeyEvent.Callback.onKeyMultiple()实现,如果视图是可用的并且是可点击的,那么传入 KEYCODE_DPAD_CENTERKEYCODE_ENTER值是执行的是按下视图操作。

           参数

                  keyCode 一个表示按下操作的键值.

    event 表示按钮事件的对象

                      返回值

    如果你认为已经完成事件处理,不想让让下一个处理器来处理此事件,则返回true,否则返回false

             public boolean onKeyMultiple (int keyCode, int repeatCount, KeyEvent event)

       默认由KeyEvent.Callback.onKeyMultiple()实现,总是返回false(不处理此事件)。

             参数

                       keyCode 键值.

    repeatCount 该动作发生的次数.

    event 事件对象

                      返回值

    如果你认为已经完成事件处理,不想让让下一个处理器来处理此事件,则返回true,否则返回false

             public boolean onKeyUp (int keyCode, KeyEvent event)

       默认由KeyEvent.Callback.onKeyMultiple()实现,如果视图是可用的并且是可点击的,那么传入KEYCODE_DPAD_CENTERKEYCODE_ENTER值是执行的是点击视图操作。

    参数

                  keyCode 键值.

    event 事件对象.

                      返回值

    如果你认为已经完成事件处理,不想让让下一个处理器来处理此事件,则返回true,否则返回false

             public void setAdapter (ListAdapter adapter)

       设置GridView的数据。

                      参数

                                adapter grid提供数据的适配器 

             public void setColumnWidth (int columnWidth)

       设置GridView的列宽.

                      参数

                                columnWidth 列的宽度,以像素为单位

             public void setGravity (int gravity)

       设置控件内容的位置,默认值为:Gravity.LEFT.

                      参数

                                gravity 位置值

             public void setHorizontalSpacing (int horizontalSpacing)

       设置列间距.

                      参数

                                horizontalSpacing 列间距值

    public void setNumColumns (int numColumns)

            设置grid的列数

    参数

    numColumns 列数值.

    public void setSelection (int position)

            设置选中的条目.

    参数

    position . 数据条目在列表中的索引值(从0开始),如果在可触摸的模式下,在该索引值下的条目将不会被选中,但是该索引值仍然指向该条目。

    public void setStretchMode (int stretchMode)

    设置grid中的条目以什么缩放模式去填充空间。.

    参数

    stretchMode 可选值:NO_STRETCHSTRETCH_SPACINGSTRETCH_SPACING_UNIFORM,或STRETCH_COLUMN_WIDTH

    public void setVerticalSpacing (int verticalSpacing)

    设置行间距.

       参数

          verticalSpacing 间距值,以像素为单位 

      六、代码示例

        下面给出一个小例子先看效果:

        

        a).  GridView01.java

    public class GridView01 extends Activity {
        
    private GridView gridview;
        @Override
        
    protected void onCreate(Bundle savedInstanceState) {
            
    // TODO Auto-generated method stub
            super.onCreate(savedInstanceState);
            setContentView(R.layout.gridview);
            
    //准备要添加的数据条目
            List<Map<String, Object>> items = new ArrayList<Map<String,Object>>();
            
    for (int i = 0; i < 10; i++) {
                Map
    <String, Object> item = new HashMap<String, Object>();
                item.put(
    "imageItem", R.drawable.icon);
                item.put(
    "textItem""text" + i);
                items.add(item);
            }
    //实例化一个适配器
            SimpleAdapter adapter = new SimpleAdapter(this, items, R.layout.grid_item, new String[]{"imageItem""textItem"}, new int[]{R.id.image_item, R.id.text_item});
            
    //获得GridView实例
            gridview = (GridView)findViewById(R.id.mygridview);
            
    //gridview.setNumColumns(3);//可以在xml中设置
            
    //gridview.setGravity(Gravity.CENTER);//同上
    //将GridView和数据适配器关联
            gridview.setAdapter(adapter);
        }
    }

        b).  gridview.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">
        
    <GridView android:id="@+id/mygridview"
            android:numColumns
    ="3"
            android:gravity
    ="center_horizontal"
            android:layout_width
    ="wrap_content"
            android:layout_height
    ="wrap_content">
        
    </GridView>
    </LinearLayout>

        c).  grid_item.xml

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout android:id="@+id/RelativeLayout01"
        android:layout_width
    ="fill_parent" android:layout_height="fill_parent"
        xmlns:android
    ="http://schemas.android.com/apk/res/android">
        
    <ImageView android:id="@+id/image_item"
            android:layout_width
    ="wrap_content"
            android:layout_height
    ="wrap_content">
        
    </ImageView>
        
    <TextView android:id="@+id/text_item"
            android:layout_below
    ="@+id/image_item"
            android:layout_height
    ="wrap_content"
            android:layout_width
    ="wrap_content">
        
    </TextView>
    </RelativeLayout>

      七、PDF下载

        CSDN:http://download.csdn.net/source/2767154

    结束

      再次感谢0_1提供的优质翻译稿,感谢他辛勤的付出,同时翻译组期待更多的人加入,也欢迎大家一起来纠错!

  • 相关阅读:
    LeetCode OJ--Sort Colors
    LeetCode OJ--Single Number II **
    LeetCode OJ--Single Number
    LeetCode OJ--Subsets II
    LeetCode OJ--ZigZag Conversion
    3ds Max学习日记(三)
    3ds Max学习日记(二)
    3ds Max学习日记(一)
    PokeCats开发者日志(十三)
    PokeCats开发者日志(十二)
  • 原文地址:https://www.cnblogs.com/over140/p/1855366.html
Copyright © 2011-2022 走看看