BottomNavigationView简单使用


简单说明

之前见过类似这个库, 是带ripple效果的
不记得具体地址了,和这个类似
https://github.com/Ashok-Varma/BottomNavigation

还有:
https://github.com/armcha/LuseenBottomNavigation

在看 简友:[英勇青铜5] 文章的时候
http://www.jianshu.com/users/8edc8ef5fef3/latest_articles

发现,在 com.android.support:design:25.0.0 中
有对应的类支持
可能是自己其他方面事情的原因,android的代码量现在减少了很多,包括去了解新东西


大体效果

和之前的一些切换差不多
只是多了一个动画效果


或者简单padding一下,放到靠中间一点的位置(或者别的地方也行)


简单使用

添加比较简单
大体分为下面几部

  • 在 build.gradle 文件中增加依赖:
    compile 'com.android.support:design:25.0.0'

  • 在 res/menu/ 文件夹下创建一个 xml 文件
    没有menu文件夹,则自己创建一个即可
    将其xml文件,命名为 xxx_xxx.xml,自己的是 bottom_navigation_main.xml

    • 内容大体为:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/basketball"
android:enabled="true"
android:icon="@android:drawable/ic_menu_call"
android:title="basketball"
app:showAsAction="ifRoom" />
<item
android:id="@+id/football"
android:enabled="true"
android:icon="@android:drawable/ic_popup_reminder"
android:title="football"
app:showAsAction="ifRoom" />

<item
    android:id="@+id/volleyball"
    android:enabled="true"
    android:icon="@android:drawable/ic_dialog_info"
    android:title="volleyball"
    app:showAsAction="ifRoom" />

<item
    android:id="@+id/dodo"
    android:enabled="true"
    android:icon="@android:drawable/ic_input_add"
    android:title="dodo"
    app:showAsAction="ifRoom" />

</menu>

- 写对应的layout
  自己添加了一个TextView,切换后,修改TextView,表示切换:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.aohuan.demo.bottomnavigation.MainActivity">

<!--android:paddingBottom="@dimen/activity_vertical_margin"-->
<!--android:paddingLeft="@dimen/activity_horizontal_margin"-->
<!--android:paddingRight="@dimen/activity_horizontal_margin"-->
<!--android:paddingTop="@dimen/activity_vertical_margin"-->
<!--android:background="@android:color/holo_red_light"-->

<TextView
    android:id="@+id/tv_dodo"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    android:text="BASKETBALL" />

<android.support.design.widget.BottomNavigationView
    android:id="@+id/bottom_navigation"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    app:itemBackground="@color/colorPrimary"
    app:itemIconTint="@color/white"
    app:itemTextColor="@color/colorAccent"
    app:menu="@menu/bottom_navigation_main" />

</RelativeLayout>


- Activity只是简单调用

package com.aohuan.demo.bottomnavigation;

import android.support.annotation.NonNull;
import android.support.design.widget.BottomNavigationView;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.MenuItem;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {

private TextView mTvDodo;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mTvDodo = (TextView) findViewById(R.id.tv_dodo);
    BottomNavigationView bottomNavigationView = (BottomNavigationView)
            findViewById(R.id.bottom_navigation);
    bottomNavigationView.setOnNavigationItemSelectedListener(
        new BottomNavigationView.OnNavigationItemSelectedListener() {
            @Override
            public boolean onNavigationItemSelected(@NonNull MenuItem item) {
                switch (item.getItemId()) {
                }
                mTvDodo.setText(item.getTitle().toString().toUpperCase());
                return false;
            }
        }
    );
}

}


---
### 简单小节
这个控件用起来还是挺方便的
可以根据自己的需求,再次进行封装
具体的源码,也很短
也就300多行
里面关联了 BottomNavigationMenuView, BottomNavigationPresenter, MenuBuilder 等类
其中, MenuBuilder 比较复杂
对应的响应,通过内部接口OnNavigationItemSelectedListener 去Invoke回传

最近代码量很少,自己多花点时间看看组件,写写demo

具体代码,可以见
https://github.com/2954722256/use_little_demo
对应 bottomnavigation 的 Module
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容