`
xiaoming123123
  • 浏览: 100326 次
  • 性别: Icon_minigender_1
  • 来自: 南昌
社区版块
存档分类
最新评论

popupWindow弹出式窗口

阅读更多

 

转自:http://www.eoeandroid.com/thread-48051-1-1.html

昨天上午去了个面试,公司名我就不说了。面我那哥们问我有没有实现过半透明的popupwindow。哎,俺实在,没有做过那就是没有做过。估计那哥们也没打算要我,嫌我经验不够,我也没有舌灿莲花那种口才。公司老总说要求签卖身契,3年合同,3年之内辞职要赔钱。3年时间何其漫长,要是公司留得住人,不用签卖身契照样生意兴隆,人才(财)滚滚而来。现在打算去广州了,女朋友一个人在那边,男人嘛,该承担还是得承担,论坛里哪位兄弟公司需要招人,能不能推荐一下,最好在广州的,不胜感激,谢谢。
不罗嗦了,言归正传。。。
下午回来想想不爽,这个东西我还真要把它弄出来。网上搜了一下,没合适的,最多的就是两种:
1.设置半透明主题
2.设置window的alpha值
  1. //                        WindowManager.LayoutParams lp = getWindow().getAttributes();
  2. //            lp.alpha = 0.5f; //0.0-1.0
  3. //            getWindow().setAttributes(lp);
复制代码

发现这两种都不能满足要求,起码的颜色就不太对。想做好点,做成类似alertDialog的样子,带边框,弹出窗口带动画效果,之后背景置灰,那多帅。
看到那个仿uc浏览器的源码,是用alertdialog做的,达到那种效果,加点动画就行了。下图是从那个ucweb源码里面弄出来的。

dialog.jpg


 


       上面的代码就不贴了,我上传的项目文件里面也有。
        下面是弹出popupwindow的图片,第一张是动画中,第二张是完全弹出的:

popupwindowAnim.jpg

 


popupwindow.jpg

 



  


         弹出popwindow的代码如下,比较乱,多包涵:


  1. popupWindow = new PopupWindow(menuView, LayoutParams.FILL_PARENT,
  2.                                 LayoutParams.FILL_PARENT, true);
  3.                 popupWindow.showAtLocation(findViewById(R.id.parent), Gravity.CENTER
  4.                                 | Gravity.CENTER, 0, 0);
  5.                 popupWindow.setAnimationStyle(R.style.PopupAnimation);
  6.                 // 加上下面两行可以用back键关闭popupwindow,否则必须调用dismiss();
  7.                 ColorDrawable dw = new ColorDrawable(-00000);
  8.                 popupWindow.setBackgroundDrawable(dw);
  9.                 popupWindow.update();
复制代码

下面是实现步骤:   
1。背景置灰:
     popupWindow = new PopupWindow(menuView, LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT, true);
     第二三个参数必须是LayoutParams.FILL_PARENT,这样才能填充整个屏幕,达到背景置灰的目的。
     整个popupwindow里面是一个GridView,图片什么的也是用的那个仿UC浏览器界面项目的,在此谢谢了。
     关键的东西都在xml里面。
      
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3.            android:orientation="vertical" android:layout_width="fill_parent"
  4.             android:gravity="center" android:layout_height="fill_parent"
  5.            android:layout_gravity="center" android:background="#b0000000" >
  6.          <LinearLayout android:orientation="vertical"
  7.                    android:layout_width="wrap_content" android:gravity="center"
  8.                    android:layout_height="wrap_content" android:layout_gravity="center"
  9.                    android:background="@drawable/downbutton_corner">
  10.                  <GridView android:id="@+id/gridview" android:layout_width="wrap_content"
  11.                             android:layout_height="wrap_content" android:numColumns="4"
  12.                             android:verticalSpacing="5dip" android:horizontalSpacing="5dip"
  13.                             android:stretchMode="columnWidth" android:gravity="center"
  14.                             android:layout_gravity="center" /></LinearLayout></LinearLayout>
复制代码

第一个linearlayout里面的android:background="#b0000000",就是全屏背景,网上搜的好多半透明都是“#e0000000”,我觉得那颜色太深,“#b0000000”更合适。
第二个linearlayout是popupwind的背景,里面的android:background="@drawable/downbutton_corner"是关键,边框,圆角都是里面定义的。

2。popupwindow的边框,圆角背景。downbutton_corne.xml
  1. <shape xmlns:android="http://schemas.android.com/apk/res/android"
  2.         android:shape="rectangle">
  3.         <gradient android:startColor="#c0000000" android:endColor="#c0000000"
  4.                 android:angle="90" /><!--背景颜色渐变 -->
  5.         <stroke android:dashWidth="2dp" android:dashGap="2dp"
  6.                 android:width="2dp" android:color="#FF00ff00"></stroke>
  7.         <!--描边 -->
  8.         <corners android:bottomRightRadius="5dp"
  9.                 android:bottomLeftRadius="5dp" android:topLeftRadius="5dp"
  10.                 android:topRightRadius="5dp" /><!--设置圆角-->
  11. </shape>
复制代码

这个涉及到shape画图,要是不懂的话。网上很多资料,搜一下就是了。我博客里面也有,http://blog.csdn.net/ymdcr/archive/2010/12/01/6048256.aspx
<gradient android:startColor="#c0000000" android:endColor="#c0000000" android:angle="90" /><!--背景颜色渐变 -->
我就设置了一个固定的颜色"#c0000000"。android:angle="90"这个是设置颜色渐变方向,从上到下啊,从左到右啊,貌似只能90的倍数,也只有四个方向嘛。
<stroke ></stroke>,边框就是这个实现的。
dashWidth指的是边线的宽度 dashGap 指的是每条线之间的间距,(因为是边线是很多小横线组成的)。

3。淡入淡出动画
popupWindow.setAnimationStyle(R.style.PopupAnimation);
这条代码是设置style的,动画文件就是在style文件里面引入的。下面是淡入的动画,动画教程网上也很多。淡出的动画就这些参数值交换位置就是了。android:duration这个是持续时间,为了截图,我把它弄成5秒了。
  1. <set xmlns:android="http://schemas.android.com/apk/res/android">
  2.         <scale android:fromXScale="0.6" android:toXScale="1.0"
  3.                 android:fromYScale="0.6" android:toYScale="1.0" android:pivotX="50%"
  4.                 android:pivotY="50%" android:duration="5000" />
  5.         <alpha android:interpolator="@android:anim/decelerate_interpolator"
  6.                 android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="5000" />
  7. </set>
复制代码


大概就是这些了。

还有一个关键的问题。弹出pop之后,back键无效了,必须在pop里面设置事件dismiss掉。下面是问题的描述,哪位解决了,告诉我一下,谢谢。我的邮箱:ytdcr@tom.com
问题解决了,是因为没设置背景的原因。    
popupWindow.setBackgroundDrawable(new BitmapDrawable());
//把这一行放在
showAtLocation前面就行了,以前是放在后面的,粗心了。
popupWindow.showAtLocation(findViewById(R.id.parent), Gravity.CENTER
                | Gravity.CENTER, 0, 0);
  
网上也有很多人说,弹出pop之后,不响应键盘事件了,这个其实是焦点在pop里面的view去了。
以这个为例,焦点就在gridview上面去了。28楼的兄弟提示的,谢了。
在gridview加上
setOnKeyListener,就能解决。
  1. menuGrid.setOnKeyListener(new OnKeyListener() {
  2.             @Override
  3.             public boolean onKey(View v, int keyCode, KeyEvent event) {
  4.                 switch (keyCode) {
  5.                 case KeyEvent.KEYCODE_MENU:
  6.                     if (popupWindow != null && popupWindow.isShowing()) {
  7.                         popupWindow.dismiss();
  8.                         System.out.println("menuGridfdsfdsfdfd");
  9.                     }
  10.                     break;
  11.                 }
  12.             
  13.                 return true;
  14.             }
  15.         });
复制代码
[ code]/**
     * ColorDrawable dw = new ColorDrawable(-00000);
     * popupWindow.setBackgroundDrawable(dw);
     * 本来看了个示例,加上上面这两行就不用调用dismiss,点击窗口之外的部位,或者按back键都能关闭窗口。 但是我这样写了,还是不行。
     * 而且竟然捕获不到键盘事件,杯具,希望哪个解决了这个问题告诉我,谢谢。 ytdcr@tom.com
     */
    /*
     * @Override public boolean onKeyDown(int keyCode, KeyEvent event) { switch
     * (keyCode) { case KeyEvent.KEYCODE_BACK: if (popupWindow != null) {
     * popupWindow.dismiss(); }
     *
     * Toast.makeText(this, "fd", 1000).show(); break;
     *
     * } return super.onKeyUp(keyCode, event); }
     */[/code]

分享到:
评论
1 楼 kenlistian 2012-09-02  
不错,做的非常好,适合新手学习

相关推荐

    自定义PopupWindow实现底部弹出式菜单

    在Android开发中,`PopupWindow` 是一个非常实用的组件,它允许开发者创建浮动、可定制的窗口,常用于实现各种弹出式效果,如底部菜单、上下拉选择器等。本篇将深入探讨如何利用`PopupWindow`来实现一个自定义的底部...

    Android安卓源码_PopupWindow弹出菜单.zip

    本资源"Android安卓源码_PopupWindow弹出菜单.zip"提供了一个具体的示例,帮助开发者深入理解如何在实际应用中使用`PopupWindow`。 `PopupWindow`的基本概念: 1. `PopupWindow`类是Android SDK中的一个类,它可以...

    PopupWindow使用,弹出菜单窗口

    PopupWindow在Android开发中是一种非常常用的组件,它用于创建弹出式窗口,通常用作对话框、下拉菜单或者快捷操作按钮。这个组件允许开发者在应用程序的任何位置显示一个浮动的视图,提供了灵活的布局和交互方式。...

    窗帘式 从上往下弹出popupwindow带遮罩

    在PopupWindow弹出之前,为父布局添加一个半透明的遮罩层。遮罩层可以是一个全屏的LinearLayout或RelativeLayout,设置其背景为半透明色。 ```java ViewGroup parentLayout = (ViewGroup) findViewById(R.id....

    Android弹出式窗口(PopupWindow)

    3. 搜索框:在用户点击搜索图标后,弹出一个包含输入框的窗口。 4. 自定义操作:在特定视图上提供额外的可操作选项。 总之,PopupWindow是Android开发中一个非常实用的工具,通过合理的布局设计和动画效果,可以...

    带缓冲的弹出式窗口(宋鑫)

    首先,弹出式窗口(PopupWindow)在Android应用中是一种常见的UI组件,用于展示临时或上下文相关的信息。它可以在当前屏幕的任意位置显示,并且能够根据需要自动隐藏。带缓冲的弹出式窗口则是在弹出窗的基础上,加入...

    Android源码——PopupWindow实现弹出菜单.zip

    在Android开发中,`PopupWindow` 是一个非常重要的组件,常用于实现各种弹出式菜单、下拉选择器等交互效果。本资料包"Android源码——PopupWindow实现弹出菜单.zip"主要聚焦于如何利用`PopupWindow`来创建自定义的弹...

    从顶部弹出的PopupWindow,动画弹出

    在Android开发中,`PopupWindow` 是一个非常实用的组件,它允许我们创建浮动、弹出式的窗口,可以用于实现各种对话框效果。本篇将深入探讨如何利用`PopupWindow` 创建从顶部弹出的动画效果,以及相关的重要知识点。 ...

    jQuery弹出层窗口插件popupWindow.js

    jQuery弹出层窗口插件popupWindow.js是一款基于jQuery的轻量级组件,它极大地简化了在Web应用中创建模态对话框或浮动窗口的过程。这个插件提供了丰富的功能,包括最大化、最小化、窗口拖拽以及自定义尺寸调整,使得...

    jQuery实现弹出层窗口插件popupWindow.js.zip

    3. **响应式设计**:针对不同的设备和屏幕尺寸,调整弹出窗口的布局和大小。 总结,popupWindow.js作为一款基于jQuery的弹出层插件,提供了丰富的功能和高度的可定制性,是实现网页弹出窗口功能的理想选择。通过...

    弹出式窗体模板(for Microsoft Visual Studio)

     本系统是为Microsoft Visual Studio开发的一套弹出式窗体的模板,通过此模板,用户可以在自己的应用程序中轻松建立弹出式窗口。系统实现了窗口的弹出、回落、渐隐和渐现等效果,并且支持不规则窗体的建立(需要...

    Android代码-之用PopupWindow实现弹出菜单.zip

    在Android开发中,PopupWindow是一种常用的UI组件,用于在界面上创建临时的、浮动的视图,常用于实现各种弹出式菜单、下拉选择器等。本资料包"Android代码-之用PopupWindow实现弹出菜单.zip"显然是为了演示如何在...

    PopupWindow实现方法(类似百度与谷歌地图主题图层弹出方法)

    PopupWindow是Android系统中用于创建弹出式窗口的一个类,常用于实现类似对话框的效果,但相比Dialog,它更加灵活,可以自定义更多的布局和交互方式。本实践案例旨在实现百度地图和谷歌地图主题图层按钮点击后弹出的...

    Dialog和PopupWindow底部弹出

    在Android开发中,Dialog和PopupWindow是两种常用的用于创建弹出式界面的组件。它们都可以实现底部弹出的效果,但有着不同的特性和使用场景。在本篇内容中,我们将深入探讨如何利用Dialog和PopupWindow来实现底部弹...

    Android PopupWindow实现右侧、左侧和底部弹出菜单

    PopupWindow的特性包括大小可变、背景可透明、支持动画效果等,这使得它成为设计弹出式界面的首选工具。 要实现右侧、左侧和底部弹出菜单,我们需要完成以下几个步骤: 1. **创建布局文件**: 首先,为每个菜单...

    android自定义popupwindow仿微信右上角弹出菜单效果

    在Android开发中,`PopupWindow` 是一个非常实用的组件,它可以用来创建各种弹出式菜单或对话框。本文将详细介绍如何使用`PopupWindow`在Android应用中模仿微信右上角的弹出菜单效果。 首先,我们需要理解`...

    Android PopupWindow实现弹出菜单.zip

    在Android开发中,PopupWindow是一个非常实用的组件,它能够创建一种浮动的窗口效果,常用于实现各种弹出式菜单、提示信息等。本资料"Android PopupWindow实现弹出菜单.zip"应该包含了如何利用PopupWindow在Android...

    安卓Android源码——Android之用PopupWindow实现弹出菜单.zip

    总结来说,`PopupWindow`在Android开发中扮演着重要的角色,它可以轻松创建各种弹出式UI,如菜单、提示框等。通过理解和熟练运用`PopupWindow`,开发者能够为应用程序增添更多丰富的交互体验。这个压缩包中的...

    探索Popupwindow-对话框风格的窗口(一)

    PopupWindow是Android开发中一种非常实用的组件,它允许开发者创建弹出式窗口,通常用于显示临时信息或者提供额外的功能选项。在这个“探索PopupWindow-对话框风格的窗口(一)”主题中,我们将深入理解PopupWindow...

    PopupWindow

    在Android应用开发中,PopupWindow常用于创建弹出式菜单、提示信息或者增强用户交互体验。下面将详细介绍PopupWindow的使用方法、特性以及常见应用场景。 1. **PopupWindow的基本结构** PopupWindow主要由三部分...

Global site tag (gtag.js) - Google Analytics