ToolBar 的封裝

ToolBar的封裝主要是利用ViewGroup把自定義的 View一個(gè)個(gè)加進(jìn)去。
首先我們先定義一個(gè)Toobar.xml代碼如下:

<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    android:background="@color/accent_material_light"
    app:navigationIcon="?attr/homeAsUpIndicator"
    android:id="@+id/toobar_id"
    />

主方法入口MainActivity,直接繼承ToolBarActivity代碼如下:

package com.example.luis.toolbarenc;

import android.os.Bundle;

public class MainActivity extends ToolBarActivity  {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }    
}

ToolBarActivity是繼承AppCompatActivity 并重寫(xiě)setContentView方法,代碼如下:

package com.example.luis.toolbarenc;

import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.MenuItem;
import android.view.Window;

/**
 * Create by luis on 2016/4/12 18:43
 * e-mail:aer874475222@163.com
 */
public abstract class ToolBarActivity extends AppCompatActivity {
    private ToolBarHelper mToolBarHelper;
    public Toolbar toolbar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

    }

    @Override
    public void setContentView(int layoutResID) {
        supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
        mToolBarHelper = new ToolBarHelper(this, layoutResID);
        toolbar = mToolBarHelper.getToolBar();
        setContentView(mToolBarHelper.getContentView()); /*把 toolbar 設(shè)置到Activity 中*/
        setSupportActionBar(toolbar); /*自定義的一些操作*/
        onCreateCustomToolBar(toolbar);
    }

    public void onCreateCustomToolBar(Toolbar toolbar) {
        toolbar.setContentInsetsRelative(0, 0);
    }a

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        if (item.getItemId() == android.R.id.home) {
            finish();
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}

這里我們還要定義ToolBarHelper 這個(gè)工具類(lèi)

package com.example.luis.toolbarenc;

import android.content.Context;
import android.content.res.TypedArray;
import android.support.v7.widget.Toolbar;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.FrameLayout;

/**
 * Create by luis on 2016/4/12 18:44
 * e-mail:aer874475222@163.com
 */
public class ToolBarHelper { /*上下文,創(chuàng)建view的時(shí)候需要用到*/
    private Context mContext; /*base view*/
    private FrameLayout mContentView; /*用戶(hù)定義的view*/
    private View mUserView; /*toolbar*/
    private Toolbar mToolBar; /*視圖構(gòu)造器*/
    private LayoutInflater mInflater; /*
    * 兩個(gè)屬性
    * 1、toolbar是否懸浮在窗口之上
    * 2、toolbar的高度獲取
    * */
    private static int[] ATTRS = {
            R.attr.windowActionBarOverlay,
            R.attr.actionBarSize
    };

    public ToolBarHelper(Context context, int layoutId) {
        this.mContext = context;
        mInflater = LayoutInflater.from(mContext); /*初始化整個(gè)內(nèi)容*/
        initContentView(); /*初始化用戶(hù)定義的布局*/
        initUserView(layoutId); /*初始化toolbar*/
        initToolBar();
    }

    private void initContentView() { /*直接創(chuàng)建一個(gè)幀布局,作為視圖容器的父容器*/
        mContentView = new FrameLayout(mContext);
        ViewGroup.LayoutParams params = new ViewGroup.LayoutParams

(ViewGroup.LayoutParams.MATCH_PARENT,
                ViewGroup.LayoutParams.MATCH_PARENT);
        mContentView.setLayoutParams(params);

    }

    private void initToolBar() { /*通過(guò)inflater獲取toolbar的布局文件*/
        View toolbar = mInflater.inflate(R.layout.toolbar, mContentView);
        mToolBar = (Toolbar) toolbar.findViewById(R.id.toobar_id);
    }

    private void initUserView(int id) {
        mUserView = mInflater.inflate(id, null);
        FrameLayout.LayoutParams params = new FrameLayout.LayoutParams

(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT);
        TypedArray typedArray = mContext.getTheme().obtainStyledAttributes(ATTRS); /*獲取

主題中定義的懸浮標(biāo)志*/
        boolean overly = typedArray.getBoolean(0, false); /*獲取主題中定義的toolbar的高度

*/
        int toolBarSize = (int) typedArray.getDimension(1, (int) mContext.getResources

().getDimension(R.dimen.abc_action_bar_default_height_material));
        typedArray.recycle(); /*如果是懸浮狀態(tài),則不需要設(shè)置間距*/
        params.topMargin = overly ? 0 : toolBarSize;
        mContentView.addView(mUserView, params);

    }

    public FrameLayout getContentView() {
        return mContentView;
    }

    public Toolbar getToolBar() {
        return mToolBar;
    }
}

這樣就完成了?。?!


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,058評(píng)論 25 709
  • Android程序員都知道Activity調(diào)用setContentView的方法是將xml布局文件加載到Activ...
    AxeChen閱讀 6,245評(píng)論 4 14
  • 無(wú)題 我無(wú)處躲藏,巴巴望著 黃昏走得比想象中快 不說(shuō)一聲的掠奪 被扒掉了衣裳 我輕柔的月紗 仿佛轉(zhuǎn)瞬間就要 卷入神...
    七君閱讀 526評(píng)論 0 0
  • 所謂迷茫,就是才華配不上夢(mèng)想:大事干不了,小事不肯干;不想做手邊的事,只想做天邊的事。解除迷茫,就從小事做起,從身...
    老鼠_88e8閱讀 287評(píng)論 0 0
  • 本文是 Android 系統(tǒng)學(xué)習(xí)系列文章中的第一章節(jié)的內(nèi)容,介紹了 PackageManagerService 在...
    _qisen閱讀 3,246評(píng)論 0 6

友情鏈接更多精彩內(nèi)容