封裝TitleBar

在項(xiàng)目開發(fā)過程中弧关,會(huì)發(fā)現(xiàn)帶有返回鍵盅安、標(biāo)b題和按鈕的 TitleBar 總是出現(xiàn)在多個(gè)界面中,如下圖世囊。而且它們的界面和邏輯都一樣别瞭。如果每個(gè)界面都寫一次代碼,就造成了重復(fù)代碼株憾,對(duì)開發(fā)效率和心情都有很大的影響蝙寨。因此,應(yīng)該對(duì)這樣的重復(fù) TitleBar 進(jìn)行封裝嗤瞎,一次編寫到處使用

常用的 TitleBar 有兩種墙歪,下面這是帶返回鍵、標(biāo)題的 TitleBar

返回鍵贝奇,標(biāo)題

這是帶返回鍵虹菲、標(biāo)題、提交按鈕就的 TitleBar

返回鍵掉瞳,標(biāo)題毕源、按鈕

自定義屬性

標(biāo)題的文字需要根據(jù)不同的界面顯示不通過的內(nèi)容,按鈕的文字也是一樣陕习,所以就需要用到自定義屬性霎褐。在 res/values 文件夾中創(chuàng)建 attrs.xml 文件,添加如下內(nèi)容

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <declare-styleable name="MyTitleBar">
        <attr name="mtb_title" format="string"/>
        <attr name="mtb_btn_text" format="string"/>
    </declare-styleable>

</resources>

注意一下自定義屬性前面都帶有 mtb_ 前綴(My Title Bar 的縮寫)该镣,這是為了防止和其他自定義屬性同名

預(yù)定義控件ID

定義一下返回鍵冻璃、標(biāo)題、按鈕的 ID

<?xml version="1.0" encoding="utf-8"?>
<resources>
    
    <item name="titleBar_btn_back" type="id"/><!-- 左邊的返回鍵 -->
    <item name="titleBar_title" type="id"/><!-- 標(biāo)題 -->
    <item name="titleBar_btn_ok" type="id"/><!-- 右邊的按鈕 -->

</resources>

創(chuàng)建TitleBard的布局

創(chuàng)建 res/layout/titlebar_back_title_btn.xml 布局文件

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="@dimen/titlebar_height"
    android:background="@color/blue">

    <ImageButton
        android:id="@id/titleBar_btn_back"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:background="@null"
        android:paddingLeft="15dp"
        android:paddingRight="15dp"
        android:src="@drawable/mytitlebar_back_arrow"/>

    <TextView
        android:id="@id/titleBar_title"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_centerInParent="true"
        android:gravity="center"
        android:textColor="#fff"
        android:textSize="@dimen/text_size_large"
        tools:text="明星教練"/>

    <Button
        android:id="@id/titleBar_btn_ok"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_alignParentEnd="true"
        android:layout_alignParentRight="true"
        android:background="@drawable/titlebar_btn_ok_selector"
        android:minWidth="70dp"
        android:onClick="onTitleBarBtnClick"
        android:text="完成"
        android:textColor="@color/white"
        android:textSize="@dimen/text_size_normal"/>
</RelativeLayout>

相關(guān)的資源如下

顏色 color.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="blue">#1f75c0</color>
    <color name="white">#fff</color>
</resources>

尺寸 dimens.xml

<resources>
    <dimen name="titlebar_height">50dp</dimen>
    <dimen name="text_size_normal">16sp</dimen>
    <dimen name="text_size_large">18sp</dimen>
</resources>

注意一下右邊的按鈕的布局

<Button
    android:id="@id/titleBar_btn_ok"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_alignParentEnd="true"
    android:layout_alignParentRight="true"
    android:background="@drawable/titlebar_btn_ok_selector"
    android:minWidth="70dp"
    android:onClick="onTitleBarBtnClick"
    android:text="完成"
    android:textColor="@color/white"
    android:textSize="@dimen/text_size_normal"/>

其中的

android:onClick="onTitleBarBtnClick"

這是為按鈕設(shè)置了一個(gè)監(jiān)聽事件,等下會(huì)講解

創(chuàng)建 MyTitleBar 類

public class MyTitleBar extends FrameLayout {

    // 左邊的返回鍵
    private ImageButton mIvBtnBack;
    // 標(biāo)題文字
    private TextView mTvTitle;
    // 右邊的按鈕
    private Button mBtnRight;

    public MyTitleBar(Context context, AttributeSet attrs) {
        super(context, attrs);

        LayoutInflater.from(context).inflate(R.layout.titlebar_back_title_btn, this);

        mIvBtnBack = (ImageButton) findViewById(R.id.titleBar_btn_back);
        mTvTitle = (TextView) findViewById(R.id.titleBar_title);
        mBtnRight = (Button) findViewById(R.id.titleBar_btn_ok);
        
        
        TypedArray typedArray = context.obtainStyledAttributes(attrs, R.styleable.MyTitleBar);
        try {
            
            String titleText = typedArray.getString(R.styleable.MyTitleBar_mtb_title);
            mTvTitle.setText(titleText);
            
            String btnText = typedArray.getString(R.styleable.MyTitleBar_mtb_btn_text);
            mBtnRight.setText(btnText);
        } finally {
            typedArray.recycle();
        }

        // 左邊按鈕的監(jiān)聽事件
        mIvBtnBack.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                ((Activity) getContext()).finish();
            }
        });
    }

    /**
     * 重新設(shè)置左邊按鈕的點(diǎn)擊事件監(jiān)聽器
     */
    public void setBtnBckClickListener(View.OnClickListener listener) {
        mIvBtnBack.setOnClickListener(listener);
    }
}

使用

MainActivity.xml

<?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"
    android:id="@+id/activity_title_bar"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.owen.dialogsample.views.MyTitleBar
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:mtb_btn_text="提交"
        app:mtb_title="標(biāo)題"/>

</RelativeLayout>

MainActivity.java 中俱饿,別忘了創(chuàng)建 onTitleBarBtnClick(View v) 方法歌粥,否則點(diǎn)擊按鈕時(shí)會(huì)崩潰

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    public void onTitleBarBtnClick(View v) {
        Toast.makeText(this, "右邊按鈕被點(diǎn)擊了", Toast.LENGTH_SHORT).show();
    }
}

效果圖如下

![效果圖]](http://upload-images.jianshu.io/upload_images/3617116-471594ef8d53d5ec.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市拍埠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌土居,老刑警劉巖枣购,帶你破解...
    沈念sama閱讀 206,602評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異擦耀,居然都是意外死亡棉圈,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門眷蜓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)分瘾,“玉大人,你說(shuō)我怎么就攤上這事吁系〉抡伲” “怎么了?”我有些...
    開封第一講書人閱讀 152,878評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵汽纤,是天一觀的道長(zhǎng)上岗。 經(jīng)常有香客問我,道長(zhǎng)蕴坪,這世上最難降的妖魔是什么肴掷? 我笑而不...
    開封第一講書人閱讀 55,306評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮背传,結(jié)果婚禮上呆瞻,老公的妹妹穿的比我還像新娘。我一直安慰自己径玖,他們只是感情好痴脾,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,330評(píng)論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著挺狰,像睡著了一般明郭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上丰泊,一...
    開封第一講書人閱讀 49,071評(píng)論 1 285
  • 那天薯定,我揣著相機(jī)與錄音,去河邊找鬼瞳购。 笑死话侄,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播年堆,決...
    沈念sama閱讀 38,382評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼吞杭,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了变丧?” 一聲冷哼從身側(cè)響起芽狗,我...
    開封第一講書人閱讀 37,006評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎痒蓬,沒想到半個(gè)月后童擎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,512評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡攻晒,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,965評(píng)論 2 325
  • 正文 我和宋清朗相戀三年顾复,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鲁捏。...
    茶點(diǎn)故事閱讀 38,094評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡芯砸,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出给梅,到底是詐尸還是另有隱情假丧,我是刑警寧澤,帶...
    沈念sama閱讀 33,732評(píng)論 4 323
  • 正文 年R本政府宣布破喻,位于F島的核電站虎谢,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏曹质。R本人自食惡果不足惜婴噩,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,283評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望羽德。 院中可真熱鬧几莽,春花似錦、人聲如沸宅静。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)姨夹。三九已至纤垂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間磷账,已是汗流浹背峭沦。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留逃糟,地道東北人吼鱼。 一個(gè)月前我還...
    沈念sama閱讀 45,536評(píng)論 2 354
  • 正文 我出身青樓蓬豁,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親菇肃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子地粪,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,828評(píng)論 2 345

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)琐谤,斷路器蟆技,智...
    卡卡羅2017閱讀 134,600評(píng)論 18 139
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,514評(píng)論 25 707
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)、插件笑跛、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,029評(píng)論 4 62
  • 第一章付魔。 降生 每年的這個(gè)時(shí)候大雪都會(huì)為大東北披上新裝,和以前一樣還是這個(gè)季節(jié)還是同樣的雪花飞蹂,一對(duì)...
    青巖頌閱讀 201評(píng)論 0 1
  • 運(yùn)行時(shí)數(shù)據(jù)區(qū)域 程序計(jì)數(shù)器 一塊較小的內(nèi)存空間,(java中的多線程是輪流切換并分配處理器時(shí)間翻屈,在任一個(gè)確定的時(shí)刻...
    zcwfeng閱讀 168評(píng)論 0 1