我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android常用控件Spinner的使用(详解)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android常用控件Spinner的使用(详解)

一、Spinner介绍

在Android开发过程中,Spinner下拉控件是比较常用的控件,它可以以下拉框和dialog的方式进行展示。默认是下拉框方式。

Spinner效果

在这里插入图片描述
上图可以看出实现Spinner的方式有两种:一、ArrayAdater 数组适配器 二、自定义适配器。

ArrayAdapter所需要的代码

1、布局界面activity_main.xml代码

在这里插入图片描述

2、MainActivity.java代码

在这里插入图片描述

3、spinner.item_1.xml代码

在这里插入图片描述

@BindView()代码解释

首先说明一下@BindView的作用,从字面意思可以看出这个意思是:绑定视图。他的作用等同于  spinner=findViewById(R.id.main_spinner);,需要使用的小伙伴可以在app目录下的bulid.grale中添加这二行代码。implementation 'com.jakewharton:butterknife:10.0.0'annotationProcessor 'com.jakewharton:butterknife-compiler:10.0.0'`然后在MainAcitivty.java的Oncreate方法里面添加       ButterKnife.bind(this);

下面是bind的两个参数

 public static Unbinder bind(@NonNull Object target, @NonNull View source) {} //Obejct:默认填this //source:这里需要加入View,在自定义适配器中有用到
    class ViewHolder {        @BindView(R.id.spinner_item_2_imageView)        ImageView imageView2;        @BindView(R.id.spinner_item_2_name)        TextView name2;        public ViewHolder(View view) {            ButterKnife.bind(this, view);        }    }}

ArrayAdapter代码解析

在这里插入图片描述

String:在这里不一定是String,也可以是int ,float,double等等,根据你数据的类型判断这里改填什么
getBaseContext:这里需要传入Context的对象,直接getBaseContext或者getContext都可以。
R.layout.spinner.item_1:这里需要传入一个布局,直接new Layout Resouce File就可以了。
data:数据源

ArrayAdapter数组适配器 也就介绍完了,看起来还是很简单,接下来,我们需要实现图片+文字的方式出现,需要使用到自定义适配器了。

自定义适配器所需要的代码

1、activity.main.xml布局

    <Spinner        android:id="@+id/main_spinner2"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_marginTop="5dp"        android:spinnerMode="dropdown"        />        //android:spinnerMode="dropdown"         dialog方式展示

2、spinner.item_2.xml代码

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent"    android:layout_height="wrap_content"    android:orientation="horizontal">    <ImageView        android:id="@+id/spinner_item_2_imageView"        android:layout_width="match_parent"        android:layout_height="80dp"        android:layout_weight="1"        android:class="lazy" data-src="@drawable/ic_launcher_background" />    <TextView        android:id="@+id/spinner_item_2_name"        android:layout_width="match_parent"        android:layout_height="wrap_content"        android:layout_gravity="center"        android:layout_weight="1"        android:gravity="center"        android:text="下拉框1"/></LinearLayout>//由于TextView和ImageView在同一个LinearLayout中,我们将布局平分两部分//在View中分别添加android:layout_weight="1"

3、SpinnerBean.java代码

public class SpinnerBean {    int ImageView;    String name;    public int getImageView() {        return ImageView;    }    public void setImageView(int imageView) {        ImageView = imageView;    }    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public SpinnerBean(int imageView, String name) {        ImageView = imageView;        this.name = name;    }}

4、SpinnerAdapter.java

public class SpinnerAdapter extends BaseAdapter {    Context context;    List<SpinnerBean> mDatas;    public SpinnerAdapter(Context context, List<SpinnerBean> mDatas) {        this.context = context;        this.mDatas = mDatas;    }    @Override    public int getCount() {        return mDatas.size();    }    @Override    public Object getItem(int position) {        return mDatas.get(position);    }    @Override    public long getItemId(int position) {        return position;    }    @Override    public View getView(int posiiton, View convertView, ViewGroup parent) {        ViewHolder holder = null;        if (convertView == null) {            convertView = LayoutInflater.from(context).inflate(R.layout.spinner_item_2, null);            holder = new ViewHolder(convertView);            convertView.setTag(holder);        } else {            holder = (ViewHolder) convertView.getTag();        }        holder.imageView2.setImageResource(mDatas.get(posiiton).getImageView());        holder.name2.setText(mDatas.get(posiiton).getName());        return convertView;    }    class ViewHolder {        @BindView(R.id.spinner_item_2_imageView)        ImageView imageView2;        @BindView(R.id.spinner_item_2_name)        TextView name2;        public ViewHolder(View view) {            ButterKnife.bind(this, view);        }    }}

MainActivty.java代码

    List<SpinnerBean> customData;    private void initSpinner2() {        customData = new ArrayList<>();        SpinnerBean spinnerBean = new SpinnerBean(R.drawable.ic_launcher_background, "下拉框1");        SpinnerBean spinnerBean2 = new SpinnerBean(R.mipmap.ic_launcher_round, "下拉框2");        SpinnerBean spinnerBean3 = new SpinnerBean(R.drawable.ic_launcher_background, "下拉框3");        SpinnerBean spinnerBean4 = new SpinnerBean(R.mipmap.ic_launcher_round, "下拉框4");        SpinnerBean spinnerBean5 = new SpinnerBean(R.drawable.ic_launcher_background, "下拉框5");        SpinnerBean spinnerBean6 = new SpinnerBean(R.mipmap.ic_launcher_round, "下拉框6");        SpinnerBean spinnerBean7 = new SpinnerBean(R.drawable.ic_launcher_background, "下拉框7");        SpinnerBean spinnerBean8 = new SpinnerBean(R.mipmap.ic_launcher_round, "下拉框8");        SpinnerBean spinnerBean9 = new SpinnerBean(R.drawable.ic_launcher_background, "下拉框9");        customData.add(spinnerBean);        customData.add(spinnerBean2);        customData.add(spinnerBean3);        customData.add(spinnerBean4);        customData.add(spinnerBean5);        customData.add(spinnerBean6);        customData.add(spinnerBean7);        customData.add(spinnerBean8);        customData.add(spinnerBean9);        SpinnerAdapter spinnerAdapter = new SpinnerAdapter(getBaseContext(), customData);        spinner2.setAdapter(spinnerAdapter);    }

自定义适配器代码解析

首先介绍一下为什么需要创建SpinnerBean,java和spinner.item_2.xml。使用Android已有的适配器只能指定一个数据类型,无法加载由多个(String、int)组成的Bean,这些就使用到Java中的泛型

List泛型的作用:可以动态的添加索引序列。其中SpinnerBean.java就给我们展示如何定义一个泛型。

    int ImageView;    String name;       public SpinnerBean(int imageView, String name) {        ImageView = imageView;        this.name = name;    }    //按住alt+int键        快速构建get、set和构造方法    //创建好之后,在MainAcitivty中new List就可以添加数据了

SpinnerAdapter自定义适配器

自定义适配器中有四种方法:getCount(),getItem(),getItemId(),getView()
getCount():获取数据的总条数
getItem():获取索引值所对应的对象
getItemId():获取索引值所对应的对象名称
getView():获取界面

前三个比较容易理解,说一下第四个getView()
在这里插入图片描述

position:表示位置
convertView:这里是自定义适配器优化的一个方面,可以对一个View进行缓存,只需要改变数据即可,不用创建getCount()个View。
parent:…

convertView内存优化的代码

        ViewHolder holder = null;        if (convertView == null) {//convertView暂时还没有布局        //将需要展示的layout赋值给convertView,方便使用            convertView = LayoutInflater.from(context).inflate(R.layout.spinner_item_2, null);            //将带有convertView的ViewHolder赋值给holder            holder = new ViewHolder(convertView);            //设置View            convertView.setTag(holder);        } else {            holder = (ViewHolder) convertView.getTag();        }

来源地址:https://blog.csdn.net/qq_62079241/article/details/129719066

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android常用控件Spinner的使用(详解)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android中Spinner(下拉框)控件的使用详解

android给我们提供了一个spinner控件,这个控件主要就是一个列表,那么我们就来说说这个控件吧,这个控件在以前的也看见过,但今天还是从新介绍一遍吧。 Spinner位于 android.widget包下,每次只显示用户选中的元素,当
2022-06-06

Android之Spinner使用详解

Spinner是Android中常用的控件之一,用于显示一个下拉列表,用户可以从中选择一个选项。以下是关于Spinner的使用详解:1. 在布局文件中定义Spinner控件:```xmlandroid:id="@+id/spinner"an
2023-09-09

Android常见控件使用详解

本文实例为大家分享了六种Android常见控件的使用方法,供大家参考,具体内容如下 1、TextView 主要用于界面上显示一段文本信息 2、Button 用于和用户交互的一个按钮控件//为Button点击事件注册一个监听器 public
2022-06-06

怎么在Android中使用Spinner控件

今天就跟大家聊聊有关怎么在Android中使用Spinner控件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。一、使用方法1、在layout中创建Spinner控件
2023-05-30

Android控件Spinner的用法是什么

Spinner是Android平台上的一种下拉列表控件,用于显示可选项列表,并允许用户从中选择一个选项。使用Spinner的步骤如下:在布局文件中添加Spinner控件:在代码中获取Spinner的实例:Spinner spinner =
2023-10-22

android应用开发之spinner控件的简单使用

Android的控件有很多种,其中就有一个Spinner的控件,这个控件其实就是一个下拉显示列表。Spinner是位于 android.widget包下的,每次只显示用户选中的元素,当用户再次点击时,会弹出选择列表供用户选择,而选择列表中
2022-06-06

Android最常用的控件ListView(详解)

ListView是Android开发中最常用的控件之一,用于显示一个可滚动的列表,其中每个列表项都是可以点击的。ListView的使用非常广泛,可以用于展示任意类型的数据,比如文本、图片、复杂的自定义视图等。ListView的基本结构是由一
2023-09-09

Android控件Spinner的作用有哪些

Android控件Spinner的作用主要有以下几点:提供下拉选择功能:Spinner控件可以通过下拉列表的形式显示多个选项,用户可以通过点击选择其中一个选项。显示数据集合:Spinner可以将一个数据集合显示在下拉列表中,用户可以从中选择
2023-10-24

如何在Android中使用Spinner下拉菜单控件

这期内容当中小编将会给大家带来有关如何在Android中使用Spinner下拉菜单控件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。activity_main.xml
2023-05-30

android studio 的下拉菜单Spinner使用详解

一、认识Spinner Spinner其实就是一个列表选择框。不过Android的列表选择框并不需要显示下拉列表,而是相当于弹出一个菜单供用户选择。 Spinner 与 Gallery 都继承了AbsSpinner,AbsSpinner 继
2022-06-06

Android控件之Spinner用法实例分析

本文实例讲述了Android控件之Spinner用法。分享给大家供大家参考。具体如下: 以下模拟下拉列表的用法 布局文件:
2022-06-06

Android中如何使用Spinner组件

今天就跟大家聊聊有关Android中如何使用Spinner组件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Android Spinner 组件Spinner: 下拉组件使用事项:布
2023-05-30

Android控件AppWidgetProvider使用方法详解

介绍AppWidgetProvider是Android中提供的用于实现桌面小工具的类,其本质是一个广播,即BroadcastReceiver,在实际的使用中,把AppWidgetProvider当成一个BroadcastReceiver即可
2023-05-30

Android评分RationBar控件使用详解

Android评分RationBar控件,供大家参考,具体内容如下主要是不想用太多三方的控件,所以决定尽可能自己写,最近有写一个评分的页面,废话不多说直接上图我觉得嘛 这个东西用ViewGroup包起来感觉会写很多View 于是我决定使用之
2022-06-06

Android列表选择框Spinner使用方法详解

安卓提供的列表选择框(Spinner)相当于web端用户注册时的选择下拉框,比如注册候选择省份城市等。如下图便是一个列表选择框下拉列表的列表选择项能够通过xml文件的android:entries属性指定,或是在java代码中导入,属性an
2022-06-06

Android Spinner 下拉菜单的使用

Android 中下拉菜单,即如html中的