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

本教程为大家分享了Android PopupWindow弹出菜单的具体代码,供大家参考,具体内容如下

项目代码:http://xiazai.jb51.net/201611/yuanma/PopupLeftMenu(jb51.net).rar

项目SDK是5.1,建议将代码拷到自己的工程中去

代码如下:

MainActivity类:

package com.example.popupleftmenu; 

import android.app.Activity;
import android.content.Context;
import android.graphics.drawable.ColorDrawable;
import android.os.Bundle;
import android.view.Gravity;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.view.ViewGroup.LayoutParams;
import android.view.WindowManager;
import android.widget.Button;
import android.widget.PopupWindow;
import android.widget.Toast; 

public class MainActivity extends Activity { 

 private Context context = null;
 private PopupWindow popupWindow;
 private int from = 0; 

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  context = this;
  setContentView(R.layout.activity_main);
  Button popLeftBtn = (Button)findViewById(R.id.pop_left_btn);
  Button popRightBtn = (Button)findViewById(R.id.pop_right_btn);
  Button popBottomBtn = (Button)findViewById(R.id.pop_bottom_btn);
  popLeftBtn.setOnClickListener(popClick);
  popRightBtn.setOnClickListener(popClick);
  popBottomBtn.setOnClickListener(popClick);
 } 

 OnClickListener popClick = new OnClickListener() { 

  @Override
  public void onClick(View v) {
   switch(v.getId()){
    case R.id.pop_left_btn:{
     from = Location.LEFT.ordinal();
     break;
    }
    case R.id.pop_right_btn:{
     from = Location.RIGHT.ordinal();
     break;
    }
    case R.id.pop_bottom_btn:{
     from = Location.BOTTOM.ordinal();
     break;
    }
   } 

   //调用此方法,menu不会顶置
   //popupWindow.showAsDropDown(v);
   initPopupWindow(); 

  }
 };
 /**
  * 添加新笔记时弹出的popWin关闭的事件,主要是为了将背景透明度改回来
  *
  */
 class popupDismissListener implements PopupWindow.OnDismissListener{ 

  @Override
  public void onDismiss() {
   backgroundAlpha(1f);
  } 

 } 

 protected void initPopupWindow(){
  View popupWindowView = getLayoutInflater().inflate(R.layout.pop, null);
  //内容,高度,宽度
  if(Location.BOTTOM.ordinal() == from){
   popupWindow = new PopupWindow(popupWindowView, LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT, true);
  }else{
   popupWindow = new PopupWindow(popupWindowView, LayoutParams.WRAP_CONTENT, LayoutParams.FILL_PARENT, true);
  }
  //动画效果
  if(Location.LEFT.ordinal() == from){
   popupWindow.setAnimationStyle(R.style.AnimationLeftFade);
  }else if(Location.RIGHT.ordinal() == from){
   popupWindow.setAnimationStyle(R.style.AnimationRightFade);
  }else if(Location.BOTTOM.ordinal() == from){
   popupWindow.setAnimationStyle(R.style.AnimationBottomFade);
  }
  //菜单背景色
  ColorDrawable dw = new ColorDrawable(0xffffffff);
  popupWindow.setBackgroundDrawable(dw);
  //宽度
  //popupWindow.setWidth(LayoutParams.WRAP_CONTENT);
  //高度
  //popupWindow.setHeight(LayoutParams.FILL_PARENT);
  //显示位置
  if(Location.LEFT.ordinal() == from){
   popupWindow.showAtLocation(getLayoutInflater().inflate(R.layout.activity_main, null), Gravity.LEFT, 0, 500);
  }else if(Location.RIGHT.ordinal() == from){
   popupWindow.showAtLocation(getLayoutInflater().inflate(R.layout.activity_main, null), Gravity.RIGHT, 0, 500);
  }else if(Location.BOTTOM.ordinal() == from){
   popupWindow.showAtLocation(getLayoutInflater().inflate(R.layout.activity_main, null), Gravity.BOTTOM|Gravity.CENTER_HORIZONTAL, 0, 0);
  }
  //设置背景半透明
  backgroundAlpha(0.5f);
  //关闭事件
  popupWindow.setOnDismissListener(new popupDismissListener()); 

  popupWindowView.setOnTouchListener(new OnTouchListener() { 

   @Override
   public boolean onTouch(View v, MotionEvent event) {
    /*if( popupWindow!=null && popupWindow.isShowing()){
     popupWindow.dismiss();
     popupWindow=null;
    }*/
    // 这里如果返回true的话,touch事件将被拦截
    // 拦截后 PopupWindow的onTouchEvent不被调用,这样点击外部区域无法dismiss
    return false;
   }
  }); 

  Button open = (Button)popupWindowView.findViewById(R.id.open);
  Button save = (Button)popupWindowView.findViewById(R.id.save);
  Button close = (Button)popupWindowView.findViewById(R.id.close); 

  open.setOnClickListener(new OnClickListener() { 

   @Override
   public void onClick(View v) {
    Toast.makeText(context, "Open", Toast.LENGTH_LONG).show();
    popupWindow.dismiss();
   }
  }); 

  save.setOnClickListener(new OnClickListener() { 

   @Override
   public void onClick(View v) {
    Toast.makeText(context, "Open", Toast.LENGTH_LONG).show();
    popupWindow.dismiss();
   }
  }); 

  close.setOnClickListener(new OnClickListener() { 

   @Override
   public void onClick(View v) {
    Toast.makeText(context, "Open", Toast.LENGTH_LONG).show();
    popupWindow.dismiss();
   }
  });
 } 

 /**
  * 设置添加屏幕的背景透明度
  * @param bgAlpha
  */
 public void backgroundAlpha(float bgAlpha)
 {
  WindowManager.LayoutParams lp = getWindow().getAttributes();
  lp.alpha = bgAlpha; //0.0-1.0
  getWindow().setAttributes(lp);
 }
 /**
  * 菜单弹出方向
  *
  */
 public enum Location { 

  LEFT,
  RIGHT,
  TOP,
  BOTTOM; 

 }
} 

两个布局文件:

1.activity_main.xml,就三个Button

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 android:orientation="vertical"> 

 <Button
  android:id="@+id/pop_left_btn"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="@string/pop_left"/> 

 <Button
  android:id="@+id/pop_right_btn"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="@string/pop_right"/> 

 <Button
  android:id="@+id/pop_bottom_btn"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:text="@string/pop_bottom"/> 

</LinearLayout>

2. pop.xml,也是三个Button,可以自己修改

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 android:orientation="vertical" > 

 <!-- <LinearLayout
  android:layout_width="wrap_content"
  android:layout_height="fill_parent"
  android:orientation="vertical"
  android:background="#ffffff"> --> 

  <Button android:id="@+id/open"
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   android:text="@string/open"/> 

  <Button android:id="@+id/save"
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   android:text="@string/save"/> 

  <Button android:id="@+id/close"
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   android:text="@string/close"/> 

 <!-- </LinearLayout> --> 

</LinearLayout> 

strings.xml

<string name="pop_left">弹出左侧菜单</string>
 <string name="pop_right">弹出右侧菜单</string>
 <string name="pop_bottom">弹出底部菜单</string>
 <string name="open">打开</string>
 <string name="save">保存</string>
 <string name="close">关闭</string>

styles.xml

<style name="AnimationLeftFade">
  <item name="android:windowEnterAnimation">@anim/in_lefttoright</item>
  <item name="android:windowExitAnimation">@anim/out_righttoleft</item>
 </style> 

 <style name="AnimationRightFade">
  <item name="android:windowEnterAnimation">@anim/in_righttoleft</item>
  <item name="android:windowExitAnimation">@anim/out_lefttoright</item>
 </style> 

 <style name="AnimationBottomFade">
  <item name="android:windowEnterAnimation">@anim/in_bottomtotop</item>
  <item name="android:windowExitAnimation">@anim/out_toptobottom</item>
 </style>

左边弹出菜单动画文件:

in_lefttoright.xml:从左边入

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"> 

 <translate
  android:fromXDelta="-100%"
  android:toXDelta="0"
  android:duration="500"/> 

</set>

out_righttoleft.xml:从右边出

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android"> 

 <translate android:fromXDelta="0"
  android:toXDelta="-100%"
  android:duration="500"/> 

</set>

其他动画文件自己参考写,就是fromXDelta, fromYDelta, toXDelta和toYDelta使用。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android使用Activity实现从底部弹出菜单或窗口的方法

    本文实例讲述了Android使用Activity实现从底部弹出菜单或窗口的方法.分享给大家供大家参考,具体如下: 这里使用activity实现弹出滑动窗口或菜单,主要是使用了一些设置activity的样式来实现弹出窗口和滑动效果,实现如下: 第一步:设计要弹出窗口的xml布局: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://sche

  • Android ListView长按弹出菜单二种实现方式示例

    复制代码 代码如下: /** * 知识点1:ListView item:两种长按弹出菜单方式* 知识点2:ListView SimpleAdapter的使用* 知识点 3:在java代码中创建一个ListView*/ public class ListOnLongClickActivity extends Activity {         private LinearLayout myListViewlayout;         private ListView mListView;   

  • Android实现底部弹出按钮菜单升级版

    本文实例为大家分享了Android实现底部弹出按钮菜单的具体代码,在Android实现底部缓慢弹出菜单的升级,供大家参考,具体内容如下 只贴出关键代码 case R.id.myself_share: //我的分享 getShareMune(); getShareMune() private void getShareMune() { final Dialog mdialog = new Dialog(getActivity(), R.style.photo_dialog); mdialog.se

  • Android之用PopupWindow实现弹出菜单的方法详解

    在使用UC-WebBrowser时,你会发现它的弹出菜单跟系统自带的菜单不一样.它实现更多菜单选项的显示和分栏.其实,它的本身是PopupWindow或者是AlertDialog对话框,在里面添加两个GridView控件,一个是菜单标题栏,一个是菜单选项.菜单选项视图的切换可以通过适配器的变换,轻松地实现.点击下载该实例:一.运行截图:           二.实现要点:(1)屏蔽系统弹出的菜单:1.首先创建至少一个系统的菜单选项 复制代码 代码如下: @Override public bool

  • android popwindow实现左侧弹出菜单层及PopupWindow主要方法介绍

    PopupWindow可以实现浮层效果,主要方法有:可以自定义view,通过LayoutInflator方法:可以出现和退出时显示动画:可以指定显示位置等. 为了将PopupWindow的多个功能展现并力求用简单的代码实现,编写了一个点击按钮左侧弹出菜单的功能,实现出现和退出时显示动画效果并点击其他区域时弹出层自动消失,效果图如下: 源码: 1.PopwindowOnLeftActivity.java 复制代码 代码如下: package com.pop.main; import android

  • 简单实现Android弹出菜单效果

    本文实例为大家分享了Android弹出菜单效果的具体代码,供大家参考,具体内容如下 功能描述:用户单击按钮弹出菜单.当用户选择一个菜单项,会触发MenuItemClick事件并让弹出的菜单消失:如果用户在菜单外单击,则直接消失弹出的菜单.当菜单消失时,会引发DismissEvent事件(利用此事件可在菜单消失时做一些后续处理). 1.运行效果 2.添加菜单项 在Resources文件夹下添加一个menu子文件夹,然后在此子文件夹下添加一个名为demo07_popup_menu.xml的文件: <

  • Android仿QQ滑动弹出菜单标记已读、未读消息

    在上一篇<Android仿微信滑动弹出编辑.删除菜单效果.增加下拉刷新功能>里,已经带着大家学习如何使用SwipeMenuListView这一开源库实现滑动列表弹出菜单,接下来,将进一步学习,如何为不同的list item呈现不同的菜单,此处我们做一个实例:Android 高仿QQ滑动弹出菜单标记已读.未读消息,看下效果图: 1. 创建项目,并导入SwipeMenuListView类库 2. 创建消息实体bean: public class Msg { public int id; publi

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

    微信右上角的操作菜单看起来很好用,就照着仿了一下,不过是旧版微信的,手里刚好有一些旧版微信的资源图标,给大家分享一下. 不知道微信是用什么实现的,我使用popupwindow来实现,主要分为几块内容: 1.窗口布局文件:popwin_share.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com

  • Android实现类似于PC中的右键弹出菜单效果

    Android系统中的ContextMenu(上下文菜单)类似于PC中的右键弹出菜单,当一个视图注册到一个上下文菜单时,执行一个在该对象上的"长按"动作,将出现一个提供相关功能的浮动菜单.上下文菜单可以被注册到任何视图对象中,不过,最常见的是用于列表视图ListView的item,在按中列表项时,会转换其背景色而提示将呈现上下文菜单.  注意:上下文菜单不支持图标和快捷键. 为了创建一个上下文菜单,你必须重写这个活动的上下文菜单回调函数:onCreateContextMenu() 和

  • Android中微信小程序开发之弹出菜单

    先给大家展示下效果图,具体效果图如下所示: 具体代码如下所示: 1.index.js //index.js //获取应用实例 var app = getApp() Page({ data: { isPopping: false,//是否已经弹出 animationPlus: {},//旋转动画 animationcollect: {},//item位移,透明度 animationTranspond: {},//item位移,透明度 animationInput: {},//item位移,透明度

随机推荐