使用BottomNavigationView构造底部导航栏

2019.9.10 修改

取代RadioGroup和RadioButton创建底部选择栏

使用AndroidStudio自动创建Activity,选择Bottom Navigation Activity

重点内容:

  1. 布局:

    <android.support.design.widget.BottomNavigationView
        android:id="@+id/navigation"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?android:attr/windowBackground"
        app:menu="@menu/navigation"/>
    
  2. 创建menu文件

    <menu xmlns:android="http://schemas.android.com/apk/res/android">
        <item
            android:id="@+id/navigation_home"
            android:icon="@drawable/ic_home_black_24dp"
            android:title="@string/title_home"/>
        <item
            android:id="@+id/navigation_dashboard"
            android:icon="@drawable/ic_dashboard_black_24dp"
            android:title="@string/title_dashboard"/>
        <item
            android:id="@+id/navigation_notifications"
            android:icon="@drawable/ic_notifications_black_24dp"
            android:title="@string/title_notifications"/>
    </menu>
    
  3. 监听事件

    navigation.setOnNavigationItemSelectedListener(mOnNavigationItemSelectedListener)
    
  4. 设置图片大小

    //扩展方法,直接调用,传入dp
    fun BottomNavigationView.setChildDimension(width: Float, height: Float) {
        val menuView = getChildAt(0) as BottomNavigationMenuView
        for (i in 0 until menuView.childCount) {
            val iconView = menuView.getChildAt(i).findViewById<View>(R.id.icon)
            val layoutParams = iconView.layoutParams
            val displayMetrics = resources.displayMetrics
            layoutParams.height = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, width, displayMetrics).toInt()
            layoutParams.width = TypedValue.applyDimension(TypedValue.COMPLEX_UNIT_DIP, height, displayMetrics).toInt()
            iconView.layoutParams = layoutParams
        }
    }
    
  5. 设置小红点

    BottomNavigationMenuView menuView = mNavView.getChildAt(0) as BottomNavigationMenuView
    val tab = menuView.getChildAt(1)
    val itemView = tab as BottomNavigationItemView
    val mDot = View(this)
    val params = BottomNavigationItemView.LayoutParams(dip(this, 8), dip(8))
    params.gravity = Gravity.END
    params.setMargins(0, dip(8), dip(45), 0)
    mDot.setLayoutParams(params)
    itemView.addView(mDot)
    mDot.setBackgroundResource(R.drawable.dot)
    
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值