【Android进阶学习】Popupwindow的应用

简介:

PopupWindow 是一种阻塞式的弹出窗口,这就意味着在我们退出这个弹出框之前,程序会一直等待。它可以浮动在当前Activity的任何的位置上。 需要注意的是,PopupWindow必须触发某个焦点或者某个事件才会显示出来,不然总会会出现错误。

下面是使用PopupWindow 弹出自定义菜单的例子

当我们点击Menu键的时候,会在当前的Activity最下方弹出一个菜单。

效果图如下:

 PopupMenuDemo.java


 
 
  1. package com.lingdududu.popupWindow;  
  2.  
  3. import android.app.Activity;  
  4. import android.content.Context;  
  5. import android.graphics.drawable.BitmapDrawable;  
  6. import android.os.Bundle;  
  7. import android.view.Gravity;  
  8. import android.view.KeyEvent;  
  9. import android.view.LayoutInflater;  
  10. import android.view.Menu;  
  11. import android.view.MenuItem;  
  12. import android.view.View;  
  13. import android.view.ViewGroup;  
  14. import android.widget.BaseAdapter;  
  15. import android.widget.GridView;  
  16. import android.widget.ImageView;  
  17. import android.widget.LinearLayout;  
  18. import android.widget.PopupWindow;  
  19. import android.widget.TextView;  
  20. import android.widget.LinearLayout.LayoutParams;  
  21.  
  22. public class PopupMenuDemo extends Activity {  
  23.       
  24.     private int[] resArray = new int[] {  
  25.             R.drawable.icon_menu_addto, R.drawable.icon_menu_audioinfo,  
  26.             R.drawable.icon_menu_findlrc, R.drawable.icon_menu_scan  
  27.     };  
  28.       
  29.     private String[] title = new String[]{  
  30.             "添加""信息""搜索""查看" 
  31.     };  
  32.       
  33.     private PopupWindow pw = null;  
  34.       
  35.     /** Called when the activity is first created. */ 
  36.     @Override 
  37.     public void onCreate(Bundle savedInstanceState) {  
  38.         super.onCreate(savedInstanceState);  
  39.         setContentView(R.layout.main);  
  40.     }  
  41.       
  42.  
  43.     @Override 
  44.     public boolean onCreateOptionsMenu(Menu menu) {  
  45.         menu.add("");  
  46.         return super.onCreateOptionsMenu(menu);  
  47.           
  48.     }  
  49.       
  50.     /**  
  51.      * 在此方法中实现自定义菜单栏  
  52.      */ 
  53.     public boolean onMenuOpened(int featureId, Menu menu) {  
  54.         if (pw != null) {  
  55.             if (pw.isShowing()) {  
  56.                 // 就关闭弹出窗口  
  57.                 pw.dismiss();  
  58.             }   
  59.             else {  
  60.                 //在指定位置弹出窗口  
  61.                 pw.showAtLocation(findViewById(R.id.tv), Gravity.CENTER, 0300);  
  62.             }  
  63.         }   
  64.         else {  
  65.  
  66.             LayoutInflater inflater = (LayoutInflater)this.getSystemService(Context.LAYOUT_INFLATER_SERVICE);        
  67.             View view = inflater.inflate(R.layout.menu, null);  
  68.             GridView grid1 = (GridView)view.findViewById(R.id.menuGridChange);  
  69.             grid1.setAdapter(new ImageAdapter(this));  
  70.               
  71.               
  72.             //生成PopupWindow对象  
  73.             pw = new PopupWindow(view,LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT);  
  74.               
  75.             //在指定位置弹出窗口  
  76.             pw.showAtLocation(findViewById(R.id.tv), Gravity.CENTER, 0300);  
  77.  
  78.         }  
  79.         // 此处返回false,系统不会执行onCreateOptionsMenu中添加的菜单  
  80.         return false;  
  81.     }  
  82.  
  83.  
  84.     public boolean onKeyDown(int keyCode, KeyEvent event) {  
  85.           
  86.         if(keyCode==KeyEvent.KEYCODE_BACK){  
  87.             pw.dismiss();  
  88.             return false;  
  89.         }  
  90.         return super.onKeyDown(keyCode, event);  
  91.     }  
  92.     @Override 
  93.     public boolean onOptionsItemSelected(MenuItem item) {  
  94.         return super.onOptionsItemSelected(item);  
  95.     }  
  96.  
  97.  
  98.     public class ImageAdapter extends BaseAdapter {  
  99.           
  100.         private Context context;  
  101.           
  102.         public ImageAdapter(Context context) {  
  103.             this.context = context;  
  104.         }  
  105.           
  106.         @Override 
  107.         public int getCount() {  
  108.             return resArray.length;  
  109.         }  
  110.  
  111.         @Override 
  112.         public Object getItem(int arg0) {  
  113.             return resArray[arg0];  
  114.         }  
  115.  
  116.         @Override 
  117.         public long getItemId(int arg0) {  
  118.             return arg0;  
  119.         }  
  120.  
  121.         @Override 
  122.         public View getView(int arg0, View arg1, ViewGroup arg2) {  
  123.             LinearLayout linear = new LinearLayout(context);  
  124.             LinearLayout.LayoutParams params = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);  
  125.             linear.setOrientation(LinearLayout.VERTICAL);  
  126.               
  127.             ImageView iv = new ImageView(context);  
  128.             iv.setImageBitmap(((BitmapDrawable)context.getResources().getDrawable(resArray[arg0])).getBitmap());  
  129.             LinearLayout.LayoutParams params2 = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);  
  130.             params2.gravity=Gravity.CENTER;  
  131.             linear.addView(iv, params2);  
  132.               
  133.             TextView tv = new TextView(context);  
  134.             tv.setText(title[arg0]);  
  135.             LinearLayout.LayoutParams params3 = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);  
  136.             params3.gravity=Gravity.CENTER;  
  137.               
  138.             linear.addView(tv, params3);  
  139.               
  140.             return linear;  
  141.         }  
  142.     }  

main.xml


 
 
  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.     > 
  7. <TextView    
  8.     android:id="@+id/tv" 
  9.     android:layout_width="fill_parent"   
  10.     android:layout_height="wrap_content"   
  11.     android:text="@string/hello" 
  12.     /> 
  13. </LinearLayout> 

menu.xml


 
 
  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.     > 
  7. <TextView    
  8.     android:id="@+id/tv" 
  9.     android:layout_width="fill_parent"   
  10.     android:layout_height="wrap_content"   
  11.     android:text="@string/hello" 
  12.     /> 
  13. </LinearLayout> 

 

menu_bg_frame.xml 这个文件是菜单背景的样式文件,在drawable-hdpi文件下面


 
 
  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <shape android:shape="rectangle" xmlns:android="http://schemas.android.com/apk/res/android"> 
  3.     <solid android:color="#b4000000" /> 
  4.     <stroke android:width="2.0dip" android:color="#b4ffffff" android:dashWidth="3.0dip" android:dashGap="0.0dip" /> 
  5.     <padding android:left="7.0dip" android:top="7.0dip" android:right="7.0dip" android:bottom="7.0dip" /> 
  6.     <corners android:radius="8.0dip" /> 
  7. </shape> 

 

本文转自 lingdududu 51CTO博客,原文链接: 

http://blog.51cto.com/liangruijun/739459




相关文章
|
1月前
|
IDE Java 开发工具
深入探索安卓应用开发:从环境搭建到第一个"Hello, World!"应用
本文将引导读者完成安卓应用开发的初步入门,包括安装必要的开发工具、配置开发环境、创建第一个简单的安卓项目,以及解释其背后的一些基本概念。通过一步步的指导和解释,本文旨在为安卓开发新手提供一个清晰、易懂的起点,帮助读者顺利地迈出安卓开发的第一步。
205 65
|
1月前
|
存储 Java Android开发
探索安卓应用开发:构建你的第一个"Hello World"应用
【9月更文挑战第24天】在本文中,我们将踏上一段激动人心的旅程,深入安卓应用开发的奥秘。通过一个简单而经典的“Hello World”项目,我们将解锁安卓应用开发的基础概念和步骤。无论你是编程新手还是希望扩展技能的老手,这篇文章都将为你提供一次实操体验。从搭建开发环境到运行你的应用,每一步都清晰易懂,确保你能顺利地迈出安卓开发的第一步。让我们开始吧,探索如何将一行简单的代码转变为一个功能齐全的安卓应用!
|
28天前
|
Java Maven 开发工具
第一个安卓项目 | 中国象棋demo学习
本文是作者关于其第一个安卓项目——中国象棋demo的学习记录,展示了demo的运行结果、爬坑记录以及参考资料,包括解决Android Studio和maven相关问题的方法。
第一个安卓项目 | 中国象棋demo学习
|
6天前
|
调度 Android开发 开发者
构建高效Android应用:探究Kotlin多线程优化策略
【10月更文挑战第11天】本文探讨了如何在Kotlin中实现高效的多线程方案,特别是在Android应用开发中。通过介绍Kotlin协程的基础知识、异步数据加载的实际案例,以及合理使用不同调度器的方法,帮助开发者提升应用性能和用户体验。
22 4
|
6天前
|
编解码 Android开发 UED
构建高效Android应用:从内存优化到用户体验
【10月更文挑战第11天】本文探讨了如何通过内存优化和用户体验改进来构建高效的Android应用。介绍了使用弱引用来减少内存占用、懒加载资源以降低启动时内存消耗、利用Kotlin协程进行异步处理以保持UI流畅,以及采用响应式设计适配不同屏幕尺寸等具体技术手段。
22 2
|
16天前
|
JSON API Android开发
探索安卓开发之旅:打造你的第一个天气应用
在这篇文章中,我们将一起踏上一段激动人心的旅程,学习如何在安卓平台上开发一个简单的天气应用。通过实际操作和代码示例,我们将逐步构建一个能够显示当前位置天气情况的应用。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供清晰的指导和启发性的见解,帮助你理解和掌握安卓开发的基础知识。让我们一起探索代码的世界,解锁新技能,实现你的创意和梦想。
|
20天前
|
安全 Java API
Java 泛型在安卓开发中的应用
在Android开发中,Java泛型广泛应用于集合类、自定义泛型类/方法、数据绑定、适配器及网络请求等场景,有助于实现类型安全、代码复用和提高可读性。例如,结合`ArrayList`使用泛型可避免类型转换错误;自定义泛型类如`ApiResponse&lt;T&gt;`可处理不同类型API响应;RecyclerView适配器利用泛型支持多种视图数据;Retrofit结合泛型定义响应模型,明确数据类型。然而,需注意类型擦除导致的信息丢失问题。合理使用泛型能显著提升代码质量和应用健壮性。
|
16天前
|
XML 数据可视化 Android开发
Android应用界面
Android应用界面中的布局和控件使用,包括相对布局、线性布局、表格布局、帧布局、扁平化布局等,以及AdapterView及其子类如ListView的使用方法和Adapter接口的应用。
11 0
Android应用界面
|
1月前
|
开发框架 搜索推荐 开发工具
打造个性化安卓应用:从零开始的Flutter之旅
【8月更文挑战第51天】本文是一篇面向初学者的Flutter入门教程,旨在通过简单易懂的语言和实际代码示例,引导读者步入跨平台移动应用开发的世界。文章首先介绍了Flutter的基本概念和优势,然后逐步展示了如何搭建开发环境、创建第一个Flutter应用,并实现了一个简单的待办事项列表。最后,文章探讨了Flutter在实现高性能和美观界面方面的潜力,鼓励读者发挥创意,探索更多可能。
79 15
|
27天前
|
监控 安全 Java
Kotlin 在公司上网监控中的安卓开发应用
在数字化办公环境中,公司对员工上网行为的监控日益重要。Kotlin 作为一种基于 JVM 的编程语言,具备简洁、安全、高效的特性,已成为安卓开发的首选语言之一。通过网络请求拦截,Kotlin 可实现网址监控、访问时间记录等功能,满足公司上网监控需求。其简洁性有助于快速构建强大的监控应用,并便于后续维护与扩展。因此,Kotlin 在安卓上网监控应用开发中展现出广阔前景。
16 1