Android控件之GridView用法實例分析
本文實例講述了Android控件之GridView用法。分享給大家供大家參考。具體如下:
GridView是一項顯示二維的viewgroup,可滾動的網(wǎng)格。一般用來顯示多張圖片。
以下模擬九宮圖的實現(xiàn),當鼠標點擊圖片時會進行相應(yīng)的跳轉(zhuǎn)鏈接。
目錄結(jié)構(gòu)如下:
main.xml布局文件,存放GridView控件
<?xml version="1.0" encoding="utf-8"?> <!-- android:numColumns="auto_fit" ,GridView的列數(shù)設(shè)置為自動 android:columnWidth="90dp",每列的寬度,也就是Item的寬度 android:stretchMode="columnWidth",縮放與列寬大小同步 android:verticalSpacing="10dp",兩行之間的邊距,如:行一(NO.0~NO.2)與行二(NO.3~NO.5)間距為10dp android:horizontalSpacing="10dp",兩列之間的邊距 --> <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" />
night_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:layout_width="wrap_content" android:layout_centerHorizontal="true" android:id="@+id/itemImage" > </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>
strings.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="hello">Hello World, GvActivity!</string> <string name="app_name">九宮圖</string> <string name="test_name1">跳轉(zhuǎn)到TestActivity1</string> <string name="test_name2">跳轉(zhuǎn)到TestActivity2</string> <string name="test_name3">跳轉(zhuǎn)到TestActivity3</string> </resources>
清單文件
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.ljq.gv" android:versionCode="1" android:versionName="1.0"> <application android:icon="@drawable/icon" android:label="@string/app_name"> <activity android:name=".GvActivity" android:label="@string/app_name"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <activity android:name=".TestActivity1" android:label="@string/test_name1"/> <activity android:name=".TestActivity2" android:label="@string/test_name2"/> <activity android:name=".TestActivity3" android:label="@string/test_name3"/> </application> <uses-sdk android:minSdkVersion="7" /> </manifest>
跳轉(zhuǎn)類TestActivity1、TestActivity2、TestActivity3
package com.ljq.gv; import android.app.Activity; import android.os.Bundle; public class TestActivity1 extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //setContentView(R.layout.main); } } package com.ljq.gv; import android.app.Activity; import android.os.Bundle; public class TestActivity2 extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //setContentView(R.layout.main); } } package com.ljq.gv; import android.app.Activity; import android.os.Bundle; public class TestActivity3 extends Activity { @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); //setContentView(R.layout.main); } }
類GvActivity:
package com.ljq.gv; import java.util.ArrayList; import java.util.HashMap; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.widget.AdapterView; import android.widget.GridView; import android.widget.SimpleAdapter; import android.widget.Toast; import android.widget.AdapterView.OnItemClickListener; public class GvActivity extends Activity { private String texts[] = null; private int images[] = null; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); images=new int[]{R.drawable.p1, R.drawable.p2, R.drawable.p3, R.drawable.p4, R.drawable.p5,R.drawable.p6, R.drawable.p7,R.drawable.p8}; texts = new String[]{ "宮式布局1", "宮式布局2", "宮式布局3", "宮式布局4", "宮式布局5", "宮式布局6", "宮式布局7", "宮式布局8"}; GridView gridview = (GridView) findViewById(R.id.gridview); ArrayList<HashMap<String, Object>> lstImageItem = new ArrayList<HashMap<String, Object>>(); for (int i = 0; i < 8; i++) { HashMap<String, Object> map = new HashMap<String, Object>(); map.put("itemImage", images[i]); map.put("itemText", texts[i]); lstImageItem.add(map); } SimpleAdapter saImageItems = new SimpleAdapter(this, lstImageItem,// 數(shù)據(jù)源 R.layout.night_item,// 顯示布局 new String[] { "itemImage", "itemText" }, new int[] { R.id.itemImage, R.id.itemText }); gridview.setAdapter(saImageItems); gridview.setOnItemClickListener(new ItemClickListener()); } class ItemClickListener implements OnItemClickListener { /** * 點擊項時觸發(fā)事件 * * @param parent 發(fā)生點擊動作的AdapterView * @param view 在AdapterView中被點擊的視圖(它是由adapter提供的一個視圖)。 * @param position 視圖在adapter中的位置。 * @param rowid 被點擊元素的行id。 */ public void onItemClick(AdapterView<?> parent, View view, int position, long rowid) { HashMap<String, Object> item = (HashMap<String, Object>) parent.getItemAtPosition(position); //獲取數(shù)據(jù)源的屬性值 String itemText=(String)item.get("itemText"); Object object=item.get("itemImage"); Toast.makeText(GvActivity.this, itemText, Toast.LENGTH_LONG).show(); //根據(jù)圖片進行相應(yīng)的跳轉(zhuǎn) switch (images[position]) { case R.drawable.p1: startActivity(new Intent(GvActivity.this, TestActivity1.class));//啟動另一個Activity finish();//結(jié)束此Activity,可回收 break; case R.drawable.p2: startActivity(new Intent(GvActivity.this, TestActivity2.class)); finish(); break; case R.drawable.p3: startActivity(new Intent(GvActivity.this, TestActivity3.class)); finish(); break; } } } }
運行結(jié)果
希望本文所述對大家的Android程序設(shè)計有所幫助。
- Android中實現(xiàn)多行、水平滾動的分頁的Gridview實例源碼
- android ListView和GridView拖拽移位實現(xiàn)代碼
- Android中RecyclerView布局代替GridView實現(xiàn)類似支付寶的界面
- Android GridView實現(xiàn)滾動到指定位置的方法
- android中GridView的用法示例
- android GridView多選效果的實例代碼
- Android開發(fā)之使用GridView展示圖片的方法
- Android GridView仿微信朋友圈顯示圖片
- Android實現(xiàn)九宮格(GridView中各項平分空間)的方法
- Android實現(xiàn)GridView中ImageView動態(tài)變換的方法
- Android開發(fā)之實現(xiàn)GridView支付寶九宮格
- Android開發(fā)中GridView用法示例
相關(guān)文章
Android 基于google Zxing實現(xiàn)二維碼、條形碼掃描,仿微信二維碼掃描效果(推薦)
這篇文章主要介紹了 Android 基于google Zxing實現(xiàn)二維碼、條形碼掃描,仿微信二維碼掃描效果,非常不錯,具有參考借鑒價值,需要的朋友參考下2017-01-01Android之解析JSON數(shù)據(jù)示例(android原生態(tài),F(xiàn)astJson,Gson)
本篇文章主要介紹了Android之解析JSON數(shù)據(jù)示例,主要使用android原生態(tài)代碼解析,F(xiàn)astJson,Gson三種方法,有興趣的可以了解一下。2017-02-02Android自定義ViewGroup之FlowLayout(三)
這篇文章主要為大家詳細介紹了Android自定義ViewGroup之FlowLayout,常用于關(guān)鍵字標簽,搜索熱詞列表等功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09Android實現(xiàn)調(diào)用攝像頭拍照與視頻功能
這篇文章主要為大家詳細介紹了Android實現(xiàn)調(diào)用攝像頭拍照與視頻功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-04-04Kotlin中Stack與LinkedList的實現(xiàn)方法示例
這篇文章主要給大家介紹了關(guān)于Kotlin中Stack與LinkedList實現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06android實現(xiàn)微信聯(lián)合登錄開發(fā)示例
本篇文章主要介紹了android實現(xiàn)微信聯(lián)合登錄開發(fā)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10