底部導(dǎo)航欄的組合布局

本篇文章主要記錄昨天學(xué)習(xí)的組合布局實現(xiàn)底部導(dǎo)航欄的效果
顯示效果:


image.png

主要知識點結(jié)構(gòu):

  • 如何添加子控件到指定的布局容器
  • 如何實現(xiàn)布局界面之間的交互

那么如何添加子控件到指定的布局容器呢酬荞?

/**
     * 知識點:
     *     當(dāng)繼承于系統(tǒng)自帶的layout時 已經(jīng)規(guī)定好了規(guī)則
     *     只關(guān)心如何添加自己的子控件進去
     *     在哪里添加子控件?
     *     創(chuàng)建的時候添加
     * */

如何實現(xiàn)布局界面之間的交互

/**
這里可以通過子控件的點擊事件回調(diào)來實現(xiàn)
* */

下面我們開始具體實現(xiàn)如上效果,大致流程如下

  • 首先導(dǎo)入我們需要的項目資源到drawablemipmap包下
  • 然后實現(xiàn)單個控件的顯示和點按功能
  • 最后組合多個控件實現(xiàn)自己想要的效果

導(dǎo)入項目資源就不提了,我們首先先實現(xiàn)單個控件的顯示和點按功能
BarItem.Kotlin

class BarItem: LinearLayout {

    //正常狀態(tài)的icon資源
    var normalIcon:Int = 0
    //選中狀態(tài)的icon資源
    var selectIcon:Int = 0
    //顯示標題
    var text:String = ""
        set(value) {
            field = value
            titleTextView?.text = value
        }
    //字體顏色
    var textColor:Int = 0
    //是否選中
    var mIsSelected:Boolean = false
        set(value) {
            field = value
            updateUI()
        }

    //更新UI
    private fun updateUI() {
        if (mIsSelected){
            iconImageView?.setBackgroundResource(selectIcon)
            titleTextView?.setTextColor(textColor)
        }else{
            iconImageView?.setBackgroundResource(normalIcon)
            titleTextView?.setTextColor(Color.BLACK)
        }
    }

    private var iconImageView:ImageView? = null
    private var titleTextView:TextView? = null

    constructor(context: Context):super(context){
        initView()
    }

    constructor(context: Context,attrs:AttributeSet?):super(context, attrs){
        initView()
        initAttr(context, attrs)
    }

    //提取自定義屬性
    private fun initAttr(context: Context,attrs:AttributeSet?){
        val array = context.obtainStyledAttributes(attrs,R.styleable.BarItem)
        normalIcon = array.getResourceId(R.styleable.BarItem_normalIcon,R.mipmap.home)
        selectIcon = array.getResourceId(R.styleable.BarItem_selectIcon,R.mipmap.home_selected)
        text = array.getString(R.styleable.BarItem_text).toString()
        textColor = array.getInteger(R.styleable.BarItem_textColor, Color.RED)
        mIsSelected = array.getBoolean(R.styleable.BarItem_selected,false)
        array.recycle()
    }

    //布局子控件
    private fun initView(){
        //橫向布局
        orientation = VERTICAL
        //居中對齊
        gravity = Gravity.CENTER
        iconImageView = ImageView(context).also {
            val lp = LayoutParams(dp2px(32),dp2px(32))
            addView(it,lp)
        }
        titleTextView = TextView(context).also {
            val lp = LayoutParams(LayoutParams.WRAP_CONTENT,LayoutParams.WRAP_CONTENT)
            addView(it,lp)
        }
    }

    override fun onTouchEvent(event: MotionEvent?): Boolean {
        if (!mIsSelected){
            mIsSelected = true
        }
        return true
    }


    //dp值 轉(zhuǎn) px值
    private fun dp2px(dp:Int) = (context.resources.displayMetrics.density * dp).toInt()
}

在這里,我們在布局創(chuàng)建的時候添加子控件,也就是initView()方法在構(gòu)造方法里使用,然后聲明了對應(yīng)的屬性边坤,mIsSelected屬性用于判斷是否選中,當(dāng)出現(xiàn)點擊事件時谅年,它的值設(shè)置為true茧痒,這里我們設(shè)置了updateUI方法,用于更改對應(yīng)顯示的樣式融蹂,這里沒有設(shè)置屬性私有化的目的是便于外部設(shè)置對應(yīng)的屬性值旺订,我們使用xml布局顯示下效果
activity_main.xml布局

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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=".MainActivity">

    <me.jrl.demo1.BarItem
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        app:normalIcon="@mipmap/home"
        app:selectIcon="@mipmap/home_selected"
        app:text="主頁"
        app:textColor="@android:color/holo_red_light"
        app:selected="true"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.5"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>

顯示效果


image.png

下面我們組合實現(xiàn)底部導(dǎo)航欄
BarItem里聲明的回調(diào)方法

//回調(diào)
    var callBack:((p:Int)->Unit)? = null

在點擊事件中回調(diào)我們想要的position值

override fun onTouchEvent(event: MotionEvent?): Boolean {
        if (event?.action == MotionEvent.ACTION_DOWN){
            if (!mIsSelected) {
                mIsSelected = true
                callBack?.let {
                    it(position)
                }
            }
        }
        return true
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末弄企,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子区拳,更是在濱河造成了極大的恐慌拘领,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,366評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件樱调,死亡現(xiàn)場離奇詭異约素,居然都是意外死亡,警方通過查閱死者的電腦和手機笆凌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評論 3 395
  • 文/潘曉璐 我一進店門圣猎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人菩颖,你說我怎么就攤上這事样漆。” “怎么了晦闰?”我有些...
    開封第一講書人閱讀 165,689評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長鳍怨。 經(jīng)常有香客問我呻右,道長,這世上最難降的妖魔是什么鞋喇? 我笑而不...
    開封第一講書人閱讀 58,925評論 1 295
  • 正文 為了忘掉前任声滥,我火速辦了婚禮,結(jié)果婚禮上侦香,老公的妹妹穿的比我還像新娘落塑。我一直安慰自己,他們只是感情好罐韩,可當(dāng)我...
    茶點故事閱讀 67,942評論 6 392
  • 文/花漫 我一把揭開白布憾赁。 她就那樣靜靜地躺著,像睡著了一般散吵。 火紅的嫁衣襯著肌膚如雪龙考。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評論 1 305
  • 那天矾睦,我揣著相機與錄音晦款,去河邊找鬼。 笑死枚冗,一個胖子當(dāng)著我的面吹牛缓溅,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播赁温,決...
    沈念sama閱讀 40,447評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼坛怪,長吁一口氣:“原來是場噩夢啊……” “哼州藕!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起酝陈,我...
    開封第一講書人閱讀 39,349評論 0 276
  • 序言:老撾萬榮一對情侶失蹤床玻,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后沉帮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體锈死,經(jīng)...
    沈念sama閱讀 45,820評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,990評論 3 337
  • 正文 我和宋清朗相戀三年穆壕,在試婚紗的時候發(fā)現(xiàn)自己被綠了待牵。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,127評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡喇勋,死狀恐怖缨该,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情川背,我是刑警寧澤贰拿,帶...
    沈念sama閱讀 35,812評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站熄云,受9級特大地震影響膨更,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜缴允,卻給世界環(huán)境...
    茶點故事閱讀 41,471評論 3 331
  • 文/蒙蒙 一荚守、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧练般,春花似錦矗漾、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至都办,卻和暖如春嫡锌,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背琳钉。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評論 1 272
  • 我被黑心中介騙來泰國打工势木, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人歌懒。 一個月前我還...
    沈念sama閱讀 48,388評論 3 373
  • 正文 我出身青樓啦桌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子甫男,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,066評論 2 355