文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android自定义popupwindow实例代码

2022-06-06 05:44

关注

先来看看效果图:

一、布局 


<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="vertical"
  android:background="#ffffff"
  android:padding="20dp" >
  <TextView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:clickable="true"
    android:gravity="center"
    android:textColor="@android:color/holo_orange_dark"
    android:text="确定" />
  <TextView
    android:layout_marginTop="20dp"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_marginBottom="10dp"
    android:clickable="true"
    android:gravity="center"
    android:text="取消" />
</LinearLayout>

2、自定义MypopupWindow继承PopupWindow

public class MyPopupWindow extends PopupWindow {  

3、重写构造方法与动画样式
在styles.xml自定义样式,动画


<style name="MyPopupWindow">
    <item name="android:windowEnterAnimation">@anim/pop_in</item>
    <item name="android:windowExitAnimation">@anim/pop_out</item>
  </style>

 pop_in


<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
  <!-- 平移
  <translate
     android:duration="5000"
     android:fromXDelta="100%"
     android:toXDelta="0"/>
     -->
  <scale
    android:fromXScale="0"
    android:fromYScale="0"
    android:pivotX="50%"
    android:pivotY="50%"
    android:toXScale="0.8"
    android:toYScale="0.5"
    android:duration="200"/>
  <!--
fromXScale
fromYScale
起始时X,Y座标,
pivotX
pivotY
动画起始位置,相对于屏幕的百分比,两个都为50%表示动画从屏幕中间开始
toXScale
toYScale
动画最终缩放的倍数, 1.0为正常大小,大于1.0放大
duration
动画持续时间
 -->
  <!--透明度-->
  <alpha
    android:duration="200"
    android:fromAlpha="0.0"
    android:toAlpha="1.0"/>
</set>

pop_out


<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
  <!-- <translate
    android:duration="5000"
    android:fromXDelta="0"
    android:toXDelta="100%"/>-->
  <scale
    android:fromXScale="0.8"
    android:fromYScale="0.5"
    android:pivotX="50%"
    android:pivotY="50%"
    android:toXScale="0"
    android:toYScale="0"
    android:duration="200"/>
  <alpha
    android:duration="200"
    android:fromAlpha="1.0"
    android:toAlpha="0.0"/>
</set>

4、重写构造方法并设置点击外部可以消失监听


 super(context);
    this.mContext=context;
    //打气筒
    mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    //打气
    mContentView = mInflater.inflate(R.layout.layout_dialog,null);
    //设置View
    setContentView(mContentView);
    //设置宽与高
    setWidth(WindowManager.LayoutParams.MATCH_PARENT);
    setHeight(WindowManager.LayoutParams.WRAP_CONTENT);
    
    setAnimationStyle(R.style.MyPopupWindow);
    
    setBackgroundDrawable(new ColorDrawable());
    
    setFocusable(true);
    
    setOutsideTouchable(true);
    
    setTouchable(true);
    
    setTouchInterceptor(new View.OnTouchListener() {
      @Override
      public boolean onTouch(View v, MotionEvent event) {
        
        if(event.getAction()==MotionEvent.ACTION_OUTSIDE){
          return true;
        }
        //不是点击外部
        return false;
      }
    });

5、显示及设置窗口变暗与变亮


public void displayDialog(View view){
    MyPopupWindow myPopupWindow = new MyPopupWindow(this);
    myPopupWindow.showAsDropDown(mBtnDispaly,0,0);
    lightOff();
    
    myPopupWindow.setOnDismissListener(new PopupWindow.OnDismissListener() {
      @Override
      public void onDismiss() {
        WindowManager.LayoutParams layoutParams = getWindow().getAttributes();
        layoutParams.alpha=1.0f;
        getWindow().setAttributes(layoutParams);
      }
    });
  }
  
  private void lightOff() {
    WindowManager.LayoutParams layoutParams = getWindow().getAttributes();
    layoutParams.alpha=0.3f;
    getWindow().setAttributes(layoutParams);
  }

6、完整


package liu.basedemo.view;
import android.content.Context;
import android.graphics.drawable.ColorDrawable;
import android.view.LayoutInflater;
import android.view.MotionEvent;
import android.view.View;
import android.view.WindowManager;
import android.widget.PopupWindow;
import liu.basedemo.R;

public class MyPopupWindow extends PopupWindow {
  Context mContext;
  private LayoutInflater mInflater;
  private View mContentView;
  public MyPopupWindow(Context context) {
    super(context);
    this.mContext=context;
    //打气筒
    mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    //打气
    mContentView = mInflater.inflate(R.layout.layout_dialog,null);
    //设置View
    setContentView(mContentView);
    //设置宽与高
    setWidth(WindowManager.LayoutParams.MATCH_PARENT);
    setHeight(WindowManager.LayoutParams.WRAP_CONTENT);
    
    setAnimationStyle(R.style.MyPopupWindow);
    
    setBackgroundDrawable(new ColorDrawable());
    
    setFocusable(true);
    
    setOutsideTouchable(true);
    
    setTouchable(true);
    
    setTouchInterceptor(new View.OnTouchListener() {
      @Override
      public boolean onTouch(View v, MotionEvent event) {
        
        if(event.getAction()==MotionEvent.ACTION_OUTSIDE){
          return true;
        }
        //不是点击外部
        return false;
      }
    });
    
    initView();
    initListener();
  }
  private void initView() {
  }
  private void initListener() {
  }
}
您可能感兴趣的文章:Android 使用PopupWindow实现弹出更多的菜单实例详解Android简单实现自定义弹框(PopupWindow)Android编程实现的自定义弹窗(PopupWindow)功能示例android PopupWindow点击外部和返回键消失的解决方法Android popupwindow简单使用方法介绍Android PopupWindow全屏详细介绍及实例代码Android组件popupwindow使用方法详解Android用PopupWindow实现自定义overflowAndroid自定义仿微信PopupWindow效果android自定义popupwindow仿微信右上角弹出菜单效果Popupwindow 的简单实用案例(显示在控件下方)


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯