溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Android中怎么利用MainUpView實(shí)現(xiàn)飛框選中效果

發(fā)布時(shí)間:2021-07-12 14:02:43 來源:億速云 閱讀:183 作者:Leah 欄目:移動(dòng)開發(fā)

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)碛嘘P(guān)Android中怎么利用MainUpView實(shí)現(xiàn)飛框選中效果,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

    1.首先可以在我們的頁面根布局下添加這一控件

<com.open.androidtvwidget.view.MainUpView
        android:id="@+id/mainUpView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:tag="upView"
        bind:effect_bridge="@{viewmodel.bridge}"
        bind:rect_padding="@{viewmodel.rectPadding}"
        bind:up_rect_drawable="@{viewmodel.rectDrawable}" />

</RelativeLayout>

     這里并不需要調(diào)整布局,因?yàn)轱w框一般情況下我們?cè)O(shè)定為不可見的。在這里綁定了三個(gè)屬性,一個(gè)是effect_bridge,一個(gè)是rect_padding,一個(gè)是up_rect_drawable.我們可以看一下這三個(gè)屬性的定義。在ViewModel中我們添加如下三個(gè)成員(對(duì)于databinding的具體內(nèi)容不在這里細(xì)述):

@Bindable
public int rectDrawable = R.drawable.white_light_10;

@Bindable
public EffectNoDrawBridge bridge = new EffectNoDrawBridge();

@Bindable
public Rect rectPadding = new Rect(0, 10, 0, 10);

    effect_bridge是飛框?qū)ο?我們控制飛框的聚焦跟移動(dòng)都是操作這一個(gè)對(duì)象,rect_padding是飛框的內(nèi)邊距,可以調(diào)整這個(gè)Rect對(duì)象的大小,來調(diào)整飛框離內(nèi)部四個(gè)邊緣的距離,我們可以根據(jù)實(shí)際的狀態(tài)適當(dāng)調(diào)整,而rectDrawable則是具體的飛框樣式,這里推薦使用9-Patch格式的圖片,這樣飛框在縮放的時(shí)候不容易變形。

    實(shí)際需要我們操作的是mainupview本身以及對(duì)應(yīng)的bridge對(duì)象。

MainUpView mainUpView = (MainUpView) mainView.findViewById(R.id.mainUpView);
OpenEffectBridge bridge = (OpenEffectBridge) mainUpView.getEffectBridge();

    在首頁中,我們可以獲取mainupview對(duì)象,并通過getEffectBridge()方法獲取對(duì)應(yīng)的bridge。

    mainUpView.setFocusView(newFocus, scale);
    mainUpView.setFocusView(newFocus, oldFocus, scale);

    利用這兩個(gè)函數(shù),我們可以使mainUpView捕獲當(dāng)前獲得焦點(diǎn)的View對(duì)象,飛框也隨之移動(dòng)并顯示。傳入的scale參數(shù)是飛框捕獲view后的放大系數(shù),用于實(shí)現(xiàn)放大的效果。

    當(dāng)然了,當(dāng)屏幕上view的布局不均勻的時(shí)候,飛框效果可能比較突兀,因?yàn)榭梢钥吹揭粋€(gè)白色的框在屏幕上閃過,如果屏幕兩個(gè)控件之間的空隙較大,效果并不美觀。我們可以設(shè)置飛框的動(dòng)畫監(jiān)聽,讓飛框在移到目的控件后才顯示。

bridge.setOnAnimatorListener(new OpenEffectBridge.NewAnimatorListener() {
                        @Override
                        public void onAnimationStart(OpenEffectBridge bridge, View view, 
                                                                    Animator animation) {
                            bridge.setVisibleWidget(true);
                        }

                        @Override
                        public void onAnimationEnd(OpenEffectBridge bridge, View view,
                                                                 Animator animation) {
                            if (mSaveBridge == bridge && view.hasFocus())
                                bridge.setVisibleWidget(false);
                        }
                    });

    在這里,setVisibleWidget方法控制bridge是否顯示,傳入為true的時(shí)候隱藏。我們的操作是在動(dòng)畫開始的時(shí)候隱藏bridge,動(dòng)畫結(jié)束后再重新顯示。

上述就是小編為大家分享的Android中怎么利用MainUpView實(shí)現(xiàn)飛框選中效果了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI