CollapsingToolbarLayout:意外的视图堆栈行为
CollapsingToolbarLayout: unexpected view stack behavior
CollapsingToolbarLayout
(自定义 FrameLayout
)的子项似乎不符合 FrameLayout
的预期堆栈行为。我希望视图按照它们在 XML 布局中提供的顺序在彼此之上绘制。
在下面的示例中,当折叠 CollapsingToolbarLayout
时,“layout_button_bar” LinearLayout
在“button_follow”和“button_like”下方滚动纽扣。如果 LinearLayout
是在上述按钮之后定义的,我希望 LinearLayout
滚动到两个按钮上方,遮住它们,而不是在它们下方。有人熟悉解决方法吗?
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/coordinator_layout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/app_bar_layout"
android:layout_width="match_parent"
android:layout_height="@dimen/collapsible_app_bar_height"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsing_toolbar_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:contentScrim="@color/background_content_frame"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center_horizontal"
android:src="@drawable/some_image"
app:layout_collapseMode="parallax"/>
<ImageView
android:id="@+id/image_header_gradient"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@drawable/scrim_top_bottom_banner"
app:layout_collapseMode="parallax"
tools:ignore="ContentDescription"/>
<android.support.v7.widget.Toolbar
android:id="@+id/collapsible_toolbar"
android:layout_width="match_parent"
android:layout_height="104dp"
android:minHeight="?attr/actionBarSize"
android:gravity="top"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:layout_collapseMode="pin"/>
<Button
android:id="@+id/button_follow"
android:layout_width="@dimen/text_button_width"
android:layout_height="wrap_content"
android:layout_gravity="bottom|start"
android:layout_marginStart="@dimen/bottom_landing_button_margin"
android:layout_marginBottom="@dimen/slide_handle_height"
android:gravity="center_vertical|start"
android:drawablePadding="@dimen/spacing_xsmall"
android:drawableStart="@drawable/selector_follow"
android:visibility="gone"
android:textColor="@color/vertigo_alabaster_white"
app:layout_collapseMode="parallax"/>
<Button
android:id="@+id/button_like"
android:layout_width="@dimen/text_button_width"
android:layout_height="wrap_content"
android:layout_gravity="bottom|start"
android:layout_marginStart="@dimen/bottom_landing_button_margin"
android:layout_marginBottom="@dimen/slide_handle_height"
android:gravity="center_vertical|start"
android:drawablePadding="@dimen/spacing_xsmall"
android:drawableStart="@drawable/selector_like"
android:visibility="gone"
android:textColor="@color/vertigo_alabaster_white"
app:layout_collapseMode="parallax"/>
<LinearLayout
android:id="@+id/layout_button_bar"
android:layout_width="match_parent"
android:layout_height="@dimen/button_bar_height"
android:layout_gravity="bottom"
android:gravity="center_vertical"
android:orientation="horizontal"
android:background="@color/slide_handle">
<!-- 3 Buttons -->
</LinearLayout>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v7.widget.RecyclerView
android:id="@+id/recycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
</android.support.design.widget.CoordinatorLayout>
库:com.android.support:设计 23.0.1 |主题:Theme.AppCompat.NoActionBar
预崩:
中崩溃:
只需将类似 Button
和后续 Button
包裹在 Layout
中。例如 LinearLayout
:
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
android:gravity="center_vertical"
android:orientation="horizontal"
android:layout_marginBottom="80dp"
app:layout_collapseMode="parallax">
<Button
android:id="@+id/button_follow"
...
/>
<Button
android:id="@+id/button_like"
...
/>
</LinearLayout>
CollapsingToolbarLayout
(自定义 FrameLayout
)的子项似乎不符合 FrameLayout
的预期堆栈行为。我希望视图按照它们在 XML 布局中提供的顺序在彼此之上绘制。
在下面的示例中,当折叠 CollapsingToolbarLayout
时,“layout_button_bar” LinearLayout
在“button_follow”和“button_like”下方滚动纽扣。如果 LinearLayout
是在上述按钮之后定义的,我希望 LinearLayout
滚动到两个按钮上方,遮住它们,而不是在它们下方。有人熟悉解决方法吗?
<android.support.design.widget.CoordinatorLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/coordinator_layout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/app_bar_layout"
android:layout_width="match_parent"
android:layout_height="@dimen/collapsible_app_bar_height"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsing_toolbar_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:contentScrim="@color/background_content_frame"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_gravity="center_horizontal"
android:src="@drawable/some_image"
app:layout_collapseMode="parallax"/>
<ImageView
android:id="@+id/image_header_gradient"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:src="@drawable/scrim_top_bottom_banner"
app:layout_collapseMode="parallax"
tools:ignore="ContentDescription"/>
<android.support.v7.widget.Toolbar
android:id="@+id/collapsible_toolbar"
android:layout_width="match_parent"
android:layout_height="104dp"
android:minHeight="?attr/actionBarSize"
android:gravity="top"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:layout_collapseMode="pin"/>
<Button
android:id="@+id/button_follow"
android:layout_width="@dimen/text_button_width"
android:layout_height="wrap_content"
android:layout_gravity="bottom|start"
android:layout_marginStart="@dimen/bottom_landing_button_margin"
android:layout_marginBottom="@dimen/slide_handle_height"
android:gravity="center_vertical|start"
android:drawablePadding="@dimen/spacing_xsmall"
android:drawableStart="@drawable/selector_follow"
android:visibility="gone"
android:textColor="@color/vertigo_alabaster_white"
app:layout_collapseMode="parallax"/>
<Button
android:id="@+id/button_like"
android:layout_width="@dimen/text_button_width"
android:layout_height="wrap_content"
android:layout_gravity="bottom|start"
android:layout_marginStart="@dimen/bottom_landing_button_margin"
android:layout_marginBottom="@dimen/slide_handle_height"
android:gravity="center_vertical|start"
android:drawablePadding="@dimen/spacing_xsmall"
android:drawableStart="@drawable/selector_like"
android:visibility="gone"
android:textColor="@color/vertigo_alabaster_white"
app:layout_collapseMode="parallax"/>
<LinearLayout
android:id="@+id/layout_button_bar"
android:layout_width="match_parent"
android:layout_height="@dimen/button_bar_height"
android:layout_gravity="bottom"
android:gravity="center_vertical"
android:orientation="horizontal"
android:background="@color/slide_handle">
<!-- 3 Buttons -->
</LinearLayout>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v7.widget.RecyclerView
android:id="@+id/recycler_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scrollbars="vertical"
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
</android.support.design.widget.CoordinatorLayout>
库:com.android.support:设计 23.0.1 |主题:Theme.AppCompat.NoActionBar
预崩:
中崩溃:
只需将类似 Button
和后续 Button
包裹在 Layout
中。例如 LinearLayout
:
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
android:gravity="center_vertical"
android:orientation="horizontal"
android:layout_marginBottom="80dp"
app:layout_collapseMode="parallax">
<Button
android:id="@+id/button_follow"
...
/>
<Button
android:id="@+id/button_like"
...
/>
</LinearLayout>