Android 新手引导蒙层效果实现代码示例

 更新时间:2017年01月06日 16:28:37   作者:Kevin_Xu1114  
本篇文章主要介绍了Android 新手引导蒙层效果实现代码示例,具有一定的参考价值,有兴趣的可以了解一下。

先上效果图:

这个效果一开始我是想直接让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开发中Intent传递对象的方法分析

    Android开发中Intent传递对象的方法分析

    这篇文章主要介绍了Android开发中Intent传递对象的方法,结合实例分析了Intent传递对象所涉及的具体方法、实现步骤与相关注意事项,需要的朋友可以参考下
    2016-02-02
  • Android编程单选项框RadioGroup综合应用示例

    Android编程单选项框RadioGroup综合应用示例

    这篇文章主要介绍了Android编程单选项框RadioGroup用法,结合实例形式分析了Android单选按钮组RadioGroup的定义与具体使用技巧,需要的朋友可以参考下
    2016-10-10
  • Android利用Badge组件实现未读消息小红点

    Android利用Badge组件实现未读消息小红点

    在 App 的运营中,活跃度是一个重要的指标,日活/月活……为了提高活跃度,就发明了小红点。这一篇,来介绍一个徽标(Badge)组件,能够快速搞定应用内的小红点,希望对大家有所帮助
    2023-01-01
  • android 网络连接处理分析

    android 网络连接处理分析

    在Android中,可以有多种方式来实现网络编程,本文将详细介绍android 网络连接处理,需要了解的朋友可以参考下
    2012-11-11
  • android实现状态栏添加图标的函数实例

    android实现状态栏添加图标的函数实例

    这篇文章主要介绍了android实现状态栏添加图标的函数,较为详细的分析了Android状态栏添加及删除图标的具体实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • android 实现圆角图片解决方案

    android 实现圆角图片解决方案

    现在我们就来看看怎么样把图片的四角都变成圆形的,为什么要这样做那,可能是为了美化界面吧,下面我们就来看看代码吧
    2012-11-11
  • Kotlin中的对象表达式和对象声明的具体使用

    Kotlin中的对象表达式和对象声明的具体使用

    这篇文章主要介绍了Kotlin中的对象表达式和对象声明的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11
  • Android LayoutParams使用案例详解

    Android LayoutParams使用案例详解

    这篇文章主要介绍了Android LayoutParams使用案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • Android 打包三种方式实例详解

    Android 打包三种方式实例详解

    这篇文章主要介绍了 Android 打包三种方式实例详解的相关资料,需要的朋友可以参考下
    2017-04-04
  • Android EventBus(普通事件/粘性事件)详解

    Android EventBus(普通事件/粘性事件)详解

    这篇文章主要为大家详细介绍了Android EventBus 普通事件/粘性事件的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11

最新评论