[关闭]
@natsumi 2015-10-22T02:19:39.000000Z 字数 2583 阅读 1342

直接拿来用!Android-LollipopShowcase

Android Design


【简介】
Android-LollipopShowcase是由来自奥地利的移动、后端及Web开发者Mike Penz所开发的演示应用,集中演示了新Material Design中所有的UI效果,以及Android Lollipop中其他非常酷炫的特性元素,比如Toolbar、RecyclerView、ActionBarDrawerToggle、Floating Action Button(FAB)、Android Compat Theme等。

【项目地址】
https://github.com/mikepenz/LollipopShowcase

【其实也不那么直接==】


导入jar包

先把LollipopShowcase中的LollipopShowcase/app/build/intermediates/exploded-aar/com.mikepenz拷贝到MyAPP/app/intermediates/exploded-aar/目录下~
然后仿照LollipopShowcase/app/build.gradle修改MyAPP/app/build.gradle中的dependencies

  1. dependencies {
  2. compile fileTree(include: ['*.jar'], dir: 'libs')
  3. compile 'com.android.support:support-v4:23.0.0'
  4. compile 'com.android.support:appcompat-v7:23.0.0'
  5. compile 'com.android.support:recyclerview-v7:23.0.0'
  6. compile 'com.android.support:cardview-v7:23.0.0'
  7. compile 'com.android.support:design:23.0.0'
  8. compile 'com.facebook.rebound:rebound:0.3.8'
  9. compile 'com.mikepenz:iconics:1.2.0@aar'
  10. compile('com.mikepenz:aboutlibraries:5.0.6@aar') {
  11. transitive = true
  12. }
  13. compile('com.mikepenz:materialdrawer:3.0.9@aar') {
  14. transitive = true
  15. }
  16. }

自定义的按钮

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="
  3. <item android:state_focused="false">
  4. <shape>
  5. <solid android:color="@color/find_passwordbar_bg"/>
  6. <stroke android:width="0.5dp" android:color="#C8C8C8"/>
  7. </shape>
  8. </item>
  9. <item android:state_focused="true">
  10. <shape>
  11. <solid android:color="@color/find_passwordbar_bg"/>
  12. <stroke android:width="0.5dp" android:color="@color/main_color"/>
  13. </shape>
  14. </item>
  15. </selector>

各属性介绍

  1. solid:实心,就是填充的意思
  2. android:color指定填充的颜色
  3. gradient:渐变
  4. android:startColorandroid:endColor分别为起始和结束颜色,ndroid:angle是渐变角度,必须为45的整数倍。
  5. 另外渐变默认的模式为android:type="linear",即线性渐变,可以指定渐变为径向渐变,android:type="radial",径向渐变需要指定半径android:gradientRadius="50"
  6. stroke:描边
  7. android:width="2dp" 描边的宽度,android:color 描边的颜色。
  8. 我们还可以把描边弄成虚线的形式,设置方式为:
  9. android:dashWidth="5dp"
  10. android:dashGap="3dp"
  11. 其中android:dashWidth表示'-'这样一个横线的宽度,android:dashGap表示之间隔开的距离。
  12. corners:圆角
  13. android:radius为角的弧度,值越大角越圆。
  14. 我们还可以把四个角设定成不同的角度,方法为:
  15. <corners
  16. android:topRightRadius="20dp" 右上角
  17. android:bottomLeftRadius="20dp" 右下角
  18. android:topLeftRadius="1dp" 左上角
  19. android:bottomRightRadius="0dp" 左下角
  20. />

此处输入图片的描述

遇到theme的问题

You need to use a Theme.AppCompat theme (or descendant) with this activity

报错如下:
java.lang.IllegalStateException: You need to use a Theme.AppCompat theme (or descendant) with this activity.

解决方法:
创建的activity继承自support-v7的ActionBarActivity的,只能用AppCompat主题。现在推toolbar了所以就干脆把父类ActionBarActivity改成Activity。

细节修改:
不过我这里MainActivity用的是AS自动生成的带有Fragment的ActionBarActivity,Fragment用的是v4的,ActionBarActivity是v7的。修改后的父类是Android.app.Activity,Activity类没有getSupportFragmentManager函数,需改成getFragmentManager函数,相应的要把Fragment改成Android.app.Fragment。这样待AS自动导包后,就没有报错了~

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注