在低版本android系統上實現Material design應用
?Material Design真的很好看,動畫效果真的很實用。前面也寫了一些文章介紹如何編寫Material風格的程序,但是很多都是一些新的api,低版本上面沒有這些api,我們沒辦法使用。但是不用氣餒,google官方,以及一些大牛,給我們提供了一些程序,讓我們在低版本上面可以實現Material風格的程序,這里就給大家介紹一下。
妹子圖截屏
使用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-icons、https://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/,轉載請注明出處。