Android下拉选择框之PopupWindow
1.效果图
2.思路分析
1.点击弹出对话框 popupwindow
2.对popupwindow进行相关设置,popupwindow中设置view为listview
3.listview中item设置点击事件
4.显示popupwindow
3.代码
1.布局文件
1.activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"> <RelativeLayout
android:layout_width="300dp"
android:layout_height="wrap_content"
android:layout_marginTop="20dp"
android:layout_marginLeft="20dp"
>
<EditText
android:layout_width="300dp"
android:layout_height="wrap_content"
android:id="@+id/tv" />
<ImageButton
android:id="@+id/imgshowdown"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/down_arrow"
android:padding="4dp"
android:layout_alignTop="@+id/tv"
android:background="@null"
android:layout_alignParentRight="true"
/> </RelativeLayout> </RelativeLayout>
2.item_num_list
<?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="match_parent"
android:gravity="center_vertical"
android:padding="3dp"
>
<ImageView
android:layout_width="20dp"
android:layout_height="20dp"
android:src="@drawable/ic_default_person"
android:layout_marginRight="10dp"
/>
<TextView
android:layout_width="0dp"
android:layout_height="wrap_content"
android:id="@+id/tv"
android:layout_weight="1"
/>
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/img"
android:src="@drawable/delete"
android:padding="5dp"
/> </LinearLayout>
2.MainActivity
public class MainActivity extends AppCompatActivity implements View.OnClickListener, AdapterView.OnItemClickListener {
@BindView(R.id.tv)
EditText tv;
@BindView(R.id.imgshowdown)
ImageButton imgshowdown; private ListView listView;
private List<String> datas;
private MyAdapter adapter; private PopupWindow popupWindow; // private TextView tv;
// private
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ButterKnife.bind(this);
imgshowdown.setOnClickListener(this);
} @Override
public void onClick(View v) {
initListView();//初始化listview
showpopup();//初始化popupwindow 并显示出来
} private void showpopup() {
if(popupWindow==null){
popupWindow=new PopupWindow(listView, tv.getWidth(), 300);
popupWindow.setOutsideTouchable(true);//点击外部消失 //设置背景 不然 setOutsideTouchable(true) 不起作用
popupWindow.setBackgroundDrawable(new BitmapDrawable());
popupWindow.setFocusable(true); //设置可获取焦点
}
popupWindow.showAsDropDown(tv,0,0);//显示位置
} private void initListView() {
if(datas==null){
datas=new ArrayList<>();
for (int i = 0; i <30 ; i++) {
datas.add("person"+i);
}
}
if (listView == null) {
listView = new ListView(this);
listView.setDividerHeight(0);
listView.setBackgroundResource(R.drawable.listview_background);
listView.setOnItemClickListener(this);
adapter=new MyAdapter();
listView.setAdapter(adapter);
}
} @Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
tv.setText(datas.get(position));
popupWindow.dismiss();
} //listview 适配器
class MyAdapter extends BaseAdapter { @Override
public int getCount() {
return datas.size();
} @Override
public Object getItem(int position) {
return datas.get(position);
} @Override
public long getItemId(int position) {
return position;
} @Override
public View getView(final int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = View.inflate(parent.getContext(), R.layout.item_num_list, null);
holder=new ViewHolder(convertView);
// holder.tv.setText();
convertView.setTag(holder); }else{
holder= (ViewHolder) convertView.getTag();
}
holder.tv.setText(datas.get(position));
holder.img.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
datas.remove(position);
notifyDataSetChanged();
if(datas.size()==0){
popupWindow.dismiss();
}
}
});
return convertView;
} }
static class ViewHolder {
@BindView(R.id.tv)
TextView tv;
@BindView(R.id.img)
ImageView img; ViewHolder(View view) {
ButterKnife.bind(this, view);
}
}
}
Android下拉选择框之PopupWindow的更多相关文章
- 下拉选择框,PopupWindow的使用
实现下拉选择框 直接上代码 Activity.java package com.example.shaofei.customerviewdemo1; import android.os.Bundle; ...
- android下拉选择框spinner
spinner是什么东西呢?有点像下拉菜单,其实是一个弹出窗口,但是是可以进行进一步操作的弹出窗口.你点击那个三角形的符号,弹出一个窗口,通常是列表,然后进行操作. 它在xml文件中的定义和其它控件没 ...
- java、easyui-combotree树形下拉选择框
最近一直在研究这个树形的下拉选择框,感觉非常的有用,现在整理下来供大家使用: 首先数据库的表架构设计和三级菜单联动的表结构是一样,(父子关系) 1.下面我们用hibernate建一下对应的额实体类: ...
- FancySelect – 更好用的 jQuery 下拉选择框插件
FancySelect 这款插件是 Web 开发中下拉框功能的一个更好的选择.FancySelect 使用方便,只要绑定页面上的任何 Select 元素,并调用就 .fancySelect() 就可以 ...
- HTML、CSS小知识--兼容IE的下拉选择框select
HTML <div class="s_h_ie"> <select id="Select1" disabled="disabled& ...
- Bootstrap系列 -- 15. 下拉选择框select
Bootstrap框架中的下拉选择框使用和原始的一致,多行选择设置multiple属性的值为multiple.Bootstrap框架会为这些元素提供统一的样式风格 <form role=&quo ...
- CSS自定义select下拉选择框(不用其他标签模拟)
今天群里有人问到怎么自定义select下拉选择框的样式,于是群里就展开了激烈的讨论,刚开始一直就是考虑怎样使用纯CSS实现,把浏览器默认的样式覆盖掉,但最后均因兼容问题处理不好而失败告终,最后的解决方 ...
- 基于jQuery美化联动下拉选择框
今天给大家介绍一款基于jQuery美化联动下拉选择框.这款下下拉选择框js里自带了全国所有城市的数数库.下拉选择框适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲 ...
- ul+jquery自定义下拉选择框
<!doctype html> <html> <head> <meta charset="UTF-8"> <title> ...
随机推荐
- linux 查看系统信息和安装哪些软件的命令
https://www.cnblogs.com/wangkongming/p/4531341.html 查看系统磁盘硬盘占用率 https://blog.csdn.net/aaashen/articl ...
- gen_server模块
转自http://www.xuebuyuan.com/2132233.html
- php小白和菜鸟 上班路上可以看的修行博客
上班地铁 公交上我们不要去追剧 不要去打游戏 不要看看有效性的海量新闻, 我们需要去技术博客里遨游, 下面就推荐点与php有关的可以学习的技术博客; 大部分程序员在自学的道路上不知道走了多少坑,这个视 ...
- springmvc freemarker 全局变量的三种配置方式
方法一 直接在spring-servlet.xml 中进行配置 <bean id="freemarkerConfiguration" class="org.spri ...
- Difference between boot ip. service ip and persistent ip in hacmp
- boot IP is the original address on a network interface even when the cluster is down - service IP ...
- PHP生成唯一固定长度邀请码
function create_invite_code() { $code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'; $rand = $code[rand(0,25)] .str ...
- ubuntu安装composer
1.下载composer.phar wget https://getcomposer.org/composer.phar 2.重命名composer.phar为composer mv composer ...
- PHP中的精确计算bcadd,bcsub,bcmul,bcdiv
引言:一定要确保数据的准确性.这是一个好的程序员的基本素养. <?php /** * 精确加法 * @param [type] $a [description] * @param [type] ...
- Three.js会飞走飞回来的鸟
效果图 demo import './index.css'; // stats var stats; (function(){ stats = new Stats(); document.body.a ...
- Python Twisted系列教程13:使用Deferred新功能实现新客户端
作者:dave@http://krondo.com/deferred-all-the-way-down/ 译者:杨晓伟(采用意译) 你可以从这里从头阅读这个系列. 介绍 回忆下第10部分中的客户端5 ...