Android下拉框PopupWindow使用详解
更新时间:2017年10月20日 14:12:14 作者:konekou
这篇文章主要为大家详细介绍了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;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
Github简单易用的 Android ViewModel Retrofit框架
这篇文章主要介绍了Github简单易用的Android ViewModel Retrofit框架,RequestViewMode有自动对LiveData进行缓存管理,每个retrofit api接口复用一个livedata的优势。下文具体详情,感兴趣的小伙伴可以参考一下2022-06-06
Android学习笔记(一)环境安装及第一个hello world
最近在学习安卓开发,记录下环境安装和第一个hello world的诞生过程,希望对大家有所帮助2014-07-07
Android直播软件搭建之实现背景颜色滑动渐变效果的详细代码
这篇文章主要介绍了Android直播软件搭建之实现背景颜色滑动渐变效果的详细代码,代码简单易懂,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2021-09-09
Kotlin语言使用BroadcastReceiver示例介绍
Android开发的四大组件分别是:活动(activity),用于表现功能;服务(service),后台运行服务,不提供界面呈现;广播接受者(Broadcast Receive),勇于接收广播;内容提供者(Content Provider),支持多个应用中存储和读取数据,相当于数据库,本篇着重介绍广播组件2022-09-09
Android通过实现GridView的横向滚动实现仿京东秒杀效果
这篇文章主要介绍了Android通过实现GridView的横向滚动实现仿京东秒杀效果,实现代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2018-07-07


最新评论