[開源解析]Yalantis/Side-Menu.Android

一桐磁、效果分析

效果圖1
效果圖2
布局:
  • DrawerLayout+Fragment
重點:
  • 側(cè)邊欄的數(shù)據(jù)結(jié)構(gòu)(名稱+資源文件)
  • 側(cè)邊欄的動畫效果(點擊ActionBar中的home按鈕捺宗,顯示側(cè)邊欄時的旋轉(zhuǎn)效果)

二镀娶、自定義DrawerLayout側(cè)邊欄

DrawLayout需要注意兩點:

  1. DrawerLayout最好是跟布局
  2. DrawerLayout中的子布局先后順序要注意,抽屜布局要放在最后麻诀,因為DrawerLayout布局和RelativeLayout布局類似初家,后寫的布局會覆蓋前面的布局。

三坷牛、側(cè)邊欄結(jié)構(gòu)設(shè)計

Interface:

public interface Resourceble {
    public int getImageRes();       //圖片資源文件罕偎,引用時放在項目的drawable文件夾下
    public String getName();        //每個資源文件對應(yīng)的名稱
}

數(shù)據(jù)模型類:

public class SlideMenuItem implements Resourceble {
    private String name;
    private int imageRes;

    public SlideMenuItem(String name, int imageRes) {
        this.name = name;
        this.imageRes = imageRes;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getImageRes() {
        return imageRes;
    }

    public void setImageRes(int imageRes) {
        this.imageRes = imageRes;
    }
}

四、側(cè)邊欄動畫設(shè)計

側(cè)邊欄的每一個Item都是SlideMenuItem實例京闰。每個SlideMenuItem的動畫效果是沿著Y軸旋轉(zhuǎn)90度(顯示是逆時針90°颜及,隱藏是順時針90°),為了動畫的平滑效果忙干,用到了加速插值器器予。

  • 自定義Animation
    FlipAnimation類,extends Animation捐迫。重寫了initialize(),applyTransformation()方法乾翔。動畫的平移,旋轉(zhuǎn)施戴,透明度變化都在applyTransformation中實現(xiàn)反浓。注意代碼中注釋的角度計算,是重點赞哗。每個Item都是圍繞Y軸做了旋轉(zhuǎn)操作雷则,度數(shù)都是90度。關(guān)鍵在于:
    1 如何做到顯示和隱藏的角度計算肪笋?
    2 如何平滑顯示和隱藏月劈?
    3 每一個Item的動畫效果延遲是如何實現(xiàn)的?
@Override
    protected void applyTransformation(float interpolatedTime, Transformation t) {
        final float fromDegrees = mFromDegrees;
        
        //interpolatedTime范圍固定0-1藤乙。
        //顯示:mToDegrees為90猜揪, mFromDegrees為0,變化范圍是-90度--->0度
        //隱藏:mToDegrees為0坛梁, mFromDegrees為90而姐,變化范圍是0度--->-90度
        float degrees = fromDegrees + ((mToDegrees - fromDegrees) * interpolatedTime);

        final float centerX = mCenterX;
        final float centerY = mCenterY;
        final Camera camera = mCamera;

        final Matrix matrix = t.getMatrix();
        camera.save();
        camera.rotateY(degrees);
        camera.getMatrix(matrix);
        camera.restore();

        matrix.preTranslate(-centerX, -centerY);
        matrix.postTranslate(centerX, centerY);

    }

顯示抽屜菜單,代碼可見划咐,平滑動畫的出現(xiàn)是因為使用了加速插值器rotation.setInterpolator(new AccelerateInterpolator());

private void animateView(int position) {
        final View view = viewList.get(position);
        view.setVisibility(View.VISIBLE);
        FlipAnimation rotation =
                new FlipAnimation(90, 0, 0.0f, view.getHeight() / 2.0f);
        rotation.setDuration(ANIMATION_DURATION);                           //175ms
        rotation.setFillAfter(true);
        rotation.setInterpolator(new AccelerateInterpolator());
        rotation.setAnimationListener(new Animation.AnimationListener() {
            @Override
            public void onAnimationStart(Animation animation) {

            }

            @Override
            public void onAnimationEnd(Animation animation) {
                view.clearAnimation();
            }

            @Override
            public void onAnimationRepeat(Animation animation) {

            }
        });
        view.startAnimation(rotation);
    }

每一個Item動畫交替出現(xiàn)是用了Handler延遲調(diào)用拴念,最后的Fragment的圖片切換效果是用了一個開源的庫RevealFrameLayout

for (int i = 0; i < size; i++) {
  略...
  new Handler().postDelayed(new Runnable() {
                public void run() {
                    if (position < viewList.size()) {
                        animateView((int) position);
                    }
                    if (position == viewList.size() - 1) {                  //最后一個Item
                        screenShotable.takeScreenShot();               //調(diào)用接口的方式來改變Fragment中的圖片(這個其實也是點擊之后才發(fā)生的效果)
                        setViewsClickable(true);
                    }
                }
            }, (long) delay);
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市褐缠,隨后出現(xiàn)的幾起案子政鼠,更是在濱河造成了極大的恐慌,老刑警劉巖送丰,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缔俄,死亡現(xiàn)場離奇詭異,居然都是意外死亡器躏,警方通過查閱死者的電腦和手機俐载,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來登失,“玉大人遏佣,你說我怎么就攤上這事±空悖” “怎么了状婶?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長馅巷。 經(jīng)常有香客問我膛虫,道長,這世上最難降的妖魔是什么钓猬? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任稍刀,我火速辦了婚禮,結(jié)果婚禮上敞曹,老公的妹妹穿的比我還像新娘账月。我一直安慰自己,他們只是感情好澳迫,可當(dāng)我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布局齿。 她就那樣靜靜地躺著,像睡著了一般橄登。 火紅的嫁衣襯著肌膚如雪抓歼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天拢锹,我揣著相機與錄音谣妻,去河邊找鬼。 笑死面褐,一個胖子當(dāng)著我的面吹牛拌禾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼矾麻,長吁一口氣:“原來是場噩夢啊……” “哼拆座!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起您市,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎役衡,沒想到半個月后茵休,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年榕莺,在試婚紗的時候發(fā)現(xiàn)自己被綠了俐芯。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡钉鸯,死狀恐怖吧史,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情唠雕,我是刑警寧澤贸营,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站岩睁,受9級特大地震影響钞脂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜捕儒,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一冰啃、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧肋层,春花似錦亿笤、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蒲拉,卻和暖如春肃拜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背雌团。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工燃领, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人锦援。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓猛蔽,卻偏偏與公主長得像,于是被迫代替她去往敵國和親灵寺。 傳聞我的和親對象是個殘疾皇子曼库,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,802評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,510評論 25 707
  • ¥開啟¥ 【iAPP實現(xiàn)進入界面執(zhí)行逐一顯】 〖2017-08-25 15:22:14〗 《//首先開一個線程,因...
    小菜c閱讀 6,358評論 0 17
  • 內(nèi)容抽屜菜單ListViewWebViewSwitchButton按鈕點贊按鈕進度條TabLayout圖標下拉刷新...
    皇小弟閱讀 46,708評論 22 664
  • 六點半吃了一碗粉絲湯略板,然后培訓(xùn)到八點毁枯,開會到九點半,加班到十點半叮称。出門打卡的時候肚子咕咕了一聲种玛,我并沒有太在意藐鹤。我...
    hanxiaoxin7閱讀 118評論 0 0
  • 小小說 石獅子 ——奇石奇事小說之七 為了支持南水北調(diào)中線工程建設(shè),我只好隨著父母妻女外遷到武漢黃陂區(qū)六指街赂韵,我的...
    文心雕禪閱讀 359評論 0 1