Activity 和 Fragment 切換
通過聲明兩屏之間通用的共享元素,你可以在兩種狀態(tài)間創(chuàng)建流暢的切換。
一圖勝千言:
album_grid.xml
…
<ImageView
…
android:transitionName="@string/transition_album_cover" />
album_details.xml
…
<ImageView
…
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.目標(biāo)啟動包含共同元素的Activity 2.準(zhǔn)備要啟動的Activity的那個View3.共同元素transitionName
我們在兩屏之間定義了相同的transitionName。當(dāng)打開新的Activity的時候,切換過程就自動開始了。
除了共享元素之外,你也可以定義進入和退出元素。
CoordinatorLayout
coordinatorLayout是為了讓子View協(xié)調(diào)工作的布局
CoordinatorLayout
組織它的子views之間協(xié)作的一個Layout,它可以給子View切換提供動畫效果。
AppBarLayout
可以讓包含在其中的控件響應(yīng)被標(biāo)記了ScrollingViewBehavior的View的滾動事件
CollapsingToolbarLayout
可以控制包含在CollapsingToolbarLayout其中的控件,在響應(yīng)collapse時是移除屏幕和固定在最上面
TabLayout
結(jié)合ViewPager,實現(xiàn)多個TAB的切換的功能
NestedScrollView
與ScrollView基本相同,不過包含在NestedScrollView中的控件移動時才能時AppBarLayout縮放
<android.support.v7.widget.CardView>包含其他布局就能實現(xiàn)卡片效果
app:cardBackgroundColor 設(shè)置CardView背景顏色
app:cardCornerRadius 設(shè)置CardView圓角大小
app:cardElevation 設(shè)置CardView陰影高度
ToolBar 不是Android Design Support Library的一部分而是在這個庫中需要與其他組件一起使用,隱藏 Action Bar 并且切換到 Toolbar,因為這些有奇妙功能的新庫,包括 Design Support Library 的組件中,都被設(shè)計為和 Toolbar 協(xié)同工作
1.<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
2.放在 CoordinatorLayout 的東西必須被設(shè)計和實現(xiàn)成與它一起合作的,否則將不與任何其他兄弟 views(sibling views) 協(xié)作,提供一個組件讓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何時進入
實現(xiàn)視差效果,在用戶滾動的時候title的高度也會隨著改變。
<android.support.design.widget.CollapsingToolbarLayout
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">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_scrollFlags="scroll|enterAlways"></android.support.v7.widget.Toolbar>
<ImageView
android:src="@drawable/cheese_1"
app:layout_scrollFlags="scroll|enterAlways|enterAlwaysCollapsed"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleType="centerCrop"
app:layout_collapseMode="parallax" 我們添加一個定義了app:layout_collapseMode="parallax" 屬性的ImageView。
android:minHeight="100dp"/>
</android.support.design.widget.CollapsingToolbarLayout>
在可以滾動的View上設(shè)置屬性 app:layout_behavior.
DrawerLayout+Navitationview實現(xiàn)側(cè)滑效果
DrawerLayout作為父布局
child1:<LinearLayout></LinearLayot> 是滑動的內(nèi)容區(qū)域
child2: <LinearLayout></LinearLayot> 作為Drawer抽屜 再在Drawer中添加menu顯示
(DrawerLayout中,從左側(cè)劃出android:layout_gravity="start",從右側(cè) end )
menu:中設(shè)置<group><item></item></group> <item></item>