Material Desgin学习

移步

Activity 和 Fragment 切换
通过声明两屏之间通用的共享元素,你可以在两种状态间创建流畅的切换。
一图胜千言:

album_grid.xml


android:transitionName="@string/transition_album_cover" />
album_details.xml


android:transitionName="@string/transition_album_cover" />

AlbumActivity.java
Intent intent = new Intent();
String transitionName = getString(R.string.transition_album_cover);

ActivityOptionsCompat options =
ActivityOptionsCompat.makeSceneTransitionAnimation(activity,
albumCoverImageView, // The view which starts the transition
transitionName // The transitionName of the view we’re transitioning to
);
ActivityCompat.startActivity(activity, intent, options.toBundle());

1.目标启动包含共同元素的Activity 2.准备要启动的Activity的那个View3.共同元素transitionName

我们在两屏之间定义了相同的transitionName。当打开新的Activity的时候,切换过程就自动开始了。
除了共享元素之外,你也可以定义进入和退出元素。

CoordinatorLayout
coordinatorLayout是为了让子View协调工作的布局

CoordinatorLayout
组织它的子views之间协作的一个Layout,它可以给子View切换提供动画效果。
AppBarLayout
可以让包含在其中的控件响应被标记了ScrollingViewBehavior的View的滚动事件
CollapsingToolbarLayout
可以控制包含在CollapsingToolbarLayout其中的控件,在响应collapse时是移除屏幕和固定在最上面
TabLayout
结合ViewPager,实现多个TAB的切换的功能
NestedScrollView
与ScrollView基本相同,不过包含在NestedScrollView中的控件移动时才能时AppBarLayout缩放

包含其他布局就能实现卡片效果
app:cardBackgroundColor 设置CardView背景颜色
app:cardCornerRadius 设置CardView圆角大小
app:cardElevation 设置CardView阴影高度

ToolBar 不是Android Design Support Library的一部分而是在这个库中需要与其他组件一起使用,隐藏 Action Bar 并且切换到 Toolbar,因为这些有奇妙功能的新库,包括 Design Support Library 的组件中,都被设计为和 Toolbar 协同工作
1.
2.放在 CoordinatorLayout 的东西必须被设计和实现成与它一起合作的,否则将不与任何其他兄弟 views(sibling views) 协作,提供一个组件让CoordinatorLayout与toolbar一起工作
只是简单的用AppBarLayout包裹 Toolbar

3.Material Design 中ToolBar
app:popupTheme,这个属性就是用来自定义我们弹出的菜单的样式,
app:popupTheme="ThemeOverlay.AppCompat.Light",那么这个Overflow弹出的是白底黑字
app:popupTheme="@style/AppTheme.PopupOverlay" 黑底白字
app:layout_scrollFlags=”scroll|enterAlways” 一旦向上滚动toolbar就可见
Scroll 表示向下滚动时,这个View会被滚出屏幕范围直到隐藏.
,enterAlwaysCollapsed 再定义android:minHeight="100dp" 最小高度何时进入
exitUntilCollapsed 再定义android:minHeight="100dp" 最小高度titleview何时进入

实现视差效果,在用户滚动的时候title的高度也会随着改变。
android:id="@+id/collapsing_toolbar"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="?attr/colorPrimary"
app:expandedTitleMarginEnd="64dp"
app:expandedTitleMarginStart="48dp"
app:layout_scrollFlags="scroll|exitUntilCollapsed">

      
      

  

  在可以滚动的View上设置属性 app:layout_behavior.

DrawerLayout+Navitationview实现侧滑效果
DrawerLayout作为父布局
child1: 是滑动的内容区域
child2: 作为Drawer抽屉 再在Drawer中添加menu显示
(DrawerLayout中,从左侧划出android:layout_gravity="start",从右侧 end )
menu:中设置

你可能感兴趣的:(Material Desgin学习)