在低版本android系統上實現Material design應用

jopen 10年前發布 | 161K 次閱讀 Android開發 移動開發 Material Design

?Material Design真的很好看,動畫效果真的很實用。前面也寫了一些文章介紹如何編寫Material風格的程序,但是很多都是一些新的api,低版本上面沒有這些api,我們沒辦法使用。但是不用氣餒,google官方,以及一些大牛,給我們提供了一些程序,讓我們在低版本上面可以實現Material風格的程序,這里就給大家介紹一下。

screenmeizitu.png

妹子圖截屏

使用support library

使用support library最新的版本,appcomt21,可以在較低版本上面實現部分風格,在之前的文章我已經說過了,這里在系統的說一下。

應用主題

這部分的話之前的文章說過,鏈接在這里: http://blog.isming.me/2014/10/18/creating-android-app-with-material-design-one-theme/

使用gralde進行構建的話,在依賴中添加v7包:

dependencies {
compile 'com.android.support:appcompat-v7:21.0.+'
compile 'com.android.support:cardview-v7:21.0.+'
compile 'com.android.support:recyclerview-v7:21.0.+'
}

使用eclipse構建的話,加入最新的appcompat包即可。

另外在style文件中加入:

<!-- extend one of the Theme.AppCompat themes -->
<style name="Theme.MyTheme" parent="Theme.AppCompat.Light">
<!-- customize the color palette -->
<item name="colorPrimary">@color/material_blue_500</item>
<item name="colorPrimaryDark">@color/material_blue_700</item>
<item name="colorAccent">@color/material_green_A200</item>
</style>

在appliaction中使用我們的這個Theme.MyTheme,上一次的文章中有個錯誤,這種情況下不需要在valus-v21中創建一個同名的繼承自Material的theme,否則會報錯。這樣我們就可以使用Material風格了。不過低版本上面還是有很多地方不可以實現這種效果的。

使用Toolbar代替ActionBar。

android 5.0增加了ToolBar,可以用其代替ActionBar,在更低版本中,推薦使用,這樣,動畫特效更方便實現。

在布局文件中增加Toolbar:

<android.support.v7.widget.Toolbar
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="?attr/colorPrimaryDark"/>

在代碼中,使用Toolbar代替ActionBar(Activity必須是繼承自ActionBarActivity的):

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(getLayoutResource());
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        if (toolbar != null) {
            setSupportActionBar(toolbar);
        }
    }

使用CardView

不詳說了,參看我之前的博客吧http://blog.isming.me/2014/10/21/creating-app-with-material-design-two-list/

使用動畫

對于低版本,在support v7包中,提供了一些兼容,可以使用activity過渡動畫(不過效果沒有5.0的好)。

首先聲明主題的時候,創建一個AppTheme.Base用來聲明主題,在其上增加動畫屬性:

以下放在values/themes.xml中,用于適配低版本:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="AppTheme" parent="AppTheme.Base"/>

<style name="AppTheme.Base" parent="Theme.AppCompat">
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimary</item>
    <item name="android:windowNoTitle">true</item>
    <item name="windowActionBar">false</item>
</style>

</resources></pre>

以下放在values-v21/themes.xml中

<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="AppTheme" parent="AppTheme.Base">
    <item name="android:windowContentTransitions">true</item>
    <item name="android:windowAllowEnterTransitionOverlap">true</item>
    <item name="android:windowAllowReturnTransitionOverlap">true</item>
    <item name="android:windowSharedElementEnterTransition">@android:transition/move</item>
    <item name="android:windowSharedElementExitTransition">@android:transition/move</item>
</style>
</resources>

在代碼中啟動新Activity的時候,使用v7包中的方法,具體過渡方法跟5.0一樣,可以看我之前的博客:

ActivityOptionsCompat options = ActivityOptionsCompat.makeSceneTransitionAnimation(
     activity, transitionView, DetailActivity.EXTRA_IMAGE);
ActivityCompat.startActivity(activity, new Intent(activity, DetailActivity.class),
options.toBundle());

使用開源控件

對于很多的控件樣式,動畫,對話框等,使用兼容包無法完成,我們可以使用一些大神開發的第三方包來實現.

組件: https://github.com/navasmdc/MaterialDesignLibrary

https://github.com/keithellis/MaterialWidget

上面兩個主要是一些實現了Material的組件

Material Design的對話框: https://github.com/afollestad/material-dialogs

這個github倉庫收集了很多的開源實現,大家可以過來看看。https://github.com/lightSky/MaterialDesignCenter

其他

根據提供的規范,自己來實現相應的ui界面以及動畫效果等等。
這里提供一下谷歌的規范地址:
谷歌設計規范:http://www.google.com/design/spec/material-design/introduction.html需國內或許不能訪問http://design.1sters.com(中文)

圖標素材:https://github.com/google/material-design-iconshttps://github.com/Templarian/MaterialDesign

谷歌IO2014,Material Design的詮釋:https://github.com/google/iosched

其他人寫的應用:https://github.com/afollestad/cabinet

我寫的一個應用,從之前的版本改過來,還沒完成,大家隨便看看就行了,也是Material Design:https://github.com/sangmingming/Meizitu

原文地址:http://blog.isming.me/2014/11/17/material-design-for-pre-lollipop-android/,轉載請注明出處。

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!