今天,简单讲讲android 中的 

DecorView的使用。


getWindow().getDecorView()的方法可以获取到decorView,decorView是什么呢?
decorView是window中的最顶层view,可以从window中获取到decorView,然后decorView有个getWindowVisibleDisplayFrame方法可以获取到程序显示的区域,包括标题栏,但不包括状态栏。

  Rect rect = new Rect();              /*              * getWindow().getDecorView()得到的View是Window中的最顶层View,可以从Window中获取到该View,              * 然后该View有个getWindowVisibleDisplayFrame()方法可以获取到程序显示的区域,              * 包括标题栏,但不包括状态栏。              */              getWindow().getDecorView().getWindowVisibleDisplayFrame(rect);              1.获取状态栏高度:               根据上面所述,我们可以通过rect对象得到手机状态栏的高度              int statusBarHeight = rect.top;                           2.获取标题栏高度:              getWindow().findViewById(Window.ID_ANDROID_CONTENT);              该方法获取到的View是程序不包括标题栏的部分,这样我们就可以计算出标题栏的高度了。              int contentTop = getWindow().findViewById(Window.ID_ANDROID_CONTENT).getTop();                 //statusBarHeight是上面所求的状态栏的高度                 int titleBarHeight = contentTop - statusBarHeight                 


接下来举一个具体的例子:

先来看看实现的效果


实现的大致思路

  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的使用就讲完了。


就这么简单。

更多相关文章

  1. Android 用style简化layout布局文件
  2. android 布局文件中控件ID、name标签属性的命名包含“@”、“.”
  3. 【源码分享下载】每日更新之Android应用源码之仿微信5.2布局
  4. Android之基本样式和布局
  5. android -------- 流式布局,支持单选、多选等
  6. 约束布局ConstraintLayout的使用你知道吗

随机推荐

  1. 课程表与表单的制作
  2. Flink State 最佳实践
  3. Flink 消息聚合处理方案
  4. 自学第七十天
  5. 快来,看看spring有多烂-来自jfinaL的嘲笑
  6. Linux上,最常用的一批命令解析(10年精选)
  7. 百度大佬10分钟教会你是前端bug还是后端b
  8. 没有预热,不叫高并发,叫并发高
  9. Linux生产环境上,最常用的一套“AWK“技巧
  10. C语言学习 4.0