1

デフォルトのテンプレートに見られるように、折りたたみツールバー効果を持たせたいカスタム マスター詳細フローがあります。それを機能させるためのネスティングを理解していません。

私のアクティビティには 2 つのバリアントがあります。

マスター詳細フロー

<LinearLayout 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:baselineAligned="false"
    android:divider="?android:attr/dividerHorizontal"
    android:orientation="horizontal"
    tools:context="com.example.android.sunshine.app.MainActivity">

    <!--
    This layout is a two-pane layout for the Items master/detail flow.
    -->

    <fragment
        android:id="@+id/fragment_main"
        android:name="xyz.selfenrichment.robertotomas.three_two_one_rotate.MainFragment"
        android:tag="@string/tag_gridview_one_column"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="3"
        tools:context="xyz.selfenrichment.robertotomas.three_two_one_rotate.MainFragment"
        tools:layout="@layout/fragment_main" />

    <FrameLayout
        android:id="@+id/fragmentcontainer_detail"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="2"
        tools:layout="@layout/fragment_detail" />

</LinearLayout>

単一ペイン

<fragment xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/fragment_main"
    android:name="xyz.selfenrichment.robertotomas.three_two_one_rotate.MainFragment"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:tag="@string/tag_gridview_two_columns"
    tools:context="xyz.selfenrichment.robertotomas.three_two_one_rotate.MainFragment"
    tools:layout="@android:layout/list_content" />

そして、私の折りたたみツールバーは次のようになるはずです:

<android.support.design.widget.CoordinatorLayout ...
...
    <android.support.design.widget.AppBarLayout ...
    ...
        <android.support.design.widget.CollapsingToolbarLayout ...
        ...
            <android.support.v7.widget.Toolbar

ここで、2 つを組み合わせて、次のようなレイアウト動作を追加する必要があります。

マスター詳細フロー

<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:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:context="xyz.selfenrichment.robertotomas.popularmovies.PosterBoardActivity">

    <android.support.design.widget.AppBarLayout
        android:id="@+id/app_bar"
        android:layout_width="match_parent"
        android:layout_height="@dimen/app_bar_height"
        android:fitsSystemWindows="true"
        android:theme="@style/AppTheme.AppBarOverlay">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/toolbar_layout"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            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_collapseMode="pin"
                app:popupTheme="@style/AppTheme.PopupOverlay" />

        </android.support.design.widget.CollapsingToolbarLayout>
    </android.support.design.widget.AppBarLayout>

    <LinearLayout 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:baselineAligned="false"
        android:divider="?android:attr/dividerHorizontal"
        android:orientation="horizontal"
        tools:context="com.example.android.sunshine.app.MainActivity"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <!--
        This layout is a two-pane layout for the Items master/detail flow.
        -->

        <fragment
            android:id="@+id/fragment_main"
            android:name="xyz.selfenrichment.robertotomas.popularmovies.MainFragment"
            android:tag="@string/tag_gridview_one_column"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="3"
            tools:context="xyz.selfenrichment.robertotomas.popularmovies.MainFragment"
            tools:layout="@layout/fragment_main" />

        <FrameLayout
            android:id="@+id/fragmentcontainer_detail"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight="2"
            tools:layout="@layout/fragment_detail" />

    </LinearLayout>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/fab"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="@dimen/fab_margin"
        android:src="@android:drawable/ic_menu_manage"
        app:layout_anchor="@id/app_bar"
        app:layout_anchorGravity="bottom|end" />

</android.support.design.widget.CoordinatorLayout>

しかし、レイアウト動作をfragmentタグ、または基になるフラグメント xml (または両方)に追加すると、次のようになります。

<GridView xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/grid_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:horizontalSpacing="10dp"
    android:verticalSpacing="10dp"
    android:stretchMode="columnWidth"
    app:layout_behavior="@string/appbar_scrolling_view_behavior" />

いずれにせよ、グリッドビューをスクロールしてもツールバーは折りたたまれません。

編集:明らかに機能するかなり似た例がここにあるので、これは特に紛らわしいです。

4

1 に答える 1

2

うわー:)私はそれを見つけました。layout_behavior を設定しましたが、それをデータ アダプターにアタッチするフラグメント クラスに次の行を追加しました。

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
        mGridView.setNestedScrollingEnabled(true);
    }
于 2016-04-07T21:03:20.420 に答える