Android高亮引导控件


title: Android高亮引导控件 categories: [Android] date: 2018-07-10

Demo

代码

public class HighLightLayout extends FrameLayout {
    private Paint mPaint;
    private Path mPath = new Path();
    private List<RectRegion> mRegions;

    public HighLightLayout(@NonNull Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
        mPaint = new Paint();
        mPaint.setAntiAlias(true);
        mPaint.setColor(0xAA000000);

        setWillNotDraw(false);
    }

    @Override
    protected void onDraw(Canvas canvas) {
        mPath.reset();
        mPath.addRect(0, 0, getWidth(), getHeight(), Path.Direction.CCW);
        for (RectRegion region : mRegions) {
            RectF rectF = region.rectF;
            if (region instanceof RoundRectRegion) {
                RoundRectRegion roundRectRegion = (RoundRectRegion) region;
                mPath.addRoundRect(rectF, roundRectRegion.rx, roundRectRegion.ry, 		                       Path.Direction.CW);
            } else if (region instanceof CircleRegion) {
                CircleRegion circleRegion = (CircleRegion) region;
                float cX = (rectF.right + rectF.left) / 2;
                float cY = (rectF.bottom + rectF.top) / 2;
                mPath.addCircle(cX, cY, circleRegion.radius, Path.Direction.CW);
            } else if (region instanceof OvalRegion) {
                mPath.addOval(rectF, Path.Direction.CW);
            } else {
                mPath.addRect(rectF, Path.Direction.CW);
            }
        }
        canvas.drawPath(mPath, mPaint);
    }

    public void setRegion(@NonNull RectRegion region) {
        if (mRegions == null) {
            mRegions = new ArrayList<>();
        } else {
            mRegions.clear();
        }
        mRegions.add(region);
        invalidate();
    }

    public void setRegions(@NonNull List<RectRegion> regions) {
        mRegions = regions;
        invalidate();
    }

    @Override
    public void setBackgroundColor(int color) {
        mPaint.setColor(color);
    }
}
复制代码

HighLightLayout继承自FrameLayout,重写了onDraw方法来实现高亮区域的绘制;setRegion设置一个高亮区域,setRegions设置多个高亮区域;重写setBackgroundColor来实现设置高亮背景色。

Region 表示了一个高亮矩形区域,支持4种高亮类型,

  1. RectRegion 矩形高亮区域
public class RectRegion implements Parcelable {
    public RectF rectF;
    //... Parcelable实现代码
}
复制代码
  1. RoundRectRegion 圆角矩形高亮区域
public class RoundRectRegion extends RectRegion {
    public float rx, ry;
    //... Parcelable实现代码
}
复制代码
  1. CircleRegion 圆形高亮区域
public class CircleRegion extends RectRegion {
    public float radius;
    //... Parcelable实现代码
}
复制代码
  1. OvalRegion 椭圆高亮区域
public class OvalRegion extends RectRegion {
    //... Parcelable实现代码
}
复制代码

使用

  1. 创建一个GuideActivity,该Activity根布局是一个HighLightLayout,可以在HighLightLayout中添加任何控件

    <wangyi.blog.app.view.HighLightLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/highLightLayout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".GuideActivity">
    </wangyi.blog.app.view.HighLightLayout>
    复制代码
  2. 启动GuideActivity 并传递需要高亮显示的区域

            ArrayList<RectRegion> regions = new ArrayList<>();
    
            //矩形高亮
            RectF rectF1 = LocationUtils.getViewLocation(mButton1);
            RectRegion region1 = new RectRegion(rectF1);
            regions.add(region1);
            //圆角矩形高亮
            RectF rectF2 = LocationUtils.getViewLocation(mButton2);
            RoundRectRegion region2 = new RoundRectRegion(rectF2, 10, 10);
            regions.add(region2);
            //圆形高亮
            RectF rectF3 = LocationUtils.getViewLocation(mButton3);
            float radius = (rectF3.right - rectF3.left) / 2 + 20;
            CircleRegion region3 = new CircleRegion(rectF3, radius);
            regions.add(region3);
            //椭圆高亮
            RectF rectF4 = LocationUtils.getViewLocation(mButton4);
            LocationUtils.expandRectF(rectF4, 40);
            OvalRegion region4 = new OvalRegion(rectF4);
            regions.add(region4);
    
            Intent intent = new Intent(this, GuideActivity.class);
            intent.putExtra(GuideActivity.EXTRA_REGION_LIST, regions);
            startActivity(intent);
    复制代码
  3. GuideActivity的onCreate中设置高亮区域

            ArrayList<RectRegion> regions = getIntent().getParcelableArrayListExtra(EXTRA_REGION_LIST);
            HighLightLayout highLightLayout = findViewById(R.id.highLightLayout);
            highLightLayout.setRegions(regions);
    复制代码

Github

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值