一分鐘實現(xiàn)Android遮罩引導(dǎo)視圖
一分鐘實現(xiàn)Android遮罩引導(dǎo)視圖,供大家參考,具體內(nèi)容如下
先看一下效果圖
主角GuideView登場!
GuideView是一種基于DialogFragment實現(xiàn)的引導(dǎo)遮罩浮層視圖的輕量級解決方案,它具備以下的特性:
- 響應(yīng)導(dǎo)航按鈕的動作(因為引導(dǎo)浮層本質(zhì)是一個dialog);
- 鏈?zhǔn)揭龑?dǎo)層,支持設(shè)定一組的引導(dǎo)遮罩視圖,通過點擊切換下一個試圖,快讀與業(yè)務(wù)進(jìn)行解藕;
- 自動繪制半透明浮層、透明核心區(qū)以及確保目標(biāo)視圖和引導(dǎo)視圖的位置。
實現(xiàn)說明
頁面的結(jié)構(gòu)如下圖所示:
核心類
GuideViewBundle
引導(dǎo)視圖的配置項類,每一頁引導(dǎo)視圖對應(yīng)一個配置項。在GuideView內(nèi)部通過這個配置項去構(gòu)造GuideView的實例,并通過GuideViewFragment顯示在界面上。
其中的屬性都通過構(gòu)造器的模式,通過靜態(tài)內(nèi)部類Builder進(jìn)行構(gòu)建,屬性說明如下:
targetView
引導(dǎo)視圖需要顯示附著的目標(biāo)視圖
hintView
引導(dǎo)視圖(不包含半透明浮層以及透明焦點區(qū))
transparentSpaceXXX
默認(rèn)的情況下,透明焦點區(qū)的大小跟目標(biāo)視圖的大小保持一致,如果需要加大透明區(qū)域的大小,可以通過設(shè)置這組屬性,指定上下左右的額外的空白區(qū)域
hintViewMarginXXX
引導(dǎo)視圖(hintView)相對于目標(biāo)視圖(targetView)的邊距
hasTransparentLayer
是否顯示透明焦點區(qū)域,默認(rèn)顯示。可以選擇不繪制透明焦點區(qū)域而只有半透明的浮層
hintViewDirection
引導(dǎo)視圖(hintView)相對于目標(biāo)視圖(targetView)的位置方向,目前可以定義上(上方左對齊)、下(下方左對齊)、左(左方上對齊)、右(右方上對齊)四個方向。如果需要在位置之余有不一樣的對齊效果,可以使用hintViewMarginXXX屬性
outlineType
透明焦點區(qū)的輪廓類型,有圓形(橢圓)輪廓和方形輪廓兩種
maskColor
半透明遮罩浮層的顏色
isDismissOnClicked
全局點擊可以關(guān)閉引導(dǎo)視圖,默認(rèn)為true。如果設(shè)置false,則需要手動設(shè)置點擊hintView的特定位置關(guān)閉視圖
GuideView
界面實際展示的視圖對象,根據(jù)GuideViewBundle設(shè)置的屬性,由GuideViewFragment創(chuàng)建并添加到齊視圖容器中,對外部業(yè)務(wù)完全透明無感知到一個類
GuideViewFragment
實際顯示引導(dǎo)視圖的彈窗。其內(nèi)部加載了一個FrameLayout容器,通過在容器中添加GuideView的實例實現(xiàn)顯示引導(dǎo)視圖層。一個GuideViewFragment可以設(shè)定一組引導(dǎo)視圖,完成一組引導(dǎo)序列。請使用其靜態(tài)內(nèi)部類Builder構(gòu)建其實例,并使用Builder#addGuidViewBundle(bundle)方法添加引導(dǎo)視圖的配置項。
如果需要自定義點擊關(guān)閉的動作(GuideViewBundle.Builder#setDismissOnClicked(false)的情況下),可以使用下面的方法
void onNext()
如果還存在沒有顯示的引導(dǎo)視圖,這個方法會繼續(xù)顯示下一張,否則會關(guān)閉彈窗
添加依賴
1.在根目錄的build.gradle文件中添加jitpack倉庫
allprojects { repositories { ... maven { url 'https://jitpack.io' } } }
2.添加GuideView依賴
dependencies { compile 'com.github.easilycoder:GuideView:0.0.1' }
使用示例
GuideViewFragment.Builder() .addGuidViewBundle(GuideViewBundle.Builder() .setTargetView(tvContent) .setHintView(hintViewLeft) .setDismissOnClicked(false) .setHintViewMargin(0, -160, 0, 0) .setTransparentSpace(space, space, space, space) .setOutlineType(TYPE_RECT) .setHintViewParams(params) .setHintViewDirection(LEFT).build()) .addGuidViewBundle(GuideViewBundle.Builder() .setTargetView(tvContent) .setOutlineType(TYPE_OVAL) .setHintView(hintViewTop) .setDismissOnClicked(false) .setHintViewParams(params) .setHintViewMargin(-dp2px(this, 55f), 0, 0, 0) .setTransparentSpace(space, space, space, space) .setHintViewDirection(TOP) .build()) .addGuidViewBundle(GuideViewBundle.Builder() .setTargetView(tvContent) .setOutlineType(TYPE_OVAL) .setHintView(hintViewRight) .setDismissOnClicked(false) .setHintViewParams(params) .setHintViewMargin(0, -160, 0, 0) .setTransparentSpace(space, space, space, space) .setHintViewDirection(RIGHT) .build()) .addGuidViewBundle(GuideViewBundle.Builder() .setTargetView(tvContent) .setOutlineType(TYPE_OVAL) .setHintViewParams(params) .setHintViewMargin(-dp2px(this, 55f), 0, 0, 0) .setHintView(hintViewBottom) .setTransparentSpace(space, space, space, space) .setHintViewDirection(BOTTOM) .build()) .setCancelable(false) .build().show(supportFragmentManager, "hit")
具體實例以及設(shè)計實現(xiàn)可以參考我的GitHub倉庫:GuideView
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android自定義Dialog內(nèi)部透明、外部遮罩效果
- Android實現(xiàn)遮罩層(蒙板)效果
- Android PopupWindow實現(xiàn)遮罩層效果
- Android使用popUpWindow帶遮罩層的彈出框
- Android之淘寶商品列表長按遮罩效果的實現(xiàn)
- 360瀏覽器文本框獲得焦點后被android軟鍵盤遮罩該怎么辦
- Android頁面中引導(dǎo)蒙層的使用方法詳解
- Android實現(xiàn)新手引導(dǎo)半透明蒙層效果
- Android自定義ViewGroup實現(xiàn)豎向引導(dǎo)界面
- Android GuideView實現(xiàn)首次登陸引導(dǎo)
相關(guān)文章
Android 使用jarsigner給apk簽名的方法詳細(xì)介紹
這篇文章主要介紹了Android 使用jarsigner給apk簽名的方法詳細(xì)介紹的相關(guān)資料,APP 完成需要在一些APP 商店進(jìn)行上傳審核,供用戶下載使用,APP 需要簽名認(rèn)證,需要的朋友可以參考下2016-12-12Android開發(fā)EditText禁止輸入監(jiān)聽及InputFilter字符過濾
這篇文章主要為大家介紹了Android開發(fā)EditText禁止輸入監(jiān)聽及InputFilter字符過濾示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06解決AndroidStudio無法運行java中的mian方法問題
這篇文章主要介紹了解決AndroidStudio無法運行java中的mian方法問題,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10Android編程實現(xiàn)長按彈出選項框View進(jìn)行操作的方法
這篇文章主要介紹了Android編程實現(xiàn)長按彈出選項框View進(jìn)行操作的方法,結(jié)合實例形式分析了Android事件響應(yīng)及彈窗的功能、布局相關(guān)操作技巧,需要的朋友可以參考下2017-06-06Android源碼系列之深入理解ImageView的ScaleType屬性
Android源碼系列第一篇,這篇文章主要從源碼的角度深入理解ImageView的ScaleType屬性,感興趣的小伙伴們可以參考一下2016-06-06