Android:控制項GridView的使用執行個體_Android

來源:互聯網
上載者:User

如果是列表(單列多行形式)的使用ListView,如果是多行多列網狀形式的優先使用GridView。

<?xml version="1.0" encoding="utf-8"?><GridView xmlns:android="http://schemas.android.com/apk/res/android"  android:layout_width="match_parent"  android:layout_height="match_parent" >  </GridView>

GirdView的一些屬性:

  • android:numColumns="auto_fit" --------列數設定為自動
  • android:columnWidth="90dp",----------每列的寬度,也就是Item的寬度
  • android:stretchMode="columnWidth"------縮放與列寬大小同步
  • android:verticalSpacing="10dp"----------垂直邊距
  • android:horizontalSpacing="10dp"-------水平邊距

1、準備資料來源

2、建立適配器

3、載入適配器

GridView(網格視圖)是按照行列的方式來顯示內容的,一般用於顯示圖片,圖片等內容,比如實現九宮格圖,用GridView是首選,也是最簡單的,下面來個執行個體,

執行個體下載:demo

效果圖:

MainActivity.java

package com.example.testgridview;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import android.app.Activity;import android.os.Bundle;import android.widget.GridView;import android.widget.SimpleAdapter;public class MainActivity extends Activity {  private GridView gview;  private List<Map<String, Object>> data_list;  private SimpleAdapter sim_adapter;  // 圖片封裝為一個數組  private int[] icon = { R.drawable.address_book, R.drawable.calendar,      R.drawable.camera, R.drawable.clock, R.drawable.games_control,      R.drawable.messenger, R.drawable.ringtone, R.drawable.settings,      R.drawable.speech_balloon, R.drawable.weather, R.drawable.world,      R.drawable.youtube };  private String[] iconName = { "通訊錄", "日曆", "照相機", "時鐘", "遊戲", "簡訊", "鈴聲",      "設定", "語音", "天氣", "瀏覽器", "視頻" };  @Override  protected void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.test);    gview = (GridView) findViewById(R.id.gview);    //建立List    data_list = new ArrayList<Map<String, Object>>();    //擷取資料    getData();    //建立適配器    String [] from ={"image","text"};    int [] to = {R.id.image,R.id.text};    sim_adapter = new SimpleAdapter(this, data_list, R.layout.item, from, to);    //配置適配器    gview.setAdapter(sim_adapter);  }      public List<Map<String, Object>> getData(){        //cion和iconName的長度是相同的,這裡任選其一都可以    for(int i=0;i<icon.length;i++){      Map<String, Object> map = new HashMap<String, Object>();      map.put("image", icon[i]);      map.put("text", iconName[i]);      data_list.add(map);    }          return data_list;  }  }

test.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:layout_width="match_parent"  android:layout_height="match_parent"  android:orientation="vertical"   android:background="#000"  >  <GridView     android:id="@+id/gview"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:numColumns="auto_fit"      android:columnWidth="80dp"    android:stretchMode="columnWidth"    ></GridView></LinearLayout>

item.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"  android:orientation="vertical"   android:gravity="center"  android:padding="10dp"  >    <ImageView   android:src="@drawable/ic_launcher"  android:id="@+id/image"  android:layout_width="60dp"  android:layout_height="60dp"    /><TextView   android:id="@+id/text"  android:layout_marginTop="5dp"  android:layout_width="wrap_content"  android:layout_height="wrap_content"  android:textColor="#ffffff"  android:text="文字"  /></LinearLayout>

監聽介面: onItemClickListener

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.