• 7、android高级控件(2)(列表类视图)


    1、基本适配器BaseAdapter

    Android提供了一种适应性更强的基本适配器BaseAdapter,它允许开发者在别的代码文件中进行逻辑处理。 从BaseAdapter派生的数据适配器主要实现下面5个方法。

    构造函数:指定适配器需要处理的数据集合。

    getCount:获取数据项的个数。

    getItem:获取列表项的数据。

    getItemId:获取列表项的编号。

    getView:获取每项的展示视图,并操纵每项的内部控件。

    基本适配器的实现步骤:

    (1)编写列表项的布局文件item_list.xml。

    (2)写个新的适配器继承BaseAdapter,实现对列表项的管理操作。需要编写适配器的三个方法:

    1)创建构造方法,传入列表项需要的数据列表。

    1)重写getCount方法,返回列表项的个数。

    2)重写getView方法,根据item_list.xml里面的布局,返回指定位置的列表项的视图内容。(3)在页面代码中创建该适配器实例,并交给下拉框设置适配器。

    1. package com.example.chapter05.Bean;
    2. import com.example.chapter05.R;
    3. import java.util.ArrayList;
    4. import java.util.List;
    5. public class Planet {
    6. public int image; // 行星图标
    7. public String name; // 行星名称
    8. public String desc; // 行星描述
    9. public Planet(int image, String name, String desc) {
    10. this.image = image;
    11. this.name = name;
    12. this.desc = desc;
    13. }
    14. private static int[] iconArray = {R.drawable.shuixing, R.drawable.jinxing, R.drawable.diqiu,
    15. R.drawable.huoxing, R.drawable.muxing, R.drawable.tuxing};
    16. private static String[] nameArray = {"水星", "金星", "地球", "火星", "木星", "土星"};
    17. private static String[] descArray = {
    18. "水星是太阳系八大行星最内侧也是最小的一颗行星,也是离太阳最近的行星",
    19. "金星是太阳系八大行星之一,排行第二,距离太阳0.725天文单位",
    20. "地球是太阳系八大行星之一,排行第三,也是太阳系中直径、质量和密度最大的类地行星,距离太阳1.5亿公里",
    21. "火星是太阳系八大行星之一,排行第四,属于类地行星,直径约为地球的53%",
    22. "木星是太阳系八大行星中体积最大、自转最快的行星,排行第五。它的质量为太阳的千分之一,但为太阳系中其它七大行星质量总和的2.5倍",
    23. "土星为太阳系八大行星之一,排行第六,体积仅次于木星"
    24. };
    25. public static List getDefaultList() {
    26. List planetList = new ArrayList();
    27. for (int i = 0; i < iconArray.length; i++) {
    28. planetList.add(new Planet(iconArray[i], nameArray[i], descArray[i]));
    29. }
    30. return planetList;
    31. }
    32. }
    1. package com.example.chapter05;
    2. import android.os.Bundle;
    3. import android.view.View;
    4. import android.widget.AdapterView;
    5. import android.widget.AdapterView.OnItemSelectedListener;
    6. import android.widget.Spinner;
    7. import android.widget.Toast;
    8. import androidx.appcompat.app.AppCompatActivity;
    9. import com.example.chapter05.Adapt.PlanetBaseAdapter;
    10. import com.example.chapter05.Bean.Planet;
    11. import java.util.List;
    12. public class BaseAdapterActivity extends AppCompatActivity {
    13. private List planetList; // 声明一个行星列表
    14. @Override
    15. protected void onCreate(Bundle savedInstanceState) {
    16. super.onCreate(savedInstanceState);
    17. setContentView(R.layout.activity_base_adapter);
    18. initPlanetSpinner(); // 初始化行星列表的下拉框
    19. }
    20. // 初始化行星列表的下拉框
    21. private void initPlanetSpinner() {
    22. // 获取默认的行星列表,即水星、金星、地球、火星、木星、土星
    23. planetList = Planet.getDefaultList();
    24. // 构建一个行星列表的适配器
    25. PlanetBaseAdapter adapter = new PlanetBaseAdapter(this, planetList);
    26. // 从布局文件中获取名叫sp_planet的下拉框
    27. Spinner sp_planet = findViewById(R.id.sp_planet);
    28. sp_planet.setPrompt("请选择行星"); // 设置下拉框的标题
    29. sp_planet.setAdapter(adapter); // 设置下拉框的列表适配器
    30. sp_planet.setSelection(0); // 设置下拉框默认显示第一项
    31. // 给下拉框设置选择监听器,一旦用户选中某一项,就触发监听器的onItemSelected方法
    32. sp_planet.setOnItemSelectedListener(new MySelectedListener());
    33. }
    34. // 定义一个选择监听器,它实现了接口OnItemSelectedListener
    35. private class MySelectedListener implements OnItemSelectedListener {
    36. // 选择事件的处理方法,其中arg2代表选择项的序号
    37. public void onItemSelected(AdapterView arg0, View arg1, int arg2, long arg3) {
    38. Toast.makeText(BaseAdapterActivity.this, "您选择的是" + planetList.get(arg2).name, Toast.LENGTH_LONG).show();
    39. }
    40. // 未选择时的处理方法,通常无需关注
    41. public void onNothingSelected(AdapterView arg0) {}
    42. }
    43. }
    1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    2. android:layout_width="match_parent"
    3. android:layout_height="wrap_content"
    4. android:orientation="horizontal">
    5. <ImageView
    6. android:id="@+id/iv_icon"
    7. android:layout_width="0dp"
    8. android:layout_height="80dp"
    9. android:layout_weight="1"
    10. android:scaleType="fitCenter" />
    11. <LinearLayout
    12. android:layout_width="0dp"
    13. android:layout_height="match_parent"
    14. android:layout_weight="3"
    15. android:layout_marginLeft="5dp"
    16. android:orientation="vertical">
    17. <TextView
    18. android:id="@+id/tv_name"
    19. android:layout_width="match_parent"
    20. android:layout_height="0dp"
    21. android:layout_weight="1"
    22. android:gravity="left|center"
    23. android:textColor="@color/black"
    24. android:textSize="20sp" />
    25. <TextView
    26. android:id="@+id/tv_desc"
    27. android:layout_width="match_parent"
    28. android:layout_height="0dp"
    29. android:layout_weight="2"
    30. android:gravity="left|center"
    31. android:textColor="@color/black"
    32. android:textSize="13sp" />
    33. LinearLayout>
    34. LinearLayout>

    QQ录屏20221105164251

    2、列表视图ListView

    列表视图允许在页面上分行展示相似的数据列表,例如新闻列表、商品列表、书籍列表等,方便用户浏览与操作。 ListView与Spinner在编码上的异同点:

    (1)相同点:二者都调用setAdapter方法设置列表项的数据适配器,都可以使用基本适配器。 (2)不同点:Spinner通过setOnItemSelectedListener方法设置列表项的选中监听器;而ListView通过setOnItemClickListener设置列表项的点击监听器,通过setOnItemLongClickListener方法设置列表项的长按监听器。

    1. package com.example.chapter05;
    2. import androidx.appcompat.app.AppCompatActivity;
    3. import android.annotation.SuppressLint;
    4. import android.graphics.Color;
    5. import android.graphics.drawable.Drawable;
    6. import android.os.Bundle;
    7. import android.view.View;
    8. import android.widget.AdapterView;
    9. import android.widget.CheckBox;
    10. import android.widget.CompoundButton;
    11. import android.widget.ListView;
    12. import android.widget.Toast;
    13. import com.example.chapter05.Adapt.PlanetBaseAdapter;
    14. import com.example.chapter05.Bean.Planet;
    15. import com.example.chapter05.util.Utils;
    16. import java.util.List;
    17. public class ListViewActivity extends AppCompatActivity implements AdapterView.OnItemSelectedListener, CompoundButton.OnCheckedChangeListener {
    18. private final static String TAG = "ListViewActivity";
    19. private CheckBox ck_divider;
    20. private CheckBox ck_selector;
    21. private ListView lv_planet; // 声明一个列表视图对象
    22. List planetList = Planet.getDefaultList();
    23. @Override
    24. protected void onCreate(Bundle savedInstanceState) {
    25. super.onCreate(savedInstanceState);
    26. setContentView(R.layout.activity_list_view);
    27. lv_planet=findViewById(R.id.lv_planet);
    28. ck_divider=findViewById(R.id.ck_divider);
    29. ck_selector=findViewById(R.id.ck_selector);
    30. ck_selector.setOnCheckedChangeListener(this);
    31. ck_divider.setOnCheckedChangeListener(this);
    32. List planetList=Planet.getDefaultList();
    33. PlanetBaseAdapter adapter=new PlanetBaseAdapter(this,planetList);
    34. lv_planet.setAdapter(adapter);
    35. lv_planet.setOnItemSelectedListener(this);
    36. }
    37. @Override
    38. public void onItemSelected(AdapterView adapterView, View view, int i, long l) {
    39. }
    40. @Override
    41. public void onNothingSelected(AdapterView adapterView) {
    42. }
    43. @Override
    44. public void onCheckedChanged(CompoundButton compoundButton, boolean b) {
    45. refleshListView();
    46. }
    47. //刷新试图列表
    48. @SuppressLint("ResourceType")
    49. private void refleshListView(){
    50. lv_planet.setCacheColorHint(Color.TRANSPARENT);//防止滚动时列表拉黑
    51. if (ck_divider.isChecked()){//显示分割线
    52. Drawable drawable=getResources().getDrawable(R.color.purple_200);
    53. lv_planet.setDivider(drawable); // 设置列表视图的分隔线
    54. lv_planet.setDividerHeight(Utils.dip2px(this, 5)); // 设置列表视图的分隔线高度
    55. }
    56. else {//不显示分割线
    57. lv_planet.setDivider(null); // 设置列表视图的分隔线
    58. lv_planet.setDividerHeight(0); // 设置列表视图的分隔线高度
    59. }
    60. if (ck_selector.isChecked()) { // 显示按压背景
    61. lv_planet.setSelector(R.drawable.list_selector); // 设置列表项的按压状态图形
    62. } else { // 不显示按压背景
    63. //lv_planet.setSelector(null); // 直接设置null会报错,因为运行时报空指针异常
    64. // 从资源文件获得图形对象
    65. Drawable drawable = getResources().getDrawable(R.color.purple_200);
    66. lv_planet.setSelector(drawable); // 设置列表项的按压状态图形
    67. }
    68. }
    69. }
    1. "1.0" encoding="utf-8"?>
    2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
    3. <item android:state_pressed="true" android:drawable="@color/black"/>
    4. <item android:drawable="@color/purple_700"/>
    5. selector>
    1. "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. android:background="@color/white">
    7. <LinearLayout
    8. android:layout_width="match_parent"
    9. android:layout_height="40dp">
    10. <CheckBox
    11. android:id="@+id/ck_divider"
    12. android:layout_width="0dp"
    13. android:layout_height="match_parent"
    14. android:layout_weight="1"
    15. android:gravity="left|center"
    16. android:text="显示分隔线"
    17. android:textColor="@color/black"
    18. android:textSize="17sp" />
    19. <CheckBox
    20. android:id="@+id/ck_selector"
    21. android:layout_width="0dp"
    22. android:layout_height="match_parent"
    23. android:layout_weight="1"
    24. android:gravity="left|center"
    25. android:text="显示按压背景"
    26. android:textColor="@color/black"
    27. android:textSize="17sp" />
    28. LinearLayout>
    29. <ListView
    30. android:id="@+id/lv_planet"
    31. android:layout_width="match_parent"
    32. android:layout_height="wrap_content"
    33. android:divider="@color/black"
    34. android:dividerHeight="20dp"
    35. android:background="@null"
    36. android:listSelector="#880088"
    37. />
    38. LinearLayout>

     3、网格视图GridView

     

     

    1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    2. android:layout_width="match_parent"
    3. android:layout_height="match_parent"
    4. android:orientation="vertical"
    5. android:padding="5dp">
    6. <LinearLayout
    7. android:layout_width="match_parent"
    8. android:layout_height="40dp">
    9. <TextView
    10. android:layout_width="wrap_content"
    11. android:layout_height="match_parent"
    12. android:gravity="center"
    13. android:text="拉伸模式:"
    14. android:textColor="@color/black"
    15. android:textSize="17sp" />
    16. <Spinner
    17. android:id="@+id/sp_stretch"
    18. android:layout_width="0dp"
    19. android:layout_height="match_parent"
    20. android:layout_weight="1"
    21. android:gravity="left|center"
    22. android:spinnerMode="dialog" />
    23. LinearLayout>
    24. <GridView
    25. android:id="@+id/gv_planet"
    26. android:layout_width="match_parent"
    27. android:layout_height="wrap_content"
    28. android:background="#00ffff"
    29. android:horizontalSpacing="3dp"
    30. android:verticalSpacing="3dp"
    31. android:numColumns="2"
    32. android:stretchMode="columnWidth" />
    33. LinearLayout>
    1. package com.example.chapter05.Adapt;
    2. import android.content.Context;
    3. import android.view.LayoutInflater;
    4. import android.view.View;
    5. import android.view.ViewGroup;
    6. import android.widget.Adapter;
    7. import android.widget.AdapterView;
    8. import android.widget.BaseAdapter;
    9. import android.widget.ImageView;
    10. import android.widget.TextView;
    11. import android.widget.Toast;
    12. import com.example.chapter05.Bean.Planet;
    13. import com.example.chapter05.R;
    14. import java.util.List;
    15. public class PlanetGridAdapter extends BaseAdapter implements AdapterView.OnItemClickListener, AdapterView.OnItemLongClickListener{
    16. private Context mContext;//上下文对象
    17. private List mPlanetList;//声明行星信息列表
    18. public PlanetGridAdapter(Context mContext, List mPlanetList) {
    19. this.mContext = mContext;
    20. this.mPlanetList = mPlanetList;
    21. }
    22. @Override
    23. public int getCount() {
    24. return mPlanetList.size();
    25. }
    26. @Override
    27. public Object getItem(int i) {
    28. return mPlanetList.get(i);
    29. }
    30. @Override
    31. public long getItemId(int i) {
    32. return i;
    33. }
    34. @Override
    35. public View getView(int i, View view, ViewGroup viewGroup) {
    36. ViewHolder viewHolder;
    37. if (view==null){
    38. viewHolder=new ViewHolder();//构建一个视图持有者
    39. //根据布局文件生成转换视图象
    40. view= LayoutInflater.from(mContext).inflate(R.layout.item_grid,null);
    41. viewHolder.iv_icon=view.findViewById(R.id.iv_icon);
    42. viewHolder.tv_desc=view.findViewById(R.id.tv_desc);
    43. viewHolder.tv_name=view.findViewById(R.id.tv_name);
    44. view.setTag(viewHolder);
    45. }
    46. else {
    47. viewHolder= (ViewHolder) view.getTag();
    48. }
    49. Planet planet=mPlanetList.get(i);
    50. viewHolder.iv_icon.setImageResource(planet.image); // 显示行星的图片
    51. viewHolder.tv_name.setText(planet.name); // 显示行星的名称
    52. viewHolder.tv_desc.setText(planet.desc); // 显示行星的描述
    53. return view;
    54. }
    55. //定义一个视图持有者
    56. public final class ViewHolder {
    57. public ImageView iv_icon; // 声明行星图片的图像视图对象
    58. public TextView tv_name; // 声明行星名称的文本视图对象
    59. public TextView tv_desc; // 声明行星描述的文本视图对象
    60. }
    61. @Override
    62. public void onItemClick(AdapterView adapterView, View view, int i, long l) {
    63. String desc = String.format("您点击了第%d个行星,它的名字是%s", i + 1,
    64. mPlanetList.get(i).name);
    65. Toast.makeText(mContext, desc, Toast.LENGTH_LONG).show();
    66. }
    67. @Override
    68. public boolean onItemLongClick(AdapterView adapterView, View view, int i, long l) {
    69. String desc = String.format("您长按了第%d个行星,它的名字是%s", i + 1,
    70. mPlanetList.get(i).name);
    71. Toast.makeText(mContext, desc, Toast.LENGTH_LONG).show();
    72. return true;
    73. }
    74. }
    1. package com.example.chapter05;
    2. import android.graphics.Color;
    3. import android.os.Bundle;
    4. import android.view.View;
    5. import android.widget.AdapterView;
    6. import android.widget.ArrayAdapter;
    7. import android.widget.GridView;
    8. import android.widget.Spinner;
    9. import androidx.annotation.Nullable;
    10. import androidx.appcompat.app.AppCompatActivity;
    11. import com.example.chapter05.Adapt.PlanetGridAdapter;
    12. import com.example.chapter05.Bean.Planet;
    13. import com.example.chapter05.util.Utils;
    14. import java.util.List;
    15. public class GridViewActivity extends AppCompatActivity {
    16. private GridView gv_planet; // 声明一个网格视图对象
    17. private Object DivideSelectListener;
    18. @Override
    19. protected void onCreate(@Nullable Bundle savedInstanceState) {
    20. super.onCreate(savedInstanceState);
    21. setContentView(R.layout.activity_grid_view);
    22. List planetList=Planet.getDefaultList();
    23. //构建一个行星列表的网格适配器
    24. PlanetGridAdapter planetGridAdapter=new PlanetGridAdapter(this,planetList);
    25. //从布局视图中获取名叫gv_planet的网格视图
    26. gv_planet=findViewById(R.id.gv_planet);
    27. gv_planet.setAdapter(planetGridAdapter);//设置网格视图的适配器
    28. gv_planet.setOnItemClickListener(planetGridAdapter);
    29. gv_planet.setOnItemLongClickListener(planetGridAdapter);
    30. gv_planet.setOnItemClickListener(planetGridAdapter);
    31. initDividerSpinner();
    32. }
    33. private String[] dividerArray = {
    34. "不显示分隔线",
    35. "不拉伸(NO_STRETCH)",
    36. "拉伸列宽(COLUMN_WIDTH)",
    37. "列间空隙(STRETCH_SPACING)",
    38. "左右空隙(SPACING_UNIFORM)",
    39. "使用padding显示全部分隔线"};
    40. //初始化拉伸模式的下拉框
    41. private void initDividerSpinner(){
    42. ArrayAdapter divideAdapter=new ArrayAdapter(this,R.layout.item_select,dividerArray);
    43. Spinner sp_stretch=findViewById(R.id.sp_stretch);
    44. sp_stretch.setPrompt("设置拉伸模式");//设置下拉框标婷
    45. sp_stretch.setSelection(0);
    46. sp_stretch.setAdapter(divideAdapter);
    47. sp_stretch.setOnItemSelectedListener(new DivideSelectListener());
    48. }
    49. class DivideSelectListener implements AdapterView.OnItemSelectedListener{
    50. @Override
    51. public void onItemSelected(AdapterView adapterView, View view, int arg2, long l) {
    52. int dividerPad = Utils.dip2px(GridViewActivity.this, 2); // 定义间隔宽度为2dp
    53. gv_planet.setBackgroundColor(Color.CYAN); // 设置背景颜色
    54. gv_planet.setHorizontalSpacing(dividerPad); // 设置列表项在水平方向的间距
    55. gv_planet.setVerticalSpacing(dividerPad); // 设置列表项在垂直方向的间距
    56. gv_planet.setStretchMode(GridView.STRETCH_COLUMN_WIDTH);//是自己拉伸模式
    57. gv_planet.setColumnWidth(Utils.dip2px(GridViewActivity.this, 120));//设置每列宽度120dp
    58. gv_planet.setPadding(1,1,1,1);//设置网格视图的四周边距
    59. if (arg2 == 0) { // 不显示分隔线
    60. gv_planet.setBackgroundColor(Color.WHITE);
    61. gv_planet.setHorizontalSpacing(0);
    62. gv_planet.setVerticalSpacing(0);
    63. } else if (arg2 == 1) { // 不拉伸(NO_STRETCH)
    64. gv_planet.setStretchMode(GridView.NO_STRETCH);
    65. } else if (arg2 == 2) { // 拉伸列宽(COLUMN_WIDTH)
    66. gv_planet.setStretchMode(GridView.STRETCH_COLUMN_WIDTH);
    67. } else if (arg2 == 3) { // 列间空隙(STRETCH_SPACING)
    68. gv_planet.setStretchMode(GridView.STRETCH_SPACING);
    69. } else if (arg2 == 4) { // 左右空隙(SPACING_UNIFORM)
    70. gv_planet.setStretchMode(GridView.STRETCH_SPACING_UNIFORM);
    71. } else if (arg2 == 5) { // 使用padding显示全部分隔线
    72. gv_planet.setPadding(dividerPad, dividerPad, dividerPad, dividerPad);
    73. }
    74. }
    75. @Override
    76. public void onNothingSelected(AdapterView adapterView) {
    77. }
    78. }
    79. }

     

     

     

     

     

     

  • 相关阅读:
    【matplotlib基础】--绘图配置
    【RocketMQ】发送事务消息
    SQL基础
    deepstream6.2部署yolov5详细教程与代码解读
    [附源码]计算机毕业设计JAVA小区物业管理系统论文
    蓝盆花:神秘而迷人的自然之美
    Vis.js教程(一):基础教程
    Netty源码编译
    【四】redis持久化(RDB与AOF)
    Python函数:chr()和ord()
  • 原文地址:https://blog.csdn.net/weixin_62190821/article/details/127463094