Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發 >> 高級開發 >> Android開發:實現popupwindow中顯示listview

Android開發:實現popupwindow中顯示listview

編輯:高級開發

前文中我們講過了在android開發如何實現帶圖片和checkbox的listvIEw,如何把listview添加到popupwindow窗口中呢?關於這個listvIEw我就再不多說了,主要是實現popupwindow和美化popupwindow。

先看看我做截圖:

實現popupwindow中顯示listview

1、創建一個popupwindow,並設置相應的樣式。

Java代碼

  1. private void popAwindow(VIEw parent) {
  2. if (window == null) {
  3. LayoutInflater lay = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  4. VIEw v = lay.inflate(R.layout.popupwindow, null);
  5. v.setBackgroundDrawable(getResources().getDrawable(R.drawable.rounded_corners_vIEw));
  6. //初始化按鈕
  7. submit = (Button) v.findVIEwById(R.id.submit);
  8. submit.setOnClickListener(submitListener);
  9. cancel = (Button) v.findVIEwById(R.id.cancel);
  10. cancel.setOnClickListener(cancelListener);
  11. //初始化listvIEw,加載數據
  12. list=(ListView)v.findVIEwById(R.id.lv);
  13. MyAdapter adapter=new MyAdapter(Main.this);
  14. list.setAdapter(adapter);
  15. list.setItemsCanFocus(false);
  16. list.setChoiceMode(ListVIEw.CHOICE_MODE_MULTIPLE);
  17. list.setOnItemClickListener(listClickListener);
  18. window = new PopupWindow(v, 500,260);
  19. }
  20. //設置整個popupwindow的樣式。
  21. window.setBackgroundDrawable(getResources().getDrawable(R.drawable.rounded_corners_pop));
  22. //使窗口裡面的空間顯示其相應的效果,比較點擊button時背景顏色改變。
  23. //如果為false點擊相關的空間表面上沒有反應,但事件是可以監聽到的。
  24. //listvIEw的話就沒有了作用。
  25. window.setFocusable(true);
  26. window.update();
  27. window.showAtLocation(parent, Gravity.CENTER_VERTICAL, 0, 0);
  28. }
  29. OnItemClickListener listClickListener = new OnItemClickListener() {
  30. @Override
  31. public void onItemClick(AdapterView<?> parent, View vIEw, int position,
  32. long id) {
  33. ViewHolder vHollder = (ViewHolder) vIEw.getTag();
  34. // 在每次獲取點擊的item時將對於的checkbox狀態改變,同時修改map的值。
  35. vHollder.cBox.toggle();
  36. MyAdapter.isSelected.put(position, vHollder.cBox.isChecked());
  37. }
  38. };

給按鈕添加監聽事件:

Java代碼

  1. OnClickListener submitListener = new OnClickListener() {
  2. @Override
  3. public void onClick(VIEw v) {
  4. //這兒可以寫提交數據的代碼。
  5. closeWindow();
  6. }
  7. };
  8. OnClickListener cancelListener=new OnClickListener(){
  9. @Override
  10. public void onClick(VIEw v){
  11. closeWindow();
  12. }
  13. };
  14. private void closeWindow(){
  15. //將每個checkbox的標記改為false,以便下次彈出window時是初始的狀態。
  16. for (int j = 0; j < MyAdapter.isSelected.size(); j++) {
  17. MyAdapter.isSelected.put(j, false);
  18. ViewHolder vHollder = (VIEwHolder) list.getChildAt(j).getTag();
  19. vHollder.cBox.setChecked(false);
  20. }
  21. //提交數據時關閉popupwindow。
  22. if (window != null) {
  23. window.dismiss();
  24. }
  25. }

在layout中新建popupwindow.XML文件,具體內容如下,主要是對window的布局:

Java代碼

  1. <?XML version="1.0" encoding="utf-8"?>
  2. <LinearLayout XMLns:android="http://schemas.android.com/apk/res/android"
  3. android:orIEntation="vertical"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent">
  6. <TextVIEw
  7. android:id="@+id/tip"
  8. android:layout_width="wrap_content"
  9. android:layout_height="wrap_content"
  10. android:layout_gravity="center"
  11. android:textSize="18dip"
  12. android:background="@drawable/rounded_corners_list"
  13. android:text="這是一個popupWindow的例子"/>
  14. <!-- 如果layout_width的值為fill_parent時,居中要用android:gravity="center"-->
  15. <ListVIEw
  16. android:id="@+id/lv"
  17. android:layout_width="fill_parent"
  18. android:layout_height="wrap_content"
  19. android:background="@drawable/rounded_corners_list"/>
  20. <LinearLayout
  21. android:orIEntation="horizontal"
  22. android:layout_gravity="center"
  23. android:layout_width="wrap_content"
  24. android:layout_height="wrap_content"
  25. android:background="@drawable/rounded_corners_list">
  26. <Button
  27. android:id="@+id/submit"
  28. android:layout_width="100dip"
  29. android:layout_height="50dip"
  30. android:text="提交"/>
  31. <Button
  32. android:id="@+id/cancel"
  33. android:layout_width="100dip"
  34. android:layout_height="50dip"
  35. android:text="取消"/>
  36. </LinearLayout>
  37. </LinearLayout>

新建rounded_corners_pop.XML,用於自定義窗口的樣式文件,具體內容如下:

Java代碼

  1. <?XML version="1.0" encoding="utf-8"?>
  2. <shape XMLns:android="http://schemas.android.com/apk/res/android">
  3. <solid android:color="#ffffffff" />
  4. <stroke android:width="3dp" color="#ffff8080" />
  5. <corners android:radius="10dp" />
  6. <padding
  7. android:left="3dp"
  8. android:top="3dp"
  9. android:right="3dp"
  10. android:bottom="3dp" />
  11. </shape>

這個就可以實現圓角的樣式,周圍的白邊是通過在白的樣式上面疊加黑色的來實現的。 其他樣式文件大家可以參考上面的rounded_corners_pop.XML自己寫。

2、在main.XML中添加按鈕,一個用於顯示window,一個用於隱藏window

Java代碼

  1. <?XML version="1.0" encoding="utf-8"?>
  2. <LinearLayout XMLns:android="http://schemas.android.com/apk/res/android"
  3. android:orIEntation="horizontal"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. android:id="@+id/lmain"
  7. >
  8. <Button
  9. android:id="@+id/myButton1"
  10. android:layout_width="100dip"
  11. android:layout_height="50dip"
  12. android:text="顯示"/>
  13. <Button
  14. android:id="@+id/myButton2"
  15. android:layout_width="100dip"
  16. android:layout_height="50dip"
  17. android:text="隱藏"/>
  18. </LinearLayout>

在activity中初始化這兩個按鈕,並添加監聽事件:

Java代碼

  1. OnClickListener bPop = new OnClickListener() {
  2. @Override
  3. public void onClick(VIEw v) {
  4. popAwindow(v);
  5. }
  6. };
  7. OnClickListener boff = new OnClickListener() {
  8. @Override
  9. public void onClick(VIEw v) {
  10. if(window!=null){
  11. window.dismiss();
  12. }
  13. }
  14. };
  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved