Android高亮引導(dǎo)控件

Demo

image

代碼

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方法來實(shí)現(xiàn)高亮區(qū)域的繪制;setRegion設(shè)置一個(gè)高亮區(qū)域,setRegions設(shè)置多個(gè)高亮區(qū)域;重寫setBackgroundColor來實(shí)現(xiàn)設(shè)置高亮背景色。

Region 表示了一個(gè)高亮矩形區(qū)域,支持4種高亮類型,

  1. RectRegion 矩形高亮區(qū)域
public class RectRegion implements Parcelable {
    public RectF rectF;
    //... Parcelable實(shí)現(xiàn)代碼
}
  1. RoundRectRegion 圓角矩形高亮區(qū)域
public class RoundRectRegion extends RectRegion {
    public float rx, ry;
    //... Parcelable實(shí)現(xiàn)代碼
}
  1. CircleRegion 圓形高亮區(qū)域
public class CircleRegion extends RectRegion {
    public float radius;
    //... Parcelable實(shí)現(xiàn)代碼
}
  1. OvalRegion 橢圓高亮區(qū)域
public class OvalRegion extends RectRegion {
    //... Parcelable實(shí)現(xiàn)代碼
}

使用

  1. 創(chuàng)建一個(gè)GuideActivity,該Activity根布局是一個(gè)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 并傳遞需要高亮顯示的區(qū)域

            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中設(shè)置高亮區(qū)域

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

Github

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,355評論 25 708
  • ¥開啟¥ 【iAPP實(shí)現(xiàn)進(jìn)入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個(gè)線程,因...
    小菜c閱讀 7,390評論 0 17
  • 效果圖: Github鏈接:https://github.com/boycy815/PinchImageView ...
    CQ_TYL閱讀 2,363評論 0 0
  • 絲綢之路,這個(gè)詞在十九世紀(jì)末,由德國著名地理,地質(zhì)學(xué)家李?;舴沂状翁岢?。絲綢之路,是貫穿了亞洲,歐洲,非洲...
    QPH閱讀 615評論 0 0
  • 問題 JavaScript的Callback機(jī)制深入人心。而ECMAScript的世界同樣充斥的各種異步操作(異步...
    daoyidao閱讀 1,418評論 0 3

友情鏈接更多精彩內(nèi)容