20

カスタムの高さのツールバーを作成したいのですが、コンテンツを追加するまで問題なく動作します。次に、コンテンツが戻る矢印とアクションバー ボタンの間に配置されるように調整します。

以下のようなレイアウトを作成できるように、コンテンツを全幅にするにはどうすればよいですか? 「+」アイコンはツールバーの親レイアウトにある必要があると思いますか?

ドキュメントは言う:

アプリケーションは、任意の子ビューをツールバーに追加できます。レイアウト内のこの位置に表示されます。子ビューの Toolbar.LayoutParams が CENTER_HORIZONTAL の Gravity 値を示している場合、ビューは、他のすべての要素が測定された後、ツールバーに残っている使用可能なスペース内で中央に配置しようとします。

しかし、重力が CENTER_HORIZONTAL に設定されていません... 欲しいレイアウト

 <android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:iosched="http://schemas.android.com/apk/res-auto"
        iosched:theme="@style/ActionBarThemeOverlay"

        iosched:popupTheme="@style/ActionBarPopupThemeOverlay"
        android:id="@+id/toolbar_actionbar"
        android:background="@color/theme_primary"
        iosched:titleTextAppearance="@style/ActionBar.TitleText"
        iosched:contentInsetStart="16dp"
        iosched:contentInsetEnd="16dp"
        android:layout_width="match_parent"
        android:layout_height="128dp" >
        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

        ... My Content

現在、左マージンを 168 に設定して実行すると、私のレイアウトは次のようになります。

ここに画像の説明を入力 レイアウト

4

1 に答える 1

26

これについてまだ助けが必要かどうかはわかりませんが、現在、android-5.0-lollipopタグだけでなく、android-toolbarタグでも、未回答の質問に対する投票が最も多くなっています。だから、私はそれを与えると思った。

このレイアウトは、特に新しいDesign Support Libraryを使用すると、非常に簡単に実現できます。

実装

階層のルートはCoordinatorLayout.

ドキュメントに従って:

CoordinatorLayout の子にはアンカーがある場合があります。このビュー ID は、CoordinatorLayout の任意の子孫に対応する必要がありますが、アンカーされた子自体またはアンカーされた子の子孫ではない場合があります。これを使用して、他の任意のコンテンツ ペインに対してフローティング ビューを配置できます。

したがって、これを使用して、FloatingActionButton移動する必要がある場所を配置します。

残りは非常に簡単です。、テキストコンテナLinearLayoutToolbarタブ コンテナ、そしてViewPager. したがって、完全なレイアウトは次のようになります。

<android.support.design.widget.CoordinatorLayout
    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"
    android:fitsSystemWindows="true">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#181E80"
        android:orientation="vertical">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:minHeight="?attr/actionBarSize" />

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginBottom="48dp"
            android:paddingTop="8dp">

            <ImageView
                android:id="@android:id/icon"
                android:layout_width="54dp"
                android:layout_height="54dp"
                android:layout_alignParentStart="true"
                android:layout_marginStart="16dp"
                android:importantForAccessibility="no"
                android:src="@drawable/logo" />

            <TextView
                android:id="@android:id/text1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_alignTop="@android:id/icon"
                android:layout_marginStart="14dp"
                android:layout_toEndOf="@android:id/icon"
                android:text="Chelsea"
                android:textColor="@android:color/white"
                android:textSize="24sp" />

            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignStart="@android:id/text1"
                android:layout_below="@android:id/text1"
                android:text="England - Premier League"
                android:textColor="@android:color/white"
                android:textSize="12sp" />

        </RelativeLayout>

        <FrameLayout
            android:id="@+id/tab_container"
            android:layout_width="match_parent"
            android:layout_height="90dp"
            android:background="#272F93">

            <android.support.design.widget.TabLayout
                android:id="@+id/tabs"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom"
                app:tabContentStart="70dp"
                app:tabGravity="center"
                app:tabIndicatorColor="#F1514A"
                app:tabMode="scrollable"
                app:tabSelectedTextColor="@android:color/white"
                app:tabTextColor="#99ffffff" />

        </FrameLayout>

        <android.support.v4.view.ViewPager
            android:id="@+id/pager"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />

    </LinearLayout>

    <android.support.design.widget.FloatingActionButton
        android:layout_width="60dp"
        android:layout_height="60dp"
        android:layout_margin="16dp"
        android:src="@drawable/ic_star_white_24dp"
        app:backgroundTint="#F1514A"
        app:borderWidth="0dp"
        app:elevation="8dp"
        app:layout_anchor="@id/tab_container"
        app:layout_anchorGravity="top|right|end" />

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

追加することはそれほど多くありません。他に言及したいのは、TabLayout. 私たちのような を使用している場合ViewPagerは、おそらく次の 2 つのうちのいずれかを呼び出します。

ノート

できるだけ写真と一致するように、寸法を目で見てみました。

結果

結果

于 2015-06-27T01:05:29.080 に答える