Android巧用DecorView实现对话框功能

发布时间 - 2026-01-11 00:33:57    点击率:

如果还不知道DecorView,那也没有什么关系 ^_^

先来看看实现的效果

实现的大致思路

  1. 首先需要明白什么是DecorView,他是android中界面的根布局。其实android的activity界面整个就是一个控件树,DecorView是根节点,DecorView的孩子节点就是一个LinearLayout,这个LinearLayout的孩子系节点就包括状态栏 + 和我们自己写的布局
  2. DecorView是FramLayout的子类(可以从源码中看到)
  3. 既然DecorView是根节点,而且还是FrameLayout,所以我们可以把我们自己的布局 添加到DecorView 或者 从DecorView移除,这样就模拟出了一个Dialog的效果~~ ,当然这个Dialog的样式,动画就可以自己想怎么写就怎么写了撒
  4. 通过activity.getWindow().getDecorView()可以获得DecorView

[下面大量 代码 ]

第一个对话框的实现

public class TipsDialog {
  private Activity activity;
  private View rootView;
  private TextView confirmTextView;
  private TextView cancelTextView;
  private TextView contentTextView;

  private boolean isShowing;

  public TipsDialog(Activity activity) {
    this.activity = activity;
    isShowing = false;
    rootView = LayoutInflater.from(activity).inflate(R.layout.view_tips_dialog,null);
    confirmTextView = (TextView) rootView.findViewById(R.id.view_tips_dialog_tv_confirm);
    cancelTextView = (TextView) rootView.findViewById(R.id.view_tips_dialog_tv_cancel);
    contentTextView = (TextView) rootView.findViewById(R.id.view_tips_dialog_tv_content);

  }

  public void show(){
    if(activity == null){
      return;
    }
    if(isShowing){
      return;
    }
    ViewGroup decorView = (ViewGroup) activity.getWindow().getDecorView();
    FrameLayout.LayoutParams params = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
    params.gravity = Gravity.CENTER;
    rootView.setLayoutParams(params);
    decorView.addView(rootView);
    rootView.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        dismiss();
      }
    });

    RotateAnimation rotateAnimation = new RotateAnimation(0,720f,RotateAnimation.RELATIVE_TO_SELF,0.5f,RotateAnimation.RELATIVE_TO_SELF,0.5f);
    rotateAnimation.setDuration(2000);
    contentTextView.startAnimation(rotateAnimation);

    isShowing = true;
  }

  public void dismiss(){
    if(!isShowing){
      return;
    }
    isShowing = false;
    if(rootView.getParent() == null){
      return;
    }
    ViewGroup parent = (ViewGroup) rootView.getParent();
    parent.removeView(rootView);

  }

  public int getRandomColor(){
    Random random = new Random();
    return Color.argb(random.nextInt(200),random.nextInt(240),random.nextInt(240),random.nextInt(240));
  }

  public boolean isShowing() {
    return isShowing;
  }
}

其实就是show的时候将布局添加到DecorView上面去,dismiss的时候将布局从DecorView上面移除

提示的实现(没有处理完善~~ 仅仅就是说明哈DecorView)

public class TopTipDialog {
  private Activity activity;
  private View rootView;
  private boolean isShowing;
  private static final int VIEW_HEIGHT = 64;//px

  public TopTipDialog(Activity activity) {
    this.activity = activity;
    rootView = LayoutInflater.from(activity).inflate(R.layout.view_top_tip_dialog,null);
  }


  public void show(){

    if(isShowing){
      return;
    }
    ViewGroup decorView = (ViewGroup) activity.getWindow().getDecorView();
    FrameLayout.LayoutParams params = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, VIEW_HEIGHT);
    params.gravity = Gravity.TOP;
    params.setMargins(0,0,0,-VIEW_HEIGHT);
    rootView.setLayoutParams(params);

    TranslateAnimation translateAnimation = new TranslateAnimation(0,0,-VIEW_HEIGHT,0);
    translateAnimation.setDuration(1500);
    translateAnimation.setFillAfter(true);
    decorView.addView(rootView);
    rootView.startAnimation(translateAnimation);

    rootView.postDelayed(new Runnable() {
      @Override
      public void run() {
        TranslateAnimation translateAnimation1 = new TranslateAnimation(0,0,0,-VIEW_HEIGHT);
        translateAnimation1.setDuration(1500);
        translateAnimation1.setFillAfter(true);
        rootView.startAnimation(translateAnimation1);
      }
    },3000);

  }
}

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


# android  # decorview 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  WEB开发之注册页面验证码倒计时代码的实现  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  如何用y主机助手快速搭建网站?  Laravel如何使用Eloquent ORM进行数据库操作?(CRUD示例)  如何在万网利用已有域名快速建站?  如何在阿里云域名上完成建站全流程?  宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  Android使用GridView实现日历的简单功能  Laravel如何处理CORS跨域请求?(配置示例)  laravel服务容器和依赖注入怎么理解_laravel服务容器与依赖注入解析  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  Laravel如何自定义错误页面(404, 500)?(代码示例)  制作公司内部网站有哪些,内网如何建网站?  北京网站制作的公司有哪些,北京白云观官方网站?  如何在IIS服务器上快速部署高效网站?  EditPlus中的正则表达式实战(6)  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  ,南京靠谱的征婚网站?  html5源代码发行怎么设置权限_访问权限控制方法与实践【指南】  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  Android自定义控件实现温度旋转按钮效果  Laravel如何集成Inertia.js与Vue/React?(安装配置)  java ZXing生成二维码及条码实例分享  Python文件异常处理策略_健壮性说明【指导】  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  PHP 500报错的快速解决方法  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  网站制作软件有哪些,制图软件有哪些?  如何在Ubuntu系统下快速搭建WordPress个人网站?  免费网站制作appp,免费制作app哪个平台好?  EditPlus 正则表达式 实战(3)  详解MySQL数据库的安装与密码配置  如何正确下载安装西数主机建站助手?  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  用v-html解决Vue.js渲染中html标签不被解析的问题  如何快速辨别茅台真假?关键步骤解析  如何在香港服务器上快速搭建免备案网站?  如何批量查询域名的建站时间记录?  Swift中swift中的switch 语句  文字头像制作网站推荐软件,醒图能自动配文字吗?  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  如何快速搭建高效可靠的建站解决方案?  Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践  Android自定义listview布局实现上拉加载下拉刷新功能  如何快速生成高效建站系统源代码?  node.js报错:Cannot find module 'ejs'的解决办法  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法