Android 简单的下拉选择框实现

要实现这种效果,目前知道的方法有以下两种,Spinner 和  ListPopupWindow,当然肯定还有很多别的方法,这里我们先尝试使用ListPopupWindow来实现这个效果;

以下是一个简单的demo:



public class MainActivity extends AppCompatActivity {

    private List<String> dataList;
    private ListPopupWindow listPopupWindow;
    private Button showPopupButton;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 初始化数据
        initData();

        // 初始化 ListPopupWindow
        listPopupWindow = new ListPopupWindow(this);
        ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, dataList);
        listPopupWindow.setAdapter(adapter);
        listPopupWindow.setAnchorView(showPopupButton); // 设置锚点

        // 设置列表项点击监听器
        listPopupWindow.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                String selectedItem = dataList.get(position);
                Toast.makeText(MainActivity.this, "Selected: " + selectedItem, Toast.LENGTH_SHORT).show();
                listPopupWindow.dismiss(); // 点击后隐藏 ListPopupWindow
            }
        });

        // 初始化显示下拉选择框的按钮
        showPopupButton = findViewById(R.id.show_popup_button);
        showPopupButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                listPopupWindow.show(); // 点击按钮显示 ListPopupWindow
            }
        });
    }

    private void initData() {
        // 模拟数据
        dataList = new ArrayList<>();
        dataList.add("Option 1");
        dataList.add("Option 2");
        dataList.add("Option 3");
        // 添加更多选项...
    }
}

在这个示例中,我们创建了一个包含几个选项的数据列表 dataList,然后使用 ArrayAdapter 将它们设置到 ListPopupWindow 中。接着,我们为 ListPopupWindow 设置了一个按钮作为锚点,并设置了按钮的点击监听器,在点击按钮时显示 ListPopupWindow。最后,我们为 ListPopupWindow 设置了一个列表项点击监听器,在用户点击列表项时处理相应的逻辑,并隐藏 ListPopupWindow

确保您的布局文件中包含一个按钮控件(Button),用于触发显示 ListPopupWindow 的操作。

以上只是一个简单的demo,我们可能会遇到一些新的需求,如下

如果已经选中了某个选项,并且更新了按钮的文本为选中的选项内容,当再次点击按钮显示下拉选择框时,您可以让下拉框中的列表项与按钮内容匹配,并将匹配项显示为选中状态。

下面是一种实现方式:



public class MainActivity extends AppCompatActivity {

    private List<String> dataList;
    private ListPopupWindow listPopupWindow;
    private Button showPopupButton;
    private String selectedItem;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 初始化数据
        initData();

        // 初始化 ListPopupWindow
        listPopupWindow = new ListPopupWindow(this);
        ArrayAdapter<String> adapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, dataList);
        listPopupWindow.setAdapter(adapter);
        listPopupWindow.setAnchorView(showPopupButton); // 设置锚点

        // 设置列表项点击监听器
        listPopupWindow.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                selectedItem = dataList.get(position);
                showPopupButton.setText(selectedItem); // 更新按钮文本为选中的选项内容
                Toast.makeText(MainActivity.this, "Selected: " + selectedItem, Toast.LENGTH_SHORT).show();
                adapter.notifyDataSetChanged(); // 刷新适配器以更新选中状态
                listPopupWindow.dismiss(); // 点击后隐藏 ListPopupWindow
            }
        });

        // 初始化显示下拉选择框的按钮
        showPopupButton = findViewById(R.id.show_popup_button);
        showPopupButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                listPopupWindow.show(); // 点击按钮显示 ListPopupWindow
                // 选中当前按钮文本所对应的选项
                int index = dataList.indexOf(showPopupButton.getText().toString());
                listPopupWindow.setSelection(index);
            }
        });
    }

    private void initData() {
        // 模拟数据
        dataList = new ArrayList<>();
        dataList.add("Option 1");
        dataList.add("Option 2");
        dataList.add("Option 3");
        // 添加更多选项...
    }
}

在这个示例中,我们在点击按钮时设置了下拉框中的选项为当前按钮的文本对应的选项,并通过 listPopupWindow.setSelection(index) 方法来实现。这样,下拉框中的选项就会显示为选中状态。

我们继续:listPopupWindow.setSelection(index) 的话,如果每个index 的选中效果不一样应该怎么处理呢?

如果每个选项的选中状态效果不一样,可以在适配器中根据选中状态来设置不同的样式。在 getView() 方法中,可以根据每个选项的选中状态来设置其样式,以反映其选中状态。

下面是一个修改后的示例代码,演示如何根据每个选项的选中状态来设置不同的样式:



public class MainActivity extends AppCompatActivity {

    private List<String> dataList;
    private List<Boolean> itemSelectedStates;
    private ListPopupWindow listPopupWindow;
    private Button showPopupButton;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        // 初始化数据
        initData();

        // 初始化 ListPopupWindow
        listPopupWindow = new ListPopupWindow(this);
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, 0, dataList) {
            @Override
            public View getView(int position, View convertView, android.view.ViewGroup parent) {
                // 获取当前选项的视图
                View view = super.getView(position, convertView, parent);
                TextView textView = (TextView) view;
                // 设置选项的样式
                if (itemSelectedStates.get(position)) {
                    // 如果选项被选中,设置为粗体字体,背景色为灰色
                    textView.setAllCaps(true);
                    textView.setBackgroundColor(getResources().getColor(android.R.color.darker_gray));
                } else {
                    // 如果选项未选中,恢复普通字体样式,背景色为白色
                    textView.setAllCaps(false);
                    textView.setBackgroundColor(getResources().getColor(android.R.color.white));
                }
                return view;
            }
        };
        listPopupWindow.setAdapter(adapter);
        listPopupWindow.setAnchorView(showPopupButton); // 设置锚点

        // 设置列表项点击监听器
        listPopupWindow.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                String selectedItem = dataList.get(position);
                Toast.makeText(MainActivity.this, "Selected: " + selectedItem, Toast.LENGTH_SHORT).show();
                // 更新选中状态数组
                for (int i = 0; i < itemSelectedStates.size(); i++) {
                    itemSelectedStates.set(i, (i == position));
                }
                adapter.notifyDataSetChanged(); // 刷新适配器以更新选中状态
                listPopupWindow.dismiss(); // 点击后隐藏 ListPopupWindow
            }
        });

        // 初始化显示下拉选择框的按钮
        showPopupButton = findViewById(R.id.show_popup_button);
        showPopupButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                listPopupWindow.show(); // 点击按钮显示 ListPopupWindow
            }
        });
    }

    private void initData() {
        // 模拟数据
        dataList = new ArrayList<>();
        dataList.add("Option 1");
        dataList.add("Option 2");
        dataList.add("Option 3");
        // 添加更多选项...

        // 初始化选中状态数组,默认第一个选项为选中状态
        itemSelectedStates = new ArrayList<>();
        for (int i = 0; i < dataList.size(); i++) {
            itemSelectedStates.add(false);
        }
    }
}

在这个示例中,我们重写了 ArrayAdaptergetView() 方法,在其中根据每个选项的选中状态来设置不同的样式。当选项被选中时,我们将其字体设置为粗体并将背景色设为灰色,未选中时恢复普通字体样式并将背景色设为白色。这样可以让每个选项的选中状态效果不一样。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/615265.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【半夜学习MySQL】表结构的操作(含表的创建、修改、删除操作,及如何查看表结构)

&#x1f3e0;关于专栏&#xff1a;半夜学习MySQL专栏用于记录MySQL数据相关内容。 &#x1f3af;每天努力一点点&#xff0c;技术变化看得见 文章目录 创建表查看表结构修改表删除表 创建表 语法&#xff1a; create table table_name(field1 datatype,field2 datatype,fiel…

hive日常使用时忘记部分补充(不定时)

1、date_formate、unix_timestamp、from_unixtime用法&#xff1a; 2、lag&#xff08;&#xff09;、lead()用法&#xff1a; lag&#xff08;)窗口函数返回分区中当前行之前行&#xff08;可以指定第几行&#xff09;的值。 如果没有行&#xff0c;则返回null。 lead()窗口…

dos命令改3389端口,通过dos命令更改3389端口的操作

要使用DOS命令更改3389端口&#xff0c;通常涉及修改Windows注册表中的相关键值。请注意&#xff0c;直接操作注册表具有一定的风险&#xff0c;因此在进行任何更改之前&#xff0c;请确保您了解正在进行的操作&#xff0c;并已经采取了适当的备份措施。 以下是一个基本的操作步…

2024年4月12日饿了么春招实习试题【第二题:魔法师】-题目+题解+在线评测【二分】

2024年4月12日饿了么春招实习试题【第二题:魔法师】-题目题解在线评测【二分】 题目描述&#xff1a;输入格式输出格式样例输入样例输出评测数据与规模 解题思路一&#xff1a;解题思路二&#xff1a;解题思路三&#xff1a;动态规划 题目描述&#xff1a; 塔子哥是一名魔法师…

浅谈运维数据安全

在数字化日益深入的今天&#xff0c;运维数据安全已经成为企业信息安全体系中的核心要素。运维工作涉及到企业信息系统的各个方面&#xff0c;从硬件维护到软件升级&#xff0c;从网络配置到数据备份&#xff0c;无一不需要严谨的数据安全保障措施。本文将从运维数据安全的重要…

抖音小店入驻后,完成这个步骤,出单几率会大大提升

哈喽~我是电商月月 抖音小店的运营过程中&#xff0c;最重要的就是选品&#xff0c;好品自带流量 但在商品正式上架前一定要做好这些设置的基础搭建&#xff0c;这些工作没做好&#xff0c;商品再好&#xff0c;我们的店铺也是不会有大流量和曝光的 那到底是哪些设置&#x…

iOS性能指标和性能测试工具

一&#xff1a; iOS性能测试指标 作为一名软件测试工程师&#xff0c;在测试 iOS 应用的性能时&#xff0c;需要关注以下几个方面&#xff1a; 1. 响应时间&#xff1a;应用的启动时间、页面加载速度、接口响应时间等。 2. CPU 使用率&#xff1a;应用在各种操作下的 CPU 占…

基于Qt的Model-View显示树形数据

目标 用qt的模型-视图框架实现树型层次节点的显示&#xff0c;从QAbstractItemModel派生自己的模型类MyTreeItemModel&#xff0c;用boost::property_tree::ptree操作树型数据结构&#xff0c;为了演示&#xff0c;此处只实现了个只读的模型 MyTreeItemModel的定义 #pragma o…

设计模式-创建型-原型模式-prototype

工作经验类 public class WorkExperience implements Cloneable {private String workDate;private String company;public void setWorkDate(String workDate) {this.workDate workDate;}public void setCompany(String company) {this.company company;}Overridepublic Ob…

品鉴中的个人风格:如何形成自己与众不同的红酒品鉴体验

品鉴云仓酒庄雷盛红酒不仅是一种感官体验&#xff0c;更是一种个人风格的展现。每个人都有自己与众不同的品味和偏好&#xff0c;通过品鉴红酒&#xff0c;我们可以形成自己与众不同的红酒品鉴体验。 要形成自己与众不同的红酒品鉴体验&#xff0c;首先需要勇于尝试不同类型的红…

返回分类信息(带层级)

文章目录 1.前端展示分类管理信息1.目前项目架构2.启动前后端项目1.启动mysql容器2.启动后端 renren-fast3.启动前端1.界面2.用户名密码都是admin 3.创建分类管理菜单1.菜单管理 -> 新增 -> 新增目录2.刷新3.能够新增菜单的原因是前端脚手架与renren-fast后端脚手架通信&…

Python大数据分析——Logistic回归模型

Logistic回归模型 概念理论分析模型评估混淆矩阵ROC曲线KS曲线 函数示例 概念 之前的回归的变量是连续的数值变量&#xff1b;而Logistics回归是二元离散值&#xff0c;用来解决二分类问题。 理论分析 上式中的hβ(X)也被称为Loqistic回归模型&#xff0c;它是将线性回归模型…

LagentAgentLego智能体工具使用

1. lagent 参考文档 https://github.com/InternLM/Tutorial/blob/camp2/agent/lagent.md 使用 LMDeploy 部署 conda activate agent lmdeploy serve api_server /root/share/new_models/Shanghai_AI_Laboratory/internlm2-chat-7b \--server-name 127.0.0.1 \--model-name in…

深度学习:基于人工神经网络ANN的降雨预测

前言 系列专栏:【深度学习&#xff1a;算法项目实战】✨︎ 本专栏涉及创建深度学习模型、处理非结构化数据以及指导复杂的模型&#xff0c;如卷积神经网络(CNN)、递归神经网络 (RNN)&#xff0c;包括长短期记忆 (LSTM) 、门控循环单元 (GRU)、自动编码器 (AE)、受限玻尔兹曼机(…

数学学习笔记1——二次函数中的数形结合

二次函数中的数形结合 一、解一元二次不等式 基本方法&#xff1a;配方。 x 2 − 4 x 3 < 0 → ( x − 2 ) 2 < 1 → ∣ x − 2 ∣ < 1 → 1 < x < 3 x^2-4x3<0\to(x-2)^2<1\to\lvert x-2\rvert<1\to1<x<3 x2−4x3<0→(x−2)2<1→∣x−…

JDBC调用MogDB存储过程返回ref_cursor的方法和注意事项

MogDB在处理存储过程的时候&#xff0c;有时候需要返回结果集&#xff0c;类型为ref_cursor&#xff0c;但有时候可能会报错。而大部分应用程序都是使用Java JDBC. 根据我们这几年的数据库国产化改造经验&#xff0c;给大家分享一下JDBC调用 MogDB存储过程返回ref_cursor的方法…

【软考】模拟考卷错题本2024-05-11

1 设计模式- 适配器模式 基本上上述的图解已经涵盖了绝大多数主流的设计模式和其特点。理解记忆下即可&#xff0c;这里对下午的考题也有帮助的。 2 计算机组成原理 cpu 访问速度 这个真的是憨憨咯~看到内存就选内存&#xff0c;题目都没审好。这里的速度比cpu内部的要比外部的…

2024数维杯数学建模B题生物质和煤共热解问题的研究原创论文分享

大家好&#xff0c;从昨天肝到现在&#xff0c;终于完成了2024数维杯数学建模挑战赛B题的完整论文啦。 实在精力有限&#xff0c;具体的讲解大家可以去讲解视频&#xff1a; 2024数维杯数学建模B题煤共热解每一问高质量完整代码讲解&#xff01;_哔哩哔哩_bilibili 2024数维杯…

【初阶数据结构】单链表基础OJ题讲解

前言 &#x1f4da;作者简介&#xff1a;爱编程的小马&#xff0c;正在学习C/C&#xff0c;Linux及MySQL。 &#x1f4da;本文收录与初阶数据结构系列&#xff0c;本专栏主要是针对时间、空间复杂度&#xff0c;顺序表和链表、栈和队列、二叉树以及各类排序算法&#xff0c;持…

找不到或无法加载主类 com.ruoyi.RuoYiApplication

若依项目&#xff0c;很久不启动&#xff0c;莫名其妙报错 找不到或无法加载主类 com.ruoyi.RuoYiApplication 解决方式 参考文章 找不到或无法加载主类_错误: 找不到或无法加载主类 com.ruoyi.ruoyiapplication-CSDN博客