Material Design Library 使用匯總

我的CSDN博客同步發(fā)布:Material Design Library 使用匯總

轉(zhuǎn)載請注明出處:【huachao1001的簡書:http://www.itdecent.cn/users/0a7e42698e4b/latest_articles】

本文對Material Design Library里面的庫類的使用做一個(gè)簡單的匯總,方便以后能快速查詢、快速上手使用。本文包括以下內(nèi)容:

  • Color Palette
  • Toolbar
  • AppBarLayout
  • CollapsingToolbarLayout
  • CoordinatorLayout
  • DrawerLayout、NavigationView
  • Floating Action Button (FAB)
  • Snackbar
  • TabLayout
  • TextInputLayout

如有遺漏,歡迎大家留言告知。我會持續(xù)補(bǔ)充,謝謝~。

要使用Material Design Library ,首先得將依賴庫加入到項(xiàng)目中,在appbuild.gradle中(dependencies{ }),添加如下:

 compile 'com.android.support:design:24.0.0'

1 Color Palette

我們可以定義狀態(tài)欄、ActionBar(或ToolBar)、導(dǎo)航欄等等顏色??梢酝ㄟ^如下方式:

修改res/values/styles.xml文件如下:

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

</resources>

當(dāng)然了,可自定義的不僅僅就上面示例中的3個(gè),你還可以自定義如下圖所示的區(qū)域的顏色:

Color Palette

例如,你可以修改窗口背景色:

 <item name="android:windowBackground">@color/colorAccent</item>

2 Toolbar、AppBarLayout、CollapsingToolbarLayout

參考我的另一篇文章【玩轉(zhuǎn)AppBarLayout,更酷炫的頂部欄 】

3 CoordinatorLayout

參考我的另一篇文章【CoordinatorLayout的使用如此簡單 】

4 DrawerLayout、NavigationView

在很多應(yīng)用中都使用到了Drawer導(dǎo)航,在Design Support Library中,提供了DrawerLayout,看看如何使用的吧!

首先,需要將android.support.v4.widget.DrawerLayout作為布局的根標(biāo)簽,然后android.support.design.widget.NavigationView作為其中的子標(biāo)簽。如下所示:

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:text="hello world!" />

    </RelativeLayout>

    <android.support.design.widget.NavigationView
        android:id="@+id/navigation_view"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        app:headerLayout="@layout/drawer_header"
        app:menu="@menu/drawer" />
</android.support.v4.widget.DrawerLayout>

NavigationView包含兩個(gè)引用,一個(gè)是導(dǎo)航里面的頭部,另一個(gè)是菜單項(xiàng),res/layout/drawer_header如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="150dp"
    android:background="?attr/colorPrimaryDark"
    android:gravity="bottom"
    android:orientation="vertical"
    android:padding="16dp"
    android:theme="@style/ThemeOverlay.AppCompat.Dark">

    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="頭部"
        android:textAppearance="@style/TextAppearance.AppCompat.Body1" />

</LinearLayout>

res/menu/drawer.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">

    <group android:checkableBehavior="single">
        <item
            android:id="@+id/home"
            android:checked="true"
            android:icon="@drawable/home"
            android:title="主頁" />
        <item
            android:id="@+id/theme"
            android:icon="@drawable/theme"
            android:title="主題" />
        <item
            android:id="@+id/settings"
            android:icon="@drawable/setting"
            android:title="設(shè)置" />
    </group>

    <item android:title="二級菜單">
        <menu>
            <item
                android:icon="@drawable/favorite"
                android:title="收藏" />
            <item
                android:icon="@drawable/ablum"
                android:title="相冊" />
            <item
                android:icon="@drawable/friends"
                android:title="好友" />
        </menu>
    </item>

</menu>

然后,可以在我們的Activity里面響應(yīng)菜單點(diǎn)擊:


public class MainActivity extends Activity 
               implements NavigationView.OnNavigationItemSelectedListener {

    private DrawerLayout mDrawerLayout;
    private NavigationView mNavigationView;

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

        mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);
        mNavigationView = (NavigationView) findViewById(R.id.navigation_view);

        mNavigationView.setNavigationItemSelectedListener(this);


    }

    @Override
    public boolean onNavigationItemSelected(MenuItem menuItem) {


        // int id = menuItem.getItemId();
        String title = (String) menuItem.getTitle();
        Toast.makeText(this, "您點(diǎn)擊了 " + title, Toast.LENGTH_SHORT).show();

        return super.onContextItemSelected(menuItem);

    }


}

效果如下:


Drawer

5 Floating Action Button (FAB)

直接將android.support.design.widget.FloatingActionButton放入布局中即可,例如,要放到右下:

 <android.support.design.widget.FloatingActionButton
            android:id="@+id/fab"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_alignParentRight="true"
            android:layout_marginRight="@dimen/activity_horizontal_margin"
            android:layout_marginBottom="@dimen/activity_vertical_margin"
            android:src="@drawable/ic_done" />

如果需要監(jiān)聽點(diǎn)擊,直接通過setOnclickListener即可:

 fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Toast.makeText(MainActivity.this, "您點(diǎn)擊了FAB", Toast.LENGTH_SHORT).show();
            }
        });
FAB

6 Snackbar

一般情況下,如果你想給用戶一個(gè)簡短的響應(yīng)反饋,我們會選擇使用Toast,現(xiàn)在我們有了另一個(gè)選擇啦:Snackbar。

看看如何使用

public void onClick(View v) {

    View.OnClickListener onClickListener = new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Toast.makeText(MainActivity.this,
                    "您點(diǎn)擊了Snackbar中的確定", Toast.LENGTH_SHORT).show();
        }
    };

    Snackbar sb = Snackbar.make(v,
            "在這里是Snackbar顯示內(nèi)容",
            Snackbar.LENGTH_LONG);

    //添加點(diǎn)擊"按鈕"-->"確定"及其對應(yīng)的點(diǎn)擊事件
    sb.setAction("確定", onClickListener);
    //設(shè)置"確定"的顏色
    sb.setActionTextColor(Color.RED);

    //設(shè)置顯示消息的文字顏色
    View view = sb.getView();
    ((TextView) view.findViewById(R.id.snackbar_text)).setTextColor(Color.GREEN);

    //設(shè)置背景顏色
    view.setBackgroundColor(Color.GRAY);
    //設(shè)置透明度
    view.setAlpha(0.5f);

    //設(shè)置位置,Snackbar本質(zhì)是一個(gè)LinearLayout
    ViewGroup.LayoutParams lp = view.getLayoutParams();
    LinearLayout.LayoutParams llp = new LinearLayout.LayoutParams(lp.width, lp.height);
    llp.gravity = Gravity.TOP;

    view.setLayoutParams(llp);

    //顯示
    sb.show();

}

看看效果:

SnackBar

7 TabLayout

先看布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    android:orientation="vertical"
    tools:context="com.hc.materialdesign.MainActivity">


    <android.support.design.widget.TabLayout
        android:id="@+id/tablayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?attr/colorPrimary"
        android:theme="@style/ThemeOverlay.AppCompat.Dark"
        app:tabGravity="center"
        app:tabMode="fixed" />

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1" />

</LinearLayout>

注意到,TabLayout中有兩個(gè)陌生的屬性

  • app:tabMode:可以取如下兩個(gè)值,
  • fixed:表示Tab不能滾動
  • scrollable:表示Tab可以滾動,此時(shí)不管tabGravity取何值,都是按照從左到右排過去,即相當(dāng)于app:tabGravity="left"(當(dāng)然了,實(shí)際中沒有l(wèi)eft這個(gè)值,只是我們可以這么去理解)
  • app:tabGravity:可以取如下兩個(gè)值,
  • fill:當(dāng)tabMode取fixed時(shí)(即tab不能滾動時(shí)),tab的所有子標(biāo)簽填充tab的寬度
  • center:當(dāng)tabMode去fixed時(shí),tab中所有子標(biāo)簽居中顯示。

為了有更加直觀的理解,看幾張圖片:

當(dāng)app:tabMode="scrollable"

scrollable

當(dāng)app:tabMode="fixed"app:tabGravity="center"

center

當(dāng)app:tabMode=fixedapp:tabGravity="fill"

fill

好了,接下來看看Activity里面具體代碼:

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //初始化ViewPager及其適配器
        MyPagerAdapter adapter = new MyPagerAdapter(getSupportFragmentManager());
        ViewPager viewPager = (ViewPager) findViewById(R.id.viewpager);
        //將ViewPager與適配器關(guān)聯(lián)
        viewPager.setAdapter(adapter);
        //TabLayout
        TabLayout tabLayout = (TabLayout) findViewById(R.id.tablayout);

        //將ViewPager與TabLayout關(guān)聯(lián)
        tabLayout.setupWithViewPager(viewPager);

        //設(shè)置指示器的顏色
        tabLayout.setSelectedTabIndicatorColor(Color.GREEN);
    }

    static class MyPagerAdapter extends FragmentStatePagerAdapter {

        public MyPagerAdapter(FragmentManager fm) {
            super(fm);
        }

        @Override
        public Fragment getItem(int position) {
            return MyFragment.newInstance(position);
        }

        @Override
        public int getCount() {
            return 3;
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return "Tab " + position;
        }
    }
}

其中MyFragment很簡單,只是用于產(chǎn)生一個(gè)簡單的Fragment:

public class MyFragment extends Fragment {
    private static final String TAB_POSITION = "tab_position";

    public MyFragment() {

    }

    public static MyFragment newInstance(int tabPosition) {
        MyFragment fragment = new MyFragment();
        Bundle args = new Bundle();
        args.putInt(TAB_POSITION, tabPosition);
        fragment.setArguments(args);
        return fragment;
    }

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        Bundle args = getArguments();
        int tabPosition = args.getInt(TAB_POSITION);
        TextView tv = new TextView(getActivity());
        tv.setGravity(Gravity.CENTER);
        tv.setText("Text in Tab #" + tabPosition);
        return tv;
    }
}


運(yùn)行效果前面已經(jīng)貼出來了,這里就不再復(fù)制顯示了。

8 TextInputLayout

TextInputLayout主要是用在登錄注冊方面。

先看看效果:

Floating Labels for EditText

老規(guī)矩,從布局文件開始:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    android:orientation="vertical"
    android:padding="@dimen/activity_vertical_margin"
    tools:context="com.hc.materialdesign.MainActivity">


    <android.support.design.widget.TextInputLayout
        android:id="@+id/userName"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <EditText
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="用戶名"
            android:inputType="textEmailAddress"
   />

    </android.support.design.widget.TextInputLayout>

    <android.support.design.widget.TextInputLayout
        android:id="@+id/email"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <EditText
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:hint="郵箱"
            android:inputType="textEmailAddress" />

    </android.support.design.widget.TextInputLayout>

    <Button
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="login"
        android:text="注冊" />
</LinearLayout>

可以看到,其實(shí)就是將我們平時(shí)用的Edit控件放入到android.support.design.widget.TextInputLayout里面,并且里面只能放一個(gè)Edit,否則會報(bào)錯(cuò)。這點(diǎn)讓我不太滿意,但是可是是在實(shí)現(xiàn)上放入多個(gè)Edit不太好控制吧。

再看MainActivity對輸入框數(shù)據(jù)的驗(yàn)證:

public class MainActivity extends AppCompatActivity {
    TextInputLayout userNameWrapper;
    TextInputLayout emailWrapper;
    String emailFormate = "^(\\w)+(\\.\\w+)*@(\\w)+((\\.\\w+)+)$";

    private Pattern pattern = Pattern.compile(emailFormate);


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        userNameWrapper = (TextInputLayout) findViewById(R.id.userName);
        emailWrapper = (TextInputLayout) findViewById(R.id.email);


    }

    private boolean checkUserName() {
        String userName = userNameWrapper.getEditText().getText().toString();
        if (userName.trim().equals(""))
            return false;
        else
            return true;
    }

    private boolean checkEmail() {
        String email = emailWrapper.getEditText().getText().toString();
        Matcher matcher = pattern.matcher(email);
        return matcher.matches();
    }

    public void login(View v) {
        View view = getCurrentFocus();

        if (view != null) {
            ((InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE)).
                    hideSoftInputFromWindow(view.getWindowToken(), InputMethodManager.HIDE_NOT_ALWAYS);
        }
        if (!checkUserName()) {

            userNameWrapper.setError("用戶名不正確!");

        } else {
            userNameWrapper.setError("");
            if (!checkEmail()) {
                emailWrapper.setError("郵箱格式不正確!");

            } else {
                emailWrapper.setError("");
            }
        }


    }
}

如果數(shù)據(jù)是錯(cuò)誤的,我們只需通過setError函數(shù)來顯示即可!

最后,可能你以及注意到,界面中,用到了各種顏色。也就是說,里面的顏色我們是可以定制的,在你的style文件里面添加部分item即可:

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>


        <!-- Label color in TRUE state and bar color FALSE and TRUE State -->
        <item name="colorAccent">#00ff00</item>
        <item name="colorControlNormal">#00ffff</item>
        <item name="colorControlActivated">#ff00ff</item>
        <item name="android:textColorHint">#00ffff</item>
        <item name="textColorError">#ff0000</item>
    </style>

</resources>

參考資料:https://www.sitepoint.com/material-design-android-design-support-library/

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

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

  • afinalAfinal是一個(gè)android的ioc,orm框架 https://github.com/yangf...
    passiontim閱讀 15,835評論 2 45
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,725評論 25 709
  • 電視劇 一集 一集 又一集 結(jié)尾總在最深處 看著 一集 一集 又一集 牽扯總在結(jié)尾處 別人的生活 是我們窺探的結(jié)果...
    醉美長安閱讀 608評論 2 27
  • 寂寞 那要看你是如何定義「朋友」。并不覺得社交網(wǎng)絡(luò)和朋友得失有太多直接聯(lián)系。 效率 朋友圈、微博、facebook...
    4t0m2閱讀 327評論 0 0
  • 門口趴著條母狗的餃子店 寫作業(yè)的靈動少女 不諳世事的黑眼圈 我吃完兩碗餃子離開 少女偷偷凝望我的背影 而我這輩子都...
    摩柯菠蘿閱讀 329評論 2 2

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