先上效果图:
这个效果一开始我是想直接让UI给个切图,后来发现这样不行,适配很差,达不到效果。所以就自己动手写代码,其实思路也很简单:在这个布局的父布局上面再手动添加一个vIEw(通常linearLayout比较方便),然后把这个linearlayout的背景设置成#88000000,之后就是给这个linearlayout动态增加子vIEw,初步效果就能达到。
下面直接上代码:
public voID showGuIDeVIEw() { VIEw vIEw = getwindow().getDecorVIEw().findVIEwByID(R.ID.activity_main); if (vIEw == null) return; VIEwParent vIEwParent = vIEw.getParent(); if (vIEwParent instanceof FrameLayout) { final FrameLayout frameParent = (FrameLayout) vIEwParent;//整个父布局 final linearLayout linearLayout = new linearLayout(this);//新建一个linearLayout linearLayout.setLayoutParams(new linearLayout.LayoutParams(VIEwGroup.LayoutParams.MATCH_PARENT,VIEwGroup.LayoutParams.MATCH_PARENT)); linearLayout.setorIEntation(linearLayout.VERTICAL); linearLayout.setBackgroundResource(#88000000);//背景设置灰色透明 linearLayout.setGravity(Gravity.CENTER_HORIZONTAL); linearLayout.setonClickListener(new VIEw.OnClickListener() { @OverrIDe public voID onClick(VIEw v) { frameParent.removeVIEw(linearLayout); } }); Rect rect = new Rect(); Point point = new Point(); nearby.getGlobalVisibleRect(rect,point); //获得nearby这个控件的宽高以及XY坐标 nearby这个控件对应就是需要高亮显示的地方 ImageVIEw topGuIDevIEw = new ImageVIEw(this); topGuIDevIEw.setLayoutParams(new VIEwGroup.LayoutParams(rect.wIDth(),rect.height())); topGuIDevIEw.setBackgroundResource(R.drawable.iv_topguIDe); Rect rt = new Rect(); getwindow().getDecorVIEw().getwindowVisibledisplayFrame(rt); topGuIDevIEw.setY(point.y - rt.top);//rt.top是手机状态栏的高度 ImageVIEw bottomGuIDevIEw = new ImageVIEw(this); bottomGuIDevIEw.setLayoutParams(new VIEwGroup.LayoutParams(WRAP_CONTENT,WRAP_CONTENT)); bottomGuIDevIEw.setBackgroundResource(R.drawable.iv_bottomguIDe); bottomGuIDevIEw.setY(point.y + topGuIDevIEw.getHeight()); linearLayout.addVIEw(topGuIDevIEw); linearLayout.addVIEw(bottomGuIDevIEw); frameParent.addVIEw(linearLayout); }}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的Android 新手引导蒙层效果实现代码示例全部内容,希望文章能够帮你解决Android 新手引导蒙层效果实现代码示例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)