今天看了郭神的第二行代码,深深的被MaterialDesign的设计风格所吸引,然后就照例做了一个小Demo,希望多多支持,图片资源来源于网络。先附上我的源码地址:https://github.com/xiaweizi/MaterialDesign

照例,一波动态图来袭:

MaterialDesign风格.gif

效果还不错吧,就是有点失真...其实在这之前Android的UI风格都不是很美观,所谷歌的设计工程师们就开始研究出了一种新的设计语言---MaterialDesign。在2015年得谷歌大会上推出了DesignSupport库,使得开发者在即使不了解MaterialDesign的情况下也能非常轻松地将自己得应用Material化。

接下来我会按照下面流程介绍如何实现这一效果

Toolbar

DrawerLayout

SnackBar

CardView

RecyclerView

SwipeRefreshLayout

AppBarLayout

CollapsingToolbarLayout

沉浸式状态栏

首先添加依赖:

compile 'com.android.support:appcompat-v7:24.2.1'

compile 'com.android.support:design:24.0.0'

compile'com.android.support:recyclerview-v7:24.0.0'

compile 'com.github.bumptech.glide:glide:3.7.0'

compile 'com.android.support:cardview-v7:24.1.1'

compile 'de.hdodenhof:circleimageview:2.1.0'

1. Toolbar

效果如下:

toolbar.PNG

它有点类似于之前得ActionBar,就是活动最顶部得哪个标题栏。但是,它只能位于活动得顶部,从而影响效果,所有官方现在已经不再建议使用ActionBar了。

1. 设置AppTheme("NoActionBar")

...

2. 添加控件

android:id="@+id/toolbar"

android:layout_width="match_parent"

android:layout_height="?attr/actionBarSize"

android:background="?attr/colorPrimary"

android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"

app:popupTheme="@style/Theme.AppCompat.Light" />

其他属性我就不说了,app:popupTheme 这个是单独将弹出得菜单项指定成淡色主题。

这个时候需要指定一个新的命名空间 xmlns:app 这是由于MaterialDesign是在Android5.0系统中才出现得,而很多Material属性在5.0之前得系统中是不存在得,那么为了能够兼容之前得老系统,我们就得使用 app: 。

3. 在代码中使用

mToolbar = (Toolbar) findViewById(R.id.toolbar);

setSupportActionBar(mToolbar);

首先通过 findViewById 得到Toobar实例,然后调用setSupportActionBar()方法将实例传入。

4. 设置菜单选项

xmlns:app="http://schemas.android.com/apk/res-auto">

android:id="@+id/backup"

android:icon="@drawable/ic_backup"

android:title="Backup"

app:showAsAction="always"/>

android:id="@+id/delete"

android:icon="@drawable/ic_delete"

android:title="Delete"

app:showAsAction="ifRoom"/>

android:id="@+id/settings"

android:icon="@drawable/ic_settings"

android:title="Settings"

app:showAsAction="never"/>

在menu文件夹中创建xml文件

app:showAsAction 来指定按钮得显示位置

ifRoom: 表示屏幕空间足够得情况下显示再Toolbar,不够就显示再菜单中

always: 表示永远显示在Toolbar中,如果屏幕空间不够则不显示

never: 表示永远显示在菜单当中

5. 在代码中实用菜单选项

/***************************

* 创建菜单

***************************/

@Override

public boolean onCreateOptionsMenu(Menu menu) {

getMenuInflater().inflate(R.menu.menu, menu);

return true;

}

/***************************

* 给菜单设置点击事件

***************************/

@Override

public boolean onOptionsItemSelected(MenuItem item) {

switch (item.getItemId()) {

case R.id.backup:

Toast.makeText(MainActivity.this, "backup", Toast.LENGTH_SHORT).show();

break;

case R.id.delete:

Toast.makeText(this, "delete", Toast.LENGTH_SHORT).show();

break;

case R.id.settings:

Toast.makeText(this, "setting", Toast.LENGTH_SHORT).show();

break;

default:

}

return true;

}

2. DrawerLayout

这个在我之前得文章讲过,可以直接点击查看 高大上的侧滑菜单DrawerLayout,解决了不能全屏滑动的问题

不过左侧可以再优化下,实用新的控件 NavigationView

NavigationView

在使用前,提前准备好两个东西:menu 和 headerLayout

1. 创建menu

android:id="@+id/nav_call"

android:icon="@drawable/nav_call"

android:title="妹纸" />

android:id="@+id/nav_friends"

android:icon="@drawable/nav_friends"

android:title="段子" />

android:id="@+id/nav_location"

android:icon="@drawable/nav_location"

android:title="新闻" />

android:id="@+id/nav_mail"

android:icon="@drawable/nav_mail"

android:title="本地" />

android:id="@+id/nav_task"

android:icon="@drawable/nav_task"

android:title="收藏" />

将group得 checkableBehavior 属性指定为single,表示所有得菜单项只能单选

2. 创建headerLayout

android:layout_width="match_parent"

android:layout_height="180dp"

android:background="?attr/colorPrimary"

android:padding="10dp">

android:id="@+id/icon_image"

android:layout_width="70dp"

android:layout_height="70dp"

android:layout_centerInParent="true"

android:src="@drawable/nav_icon" />

android:id="@+id/username"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_alignParentBottom="true"

android:text="1012126908@qq.com"

android:textColor="#FFF"

android:textSize="14sp" />

android:id="@+id/mail"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_above="@id/username"

android:text="夏韦子"

android:textColor="#FFF"

android:textSize="14sp" />

3. 在布局中使用

android:id="@+id/nv_left"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:layout_gravity="left"

app:headerLayout="@layout/nav_header"

app:menu="@menu/nav_menu">

app:headerLayout : headerLayout文件

app:menu: menu文件

android:layout_gravity="left" 设置为左侧菜单

4. 在代码中使用

//给NavigationView设置item选择事件

mNavigationView.setCheckedItem(R.id.nav_call);

mNavigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {

@Override

public boolean onNavigationItemSelected(MenuItem item) {

...

return true;

}

});

3. SnackBar

跟Toast有点相似,不过不同点在于加入一个可交互按钮,当用户点击按钮得时候可以执行一些额外得逻辑操作

效果如下:

SnackBar.gif

使用起来比较简单,跟Toast很像。

Snackbar snackbar = Snackbar.make(getCurrentFocus(), item.getTitle(), Snackbar.LENGTH_SHORT);

snackbar.setAction("Undo", new View.OnClickListener() {

@Override

public void onClick(View v) {

}

});

snackbar.setActionTextColor(Color.BLUE);

snackbar.show();

4. CardView

效果如下:

CardView.PNG

CardView 其实是一个FrameLayout,只是额外提供了圆角和阴影效果,

直接在布局中使用。

xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:app="http://schemas.android.com/apk/res-auto"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:background="?android:attr/selectableItemBackground"

app:cardElevation="10dp"

android:layout_margin="5dp"

app:cardCornerRadius="18dp">

...//子布局

app:cardCornerRadius 指定卡片圆角得弧度,数值越大,圆角得弧度越大

app:cardElevation 制定卡片得高度,高度值越大,投影得范围越大

5. RecyclerView

这个在之前得文章也说过,如果需要查看,请移驾到: 简单粗暴----RecyclerView

本次得Demo里数据我就不详细说了,太多了,很简单。

6. SwipeRefreshLayout

效果如下:

SwipeRefreshLayout.gif

使用 SwipeRefreshLayout 直接可以实现下拉刷新的功能

1. 在布局中添加

android:id="@+id/srl_main"

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/rv_main"

android:layout_width="match_parent"

android:layout_height="match_parent">

2. 在代码中添加

mRefreshLayout.setColorSchemeColors(Color.RED, Color.BLUE, Color.YELLOW, Color.GREEN);

mRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {

@Override

public void onRefresh() {

refreshFruits();

}

});

可以给刷新得时候设置颜色的变换,在 onRefresh() 中实现刷新得功能

7. AppBarLayout

先看一下效果:

AppBarLayout.gif

AppBarLayout 实际是一个垂直方向得 LinearLayout,它在内部做了很多滚动事件得封装,并应用了MaterialDesign设计理念。

在布局中实用:

android:layout_width="match_parent"

android:layout_height="match_parent">

android:fitsSystemWindows="true"

android:layout_width="match_parent"

android:layout_height="wrap_content">

android:id="@+id/toolbar"

android:fitsSystemWindows="true"

android:layout_width="match_parent"

android:layout_height="?attr/actionBarSize"

android:background="?attr/colorPrimary"

android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"

app:layout_scrollFlags="scroll|enterAlways|snap"

app:popupTheme="@style/Theme.AppCompat.Light" />

...

app:layout_behavior="@string/appbar_scrolling_view_behavior">

...

app:layout_scrollFlags: 当AppBarLayout接收到滚动事件得时候,它内部得子空间就是通过这个属性影响这些事件的

scroll:表示当 RecyclerView向上滚动得时候,Toolbar会跟着一起向上滚动并实现隐藏。

enterAlways:表示当 RecyclerView向下滚动得时候,Toolbar会跟着一起向下滚动并重新显示。

snap:表示当Toolbar还没有完全隐藏或显示得时候,会根据当前滚动得距离,自动选择是隐藏还是显示。

8. CollapsingToolbarLayout

效果如下:

CollapsingToolbarLayout.gif

可折叠式标题栏这个就比之前就负责点了,我先贴代码,然后一一解释。

xmlns:android="http://schemas.android.com/apk/res/android"

xmlns:app="http://schemas.android.com/apk/res-auto"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:fitsSystemWindows="true">

android:id="@+id/appBar"

android:layout_width="match_parent"

android:layout_height="250dp"

android:fitsSystemWindows="true">

android:id="@+id/collapsing_toolbar"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"

android:fitsSystemWindows="true"

app:contentScrim="?attr/colorPrimary"

app:layout_scrollFlags="scroll|exitUntilCollapsed">

android:id="@+id/fruit_image_view"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:scaleType="centerCrop"

android:fitsSystemWindows="true"

app:layout_collapseMode="parallax" />

android:id="@+id/toolbar"

android:layout_width="match_parent"

android:layout_height="?attr/actionBarSize"

app:layout_collapseMode="pin" />

android:layout_width="match_parent"

android:layout_height="match_parent"

app:layout_behavior="@string/appbar_scrolling_view_behavior">

android:orientation="vertical"

android:layout_width="match_parent"

android:layout_height="wrap_content">

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_marginBottom="15dp"

android:layout_marginLeft="15dp"

android:layout_marginRight="15dp"

android:layout_marginTop="35dp"

app:cardCornerRadius="4dp">

android:id="@+id/fruit_content_text"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_margin="10dp" />

app:contentScrim:在趋于折叠状态以及折叠之后得背景色

app:layout_scrollFlags 这个之前讲过

scroll :表示 CollapsingToolbarLayout会随着妹纸内容详情得滚动一起滚动

exitUntilCollapsed:表示当 CollapsingToolbarLayout随着滚动完成折叠之后就保留在界面上,不再移出屏幕

app:layout_collapseMode="pin" 把Toolbar指定成pin,表示在折叠的过程中位置始终保持不变

app:layout_collapseMode="parallax" ImageView 指定成 parallax,表示会在折叠得过程中产生一定得错位偏移,这种模式得视觉效果会非常好

NestedScrollView :在ScrollView基础上增加了嵌套响应滚动事件得功能

9. 沉浸式状态栏

这个只是在Android5.0后才有的,设置状态栏为透明

在setContentView();之前添加代码:

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {

//透明状态栏

getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);

//透明导航栏

getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);

}

需要在直接子布局添加:android:fitsSystemWindows="true 表示该控件会出现在系统状态栏里

android设计风格是什么软件下载,基于MaterialDesign设计风格的妹纸app的简单实现相关推荐

  1. 基于MaterialDesign设计风格的妹纸app的简单实现

    代码地址如下: http://www.demodashi.com/demo/11644.html *今天看了郭神的第二行代码,深深的被MaterialDesign的设计风格所吸引,然后就照例做了一个小 ...

  2. android 安卓开发相关软件下载神地址

    http://www.androiddevtools.cn/ 官方地址  www.androiddevtools.cn AndroidDevTools简介 Android Dev Tools官网地址: ...

  3. android企业手机安全软件开发,基于Android的手机安全管理软件的设计与实现毕业论文.doc...

    本资源来源于互联网,版权为原作者所有.若侵犯到您的版权,请提出指正,我们将立即删除. PAGE 2 年年青岛农业大学 毕 业 论 文(设计) 题 目: 基于Android的手机安全管理软件的 设计与实 ...

  4. android测试内存的软件下载,AndroBench p10内存门app下载

    AndroBench app是一款专注于手机硬件检测的手机工具应用,能够有效真实地帮助用户反映出手机硬件的真实数据情况,让用户更好的了解手机情况.欢迎大家下载使用. 软件介绍 AndroBench是一 ...

  5. android电视传屏软件下载,希沃传屏app下载 希沃传屏(投屏软件) for Android V1.1.4.2813 安卓手机版 下载-脚本之家...

    希沃传屏手机版是一款免费的手机投屏软件,利用希沃传屏手机版可以将手机上的画面投屏到PC端,操作简单,使用方便.需要的朋友可以前来本站下载. 软件介绍 希沃传屏APP是兼容多种系统的无线多屏互动软件,可 ...

  6. linux 开源笔记软件下载,基于 Qt 的开源笔记软件 VNote 1.11.1 小更新发布

    新年伊始,VNote发布小更新v1.11.1.顾名思义,这次更新将会很"小",主要是修复已知问题.当然,这次更新也有值得大家浪费带宽下载的地方: 1. 更好的中文支持 这一次基本所 ...

  7. android测试内存的软件下载,华为p10内存测试软件(androbench) v5.0.1 免费版

    华为p10内存测试软件(androbench)其实是androbench这款内存测试软件,可以用于测试你的华为p10,是一款不错的华为p10内存测试软件,可以测试你的手机闪存性能,其他的手机也可以免费 ...

  8. 透明壁纸android,主题透明壁纸软件下载-主题透明壁纸 安卓版v1.0-PC6安卓网

    主题透明壁纸app是一款图库资源丰富高清无水印的桌面美化手机软件,主题透明壁纸app汇聚了各种各样时尚好看的高清壁纸和主题模板,用户可随时进入主题透明壁纸软件平台进行更换设置. 软件介绍 主题透明壁纸 ...

  9. linux下的plc软件下载,基于Linux系统的软PLC的实现

    以具有开放式源码和良好可靠性的Linux系统作为软件平台,利用C语言开发了软PLC.给出软PLC的总体实现方法,并以指令表语言为例进行具体介绍.该软PLC由编辑环境和执行环境组成,共同完成软PLC编程 ...

最新文章

  1. 相对最完整的软件测试工具手册
  2. 【总结整理】开发说不能做怎么办
  3. JAVA 计算String类型的时间差(秒)
  4. Linux系统vi编辑器执行命令,linux下vi编辑器命令
  5. chrome webdriver_网络爬虫之使用pyppeteer替代selenium完美绕过webdriver检测 阅读目录
  6. 03_设置轴标签和范围、轴的标签(Labels on Axes)、定义轴的范围、使用linspace定义X值 (“linspace“ to Define X Values)
  7. debian gnu linux8,Debian GNU/Linux 9.3 Stretch 和8.10 Jessie正式发布
  8. 使用yum查看安装了哪些软件包、某软件包是否已经安装
  9. int指令01 - 零基础入门学习汇编语言64
  10. 多个Email的JS检测正刚表达式.
  11. 程序员的基础和解决问题的思维很重要
  12. PyTorch:模型层和nn container
  13. (hightopo)学习笔记(1)
  14. 英语词汇篇 - 词根词缀大全
  15. Pwn-2018_HITB_CTF-gundam
  16. Photoshop制作电影胶片效果
  17. width:100%和width:auto的区别
  18. 多CPU 多核CPU | 多进程 多线程 | 并行 并发
  19. 机器视觉工程师(实习岗)面经
  20. Unity两种获取屏幕点击位置的世界坐标方法

热门文章

  1. ASA 5505 配置
  2. RFC2616中文版(8)连接
  3. 读《企业应用架框模式》
  4. Zygo保存zxg(Zemax File)文件(光学领域知道Zygo的一定要看)
  5. php数组写杨辉三角java_用java实现杨辉三角的示例代码
  6. 发现一个bug如何定位是前端还是后台问题?
  7. python网格搜索优化参数_python – 是否有可能通过网格搜索调整参数scikit-learn中的自定义内核?...
  8. 黑马博客——详细步骤(八)项目功能的实现之另一种分页方式【mongoose-sex-page】
  9. 选择软件测试作为你的职业,一个无经验的大学毕业生,可以转行做软件测试吗?
  10. 能不能做好性能测试,要看你有没有性能测试思维