Android下拉框PopupWindow使用详解

本文实例为大家分享了Android下拉框PopupWindow展示的具体代码,供大家参考,具体内容如下

activity_main.xml布局

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.spin.MainActivity" > <EditText android:id="@+id/et_editText" android:layout_width="250dp" android:layout_height="50dp" android:layout_centerHorizontal="true" android:layout_marginTop="10dp" android:text="@string/hello_world" /> <ImageView android:id="@+id/down" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/down_arrow" android:layout_alignRight="@id/et_editText" android:layout_marginTop="20dp" android:clickable="true"/> </RelativeLayout>

List_item.xml布局

<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_vertical" android:orientation="horizontal" > <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/user"/> <TextView android:id="@+id/tv_list_item" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:gravity="center_horizontal" android:text="100000000"/> <ImageView android:id="@+id/delete" android:layout_width="wrap_content" android:layout_height="wrap_content" android:background="@drawable/delete"/> </LinearLayout>

代码实现

public class MainActivity extends ActionBarActivity { private EditText et_editText;//编辑框 private ImageView down;//下拉按钮 private ListView listView; private List<String> numList; private PopupWindow popWin; private Boolean isDown=false;//判断弹窗是否显示 @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); et_editText = (EditText) findViewById(R.id.et_editText); down = (ImageView) findViewById(R.id.down); //创建集合 储存号码 numList = new ArrayList<String>(); for(int i=0;i<20;i++){ numList.add("100000000"+i); } initListView(); //对下拉按钮设置监听 当进行点击时 弹出popWin down.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { if(!isDown){ //定义一个popupWindow popWin=new PopupWindow(MainActivity.this); popWin.setWidth(et_editText.getWidth());//设置宽度 和编辑框的宽度相同 popWin.setHeight(200); //设置高度 //为popWin填充内容 popWin.setContentView(listView); //点击popWin区域之外 自动关闭popWin popWin.setOutsideTouchable(true); /** * 设置弹出窗口显示的位置 * 参数一:相对于参数的位置进行显示 即在编辑框的下面显示 * 参数二 三:x y轴的偏移量 */ popWin.showAsDropDown(et_editText, 0, 0); isDown=true; }else{ popWin.dismiss(); isDown=false; } } }); } //点击返回按钮 @Override public void onBackPressed() { /** * 当用户点击返回按钮时 是整个activity退出 而且给人的感觉是直接退出 窗口可能还是显示状态, 为了避免内存泄露,先关闭弹窗 * * 当点击返回按钮时 如果窗口存在且正在显示 则关闭窗口 */ if(popWin!=null&&popWin.isShowing()){ popWin.dismiss(); } super.onBackPressed(); } private void initListView() { listView = new ListView(this); //设置listView的背景 listView.setBackgroundResource(R.drawable.listview_background); //设置条目之间的分割线及滚动条不可见 listView.setDivider(null); listView.setVerticalScrollBarEnabled(false); //设置适配器 listView.setAdapter(new MyListAdapter()); } private class MyListAdapter extends BaseAdapter{ @Override public int getCount() { return numList==null?0:numList.size(); } @Override public View getView(final int position, View convertView, ViewGroup parent) { ViewHolder holder; if(convertView==null){ convertView=View.inflate(getApplicationContext(), R.layout.list_item, null); holder=new ViewHolder(); holder.tvNum=(TextView) convertView.findViewById(R.id.tv_list_item); holder.delete=(ImageView) convertView.findViewById(R.id.delete); convertView.setTag(holder); }else{ holder=(ViewHolder) convertView.getTag(); } holder.tvNum.setText(numList.get(position)); //对删除按钮设置监听事件 holder.delete.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { //当点击删除按钮时 删除条目 numList.remove(position); //刷新ListView MyListAdapter.this.notifyDataSetChanged(); } }); //对条目设置监听事件 点击条目后 将num设置到编辑框中 convertView.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { //点击条目后 将num设置到编辑框中 et_editText.setText(numList.get(position)); popWin.dismiss(); } }); return convertView; } @Override public Object getItem(int position) { return null; } @Override public long getItemId(int position) { return 0; } } private class ViewHolder { TextView tvNum; ImageView delete; } }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

时间: 2024-10-25 08:45:38

Android下拉框PopupWindow使用详解的相关文章

Android第三方开源下拉框NiceSpinner使用详解

android原生的下拉框Spinner基本上可以满足Android开发对于下拉选项的设计需求,但现在越来越流行的下拉框不满足于Android原生提供的下拉框Spinner所提供的设计样式,而改用自定制或者第三方设计的下拉框Spinner. NiceSpinner是一个第三方开源的下拉框Spinner,其在github上的项目主页是:https://github.com/arcadefire/nice-spinner  NiceSpinner原设计效果如动图所示: 但是通常开发者对于可能还需要对

Jquery Easyui自定义下拉框组件使用详解(21)_jquery

本文实例为大家分享了Jquery Easyui自定义下拉框组件的实现代码,供大家参考,具体内容如下 加载方式 JS调用加载 自定义下拉框不能通过标签的方式进行创建. <input id="box" /> <script> $(function () { //JS 加载调用 $('#box').combo({ required : true, multiple : true, }); }); </script> 属性列表 <script>

android模仿58筛选下拉框(PopupWindow实现)

前言:前几天用58同城APP找房子的时候,看到筛选下拉框蛮不错的,然后也有很多朋友需要实现这个功能,于是从网上下载了一个demo,在他的基础上进行修改,花了几个小时对他的代码进行修改,重构,封装.把一些公共的东西抽取出来,选择下拉框那块做成一个工具类,然后通过接口回调回来. 效果图如下: 1.MainActivity.java  用户点击区域TextView的时候,初始化自定义控件PopupWindow,然后显示PopupWindow.通过PopupWindow构造参数传入一个选择完成的监听接口

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

android给我们提供了一个spinner控件,这个控件主要就是一个列表,那么我们就来说说这个控件吧,这个控件在以前的也看见过,但今天还是从新介绍一遍吧. Spinner位于 android.widget包下,每次只显示用户选中的元素,当用户再次点击时,会弹出选择列表供用户选择,而选择列表中的元素同样来自适配器.Spinner是View类得一个子类. 1.效果图 2.创建页面文件(main.xml) <Spinner android:id="@+id/spinner1" and

Android编程之ICS式下拉菜单PopupWindow实现方法详解(附源码下载)_Android

本文实例讲述了Android编程之ICS式下拉菜单PopupWindow实现方法.分享给大家供大家参考,具体如下: 运行效果截图如下: 右边这个就是下拉菜单啦,看见有的地方叫他 ICS式下拉菜单,哎哟,不错哦! 下面先讲一下实现原理: 这种菜单实际上就是一个弹出式的菜单,于是我们想到android PopupWindow 类,给他设置一个view 在弹出来不就OK了吗. PopupWindow 的用法也很简单 主要方法: 步骤1.new 一个实例出来,我们使用这个构造方法即可, 复制代码 代码如

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

android给我们提供了一个spinner控件,这个控件主要就是一个列表,那么我们就来说说这个控件吧,这个控件在以前的也看见过,但今天还是从新介绍一遍吧. Spinner位于 android.widget包下,每次只显示用户选中的元素,当用户再次点击时,会弹出选择列表供用户选择,而选择列表中的元素同样来自适配器.Spinner是View类得一个子类. 1.效果图 2.创建页面文件(main.xml) <Spinner android:id="@+id/spinner1" and

Android编程之ICS式下拉菜单PopupWindow实现方法详解(附源码下载)

本文实例讲述了Android编程之ICS式下拉菜单PopupWindow实现方法.分享给大家供大家参考,具体如下: 运行效果截图如下: 右边这个就是下拉菜单啦,看见有的地方叫他 ICS式下拉菜单,哎哟,不错哦! 下面先讲一下实现原理: 这种菜单实际上就是一个弹出式的菜单,于是我们想到android PopupWindow 类,给他设置一个view 在弹出来不就OK了吗. PopupWindow 的用法也很简单 主要方法: 步骤1.new 一个实例出来,我们使用这个构造方法即可, 复制代码 代码如

yii2带搜索功能的下拉框实例详解_php实例

简单的小功能,但是用起来还是蛮爽的.分享出来让更多的人有更快的开发效率,开开心心快乐编程. 如果你还没有使用过composer,你可就out了,看我的教程分享,composer简直就是必备神奇有木有.都说到这个点上了,我们赶紧使用composer进行安装吧. 先给大家展示下效果图: 下面给大家说下具体实现思路: composer require kartik-v/yii2-widget-select2 "@dev" #特别说明,因为这里安装的dev版本,也就是开发版本,不稳定版本,如果

jquery获取下拉框值详解

我们利用js获取select值是比较麻烦的,下面我们来看看利用jquery来获取select值的代码吧,下面我们来看分二种获取方法. <select id="ddltype"> <option value="">请选择</option> <option value="1">安徽省</option> -- </select> <select id="ddltyp