中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

CoordinatorLayout如何在android中使用

發布時間:2021-04-02 17:32:48 來源:億速云 閱讀:167 作者:Leah 欄目:移動開發

今天就跟大家聊聊有關CoordinatorLayout如何在android中使用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

定義的布局文件如下: 

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:fitsSystemWindows="true" 
tools:context="com.lingyun.coordinatorlayoutdemo.MainActivity"> 
<android.support.design.widget.FloatingActionButton 
android:id="@+id/fab" 
android:layout_width="wrap_content" 
android:layout_height="wrap_content" 
android:layout_gravity="bottom|end" 
android:layout_margin="@dimen/fab_margin" 
android:src="@android:drawable/ic_dialog_email" /> 
</android.support.design.widget.CoordinatorLayout>

代碼就很簡單了,如下:

FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab); 
  fab.setOnClickListener(new View.OnClickListener() { 
    @Override 
    public void onClick(View view) { 
      Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG) 
          .setAction("Action", null).show(); 
    } 
  }); 
   
}

就是通過findViewById獲取FloatingActionButton,設置點擊事件,在onclick中讓Snackbar顯示一下即可。那么,效果圖就像下面展示的莪一樣:

CoordinatorLayout如何在android中使用

接下來看一個高級點的效果,就是標題欄,也就是ToolBar的擴展與收縮效果。要想要ToolBar響應滾動事件,這里我們需要用到一個控件:AppBarLayout,這個控件必須作為CoordinatorLayout的直接子View,才會響應滾動事件。首先因為我們的TooBar是需要響應滾動的視圖,所以需要為其配置一個屬性:layout_scrollFlags。然后呢,我們需要定義一下AppBarLayout與滾動視圖(如RecyclerView,NestedScrollView等可以支持嵌套滾動的控件)supportlibrary包含了一個特殊的字符串資源@string/appbar_scrolling_view_behavior,它和AppBarLayout.ScrollingViewBehavior相匹配,用來通知AppBarLayout 這個特殊的view何時發生了滾動事件,這個behavior需要設置在觸發事件(滾動)的view之上。最終layout布局如下:

主布局(activity_main.xml):

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout  
  xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent"> 
 
  <include layout="@layout/appbar_main"/> 
 
  <include layout="@layout/content_main" /> 
 
  <android.support.design.widget.FloatingActionButton 
    android:id="@+id/fab" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_gravity="bottom|end" 
    android:layout_margin="@dimen/fab_margin" 
    android:src="@android:drawable/ic_dialog_email" /> 
 
</android.support.design.widget.CoordinatorLayout>

appbar_main.xml布局:

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.AppBarLayout 
  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:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 
 
  <android.support.v7.widget.Toolbar 
    android:id="@+id/toolbar" 
    android:layout_width="match_parent" 
    android:layout_height="?attr/actionBarSize" 
    app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
    android:background="?attr/colorPrimary" 
    app:layout_scrollFlags="scroll|enterAlways"/> 
 
</android.support.design.widget.AppBarLayout>

content_main.xml布局:

<?xml version="1.0" encoding="utf-8"?> 
<android.support.v4.widget.NestedScrollView 
  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" 
  app:layout_behavior="@string/appbar_scrolling_view_behavior"> 
 
  <TextView 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:gravity="center" 
    android:text="你是誰?你從哪里來?你到哪里去?"/> 
</android.support.v4.widget.NestedScrollView>

效果圖如下:

CoordinatorLayout如何在android中使用

通過效果顯示,當視圖在滾動的時候,ToolBar滾出了屏幕,為內容區域留出了更大空間。其中控制ToolBar是否可以滾出屏幕的屬性是由app:layout_scrollFlags="scroll|enterAlways"。來說一下這個屬性,要想滾出屏幕layout_scrollFlags必須設置scrll這個flag。剩下的幾個flag解釋如下:

enterAlways:只要滾動視圖向下滾動,view就會顯示出來。

enterAlwaysCollapsed:顧名思義,這個flag定義的是何時進入(已經消失之后何時再次顯示)。假設你定義了一個最小高度(minHeight)同時enterAlways也定義了,那么view將在到達這個最小高度的時候開始顯示,并且從這個時候開始慢慢展開,當滾動到頂部的時候展開完。

exitUntilCollapsed: 同樣顧名思義,這個flag時定義何時退出,當你定義了一個minHeight,這個view將在滾動到達這個最小高度的時候消失。

下面來通過flag為exitUntilCollapsed時,來實現Toolbar的折疊顯示的效果。這個時候呢,我們把Toolbar直接放在CollapsingToolbarLayout下,先修改appbar_main.xml布局如下:

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.AppBarLayout 
  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:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 
 
  <android.support.design.widget.CollapsingToolbarLayout 
    android:layout_width="match_parent" 
    android:layout_height="248dp" 
    app:expandedTitleMarginEnd="10dp" 
    app:expandedTitleMarginStart="10dp" 
    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:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
      android:background="?attr/colorPrimary" 
      app:layout_collapseMode="pin"/> 
 
  </android.support.design.widget.CollapsingToolbarLayout> 
 
</android.support.design.widget.AppBarLayout>

先appbar_main.xml的布局如下:

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.AppBarLayout 
  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:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> 
 
  <android.support.design.widget.CollapsingToolbarLayout 
    android:layout_width="match_parent" 
    android:layout_height="248dp" 
    app:expandedTitleMarginEnd="10dp" 
    app:expandedTitleMarginStart="10dp" 
    app:contentScrim="?attr/colorPrimary" 
    app:layout_scrollFlags="scroll|exitUntilCollapsed"> 
 
    <ImageView 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:scaleType="centerCrop" 
      app:layout_collapseMode="parallax" 
      android:background="@drawable/bg"/> 
 
    <android.support.v7.widget.Toolbar 
      android:id="@+id/toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      app:popupTheme="@style/ThemeOverlay.AppCompat.Light" 
      app:layout_collapseMode="pin"/> 
 
  </android.support.design.widget.CollapsingToolbarLayout> 
 
</android.support.design.widget.AppBarLayout>

實現視覺差的屬性主要來自于app:layout_collapseMode="parallax",這個flag代表的是視差模式,即在折疊的時候會有視差折疊的效果,而“pin”,固定模式,就是在折疊的最后固定在最頂端。

上面說了那么多,其實這些效果的實現都離不開一個東西,那就是Behavior。CoordinatorLayout的工作原理是搜索定義了CoordinatorLayout Behavior的子view,不管是通過在xml中使用app:layout_behavior標簽還是通過在代碼中對view類使用@DefaultBehavior修飾符來添加注解。當滾動發生的時候,CoordinatorLayout會嘗試觸發那些聲明了依賴的子view。要自己定義CoordinatorLayoutBehavior,你需要實現layoutDependsOn() 和onDependentViewChanged()兩個方法。

看完上述內容,你們對CoordinatorLayout如何在android中使用有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

白山市| 临夏市| 高雄县| 桦甸市| 徐州市| 临泉县| 普定县| 东辽县| 竹山县| 邯郸市| 芦溪县| 莱阳市| 武陟县| 南丹县| 曲靖市| 南华县| 额敏县| 麦盖提县| 河北省| 怀安县| 阿巴嘎旗| 锡林郭勒盟| 长葛市| 兴隆县| 成都市| 梅河口市| 集安市| 新蔡县| 沈阳市| 邻水| 文安县| 彭州市| 乌鲁木齐市| 渑池县| 仁寿县| 融水| 桦南县| 南川市| 沁源县| 东至县| 石首市|