Android(安卓)GridView 网格视图

Android GridView 在二维滚动网格(行和列)中显示项目,网格项不一定是预先确定的,但它们使用 ListAdapter 自动插入到布局中。

适配器实际上是 UI 组件和将数据填充到 UI 组件中的数据源之间的桥梁。适配器保存数据并将数据发送到适配器视图,视图可以从适配器视图获取数据,并在不同视图(如 SpinnerListViewGridView 等)上显示数据。

ListViewGridViewAdapterView 的子类,可以通过将它们绑定到适配器来填充它们,适配器从外部源检索数据并创建表示每个数据项的视图。


GridView 属性

以下是 GridView 特有的重要属性:

编号属性 & 描述
1

android:id

这是唯一标识布局的 ID。

2

android:columnWidth

这将指定每个列的固定宽度可以是 px、dp、sp、in 或 mm。

3

android:gravity

指定每个单元格内的重力可能的值有 topbottomleftrightcentercenter_verticalcenter_horizontal 等。

4

android:horizontalSpacing

定义列之间的默认水平间距可以是 px、dp、sp、in 或 mm。

5

android:numColumns

定义要显示的列数可以是整数值,例如 "100" 或 auto_fit,这意味着显示尽可能多的列以填充可用空间。

6

android:stretchMode

定义列应如何拉伸以填充可用的空白空间(如果有)这必须是以下值之一 −

  • none − 禁用拉伸。

  • spacingWidth − 每列之间的间距被拉伸。

  • columnWidth − 每一列都被均匀拉伸。

  • spacingWidthUniform − 每列之间的间距均匀拉伸。

7

android:verticalSpacing

定义行之间的默认垂直间距可以是 px、dp、sp、in 或 mm。


实例

这个例子将带你通过简单的步骤来展示如何使用 TableLayout 创建你自己的 Android 应用程序。按照以下步骤修改我们在 Hello World 实例 章节中创建的 Android 应用程序:

步骤描述
1您将使用 Android Studio IDE 创建一个 Android 应用程序,并将其命名为 com.example.helloworld 包下的 helloworld,如 Hello World 实例一章所述。
2修改文件 res/layout/activity_main.xml 的内容来包含 GridView 内容,并使用它的一些属性。。
3无需更改 string.xml 文件中的默认字符串常量。Android studio 负责默认字符串常量。
4让我们在 res/drawable-hdpi 文件夹中放置一些图片,我们已经放入了 sample0.jpg, sample1.jpg, sample2.jpg, sample3.jpg, sample4.jpg, sample5.jpg, sample6.jpg 和 sample7.jpg
5在包 com.example.helloworld 下创建一个名为 ImageAdapter 的新类实例扩展 BaseAdapter。此类将实现用于填充视图的适配器的功能
6运行应用程序以启动 Android 模拟器并验证应用程序中所做更改的结果。

下面是修改后的主活动文件 src/com.example.helloworld/MainActivity.java 的内容。此文件可以包括每个基本生命周期方法:

  1. package com.example.helloworld;
  2. import android.os.Bundle;
  3. import android.app.Activity;
  4. import android.view.Menu;
  5. import android.widget.GridView;
  6. public class MainActivity extends Activity {
  7. @Override
  8. protected void onCreate(Bundle savedInstanceState) {
  9. super.onCreate(savedInstanceState);
  10. setContentView(R.layout.activity_main);
  11. GridView gridview = (GridView) findViewById(R.id.gridview);
  12. gridview.setAdapter(new ImageAdapter(this));
  13. }
  14. }

下面是 res/layout/activity_main.xml 文件的内容:

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

下面是 res/values/strings.xml 文件的内容,定义了两个常量:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <resources>
  3. <string name="app_name">HelloWorld</string>
  4. <string name="action_settings">Settings</string>
  5. </resources>

下面是 src/com.example.helloworld/ImageAdapter.java 文件的内容:

  1. package com.example.helloworld;
  2. import android.content.Context;
  3. import android.view.View;
  4. import android.view.ViewGroup;
  5. import android.widget.BaseAdapter;
  6. import android.widget.GridView;
  7. import android.widget.ImageView;
  8. public class ImageAdapter extends BaseAdapter {
  9. private Context mContext;
  10. // Constructor
  11. public ImageAdapter(Context c) {
  12. mContext = c;
  13. }
  14. public int getCount() {
  15. return mThumbIds.length;
  16. }
  17. public Object getItem(int position) {
  18. return null;
  19. }
  20. public long getItemId(int position) {
  21. return 0;
  22. }
  23. // create a new ImageView for each item referenced by the Adapter
  24. public View getView(int position, View convertView, ViewGroup parent) {
  25. ImageView imageView;
  26. if (convertView == null) {
  27. imageView = new ImageView(mContext);
  28. imageView.setLayoutParams(new GridView.LayoutParams(85, 85));
  29. imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
  30. imageView.setPadding(8, 8, 8, 8);
  31. }
  32. else
  33. {
  34. imageView = (ImageView) convertView;
  35. }
  36. imageView.setImageResource(mThumbIds[position]);
  37. return imageView;
  38. }
  39. // Keep all Images in array
  40. public Integer[] mThumbIds = {
  41. R.drawable.sample_2, R.drawable.sample_3,
  42. R.drawable.sample_4, R.drawable.sample_5,
  43. R.drawable.sample_6, R.drawable.sample_7,
  44. R.drawable.sample_0, R.drawable.sample_1,
  45. R.drawable.sample_2, R.drawable.sample_3,
  46. R.drawable.sample_4, R.drawable.sample_5,
  47. R.drawable.sample_6, R.drawable.sample_7,
  48. R.drawable.sample_0, R.drawable.sample_1,
  49. R.drawable.sample_2, R.drawable.sample_3,
  50. R.drawable.sample_4, R.drawable.sample_5,
  51. R.drawable.sample_6, R.drawable.sample_7
  52. };
  53. }

让我们尝试运行我们修改过的 Hello World!我们刚刚修改的应用程序。我假设您在进行环境设置时创建了 AVD。要从 Android Studio 运行应用程序,请打开项目的 activity 文件之一,然后单击工具栏上的运行 Eclipse Eclipse Run Icon 图标。Android studio 在您的AVD 上安装应用程序并启动它,如果您的设置和应用程序一切正常,它将显示以下模拟器窗口:


子活动实例

让我们扩展上面示例的功能,我们将全屏显示选定的网格图像。为此,我们需要引入一项新的 activity 活动。只要记住,对于我们需要执行的任何活动,就像我们必须实现一个活动类一样,在 AndroidManifest.xml 文件中定义该活动,定义相关的布局,最后通过它在主活动类中将子活动与主活动链接。因此,让我们按照步骤修改上面的实例:

步骤描述
1您将使用 Android studio IDE 创建一个 Android 应用程序,并将其命名为 com.example.helloworld 包下的 HelloWorld。如 Hello World 实例一章所述
2在包 com.example.helloworld 下面创建一个新的 ActivitySingleViewActivity.java
3res/layout/folder 下为新活动创建新的布局文件让我们将这个 XML 文件命名为 single_view.xml
4AndroidManifest 中定义您的新活动。使用 <activity…/> 标记的 xml 文件应用程序可以有一个或多个活动,没有任何限制
5运行应用程序以启动 Android 模拟器并验证应用程序中所做更改的结果。

下面是修改后的主活动文件 src/com.example.helloworld/MainActivity.java 的内容。该文件可以包括每个基本生命周期方法。

  1. package com.example.helloworld;
  2. import android.app.Activity;
  3. import android.content.Intent;
  4. import android.os.Bundle;
  5. import android.view.Menu;
  6. import android.view.View;
  7. import android.widget.AdapterView;
  8. import android.widget.AdapterView.OnItemClickListener;
  9. import android.widget.GridView;
  10. public class MainActivity extends Activity {
  11. @Override
  12. protected void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.activity_main);
  15. GridView gridview = (GridView) findViewById(R.id.gridview);
  16. gridview.setAdapter(new ImageAdapter(this));
  17. gridview.setOnItemClickListener(new OnItemClickListener() {
  18. public void onItemClick(AdapterView<?> parent,
  19. View v, int position, long id){
  20. // Send intent to SingleViewActivity
  21. Intent i = new Intent(getApplicationContext(), SingleViewActivity.class);
  22. // Pass image index
  23. i.putExtra("id", position);
  24. startActivity(i);
  25. }
  26. });
  27. }
  28. }

下面是新 activity 文件 src/com.example.helloworld/SingleViewActivity.java 的内容:

  1. package com.example.helloworld;
  2. import android.app.Activity;
  3. import android.content.Intent;
  4. import android.os.Bundle;
  5. import android.widget.ImageView;
  6. public class SingleViewActivity extends Activity {
  7. @Override
  8. public void onCreate(Bundle savedInstanceState) {
  9. super.onCreate(savedInstanceState);
  10. setContentView(R.layout.single_view);
  11. // Get intent data
  12. Intent i = getIntent();
  13. // Selected image id
  14. int position = i.getExtras().getInt("id");
  15. ImageAdapter imageAdapter = new ImageAdapter(this);
  16. ImageView imageView = (ImageView) findViewById(R.id.SingleView);
  17. imageView.setImageResource(imageAdapter.mThumbIds[position]);
  18. }
  19. }

下面是 res/layout/single_view.xml 文件的内容:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:orientation="vertical" >
  7. <ImageView android:id="@+id/SingleView"
  8. android:layout_width="fill_parent"
  9. android:layout_height="fill_parent"/>
  10. </LinearLayout>

下面是 AndroidManifest.xml 文件的内容,定义了两个常量:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"
  3. package="com.example.helloworld">
  4. <application
  5. android:allowBackup="true"
  6. android:icon="@drawable/ic_launcher"
  7. android:label="@string/app_name"
  8. android:theme="@style/AppTheme" >
  9. <activity
  10. android:name="com.example.helloworld.MainActivity"
  11. android:label="@string/app_name" >
  12. <intent-filter>
  13. <action android:name="android.intent.action.MAIN" />
  14. <category android:name="android.intent.category.LAUNCHER" />
  15. </intent-filter>
  16. </activity>
  17. <activity android:name=".SingleViewActivity"></activity>
  18. </application>
  19. </manifest>

让我们尝试运行我们修改过的 Hello World!我们刚刚修改的应用程序。我假设您在进行环境设置时创建了 AVD。要从 Android Studio 运行应用程序,请打开项目的 activity 文件之一,然后单击工具栏上的运行 Eclipse Eclipse Run Icon 图标。Android studio 在您的AVD 上安装应用程序并启动它,如果您的设置和应用程序一切正常,它将显示以下模拟器窗口:

现在,如果您单击任一图像,它将显示为单个图像,例如:

请注意,上述图片是从 Android 官方网站拍摄的。

分类导航