溫馨提示×

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

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

Android Metro風(fēng)格的Launcher開發(fā)系列第二篇

發(fā)布時(shí)間:2020-07-01 09:20:13 來源:網(wǎng)絡(luò) 閱讀:515 作者:在路上_A 欄目:移動(dòng)開發(fā)

前言:

各位小伙伴們請(qǐng)?jiān)徫腋袅诉@么久才開始寫這一系列的第二篇博客,沒辦法忙新產(chǎn)品發(fā)布,好了廢話不說了,先回顧一下:在我的上一篇博客 Android Metro風(fēng)格的Launcher開發(fā)系列第一篇寫了如何配置Android開發(fā)環(huán)境,只是用文字和圖片展示了開發(fā)Metro風(fēng)格Launcher的初步設(shè)計(jì)和產(chǎn)品要求,這一篇文章將會(huì)從代碼上講解如何實(shí)現(xiàn)對(duì)應(yīng)的UI效果,好了,評(píng)書開講!


Launcher主體框架實(shí)現(xiàn):

        Launcher主體框架我選用的是大家所熟悉的ViewPager控件,因?yàn)閂iewPager可以很容易做pager之間的切換動(dòng)畫,動(dòng)畫是可以自定義的,這樣就輕松搞定滑出屏幕的各種效果,也可以控制切換速度,這樣就很容易實(shí)現(xiàn)如下的效果:


Android Metro風(fēng)格的Launcher開發(fā)系列第二篇


1.滑動(dòng)速度控制:

這個(gè)是通過獲取ViewPager的Scroller,對(duì)Scroller重新設(shè)置一些參數(shù)就可以了,具體實(shí)現(xiàn)的代碼如下:

Field Scroller = ViewPager.class.getDeclaredField("mScroller");
Scroller.setAccessible(true);
Interpolator interpolator = new LinearInterpolator();//設(shè)置加速器
ViewPagerScroller scroller = new ViewPagerScroller(context,interpolator);//重新設(shè)置ViewPager的Scroller
Scroller.set(this, scroller);

在上面的代碼中用到了ViewPagerScroller.java,在ViewPagerScroller中的設(shè)置如下,其中的mDuration變量是自定義的動(dòng)畫時(shí)間,這個(gè)你可以根據(jù)自己的動(dòng)畫效果來設(shè)置時(shí)間長(zhǎng)度,我這定義的是500毫秒。

    @Override
    public void startScroll(int startX, int startY, int dx, int dy) {
        // Ignore received duration, use fixed one instead
        super.startScroll(startX, startY, dx, dy, mDuration);
    }

    @Override
    public void startScroll(int startX, int startY, int dx, int dy, int duration) {
        // Ignore received duration, use fixed one instead
        super.startScroll(startX, startY, dx, dy, mDuration);
    }

2.Page之間切換效果實(shí)現(xiàn):

每一屏page之間的切換是通過實(shí)現(xiàn)ViewPager.PageTransformer接口來實(shí)現(xiàn)的,具體這個(gè)接口的講解我這里就不介紹了,大家可以參考google官方文檔:Using ViewPager for Screen Slides。我的實(shí)現(xiàn)如下所示:

class LauncherPageTransformer implements ViewPager.PageTransformer {
    private static float DEFAULT_SCALE = 1.0f;
    private static float SCALE_FACTOR = 0.30f;// 縮放因子 0.50f
    private static float ROTATION_FACTOR = 20f;// 旋轉(zhuǎn)因子
    private static float ALPHA_FACTOR = 0.8f;

    @Override
    public void transformPage(View view, float position) {
        if (position <= 1) { // [-1,1]
            // Modify the default slide transition to shrink the page as well
            if (position < 0) {
                // view.setRotationY(position * ROTATION_FACTOR);
                view.setScaleX(SCALE_FACTOR * position + DEFAULT_SCALE);
                view.setScaleY(SCALE_FACTOR * position + DEFAULT_SCALE);
                // view.setAlpha(ALPHA_FACTOR * position + 1.0f);
            } else {
                // view.setRotationY(position * ROTATION_FACTOR);
                view.setScaleX(SCALE_FACTOR * -position + DEFAULT_SCALE);
                view.setScaleY(SCALE_FACTOR * -position + DEFAULT_SCALE);
                // view.setAlpha(ALPHA_FACTOR * -position + 1.0f);
            }
        }
    }

}

具體效果可以通過修改旋轉(zhuǎn)和縮放實(shí)現(xiàn)。

3.左右兩側(cè)page懸浮實(shí)現(xiàn):

主屏幕page兩側(cè)page部分顯示可以通過設(shè)置ViewPager的setPageMargin(int margin)方法實(shí)現(xiàn),具體代碼如下:

public class LauncherViewPager extends ViewPager {
    public static final int PAGE_LIMIT = 3;

    public LauncherViewPager(Context context) {
        this(context, null);
    }

    public LauncherViewPager(Context context, AttributeSet attrs) {
        super(context, attrs);
        init(context);
    }

    private void init(Context context) {
        this.setPageMargin(-getResources().getInteger(R.integer.portal_viewpager_margin));
        this.setOffscreenPageLimit(PAGE_LIMIT);
        this.setPageTransformer(true, new LauncherPageTransformer());
        try {
            Field Scroller = ViewPager.class.getDeclaredField("mScroller");
            Scroller.setAccessible(true);
            Interpolator interpolator = new LinearInterpolator();
            ViewPagerScroller scroller = new ViewPagerScroller(context,
                    interpolator);
            Scroller.set(this, scroller);
        } catch (NoSuchFieldException e) {
        } catch (IllegalArgumentException e) {
        } catch (IllegalAccessException e) {
        }
    }
}

         總結(jié):以上就是Launcher主體框架使用ViewPager實(shí)現(xiàn)左右滑動(dòng)和縮放效果講解,寫的不好的地方還請(qǐng)大家指出并批評(píng)指正,“三人行必有我?guī)煛?,任何給我的批評(píng)和建議我一定會(huì)有回復(fù)和交流,可以加我的微信號(hào),更快的交流。下一篇博客我將會(huì)講解屏幕中每一格CellView實(shí)現(xiàn),有焦點(diǎn)放大效果,實(shí)現(xiàn)每一個(gè)Focus的CellView懸浮效果和在xml文件中靈活配置關(guān)聯(lián)鏈接等。


第一時(shí)間獲得博客更新提醒,以及更多技術(shù)信息分享,歡迎關(guān)注個(gè)人微信公眾平臺(tái):程序員互動(dòng)聯(lián)盟(coder_online),掃一掃下方二維碼或搜索微信號(hào)coder_online即可關(guān)注,我們可以在線交流。

                                                          Android Metro風(fēng)格的Launcher開發(fā)系列第二篇

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

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

AI