android 蒙层动画,Android 新手引导蒙层效果实现代码示例

先上效果图:

d9f67346f6a9f12921115fad3643eb7a.png

这个效果一开始我是想直接让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);

}

}

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值