转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持!



Android L:

Google已经确认Android L就是Android Lollipop(5.0)。

前几天发现Android5.0正式版的sdk已经可以下载了,而且首次搭载Android L系统的Nexus 6和 Nexus 9也即将上市。

所以是时候开始学习Android L了!

关于Android L如何配置模拟器和创建项目,如果大家有兴趣的话可以看看我之前的一篇文章:

Android L——模拟器配置及创建项目




Material Design:

Material Design是Google推出的一个全新的设计语言,它的特点就是拟物扁平化。

Material Design包含了很多内容,我大致把它分为四部分:

主题和布局——ANDROID
L——Material Design详解(主题和布局)

视图和阴影——ANDROID
L——Material Design详解(视图和阴影)

UI控件——ANDROID
L——Material Design详解(UI控件)

动画——ANDROID
L——Material Design详解(动画篇)

今天就先来说说第三部分——Material新增的UI控件







UI控件

在Android L中新增了两个控件分别是RecyclerViewCardView



RecyclerView:

RecyclerView是ListView的升级版,它提供了更好的性能而且更容易使用。

RecyclerView这个控件是一个可以装载大量的视图集合,并且可以非常效率的进行回收和滚动。当你list中的元素经常动态改变时可以使用RecyclerView控件。

RecyclerView非常容易使用,它提供了如下两个功能:

为每个条目位置提供了layout管理器(RecyclerView.setLayoutManager

为每个条目设置了操作动画(RecyclerView.setItemAnimator

下面的例子介绍了如何定义和使用一个RecyclerView

1.在布局文件中添加一个RecyclerView

  1. <!-- A RecyclerView with some commonly used attributes -->
  2. <android.support.v7.widget.RecyclerView
  3. android:id="@+id/my_recycler_view"
  4. android:scrollbars="vertical"
  5. android:layout_width="match_parent"
  6. android:layout_height="match_parent"/>

2.初始化RecyclerView参数,设置layoutManager和adapter

  1. public class MyActivity extends Activity {
  2. private RecyclerView mRecyclerView;
  3. private RecyclerView.Adapter mAdapter;
  4. private RecyclerView.LayoutManager mLayoutManager;
  5.  
  6. @Override
  7. protected void onCreate(Bundle savedInstanceState) {
  8. super.onCreate(savedInstanceState);
  9. setContentView(R.layout.my_activity);
  10. mRecyclerView = (RecyclerView) findViewById(R.id.my_recycler_view);
  11.  
  12. // improve performance if you know that changes in content
  13. // do not change the size of the RecyclerView
  14. mRecyclerView.setHasFixedSize(true);
  15.  
  16. // use a linear layout manager
  17. mLayoutManager = new LinearLayoutManager(this);
  18. mRecyclerView.setLayoutManager(mLayoutManager);
  19.  
  20. // specify an adapter (see also next example)
  21. mAdapter = new MyAdapter(myDataset);
  22. mRecyclerView.setAdapter(mAdapter);
  23. }
  24. ...
  25. }

3.创建一个adapter

  1. public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {
  2. private String[] mDataset;
  3.  
  4. // Provide a reference to the type of views that you are using
  5. // (custom viewholder)
  6. public static class ViewHolder extends RecyclerView.ViewHolder {
  7. public TextView mTextView;
  8. public ViewHolder(TextView v) {
  9. super(v);
  10. mTextView = v;
  11. }
  12. }
  13.  
  14. // Provide a suitable constructor (depends on the kind of dataset)
  15. public MyAdapter(String[] myDataset) {
  16. mDataset = myDataset;
  17. }
  18.  
  19. // Create new views (invoked by the layout manager)
  20. @Override
  21. public MyAdapter.ViewHolder onCreateViewHolder(ViewGroup parent,
  22. int viewType) {
  23. // create a new view
  24. View v = LayoutInflater.from(parent.getContext())
  25. .inflate(R.layout.my_text_view, parent, false);
  26. // set the view's size, margins, paddings and layout parameters
  27. ...
  28. ViewHolder vh = new ViewHolder(v);
  29. return vh;
  30. }
  31.  
  32. // Replace the contents of a view (invoked by the layout manager)
  33. @Override
  34. public void onBindViewHolder(ViewHolder holder, int position) {
  35. // - get element from your dataset at this position
  36. // - replace the contents of the view with that element
  37. holder.mTextView.setText(mDataset[position]);
  38.  
  39. }
  40.  
  41. // Return the size of your dataset (invoked by the layout manager)
  42. @Override
  43. public int getItemCount() {
  44. return mDataset.length;
  45. }
  46. }

CardView:

CardView继承自FrameLayout,允许你在card视图中显示信息. CardView也可以设置阴影和圆角。(其实现在很多应用都自定义了Card视图,Google这回将card视图作为基本控件,可以拿来直接使用了)

Layout中为CardView设置圆角使用card_view:cardCornerRadius属性

代码中为CardView设置圆角使用CardView.setRadius方法

为CardView设置背景颜色使用card_view:cardBackgroundColor属性

在布局中包含一个CardView,如下:

  1. <!-- A CardView that contains a TextView -->
  2. <android.support.v7.widget.CardView
  3. xmlns:card_view="http://schemas.android.com/apk/res-auto"
  4. android:id="@+id/card_view"
  5. android:layout_gravity="center"
  6. android:layout_width="200dp"
  7. android:layout_height="200dp"
  8. card_view:cardCornerRadius="4dp">
  9.  
  10. <TextView
  11. android:id="@+id/info_text"
  12. android:layout_width="match_parent"
  13. android:layout_height="match_parent" />
  14. </android.support.v7.widget.CardView>

兼容性:


RecyclerView,CardView都包含在Android L Developer Preview Support Library中,所以他们可以在之前的版本中使用,只会有一些限制。

总结:

我将Material Design分为如下四部分:

主题和布局——ANDROID
L——Material Design详解(主题和布局)

视图和阴影——ANDROID
L——Material Design详解(视图和阴影)

UI控件——ANDROID
L——Material Design详解(UI控件)

动画——ANDROID
L——Material Design详解(动画篇)

本文所介绍的两个控件(RecyclerView,CardView)非常重要,因为在以后Android L的开发中会经常用到。

这篇文章介绍的内容都是从官方文档翻译过来的,大家看着可能有点迷糊。不过没关系,过几天我会更新一个介绍RecyclerView,CardView在Android Studio和Eclipse中是如何导包,和两个控件结合使用的小Demo。

Android
L——RecyclerView,CardView导入和使用(Demo)

Material Desgin的介绍只剩下动画部分了我会尽快更新,敬请期待。。。

ANDROID L——Material Design详解(UI控件)的更多相关文章

  1. [转]ANDROID L——Material Design详解(动画篇)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 转自:http://blog.csdn.net/a396901990/article/de ...

  2. ANDROID L——Material Design详细解释(UI控制)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! Android L: Google已经确认Android L就是Android Lolli ...

  3. ANDROID L——Material Design综合应用(Demo)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! Material Design: Material Design是Google推出的一个全 ...

  4. ANDROID L——Material Design具体解释(动画篇)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! Android L: Google已经确认Android L就是Android Lolli ...

  5. Android开发之使用Handler刷新UI控件

    一.为什么必须使用Handler 线程安全问题 这个问题要理解的话很容易,如果没有这个约束,那么同时有两个线程对一个UI控件进行调整,那么控件自然就没法正常的工作,而为了解决这种二义性(就是一个东西同 ...

  6. [转]Android 5.0——Material Design详解(动画篇)

    Material Design:Google推出的一个全新的设计语言,它的特点就是拟物扁平化. Material Design包含了很多内容,今天跟大家分享一下Material新增的动画: 在Andr ...

  7. android Material Design详解

    原文地址:http://blog.csdn.net/jdsjlzx/article/details/41441083/ 前言 我们都知道Marterial Design是Google推出的全新UI设计 ...

  8. ANDROID L——Material Design具体解释(主题和布局)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990).谢谢支持! Android L: Google已经确认Android L就是Android Lolli ...

  9. Material Design Support 8大控件介绍

    TextInputLayout 显示提示信息 能够通过调用setError()在EditText以下显示一条错误信息 FloatingActionButton 悬浮操作按钮 Snackbar 相当于底 ...

随机推荐

  1. 修复VS,恢复初始状态

    命令提示 输入命令: devenv.exe /resetuserdata 处理版本221优化改动:1.SQL优化,采用预编译方式并将SQL语句修改为大写,尽量减少Oracle数据库硬解析2.复用部分代 ...

  2. 进制转换( C++字符数组 )

    注: 较为简便的方法是用 整型(int)或浮点型(long.double 注意:该类型不一定能够准确存储数据) 来存放待转换的数值,可直接取余得到每一位数值 较为稳定的方法是用 字符数组储存待转换的数 ...

  3. Ubuntu14.04安装微软雅黑字体

    1.首先获得一套“微软雅黑”字体库(自行百度),包含两个文件msyh.ttf(普通)、msyhbd.ttf(加粗);2.在/usr/share/fonts目录下建立一个子目录,例如win,命令如下:  ...

  4. django manytomany

    转载:http://my.oschina.net/u/572994/blog/105280 例如有如下模型 models.py ? 1 2 3 4 5 6 7 from django.db impor ...

  5. arp欺骗技术

      ARP欺骗技术-获取内网目标IP访问图片!   简介: ARP(Address Resolution Protocol,地址解析协议)是一个位于TCP/IP协议栈中的网络层,负责将某个IP地址解析 ...

  6. oracle数据导入/导出

    Oracle数据导入导出imp/exp 功能:Oracle数据导入导出imp/exp就相当与oracle数据还原与备份.   大多情况都可以用Oracle数据导入导出完成数据的备份和还原(不会造成数据 ...

  7. linux常用命令(一)

    1.linux文件命名规则 1.除了/之外,所有字符都是可以用的. 2.有些字符最好别用,如空格,制表符,退格,@#&-,命令行操作时候可能会出现混淆. 3.避免使用.作为文件开头,linux ...

  8. Delphi XE6 原生解析json

    Delphi XE5带了system.json单元,原生提供了json支持类.下面是解析json用法说明: 最简单的JSON大致像这样 { "date":"周二(今天, ...

  9. Get请求中文乱码的几种解决方式

    1.将字符串转码:new String("xxxxx".getBytes("iso-8859-1"),"utf-8")         这种 ...

  10. 总结-html

    页面尺寸: var w = document.body.scrollWidth; (w + "px")var h = document.body.scrollHeight; (h ...