当前位置:   article > 正文

Android -- 下拉列表、列表视图、网格视图_android 下拉列表

android 下拉列表

下拉框 -- 文本

  • Spinner 用于从一串列表中选择某项,功能类似于单选按钮的组合

下拉列表的展示 方式有两种,一种是在当前下拉框的正下方弹出列表框,此时要把spinnerMode属性设置为 dropdown,另一种是在页面中部弹出列表对话框,此时要把spinnerMode属性设置为dialog。

运行效果

dropdown 下拉模式                                                     dialog 对话框模式

                        ​​​​​​​        

布局文件

dialog 模式

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <TextView
  7. android:layout_width="match_parent"
  8. android:layout_height="wrap_content"
  9. android:text="下拉列表框"
  10. android:textSize="20sp"/>
  11. <Spinner
  12. android:id="@+id/sp_dialog"
  13. android:layout_width="match_parent"
  14. android:layout_height="wrap_content"
  15. android:spinnerMode="dialog"
  16. />
  17. </LinearLayout>

dropdown模式

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <TextView
  7. android:layout_width="match_parent"
  8. android:layout_height="wrap_content"
  9. android:text="下拉列表框"
  10. android:textSize="20sp"/>
  11. <Spinner
  12. android:id="@+id/sp_dialog"
  13. android:layout_width="match_parent"
  14. android:layout_height="wrap_content"
  15. android:spinnerMode="dropdown"
  16. />
  17. </LinearLayout>

数组适配器

        这个适配器好比一组数据的加 工流水线,你丢给它一大把糖果(六大行星的原始数据),适配器先按顺序排列糖果(对应行星数组 starArray),然后拿来制作好的包装盒(对应每个列表项的布局文件item_select.xml),把糖果往里面 一塞,出来的便是一个个精美的糖果盒(界面上排布整齐的列表框)。这个流水线可以做得很复杂,也 可以做得简单一些,最简单的流水线就是演示用到的数组适配器ArrayAdapter

java代码调用方法

  • setPrompt:设置标题文字。注意对话框模式才显示标题,下拉模式不显示标题。
  • setAdapter:设置列表项的数据适配器。
  • setSelection:设置当前选中哪项。注意该方法要在setAdapter方法后调用。
  • setOnItemSelectedListener:设置下拉列表的选择监听器,该监听器要实现接口 OnItemSelectedListener。
  1. package com.kcs.highcontrol;
  2. import android.os.Bundle;
  3. import android.view.View;
  4. import android.widget.AdapterView;
  5. import android.widget.ArrayAdapter;
  6. import android.widget.Spinner;
  7. import androidx.appcompat.app.AppCompatActivity;
  8. import com.kcs.highcontrol.utils.ToastUtil;
  9. public class SpinnerDialogActivity extends AppCompatActivity implements AdapterView.OnItemSelectedListener {
  10. //下拉列表文本数组
  11. private final static String[] startArray = {"土星", "太阳", "地球", "金星", "火星", "木星"};
  12. private Spinner sp_dialog;
  13. @Override
  14. protected void onCreate(Bundle savedInstanceState) {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.activity_spinner_dialog);
  17. sp_dialog = findViewById(R.id.sp_dialog);
  18. //声明一个下拉列表的数组适配器
  19. ArrayAdapter<String> arrayAdapter = new ArrayAdapter<>(this, R.layout.item_select, startArray);
  20. sp_dialog.setAdapter(arrayAdapter);
  21. //设置下拉列表标题
  22. sp_dialog.setPrompt("请选择:");
  23. //设置默认显示下拉第一项
  24. sp_dialog.setSelection(0);
  25. //给下拉框设置选择监听器
  26. sp_dialog.setOnItemSelectedListener(this);
  27. }
  28. @Override
  29. public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
  30. ToastUtil.show(this, "你选择的是:" + startArray[position]);
  31. }
  32. @Override
  33. public void onNothingSelected(AdapterView<?> parent) {
  34. }
  35. }

样式

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <TextView xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="50dp"
  5. android:gravity="center"
  6. android:textColor="#0000ff"
  7. android:textSize="20sp"
  8. android:text="火星"
  9. >
  10. </TextView>

下拉列表 -- 简单适配器

使用到的图片

简单适配器

        SimpleAdapter的实现过程略微复杂,因为它的原料需要更多信息。例如,原料不但有糖果,还有贺 卡,这样就得把一大袋糖果和一大袋贺卡送进流水线,适配器每次拿一颗糖果和一张贺卡,把糖果与贺 卡按规定塞进包装盒。对于SimpleAdapter的构造方法来说,第2个参数Map容器放的是原料糖果与贺 卡,第3个参数放的是包装盒,第4个参数放的是糖果袋与贺卡袋的名称,第5个参数放的是包装盒里塞 糖果的位置与塞贺卡的位置。

运行效果

dialog模式:

布局文件

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <TextView
  7. android:layout_width="match_parent"
  8. android:layout_height="wrap_content"
  9. android:text="简单的适配器"
  10. android:textSize="20sp"/>
  11. <Spinner
  12. android:id="@+id/sp_icon"
  13. android:layout_width="match_parent"
  14. android:layout_height="wrap_content"
  15. android:spinnerMode="dialog"
  16. />
  17. </LinearLayout>

样式文件

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. xmlns:tools="http://schemas.android.com/tools"
  4. android:layout_width="match_parent"
  5. android:layout_height="wrap_content"
  6. android:orientation="horizontal">
  7. <ImageView
  8. android:id="@+id/image_name"
  9. android:layout_width="0dp"
  10. android:layout_height="50dp"
  11. android:layout_weight="1"
  12. tools:src="@drawable/diqiu"
  13. />
  14. <TextView
  15. android:id="@+id/tv_name"
  16. android:layout_width="0dp"
  17. android:layout_height="match_parent"
  18. android:layout_weight="3"
  19. android:gravity="center"
  20. android:textColor="#ff0000"
  21. android:text="地球"
  22. android:textSize="20dp"
  23. />
  24. </LinearLayout>

工具类

  1. import android.content.Context;
  2. import android.widget.Toast;
  3. public class ToastUtil {
  4. public static void show(Context ctx, String desc) {
  5. Toast.makeText(ctx, desc, Toast.LENGTH_SHORT).show();
  6. }
  7. }

主程序

  1. import android.os.Bundle;
  2. import android.view.View;
  3. import android.widget.AdapterView;
  4. import android.widget.SimpleAdapter;
  5. import android.widget.Spinner;
  6. import androidx.appcompat.app.AppCompatActivity;
  7. import com.kcs.highcontrol.utils.ToastUtil;
  8. import java.util.ArrayList;
  9. import java.util.HashMap;
  10. import java.util.Map;
  11. public class SpinnerIconActivity extends AppCompatActivity implements AdapterView.OnItemSelectedListener {
  12. // 定义下拉列表需要显示的行星图标数组
  13. private static final int[] iconArray = {
  14. R.drawable.shuixing, R.drawable.jinxing, R.drawable.diqiu,
  15. R.drawable.huoxing, R.drawable.muxing, R.drawable.tuxing
  16. };
  17. // 定义下拉列表需要显示的行星名称数组
  18. private static final String[] starArray = {"水星", "金星", "地球", "火星", "木星", "土星"};
  19. @Override
  20. protected void onCreate(Bundle savedInstanceState) {
  21. super.onCreate(savedInstanceState);
  22. setContentView(R.layout.activity_spinner_icon);
  23. //声明一个映像对象的列表
  24. ArrayList<Map<String, Object>> list = new ArrayList<>();
  25. for (int i = 0; i < iconArray.length; i++) {
  26. HashMap<String, Object> item = new HashMap<>();
  27. item.put("icon",iconArray[i]);
  28. item.put("name",starArray[i]);
  29. list.add(item);
  30. }
  31. //简单适配器,指定图片和文本两组数据
  32. SimpleAdapter adapter = new SimpleAdapter(this, list,
  33. R.layout.icon_spinner,
  34. new String[]{"icon","name"},
  35. new int[]{R.id.image_name,R.id.tv_name}
  36. );
  37. Spinner sp_icon = findViewById(R.id.sp_icon);
  38. sp_icon.setAdapter(adapter);
  39. sp_icon.setSelection(0);
  40. sp_icon.setOnItemSelectedListener(this);
  41. }
  42. @Override
  43. public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
  44. ToastUtil.show(this, "你选择的是:" + starArray[position]);
  45. }
  46. @Override
  47. public void onNothingSelected(AdapterView<?> parent) {
  48. }
  49. }

列表视图 -- 基本适配器

        Android提供了一种适应性更强的基本适配器BaseAdapter,该适配器允许 开发者在别的代码文件中编写操作代码,大大提高了代码的可读性和可维护性

从BaseAdapter派生的数据适配器主要实现下面5种方法

  1. 构造方法:指定适配器需要处理的数据集合。
  2. getCount:获取列表项的个数。
  3. getItem:获取列表项的数据。
  4. getItemId:获取列表项的编号。
  5. getView:获取每项的展示视图,并对每项的内部控件进行业务处理

运行的效果

dialog模式

布局文件

activity-base_adapter.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <TextView
  7. android:layout_width="match_parent"
  8. android:layout_height="wrap_content"
  9. android:text="基本适配器"
  10. android:textSize="20sp"/>
  11. <Spinner
  12. android:id="@+id/sp_planet"
  13. android:layout_width="match_parent"
  14. android:layout_height="wrap_content"
  15. android:spinnerMode="dropdown"
  16. />
  17. </LinearLayout>

样式文件

item_list.xml

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:orientation="horizontal">
  6. <!-- 这是显示行星图片的图像视图 -->
  7. <ImageView
  8. android:id="@+id/iv_icon"
  9. android:layout_width="0dp"
  10. android:layout_height="80dp"
  11. android:layout_weight="1"
  12. android:scaleType="fitCenter"
  13. tools:src="@drawable/diqiu" />
  14. <LinearLayout
  15. android:layout_width="0dp"
  16. android:layout_height="match_parent"
  17. android:layout_marginLeft="5dp"
  18. android:layout_weight="3"
  19. android:orientation="vertical">
  20. <!-- 这是显示行星名称的文本视图 -->
  21. <TextView
  22. android:id="@+id/tv_name"
  23. android:layout_width="match_parent"
  24. android:layout_height="0dp"
  25. android:layout_weight="1"
  26. android:gravity="start|center"
  27. android:textColor="@color/black"
  28. android:textSize="20sp"
  29. tools:text="地球" />
  30. <!-- 这是显示行星描述的文本视图 -->
  31. <TextView
  32. android:id="@+id/tv_desc"
  33. android:layout_width="match_parent"
  34. android:layout_height="0dp"
  35. android:layout_weight="2"
  36. android:gravity="start|center"
  37. android:textColor="@color/black"
  38. android:textSize="13sp"
  39. tools:text="地球是太阳系八大行星之一,排行第三,也是太阳系中直径、质量和密度最大的类地行星,距离太阳1.5亿公里" />
  40. </LinearLayout>
  41. </LinearLayout>

实体类

Planet.java

  1. package com.kcs.highcontrol.pojo;
  2. import com.kcs.highcontrol.R;
  3. import java.util.ArrayList;
  4. import java.util.List;
  5. public class Planet {
  6. /**
  7. * 行星图标
  8. */
  9. public int image;
  10. /**
  11. * 行星名称
  12. */
  13. public String name;
  14. /**
  15. * 行星描述
  16. */
  17. public String desc;
  18. public Planet(int image, String name, String desc) {
  19. this.image = image;
  20. this.name = name;
  21. this.desc = desc;
  22. }
  23. private static int[] iconArray = {R.drawable.shuixing, R.drawable.jinxing, R.drawable.diqiu,
  24. R.drawable.huoxing, R.drawable.muxing, R.drawable.tuxing};
  25. private static String[] nameArray = {"水星", "金星", "地球", "火星", "木星", "土星"};
  26. private static String[] descArray = {
  27. "水星是太阳系八大行星最内侧也是最小的一颗行星,也是离太阳最近的行星",
  28. "金星是太阳系八大行星之一,排行第二,距离太阳0.725天文单位",
  29. "地球是太阳系八大行星之一,排行第三,也是太阳系中直径、质量和密度最大的类地行星,距离太阳1.5亿公里",
  30. "火星是太阳系八大行星之一,排行第四,属于类地行星,直径约为地球的53%",
  31. "木星是太阳系八大行星中体积最大、自转最快的行星,排行第五。它的质量为太阳的千分之一,但为太阳系中其它七大行星质量总和的2.5倍",
  32. "土星为太阳系八大行星之一,排行第六,体积仅次于木星"
  33. };
  34. public static List<Planet> getDefaultList() {
  35. List<Planet> planetList = new ArrayList<Planet>();
  36. for (int i = 0; i < iconArray.length; i++) {
  37. planetList.add(new Planet(iconArray[i], nameArray[i], descArray[i]));
  38. }
  39. return planetList;
  40. }
  41. }

主程序

BaseAdapterActivity.java

  1. package com.kcs.highcontrol;
  2. import android.os.Bundle;
  3. import android.view.View;
  4. import android.widget.AdapterView;
  5. import android.widget.Spinner;
  6. import androidx.appcompat.app.AppCompatActivity;
  7. import com.kcs.highcontrol.adapter.PlanetBaseAdapter;
  8. import com.kcs.highcontrol.pojo.Planet;
  9. import com.kcs.highcontrol.utils.ToastUtil;
  10. import java.util.List;
  11. public class BaseAdapterActivity extends AppCompatActivity implements AdapterView.OnItemSelectedListener {
  12. private List<Planet> planetList;
  13. @Override
  14. protected void onCreate(Bundle savedInstanceState) {
  15. super.onCreate(savedInstanceState);
  16. setContentView(R.layout.activity_base_adapter);
  17. Spinner sp_planet = findViewById(R.id.sp_planet);
  18. // 获取默认的行星列表,即水星、金星、地球、火星、木星、土星
  19. planetList = Planet.getDefaultList();
  20. // 构建一个行星列表的适配器
  21. PlanetBaseAdapter adapter = new PlanetBaseAdapter(this, planetList);
  22. sp_planet.setAdapter(adapter);
  23. sp_planet.setSelection(0);
  24. sp_planet.setOnItemSelectedListener(this);
  25. }
  26. @Override
  27. public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
  28. ToastUtil.show(this, "您选择的是" + planetList.get(position).name);
  29. }
  30. @Override
  31. public void onNothingSelected(AdapterView<?> parent) {
  32. }
  33. }

基本适配器

PlanetBaseAdapter.java

  1. package com.kcs.highcontrol.adapter;
  2. import android.content.Context;
  3. import android.view.LayoutInflater;
  4. import android.view.View;
  5. import android.view.ViewGroup;
  6. import android.widget.BaseAdapter;
  7. import android.widget.ImageView;
  8. import android.widget.TextView;
  9. import com.kcs.highcontrol.R;
  10. import com.kcs.highcontrol.pojo.Planet;
  11. import java.util.List;
  12. /**
  13. * @author Kcs
  14. */
  15. public class PlanetBaseAdapter extends BaseAdapter {
  16. private Context mContext;
  17. private List<Planet> mPlanetList;
  18. public PlanetBaseAdapter(Context context, List<Planet> mPlanetList) {
  19. this.mContext = context;
  20. this.mPlanetList = mPlanetList;
  21. }
  22. /**
  23. * 列表项目的个数
  24. * @return size
  25. */
  26. @Override
  27. public int getCount() {
  28. return mPlanetList.size();
  29. }
  30. @Override
  31. public Object getItem(int position) {
  32. return mPlanetList.get(position);
  33. }
  34. /**
  35. * 条目
  36. * @param position
  37. * @return
  38. */
  39. @Override
  40. public long getItemId(int position) {
  41. return position;
  42. }
  43. @Override
  44. public View getView(int position, View convertView, ViewGroup parent) {
  45. ViewHolder holder;
  46. if (convertView == null){
  47. // 根据布局文件item_list.xml生成转换视图对象
  48. convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list, null);
  49. holder = new ViewHolder();
  50. holder.iv_icon = convertView.findViewById(R.id.iv_icon);
  51. holder.tv_name = convertView.findViewById(R.id.tv_name);
  52. holder.tv_desc = convertView.findViewById(R.id.tv_desc);
  53. // 将视图持有者保存到转换视图当中
  54. convertView.setTag(holder);
  55. }else{
  56. holder = (ViewHolder) convertView.getTag();
  57. }
  58. // 给控制设置好数据
  59. Planet planet = mPlanetList.get(position);
  60. holder.iv_icon.setImageResource(planet.image);
  61. holder.tv_name.setText(planet.name);
  62. holder.tv_desc.setText(planet.desc);
  63. return convertView;
  64. }
  65. public final class ViewHolder {
  66. public ImageView iv_icon;
  67. public TextView tv_name;
  68. public TextView tv_desc;
  69. }
  70. }

网格视图GridView

        网格视图GridView也是常见的列表类视图,它用于分行分列显示表格信息,比列表视图 更适合展示物品清单。除了沿用列表视图的3个方法setAdapter、setOnItemClickListener、 setOnItemLongClickListener,网格视图还新增了部分属性与方法,新属性与新方法

属性与方法

 拉伸模式

 拉伸模式效果

不显示分割线

拉伸模式为 NO_STRETCH 

拉伸列宽模式 COLUMN_WIDTH

拉伸模式为STRETCH_SPACING

拉伸模式为SPACING_UNIFORM

padding显示全部分隔线

 布局文件

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. android:orientation="vertical">
  6. <GridView
  7. android:id="@+id/gv_planet"
  8. android:layout_width="match_parent"
  9. android:layout_height="wrap_content"
  10. android:background="#00ffff"
  11. android:columnWidth="100dp"
  12. android:horizontalSpacing="2dp"
  13. android:numColumns="2"
  14. android:verticalSpacing="2dp" />
  15. </LinearLayout>

 样式布局文件

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:background="@color/white"
  6. android:orientation="vertical">
  7. <!-- 这是显示行星名称的文本视图 -->
  8. <TextView
  9. android:id="@+id/tv_name"
  10. android:layout_width="match_parent"
  11. android:layout_height="wrap_content"
  12. android:gravity="center"
  13. android:textColor="@color/black"
  14. android:textSize="20sp"
  15. tools:text="地球" />
  16. <!-- 这是显示行星图片的图像视图 -->
  17. <ImageView
  18. android:id="@+id/iv_icon"
  19. android:layout_width="match_parent"
  20. android:layout_height="100dp"
  21. android:scaleType="fitCenter"
  22. tools:src="@drawable/diqiu" />
  23. <!-- 这是显示行星描述的文本视图 -->
  24. <TextView
  25. android:id="@+id/tv_desc"
  26. android:layout_width="match_parent"
  27. android:layout_height="70dp"
  28. android:gravity="start|top"
  29. android:textColor="@color/black"
  30. android:textSize="13sp"
  31. tools:text="地球是太阳系八大行星之一,排行第三,也是太阳系中直径、质量和密度最大的类地行星,距离太阳1.5亿公里" />
  32. </LinearLayout>

 实体类

  1. package com.kcs.highcontrol.pojo;
  2. import com.kcs.highcontrol.R;
  3. import java.util.ArrayList;
  4. import java.util.List;
  5. public class Planet {
  6. /**
  7. * 行星图标
  8. */
  9. public int image;
  10. /**
  11. * 行星名称
  12. */
  13. public String name;
  14. /**
  15. * 行星描述
  16. */
  17. public String desc;
  18. public Planet(int image, String name, String desc) {
  19. this.image = image;
  20. this.name = name;
  21. this.desc = desc;
  22. }
  23. private static int[] iconArray = {R.drawable.shuixing, R.drawable.jinxing, R.drawable.diqiu,
  24. R.drawable.huoxing, R.drawable.muxing, R.drawable.tuxing};
  25. private static String[] nameArray = {"水星", "金星", "地球", "火星", "木星", "土星"};
  26. private static String[] descArray = {
  27. "水星是太阳系八大行星最内侧也是最小的一颗行星,也是离太阳最近的行星",
  28. "金星是太阳系八大行星之一,排行第二,距离太阳0.725天文单位",
  29. "地球是太阳系八大行星之一,排行第三,也是太阳系中直径、质量和密度最大的类地行星,距离太阳1.5亿公里",
  30. "火星是太阳系八大行星之一,排行第四,属于类地行星,直径约为地球的53%",
  31. "木星是太阳系八大行星中体积最大、自转最快的行星,排行第五。它的质量为太阳的千分之一,但为太阳系中其它七大行星质量总和的2.5倍",
  32. "土星为太阳系八大行星之一,排行第六,体积仅次于木星"
  33. };
  34. public static List<Planet> getDefaultList() {
  35. List<Planet> planetList = new ArrayList<Planet>();
  36. for (int i = 0; i < iconArray.length; i++) {
  37. planetList.add(new Planet(iconArray[i], nameArray[i], descArray[i]));
  38. }
  39. return planetList;
  40. }
  41. }

 适配器

  1. package com.kcs.highcontrol.adapter;
  2. import android.content.Context;
  3. import android.view.LayoutInflater;
  4. import android.view.View;
  5. import android.view.ViewGroup;
  6. import android.widget.BaseAdapter;
  7. import android.widget.ImageView;
  8. import android.widget.TextView;
  9. import com.kcs.highcontrol.R;
  10. import com.kcs.highcontrol.pojo.Planet;
  11. import java.util.List;
  12. public class PlanetGridAdapter extends BaseAdapter {
  13. private Context mContext;
  14. private List<Planet> mPlaneList;
  15. public PlanetGridAdapter(Context mContext, List<Planet> mPlaneList) {
  16. this.mContext = mContext;
  17. this.mPlaneList = mPlaneList;
  18. }
  19. /**
  20. * 获取列表项的个数
  21. */
  22. @Override
  23. public int getCount() {
  24. return mPlaneList.size();
  25. }
  26. @Override
  27. public Object getItem(int position) {
  28. return mPlaneList.get(position);
  29. }
  30. @Override
  31. public long getItemId(int position) {
  32. return position;
  33. }
  34. @Override
  35. public View getView(int position, View convertView, ViewGroup parent) {
  36. ViewHolder holder;
  37. if (convertView == null){
  38. // 根据布局文件item_list.xml生成转换视图对象
  39. convertView = LayoutInflater.from(mContext).inflate(R.layout.item_grid, null);
  40. holder = new ViewHolder();
  41. holder.iv_icon = convertView.findViewById(R.id.iv_icon);
  42. holder.tv_name = convertView.findViewById(R.id.tv_name);
  43. holder.tv_desc = convertView.findViewById(R.id.tv_desc);
  44. // 将视图持有者保存到转换视图当中
  45. convertView.setTag(holder);
  46. }else{
  47. holder = (ViewHolder) convertView.getTag();
  48. }
  49. // 给控制设置好数据
  50. Planet planet = mPlaneList.get(position);
  51. holder.iv_icon.setImageResource(planet.image);
  52. holder.tv_name.setText(planet.name);
  53. holder.tv_desc.setText(planet.desc);
  54. return convertView;
  55. }
  56. public final class ViewHolder {
  57. public ImageView iv_icon;
  58. public TextView tv_name;
  59. public TextView tv_desc;
  60. }
  61. }

主程序

  1. package com.kcs.highcontrol;
  2. import android.os.Bundle;
  3. import android.view.View;
  4. import android.widget.AdapterView;
  5. import android.widget.GridView;
  6. import androidx.appcompat.app.AppCompatActivity;
  7. import com.kcs.highcontrol.adapter.PlanetGridAdapter;
  8. import com.kcs.highcontrol.pojo.Planet;
  9. import com.kcs.highcontrol.utils.ToastUtil;
  10. import java.util.List;
  11. public class GridViewActivity extends AppCompatActivity implements AdapterView.OnItemClickListener {
  12. private GridView gv_planet;
  13. private List<Planet> planetList;
  14. @Override
  15. protected void onCreate(Bundle savedInstanceState) {
  16. super.onCreate(savedInstanceState);
  17. setContentView(R.layout.activity_grid_view);
  18. gv_planet = findViewById(R.id.gv_planet);
  19. planetList = Planet.getDefaultList();
  20. PlanetGridAdapter adapter = new PlanetGridAdapter(this, planetList);
  21. gv_planet.setAdapter(adapter);
  22. gv_planet.setOnItemClickListener(this);
  23. //设置拉伸
  24. gv_planet.setStretchMode(GridView.STRETCH_COLUMN_WIDTH);
  25. }
  26. @Override
  27. public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
  28. ToastUtil.show(this, "您选择了:" + planetList.get(position).name);
  29. }
  30. }

翻页视图

实现左右滑动的翻页功能,Android提供了相应的控件—翻页视图ViewPager。

        既然明确了翻页视图的原理类似列表视图和网格视图,它们的用法也很类似。例如,列表视图和网格视 图使用基本适配器BaseAdapter,翻页视图则使用翻页适配器PagerAdapter;列表视图和网格视图使用 列表项的点击监听器OnItemClickListener,翻页视图则使用页面变更监听器OnPageChangeListener监 听页面切换事件。

  • 翻页视图允许页面在水平方向左右滑动

翻页视图3个常用方法

  1. setAdapter:设置页面项的适配器。适配器用的是PagerAdapter及其子类。

  2. setCurrentItem:设置当前页码,也就是要显示哪个页面。

  3. addOnPageChangeListener:添加翻页视图的页面变更监听器。该监听器需实现接

    OnPageChangeListener下的3个方法,

  • onPageScrollStateChanged:在页面滑动状态变化时触发。 
  • onPageScrolled:在页面滑动过程中触发。 
  • onPageSelected:在选中页面时,即滑动结束后触发。

        翻页视图包含了多个页面项,翻页适配器展示每个页面。翻页适配器的实现原理与基本适配器类似,从PagerAdapter派生的翻页适配器主要实现下面6个方法

  1. 构造方法:指定适配器需要处理的数据集合。
  2. getCount:获取页面项的个数。
  3. isViewFromObject:判断当前视图是否来自指定对象,返回view == object即可。
  4. instantiateItem:实例化指定位置的页面,并将其添加到容器中。
  5. destroyItem:从容器中销毁指定位置的页面。
  6. getPageTitle:获得指定页面的标题文本,有搭配翻页标签栏时才要实现该方法。

演示运行效果

  ==》 ==》

布局文件

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

实体类

  1. package com.kcs.highcontrol.pojo;
  2. import com.kcs.highcontrol.R;
  3. import java.util.ArrayList;
  4. public class GoodsInfo {
  5. public int id;
  6. // 名称
  7. public String name;
  8. // 描述
  9. public String description;
  10. // 价格
  11. public float price;
  12. // 大图的保存路径
  13. public String picPath;
  14. // 大图的资源编号
  15. public int pic;
  16. // 声明一个手机商品的名称数组
  17. private static String[] mNameArray = {
  18. "iPhone11", "Mate30", "小米10", "OPPO Reno3", "vivo X30", "荣耀30S"
  19. };
  20. // 声明一个手机商品的描述数组
  21. private static String[] mDescArray = {
  22. "Apple iPhone11 256GB 绿色 4G全网通手机",
  23. "华为 HUAWEI Mate30 8GB+256GB 丹霞橙 5G全网通 全面屏手机",
  24. "小米 MI10 8GB+128GB 钛银黑 5G手机 游戏拍照手机",
  25. "OPPO Reno3 8GB+128GB 蓝色星夜 双模5G 拍照游戏智能手机",
  26. "vivo X30 8GB+128GB 绯云 5G全网通 美颜拍照手机",
  27. "荣耀30S 8GB+128GB 蝶羽红 5G芯片 自拍全面屏手机"
  28. };
  29. // 声明一个手机商品的价格数组
  30. private static float[] mPriceArray = {6299, 4999, 3999, 2999, 2998, 2399};
  31. // 声明一个手机商品的大图数组
  32. private static int[] mPicArray = {
  33. R.drawable.iphone, R.drawable.huawei, R.drawable.xiaomi,
  34. R.drawable.oppo, R.drawable.vivo, R.drawable.rongyao
  35. };
  36. // 获取默认的手机信息列表
  37. public static ArrayList<GoodsInfo> getDefaultList() {
  38. ArrayList<GoodsInfo> goodsList = new ArrayList<GoodsInfo>();
  39. for (int i = 0; i < mNameArray.length; i++) {
  40. GoodsInfo info = new GoodsInfo();
  41. info.id = i;
  42. info.name = mNameArray[i];
  43. info.description = mDescArray[i];
  44. info.price = mPriceArray[i];
  45. info.pic = mPicArray[i];
  46. goodsList.add(info);
  47. }
  48. return goodsList;
  49. }
  50. }

工具类

  1. import android.content.Context;
  2. import android.widget.Toast;
  3. public class ToastUtil {
  4. public static void show(Context ctx, String desc) {
  5. Toast.makeText(ctx, desc, Toast.LENGTH_SHORT).show();
  6. }
  7. }

适配器 PaperAdapter

  1. package com.kcs.highcontrol.adapter;
  2. import android.content.Context;
  3. import android.view.View;
  4. import android.view.ViewGroup;
  5. import android.widget.ImageView;
  6. import androidx.annotation.NonNull;
  7. import androidx.annotation.Nullable;
  8. import androidx.viewpager.widget.PagerAdapter;
  9. import com.kcs.highcontrol.pojo.GoodsInfo;
  10. import java.util.ArrayList;
  11. import java.util.List;
  12. public class ImagePagerAdapater extends PagerAdapter {
  13. private final Context mContext;
  14. private final ArrayList<GoodsInfo> mGoodsList;
  15. // 声明一个图像视图列表
  16. private List<ImageView> mViewList = new ArrayList<>();
  17. public ImagePagerAdapater(Context mContext, ArrayList<GoodsInfo> mGoodsList) {
  18. this.mContext = mContext;
  19. this.mGoodsList = mGoodsList;
  20. // 给每个商品分配一个专用的图像视图
  21. for (GoodsInfo info : mGoodsList) {
  22. ImageView view = new ImageView(mContext);
  23. //宽高
  24. view.setLayoutParams(new ViewGroup.LayoutParams(
  25. ViewGroup.LayoutParams.MATCH_PARENT,
  26. ViewGroup.LayoutParams.WRAP_CONTENT
  27. ));
  28. view.setImageResource(info.pic);
  29. mViewList.add(view);
  30. }
  31. }
  32. @Override
  33. public int getCount() {
  34. return mViewList.size();
  35. }
  36. @Override
  37. public boolean isViewFromObject(@NonNull View view, @NonNull Object object) {
  38. return view == object;
  39. }
  40. /**
  41. * 实例化指定位置的页面,并将其添加到容器中
  42. */
  43. @NonNull
  44. @Override
  45. public Object instantiateItem(@NonNull ViewGroup container, int position) {
  46. // 添加一个view到container中,而后返回一个跟这个view可以关联起来的对象,
  47. ImageView item = mViewList.get(position);
  48. // 这个对象能够是view自身,也能够是其余对象,
  49. // 关键是在isViewFromObject可以将view和这个object关联起来
  50. container.addView(item);
  51. return item;
  52. }
  53. /**
  54. * 从容器中销毁指定位置的页面
  55. * @param container
  56. * @param position
  57. * @param object
  58. */
  59. @Override
  60. public void destroyItem(@NonNull ViewGroup container, int position, @NonNull Object object) {
  61. container.removeView(mViewList.get(position));
  62. }
  63. @Nullable
  64. @Override
  65. public CharSequence getPageTitle(int position) {
  66. return mGoodsList.get(position).name;
  67. }
  68. }

主程序

  1. package com.kcs.highcontrol;
  2. import android.os.Bundle;
  3. import androidx.appcompat.app.AppCompatActivity;
  4. import androidx.viewpager.widget.ViewPager;
  5. import com.kcs.highcontrol.adapter.ImagePagerAdapater;
  6. import com.kcs.highcontrol.pojo.GoodsInfo;
  7. import com.kcs.highcontrol.utils.ToastUtil;
  8. import java.util.ArrayList;
  9. public class ViewPagerActivity extends AppCompatActivity implements ViewPager.OnPageChangeListener {
  10. private ArrayList<GoodsInfo> mGoodsList;
  11. @Override
  12. protected void onCreate(Bundle savedInstanceState) {
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.activity_view_pager);
  15. ViewPager vp_content = findViewById(R.id.vp_content);
  16. mGoodsList = GoodsInfo.getDefaultList();
  17. ImagePagerAdapater adapter = new ImagePagerAdapater(this, mGoodsList);
  18. vp_content.setAdapter(adapter);
  19. // 给翻页视图添加页面变更监听器
  20. vp_content.addOnPageChangeListener(this);
  21. }
  22. // 翻页状态改变时触发。state取值说明为:0表示静止,1表示正在滑动,2表示滑动完毕
  23. // 在翻页过程中,状态值变化依次为:正在滑动→滑动完毕→静止
  24. @Override
  25. public void onPageScrollStateChanged(int state) {
  26. }
  27. // 在翻页过程中触发。该方法的三个参数取值说明为 :第一个参数表示当前页面的序号
  28. // 第二个参数表示页面偏移的百分比,取值为0到1;第三个参数表示页面的偏移距离
  29. @Override
  30. public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
  31. }
  32. // 在翻页结束后触发。position表示当前滑到了哪一个页面
  33. @Override
  34. public void onPageSelected(int position) {
  35. ToastUtil.show(this, "您翻到的手机品牌是:" + mGoodsList.get(position).name);
  36. }
  37. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家自动化/article/detail/111505
推荐阅读
相关标签
  

闽ICP备14008679号