Dar*_*kin 7 android android-layout android-xml android-coordinatorlayout android-collapsingtoolbarlayout
这是代码.
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/main"
android:layout_height="match_parent"
android:layout_width="match_parent">
<android.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="100dp">
<android.support.design.widget.CollapsingToolbarLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_scrollFlags="scroll|enterAlways|exitUntilCollapsed">
<android.support.v7.widget.Toolbar
android:id="@+id/mytoolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:title="@string/app_name"
app:layout_collapseMode="pin"
app:theme="@style/ThemeOverlay.AppCompat.Light"/>
<android.support.design.widget.TabLayout
android:id="@+id/main_tablayout"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
app:layout_collapseMode="none"/>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<!--<android.support.v4.widget.NestedScrollView-->
<!--android:id="@+id/nestedscroll"-->
<!--android:layout_width="match_parent"-->
<!--android:layout_height="match_parent"-->
<!--android:fillViewport="true"-->
<!--android:scrollbars="horizontal"-->
<!--app:layout_behavior="@string/appbar_scrolling_view_behavior">-->
<android.support.v4.view.ViewPager
android:id="@+id/main_viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
<!--</android.support.v4.widget.NestedScrollView>-->
<android.support.design.widget.FloatingActionButton
android:id="@+id/main_fab"
android:layout_margin="16dp"
android:src="@android:drawable/ic_media_play"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:layout_anchor="@id/main_viewpager"
app:layout_anchorGravity="bottom|end"/>
</android.support.design.widget.CoordinatorLayout>
Run Code Online (Sandbox Code Playgroud)
问题:
1)工具栏不可见.
2)折叠工具栏根本不会崩溃.[已解决]
3)如果放入nestedScrollView内,Viewpager和FAB也不可见.[解决了]
更多细节:
Viewpager片段的布局将Linearlayout作为root,内部具有recyclerview.
根据代码,一切似乎都没问题.无法理解缺少的东西.协调器布局和折叠工具栏如何协同工作的一个很好的解释也确实有帮助.
1) 工具栏不可见。
首先,您需要定义要在活动类中使用什么工具栏:
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
Run Code Online (Sandbox Code Playgroud)
更改现有的 xml 代码:
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?attr/colorPrimary"
app:title="@string/app_name"
app:layout_collapseMode="parallax">
</android.support.v7.widget.Toolbar>
Run Code Online (Sandbox Code Playgroud)
到:
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize" //set initial height
app:popupTheme="@style/ThemeOverlay.AppCompat.Light" //this might be also useful
app:title="@string/app_name"
app:layout_collapseMode="parallax" />
Run Code Online (Sandbox Code Playgroud)
2)折叠工具栏根本不折叠。
您的活动是否使用了正确的主题?设置为您的AppBarLayout:
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
Run Code Online (Sandbox Code Playgroud)
如本例所示:include_list_viewpager.xml
3)Viewpager和FAB如果放在nestedScrollView里面也不可见。
没有理由这样做。添加这些行:
android:layout_marginTop="?attr/actionBarSize"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
Run Code Online (Sandbox Code Playgroud)
应该ViewPager足够了。
他们两个都应该是 的直系孩子CoordinatorLayout。
按照这个例子:http ://blog.nkdroidsolutions.com/collapsing-toolbar-with-tabs-android-example/
如果您是 Material Design 的新手,或者对其某些行为感到有点迷失,我强烈建议您查看 Chris Banes Material Design 项目cheesequare: https: //github.com/chrisbanes/cheesesquare/
希望它会有所帮助
| 归档时间: |
|
| 查看次数: |
2257 次 |
| 最近记录: |