在开放过程中需要一个类似悬浮的东西,这时候我门考虑到用window,先来看段代码:
private void initCommentView() { mCommentImageView = new ImageView(this); final ViewGroup rootView = (ViewGroup) this.getWindow().getDecorView(); WindowManager wm = (WindowManager) this. getSystemService(Context.WINDOW_SERVICE); int height = wm.getDefaultDisplay().getHeight(); int width = wm.getDefaultDisplay().getWidth(); FrameLayout.LayoutParams params = new FrameLayout.LayoutParams(ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT); params.topMargin = height - DeviceInfoUtil.getPixelFromDip(100); params.leftMargin = width - DeviceInfoUtil.getPixelFromDip(55); params.height = DeviceInfoUtil.getPixelFromDip(45); params.width = DeviceInfoUtil.getPixelFromDip(45); mCommentImageView.setBackgroundResource(R.drawable.hotel_chat_comment_enable); rootView.addView(mCommentImageView, params); mCommentImageView.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { if (mCallbacks != null && mCallbacks.mPerformanceCommentLister != null) { mCallbacks.mPerformanceCommentLister.popCommentDialog(mChatCacheBean.currentOpRedInfo.opUserId, 0, true); } } }); }
这段代码时现在处理在手机界界面的右下方添加一个按钮,不会随着页面滚动位置变化,这个view 是依赖window 的, 我门来认识下window
每个widow 是依赖一个view 和ViewRootImpl,每个window 和View 通过viewRootImpl 来建立联系,
window 有addView,updateViewLayout以及removeView 来定义,window的操作,是基于windowManagerGlobal 进行控制,最终是转换到viewRootImpl 来实现,通过调用schduleTraversals 这个入口,进行view 的添加。
在实际的开放使用的过程中activity.dialog 都是window,activity 本质上是phone window,在activity 的创建过程中,调用PolicyMananger 的makeNewWindow 的方法实现,在activity 中还实现了window 的CallBack ,因此外界可以接受状态变化的时候,就会回调,常见的接口onAttachedToWindow,onDetachedFromWindo 和dispatchTouchEvnent 等等,在PhoneWindow 的方法,
主要是包含以下的方法:
1 如果没有DecorView, 哪么就创建他
2 将View 添加到DecorView 的mContentParent 中
3 回调Activity 的onContentChanged 方法通知Acitivity 视图发生变化,
经过这么步相对于Acitivity 来说,在ActivityThread 的handleResumeActivity 方法中首选调用activity 的onResume() ,接着会调用Activity 的makeVisible() 这样derectView 才显示出来。