android底部星級(jí)菜單

這一篇文在上一篇的基礎(chǔ)上做的功能修改(上一篇地址:http://www.reibang.com/p/ecea65f4015d)
效果圖如下:

底部星級(jí)菜單效果圖.gif

主要的修改有下面幾個(gè)方面:
1.主菜單有五個(gè)赞警,點(diǎn)擊第三個(gè)會(huì)打開星級(jí)菜單
2.在星級(jí)菜單打開的情況科展,點(diǎn)擊其余的主菜單會(huì)關(guān)閉星級(jí)菜單
3.主菜單和星級(jí)菜單的位置不一樣了峭跳,星級(jí)菜單這次是180度的區(qū)域
4.星級(jí)菜單的移動(dòng)動(dòng)畫的路徑不一樣
1.前面的步驟還是一樣,自定義屬性,自定義view,繪制xml布局,在自定義的view里面獲取半徑霎匈,重寫onMeasure方法
2.重寫onLayout方法
測(cè)量主button的位置

    private void layoutCenter2() {
        LinearLayout mainView = (LinearLayout) getChildAt(0);
        int width = mainView.getMeasuredWidth();
        int height = mainView.getMeasuredHeight();
        int t = getMeasuredHeight() - height;
        mainView.layout(0, t, width, getMeasuredHeight());
        mCButton = findViewById(R.id.btnCenter);
        findViewById(R.id.btnMain1).setOnClickListener(this);
        findViewById(R.id.btnMain2).setOnClickListener(this);
        findViewById(R.id.btnMain3).setOnClickListener(this);
        findViewById(R.id.btnMain4).setOnClickListener(this);
        mCButton.setOnClickListener(this);
    }

測(cè)量星級(jí)菜單的位置


底部星級(jí)菜單位置.png
    /**
     * 設(shè)置itemMenu的位置
     */
    private void layoutIButtom() {
        int cout = getChildCount();
        for (int i = 0; i < cout - 1; i++) {
            View childView = getChildAt(i + 1);
            int width = childView.getMeasuredWidth();
            int height = childView.getMeasuredHeight();
            //相對(duì)坐標(biāo)
            int rlx = (int) (mRadius * Math.cos(Math.PI / cout * (i + 1)));
            int rly = (int) (mRadius * Math.sin(Math.PI / cout * (i + 1)));

            int l = getMeasuredWidth() / 2 + rlx - width / 2;
            int t = getMeasuredHeight() - rly - height;
            childView.layout(l, t, l + width, t + height);

            childView.setVisibility(GONE);
        }
    }

3.點(diǎn)擊中間的星級(jí)菜單的動(dòng)畫效果,主菜單還是一樣的送爸,星級(jí)菜單會(huì)有點(diǎn)區(qū)別

    /**
     * mune的動(dòng)畫效果
     *
     * @param duration
     */
    private void toggleItemMenu(int duration) {
        int count = getChildCount();
        for (int i = 0; i < count - 1; i++) {
            final View childView = getChildAt(i + 1);
            childView.setVisibility(VISIBLE);

            int rlx = (int) (mRadius * Math.cos(Math.PI / count * (i + 1)));
            int rly = (int) (mRadius * Math.sin(Math.PI / count * (i + 1)));

            AnimationSet animationSet = new AnimationSet(true);
            //位移動(dòng)畫
            TranslateAnimation translateAnimation = null;
            //打開
            if (mCurrentStatus == State.CLOSE) {
                translateAnimation = new TranslateAnimation(-rlx, 0f, rly, 0f);
                childView.setEnabled(true);
                childView.setFocusable(true);
            } else {//關(guān)閉
                translateAnimation = new TranslateAnimation(0f, -rlx, 0f, rly);
            }

            translateAnimation.setDuration(duration);
            translateAnimation.setFillAfter(true);
            //旋轉(zhuǎn)動(dòng)畫
            RotateAnimation rotateAnimation = new RotateAnimation(0, 720, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
            rotateAnimation.setDuration(duration);
            rotateAnimation.setFillAfter(true);

            animationSet.addAnimation(rotateAnimation);
            animationSet.addAnimation(translateAnimation);
            childView.startAnimation(animationSet);

            animationSet.setAnimationListener(new Animation.AnimationListener() {
                @Override
                public void onAnimationStart(Animation animation) {

                }

                @Override
                public void onAnimationEnd(Animation animation) {
                    if (mCurrentStatus == State.CLOSE) {
                        childView.setVisibility(GONE);
                    }
                }

                @Override
                public void onAnimationRepeat(Animation animation) {

                }
            });

            final int pos = i + 1;
            childView.setOnClickListener(new OnClickListener() {
                @Override
                public void onClick(View v) {
                    if (onMenuItemClick != null) {
                        onMenuItemClick.onItemMenuItemClick(pos);
                    }
                    onMenuItemAnmiate(pos - 1);
                    changeMenuStatus();
                }
            });
        }

        changeMenuStatus();
    }

其余的效果都差不多铛嘱,項(xiàng)目地址和上篇的項(xiàng)目地址是一樣的

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市袭厂,隨后出現(xiàn)的幾起案子墨吓,更是在濱河造成了極大的恐慌,老刑警劉巖纹磺,帶你破解...
    沈念sama閱讀 216,324評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件帖烘,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡橄杨,警方通過查閱死者的電腦和手機(jī)秘症,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來式矫,“玉大人乡摹,你說我怎么就攤上這事〔勺” “怎么了聪廉?”我有些...
    開封第一講書人閱讀 162,328評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我板熊,道長(zhǎng)框全,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,147評(píng)論 1 292
  • 正文 為了忘掉前任邻邮,我火速辦了婚禮竣况,結(jié)果婚禮上克婶,老公的妹妹穿的比我還像新娘筒严。我一直安慰自己,他們只是感情好情萤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評(píng)論 6 388
  • 文/花漫 我一把揭開白布鸭蛙。 她就那樣靜靜地躺著,像睡著了一般筋岛。 火紅的嫁衣襯著肌膚如雪娶视。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,115評(píng)論 1 296
  • 那天睁宰,我揣著相機(jī)與錄音肪获,去河邊找鬼。 笑死柒傻,一個(gè)胖子當(dāng)著我的面吹牛孝赫,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播红符,決...
    沈念sama閱讀 40,025評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼青柄,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了预侯?” 一聲冷哼從身側(cè)響起致开,我...
    開封第一講書人閱讀 38,867評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎萎馅,沒想到半個(gè)月后双戳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,307評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡糜芳,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評(píng)論 2 332
  • 正文 我和宋清朗相戀三年拣技,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片耍目。...
    茶點(diǎn)故事閱讀 39,688評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡膏斤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出邪驮,到底是詐尸還是另有隱情莫辨,我是刑警寧澤,帶...
    沈念sama閱讀 35,409評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站沮榜,受9級(jí)特大地震影響盘榨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蟆融,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評(píng)論 3 325
  • 文/蒙蒙 一草巡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧型酥,春花似錦山憨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至由境,卻和暖如春棚亩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背虏杰。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評(píng)論 1 268
  • 我被黑心中介騙來泰國打工讥蟆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人纺阔。 一個(gè)月前我還...
    沈念sama閱讀 47,685評(píng)論 2 368
  • 正文 我出身青樓瘸彤,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親州弟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子钧栖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評(píng)論 2 353

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

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件婆翔、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,093評(píng)論 4 62
  • 今天要和大家分享的學(xué)習(xí)筆記是關(guān)于手機(jī)攝影方面的拯杠,相信很多人都很想用手機(jī)拍好生活中的照片,說起來也是件自豪的事情啃奴。 ...
    布丁姑娘閱讀 716評(píng)論 0 16
  • 耳邊潭陪,總該有段旋律,或深入心府最蕾,或沉入執(zhí)迷依溯,從何時(shí)開始,我的意識(shí)里開始出現(xiàn)了伴奏的概念瘟则。記得大三的時(shí)候黎炉,每個(gè)人都會(huì)...
    陳小寶i閱讀 233評(píng)論 0 0