最近要改客户端,需要实现一个从底部弹出的popuwindow,像我这种渣渣android技术,能整出popuwindow但是整不出动画,百度之,记录一下。

从下面这个地址转的 http://blog.csdn.net/yxhuang2008/article/details/42617805

最近因为要用到PopupWindow,所以,就在网上搜索了一下,发现挺多关于这样的文章,现在我把它们整理了一下。

1、Android PopupWindow 的使用技巧,http://www.cnblogs.com/sw926/p/3230659.html

2、Android PopupWindow 的使用和分析,http://www.cnblogs.com/mengdd/p/3569127.html

3、Android PopupWindow 实现从底部弹出或滑出选择菜单或窗口,http://104zz.iteye.com/blog/1685389

本文是整理上面三篇文章而成,绝大部分代码是使用第三篇的,如有不妥,请联系。

一、第一步就是创建布局文件

res/layout/finish_project_popupwindow.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:orientation="vertical" >
  6. <Button
  7. android:id="@+id/popupwindow_Button_saveProject"
  8. android:layout_marginLeft="20dip"
  9. android:layout_marginRight="20dip"
  10. android:layout_marginTop="10dip"
  11. android:layout_width="match_parent"
  12. android:layout_height="wrap_content"
  13. android:text="@string/popupwindow_Button_saveProject" />
  14. <Button
  15. android:id="@+id/popupwindow_Button_abandonProject"
  16. android:layout_marginLeft="20dip"
  17. android:layout_marginRight="20dip"
  18. android:layout_marginTop="10dip"
  19. android:layout_width="match_parent"
  20. android:layout_height="wrap_content"
  21. android:text="@string/popupwindow_Button_abandonProject" />
  22. <Button
  23. android:id="@+id/popupwindow_cancelButton"
  24. android:layout_marginLeft="20dip"
  25. android:layout_marginRight="20dip"
  26. android:layout_marginTop="10dip"
  27. android:layout_width="match_parent"
  28. android:layout_height="wrap_content"
  29. android:text="@string/popupwindow_cancelButton" />
  30. </LinearLayout>

二、第二步,设置PopupWindow弹出和淡出的动画效果

1、在res目录下建立一个文件夹anim,专门用于存储PopupWindow弹出和淡出的动画效果

(1)PopupWindow  弹出时的动画效果

res/anim/enter_anim.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:shareInterpolator="false">
  4. <translate
  5. android:fromYDelta="100%p"
  6. android:toYDelta="0"
  7. android:duration="500" />
  8. <alpha
  9. android:fromAlpha="0"
  10. android:toAlpha="1.0"
  11. android:duration="300"/>
  12. </set>

(2)PopupWindow 淡出时的动画效果

res/anim/out_anim.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <set xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:shareInterpolator="false">
  4. <translate
  5. android:fromYDelta="0"
  6. android:toYDelta="100%p"
  7. android:duration="3000"/>
  8. <alpha
  9. android:fromAlpha="1.0"
  10. android:toAlpha="0"
  11. android:duration="2000"/>
  12. </set>

在<translate>标签中,fromYDelta, toYDelta 表示在y轴方法的移动,因为我是要实现从底部弹出PopupWindow的,所以,是y轴,如果想要实现从屏幕侧边的话,可以选择x轴fromXDelta, toXDelta。

duration 表示弹出或者淡出的动画时间。在<alpha>标签中表示PopupWindow透明度的变化,这样是为了比较好看。duration 同样表示时间。

(3)增加这样的Style

在res/valus/styles.xml  的<resources>标签内添加

  1. <!-- popupwindow 动画 -->
  2. <style name="Animation">
  3. <item name="android:windowEnterAnimation">@anim/enter_anim</item>
  4. <item name="android:windowExitAnimation">@anim/out_anim</item>
  5. </style>

其中,

  1. <item name="android:windowEnterAnimation">@anim/enter_anim</item>

表示窗口弹出时的动画文件,@anim/enter_anim  中enter_anim一定要和我们前面定义弹出动画的文件名一致,淡出的动画文件类似。

三、创建自定义类,继承PopupWindow

src/FinishProjectPopupWindow.java

  1. import android.app.Activity;
  2. import android.content.Context;
  3. import android.graphics.drawable.ColorDrawable;
  4. import android.util.Log;
  5. import android.view.LayoutInflater;
  6. import android.view.View;
  7. import android.view.View.OnClickListener;
  8. import android.view.ViewGroup.LayoutParams;
  9. import android.widget.Button;
  10. import android.widget.PopupWindow;
  11. public class FinishProjectPopupWindows extends PopupWindow{
  12. private static final String TAG = "FinishProjectPopupWindows";
  13. private View mView;
  14. public Button btnSaveProject, btnAbandonProject, btnCancelProject;
  15. public FinishProjectPopupWindows(Activity context,
  16. OnClickListener itemsOnClick) {
  17. super(context);
  18. Log.i(TAG, "FinishProjectPopupWindow 方法已被调用");
  19. LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  20. mView = inflater.inflate(R.layout.finish_project_popuwindow, null);
  21. btnSaveProject = (Button) mView.findViewById(R.id.popupwindow_Button_saveProject);
  22. btnAbandonProject = (Button) mView.findViewById(R.id.popupwindow_Button_abandonProject);
  23. btnCancelProject = (Button) mView.findViewById(R.id.popupwindow_cancelButton);
  24. // 设置按钮监听
  25. btnCancelProject.setOnClickListener(new OnClickListener(){
  26. @Override
  27. public void onClick(View v) {
  28. Log.i(TAG, "取消项目");
  29. dismiss();
  30. }
  31. });
  32. btnSaveProject.setOnClickListener(itemsOnClick);
  33. btnAbandonProject.setOnClickListener(itemsOnClick);
  34. //设置PopupWindow的View
  35. this.setContentView(mView);
  36. //设置PopupWindow弹出窗体的宽
  37. this.setWidth(LayoutParams.MATCH_PARENT);
  38. //设置PopupWindow弹出窗体的高
  39. this.setHeight(LayoutParams.WRAP_CONTENT);
  40. //设置PopupWindow弹出窗体可点击
  41. this.setFocusable(true);
  42. //设置SelectPicPopupWindow弹出窗体动画效果
  43. this.setAnimationStyle(R.style.Animation);
  44. //实例化一个ColorDrawable颜色为半透明
  45. ColorDrawable dw = new ColorDrawable(0xb0000000);
  46. //设置SelectPicPopupWindow弹出窗体的背景
  47. this.setBackgroundDrawable(dw);
  48. }
  49. }

四、在Activity中设置弹出PopupWindow

  1. private FinishProjectPopupWindows mFinishProjectPopupWindow
  1. mFinishProjectPopupWindow = new FinishProjectPopupWindows(MapFragmentActivity.this, itemsOnClick);
  2. // 显示PopupWindow
  1. mFinishProjectPopupWindow.showAtLocation(MapFragmentActivity.this.findViewById(R.id.main),
  2. Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 0, 0);

五、实现PopupWindow中按钮的监听

  1. private OnClickListener  itemsOnClick = new OnClickListener(){
  2. @Override
  3. public void onClick(View v) {
  4. mFinishProjectPopupWindow.dismiss();
  5. switch(v.getId()){
  6. case R.id.popupwindow_Button_saveProject:
  7. Log.i(TAG, "保存线路");
  8. break;
  9. case R.id.popupwindow_Button_abandonProject:
  10. break;
  11. case R.id.popupwindow_cancelButton:
  12. mFinishProjectPopupWindow.dismiss();
  13. Log.i(TAG, "取消");
  14. break;
  15. }
  16. }
  17. };

运行的效果

转 android 从底部弹出一个popuwindow,渐入渐出效果。我这里是用在购物车需要选择购买选项的操作。的更多相关文章

  1. 给出一个数组A,找出一对 (i, j)使得A[i] <= A[j] (i < j)并且j-i最大

    题目:给出一个数组A,找出一对 (i, j)使得A[i] <= A[j] (i <= j)并且j-i最大 ,若有多个这样的位置对,返回i最小的那一对. 最直接的想法就是对于每一个 i 从数 ...

  2. MFC上下浮动与渐入渐出消息提示框实现

    类似QQ与360软件,消息提示有两种.上下浮动.渐入渐出. 1.上下浮动提示框实现 机制,定时器响应上下浮动消息. 主要API:MoveWindow. 源码如下UpDownTipDlg.h.UpDow ...

  3. MFC渐入渐出框实现方式二

    类似360消息弹出框,实现方式一见http://blog.csdn.net/segen_jaa/article/details/7848598. 本文采用另外的API实现渐入渐出效果. 主要API:S ...

  4. 解决Jquery mobile点击较长文本body的时候Header和footer会渐入渐出的问题

         在做一个Phonegap+Jqm工程的时候,出现了如题的问题,相信很多人都遇到过Jquerymobile点击body时候header和footer会闪烁的显示和隐藏问题,fixed却并不能真 ...

  5. [Unity3D]Unity3D游戏开发之Logo渐入渐出效果的实现

    ---------------------------------------------------------------------------------------------------- ...

  6. NSIS:实现程序窗口逐渐透明的渐入渐出效果

    原文NSIS:实现程序窗口逐渐透明的渐入渐出效果 需要修改版的插件(支持timer功能): MUI:InstallOptions.dll MUI2:nsDialogs.dll 以及system插件,( ...

  7. js原生实现div渐入渐出

    jq对渐入渐出进行封装,简单的使用连个方法就可以实现.fadeIn(),fadeOut();如果我们界面没有使用jq那么原生怎么实现呢? 我们讲解一下,这个原理.当我们要实现渐入的时候,首先是让隐藏的 ...

  8. 用js写出一个漂亮的单选框选中效果

    一般的input框比较简单,我们可以用JavaScript配合css背景图片定位让我们模拟写出一个点击选中效果 首先需要有个图片素材,当页面加载的时候是背景图片定位到左图,当我们点击图片的时候,背景图 ...

  9. android Dialog 底部弹出

    . if (dialShareDialog == null) { dialShareDialog = new Dialog(context, R.style.dialog); dialShareDia ...

随机推荐

  1. iOS Block简介

    Block是对象,它封装了一段代码,这段代码可以在任何时候执行.block可以作为函数参数或者函数的返回值,而其本身又可以带输入参数或返回值.它和传统的函数指针很类似,但是有区别:block是inli ...

  2. Linux安全基础:awk命令的使用

    awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大.简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各 ...

  3. Android—自定义标题栏的实现及遇见的问题解决

    开发者设计界面时候往往不会使用系统自带的标题栏,因为不美观,所以需要自己设置标题栏. 1.根据需求在xml文件中设置标题布局 <?xml version="1.0" enco ...

  4. Shou 团队诚意满满的招募 Swifter

    一.团队介绍 团队产品 VPlayer 播放器靠自增长 3 年内获得全球 4000 万用户,开发的 Vitamio 组件更是获得微博.UC.金山等知名企业授权使用.—— 团队再次起航,经历一年多我们已 ...

  5. IOS RunLoop面试题

    一 什么是RunLoop? 从字面意思看就是运行循环,其实内部就是do-while循环,这个循环内部不断地处理各种任务(比 如Source,Timer,Observer) 一个线程对应一个RunLoo ...

  6. 用EF访问Centos下的MySQL

    环境 : MySQL 5.6.21 64位 CentOS 6.5 64位 VMware 10 Navicat for MySQL 11 VS2013 1.首先搭建centos 的MySQL开发环境 : ...

  7. MySQL修改root账号密码

    MySQL数据库中如何修改root用户的密码呢?下面总结了修改root用户密码的一些方法   1: 使用set password语句修改 mysql> select user(); +----- ...

  8. 15天玩转redis —— 第十一篇 让你彻底了解RDB存储结构

    接着上一篇说,这里我们来继续分析一下RDB文件存储结构,首先大家都知道RDB文件是在redis的“快照”的模式下才会产生,那么如果 我们理解了RDB文件的结构,是不是让我们对“快照”模式能做到一个心中 ...

  9. SQL报表(Report Builder)里面的几个常见问题(持续更新)

    一 SQL报表常常会遇到在表格中的相除,如果分母为零,一般会显示错误号,我们可以这么处理:(加上是A/B) ,, B) 但是我们不能这么写: ,,A/B) //我们不能这么写,会产生BUG,至于什么B ...

  10. Elasticsearch配置文件说明

    一.Cluster  setting Cluster indices.ttl.interval  允许设置多久过期的文件会被自动删除.默认值是60秒. indices.cache.filter.siz ...