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>
代碼實現(xiàn)
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); //創(chuàng)建集合 儲存號碼 numList = new ArrayList<String>(); for(int i=0;i<20;i++){ numList.add("100000000"+i); } initListView(); //對下拉按鈕設置監(jiān)聽 當進行點擊時 彈出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區(qū)域之外 自動關閉popWin popWin.setOutsideTouchable(true); /** * 設置彈出窗口顯示的位置 * 參數(shù)一:相對于參數(shù)的位置進行顯示 即在編輯框的下面顯示 * 參數(shù)二 三:x y軸的偏移量 */ popWin.showAsDropDown(et_editText, 0, 0); isDown=true; }else{ popWin.dismiss(); isDown=false; } } }); } //點擊返回按鈕 @Override public void onBackPressed() { /** * 當用戶點擊返回按鈕時 是整個activity退出 而且給人的感覺是直接退出 窗口可能還是顯示狀態(tài), 為了避免內存泄露,先關閉彈窗 * * 當點擊返回按鈕時 如果窗口存在且正在顯示 則關閉窗口 */ 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)); //對刪除按鈕設置監(jiān)聽事件 holder.delete.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { //當點擊刪除按鈕時 刪除條目 numList.remove(position); //刷新ListView MyListAdapter.this.notifyDataSetChanged(); } }); //對條目設置監(jiān)聽事件 點擊條目后 將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; } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Android之沉浸式狀態(tài)欄的實現(xiàn)方法、狀態(tài)欄透明
本篇文章主要介紹了Android之沉浸式狀態(tài)欄的實現(xiàn)方法、狀態(tài)欄透明,具有一定的參考價值,有興趣的可以了解一下。2017-02-02Android ListView的item背景色設置和item點擊無響應的解決方法
在Android開發(fā)中,listview控件是非常常用的控件,在大多數(shù)情況下,大家都會改掉listview的item默認的外觀。2013-11-11Android intent之間復雜參數(shù)傳遞方法詳解
這篇文章主要介紹了Android intent之間復雜參數(shù)傳遞方法,較為詳細的分析了Android中intent參數(shù)傳遞的常見方法與使用技巧,需要的朋友可以參考下2016-10-10android 仿微信demo——微信啟動界面實現(xiàn)
本篇文章主要介紹了微信小程序-閱讀小程序實例(demo),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧,希望能給你們提供幫助2021-06-06