走着官方的教程入门Material Design(一)
又到期末了,学习下Google的材料设计。写下此文记录自己的同时,分享给需要的同学,若发现文中有什么问题和不对,欢迎指出
使用 Material Design 创建新应用
首先需要使用材料主题
如果是在5.0及以上的系统,可以直接使用材料主题。否则,就需要做5.0之前系统的兼容
引用Google官方的话:
您可对您的应用进行配置,使应用能够在支持它的设备上使用材料主题,并且能够在运行早期版本 Android 的设备上还原至早期版本的主题
具体操作就是:
- 定义备用样式 style和v-21的style
- 提供备用布局 xx布局.xml和v-21的xx布局.xml
- 使用支持内容库 使用v7支持库
定义备用样式
定义一个从 res/values/styles.xml 中的早期版本主题(例如 Holo)继承的主题。
定义一个从 res/values-v21/styles.xml 中的材料主题继承且拥有相同名称的主题。
在清单文件中将此主题设置为您的应用主题。
//5.0以上系统使用的主题(res\values-v21文件夹中)
<style name="AppTheme" parent="android:Theme.Material.Light">
<!-- Customize your theme here. -->
</style> //5.0以下系统使用的主题(res\values文件夹中)
<style name="AppTheme" parent="Theme.AppCompat.Light">
<!-- Customize your theme here. -->
</style>
提供备用布局
Google是这样说的
您可在res/layout-v21/内创建用于 Android 5.0(API 级别 21)的布局文件,同时也可在res/layout/内创建用于早期版本 Android 的备用布局文件。
例如,res/layout/my_activity.xml是res/layout-v21/my_activity.xml的备用布局。
为避免代码重复,请在res/values/内定义您的风格,在res/values-v21/内为新 API 修改风格,以及使用风格继承(即:在res/values/内定义基础风格,然后在res/values-v21/内继承这些风格)。
具体操作如下:
像平时一样在layout目录里新建布局文件( 例: activity_main.xml )
在里面书写布局属性(例如: 新建一个TextView )
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@android:color/black"
android:padding="5dp"
android:text="@string/app_name"
android:textColor="@android:color/white"
android:textSize="18sp" />
可以看出5.0以上的效果除了两者的ActionBar有所不同,其余没有明显差别
现在给TextView加上Material Design新增的视图静态高度属性: elevation (ps:还要一个动画用的动态高度转换)
android:elevation="20dp"
加上之后,AS就会提示我们该属性只能使用在5.0(Api 21)系统之上
于是按着AS的提示来,Ctrl+Enter,在layout-v21文件夹复写该布局文件,然后把
android:elevation="20dp"
移到v-21布局文件里
为了看出加了elevation之后的效果,我们还需要给TextView加个简单的背景轮廓(shape).
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<corners android:radius="5dp" />
<solid android:color="@android:color/black" />
</shape>
两者布局
//layout文件夹中 activity_main
<TextView
android:id="@+id/tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/tv_back"
android:padding="5dp"
android:text="@string/app_name"
android:textColor="@android:color/white"
android:textSize="18sp" />
//layout-v21文件夹中 activity_main
<TextView
android:id="@+id/tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/tv_back"
android:elevation="15dp"
android:padding="5dp"
android:text="@string/app_name"
android:textColor="@android:color/white"
android:textSize="18sp" />
其实我们应该按照官方的将两者重复的属性写到样式(style)里复用,这里暂时就不了_
比较两者
现在就能看出两者的区别了
使用V7支持库
前面的方式都没有使用V7支持库,在v-21文件夹(style和layout)中复写只是为了让应用能在5.0以下和5.0以上的系统正常运行,所以材料设计都只能显示在5.0以上的系统
//v7包Gradle依赖
compile 'com.android.support:appcompat-v7:21.0.+'
官方的V7包给下面这些组件提供了Material Design 风格,让材料设计在5.0以下的系统也能显示
- EditText
- Spinner
- CheckBox
- RadioButton
- SwitchCompat
- CheckedTextView
这些控件都在android.support.v7.widget.AppCompatView包下
//例如EditText
<android.support.v7.widget.AppCompatEditText
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:hint="@string/app_name"
android:padding="5dp"
android:textSize="18sp" />
同时要在我们的主题(style)里加上这段颜色配置,因为AppCompatTextView默认是从colorAccent着色的
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/my_red</item>
效果图
以上只是小生简单的使用了Material Design。主要是为了熟悉要在应用中使用材料设计,需要注意的地方和正确方法。后面继续学习更加好看的材料设计_
走着官方的教程入门Material Design(一)的更多相关文章
- 官方 Material Design App
[转]MaterialDesignCenter 发表回复 转: https://github.com/lightSky/MaterialDesignCenter MaterialDesignCente ...
- 直接拿来用!十大Material Design开源项目
来自:http://www.csdn.net/article/2014-11-21/2822753-material-design-libs/1 介于拟物和扁平之间的Material Design自面 ...
- 十大Material Design开源项目
介于拟物和扁平之间的Material Design自面世以来,便引起了很多人的关注与思考,就此产生的讨论也不绝于耳.本文详细介绍了在Android开发者圈子里颇受青睐的十个Material Desig ...
- Android入门3:从Toolbar到Material Design
在Android5.0(API 21)之后,Toolbar被Google推广,逐渐走入大家视野.具体关于Actionbar和Toolbar的对比就不多啰嗦了,跟着潮流走是没错的.下面先上张简单的效果图 ...
- Asp.Net MVC4.0 官方教程 入门指南之五--控制器访问模型数据
Asp.Net MVC4.0 官方教程 入门指南之五--控制器访问模型数据 在这一节中,你将新创建一个新的 MoviesController类,并编写代码,实现获取影片数据和使用视图模板在浏览器中展现 ...
- Asp.Net MVC4.0 官方教程 入门指南之四--添加一个模型
Asp.Net MVC4.0 官方教程 入门指南之四--添加一个模型 在这一节中,你将添加用于管理数据库中电影的类.这些类是ASP.NET MVC应用程序的模型部分. 你将使用.NET Framewo ...
- Asp.Net MVC4.0 官方教程 入门指南之三--添加一个视图
Asp.Net MVC4.0 官方教程 入门指南之三--添加一个视图 在本节中,您需要修改HelloWorldController类,从而使用视图模板文件,干净优雅的封装生成返回到客户端浏览器HTML ...
- Asp.Net MVC4.0 官方教程 入门指南之二--添加一个控制器
Asp.Net MVC4.0 官方教程 入门指南之二--添加一个控制器 MVC概念 MVC的含义是 “模型-视图-控制器”.MVC是一个架构良好并且易于测试和易于维护的开发模式.基于MVC模式的应用程 ...
- Apple官方IOS开发入门教程[v0.2]
今天,又跑去找IOS开发入门教程了,结果发现没什么好的PDF. 后来发现,原来苹果官方有开发入门教程,而且写的很好.所以整理出来了,给大家分享一下. 我就不在这里贴pdf的内容了,下面有苹果官方教程的 ...
随机推荐
- java--实现将文字生成二维码图片,并在中间附上logo,下方附上文字
前段时间因为工作需要,要实现将一段文字或者url生成二维码,然后中间附上logo,下方正中间附上文字的功能. 上网找了几篇教程学习了下,由于没有保存借鉴的博文链接,所以就没po上参考文章的链接啦,感谢 ...
- .NET ORM 哪家强
ORM到底哪家强? 很多人都想知道这个问题,自已也没测试过,只能道听途说. 闲的无聊就将几个ORM拿出来比一比,假如怀疑测试代码有问题可以将它下载下来慢慢研究. 参赛ORM 1.SqlSugar:是一 ...
- vertical-align两种应用场合
vertical-align两种应用场合 (1)用在td/th中或display:table-cell元素中:让当前元素中的文本内容在竖直方向上居中 css部分: .content{ ...
- CentOS6.5菜鸟之旅:识别NTFS分区
一.前言 CentOS默认时不能识别NTFS分区的,需要那么需要安装fuse-ntfs-3g来处理了. 二.安装fuse-ntfs-3g yum install fuse-ntfs-3g
- ActiveMQ学习(四)——应用程序接口
在 Java 里有 JMS的多个实现.其中 apache 下的 ActiveMQ就是不错的选择. 用 ActiveMQ最好还是了解下 JMS JMS 公共 点对点域 发布/订阅域 Connection ...
- Spring基础——在 IOC 容器中 Bean 之间的关系
一.在 Spring IOC 容器中 Bean 之间存在继承和依赖关系. 需要注意的是,这个继承和依赖指的是 bean 的配置之间的关系,而不是指实际意义上类与类之间的继承与依赖,它们不是一个概念. ...
- 转贴:JavaScript实现Ajax请求简单示例
转至:https://my.oschina.net/u/658145/blog/167651 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 ...
- Linux - Ubuntu下JDK配置
系统版本: ubuntu 14.04 x64JDK版本: jdk-8u60-linux-x64 1.查看系统位数,输入以下命令即可 getconf LONG_BIT 2.下载对应的JDK文件,我这里下 ...
- Android --- 斗地主 [牌桌实现源码]
1.主Activity <span style="font-size:18px;color:#3333ff;">package com.bison; import an ...
- java注释指导手册
译文出处: Toien Liu 原文出处:Dani Buiza 编者的话:注解是java的一个主要特性且每个java开发者都应该知道如何使用它. 我们已经在Java Code Geeks提供了丰富 ...