web-dev-qa-db-ja.com

Android ActionBarのカスタムビューが親を満たさない

質問 here に似ていますが、いくつかの重要な違いがあります。最も顕著なのは、受け入れられた回答didが最新のサポートライブラリがリリースされるまで機能することです。

カスタムビューのレイアウトは次のとおりです。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
              Android:orientation="vertical"
              Android:layout_width="match_parent"
              Android:layout_height="match_parent"
              Android:background="#FFDD0000">

</LinearLayout>

ここで、カスタムビューのみを設定しようとすると、次のようになります。

  ActionBar actionBar = getSupportActionBar();
  actionBar.setDisplayShowCustomEnabled(true);
  actionBar.setCustomView(R.layout.actionbar);

幅全体を満たさないカスタムレイアウトになります。 enter image description here

これをもっと興味深くするために、私は別のアプリで同様の設定をしています:

  ActionBar actionBar = getSupportActionBar();
  actionBar.setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM);
  actionBar.setCustomView(R.layout.actionbar);
  actionBar.setDisplayHomeAsUpEnabled(false);
  actionBar.setHomeButtonEnabled(false);

このdidは、サポートライブラリをv21に更新するまで機能します。一度実行すると、以前はその問題がなかったアプリでも同じ問題が発生しました。

だから、私の質問は、最新のサポートライブラリを使用して、カスタムビューのアクションバーに幅を満たす方法があるかどうかです。

Editさらにテストを行った後、targetSdkVersion/compileSdkVersionを19に設定してコンパイルし、ライブラリのv7:19.0.1(またはv7:19.1.0)にはこの問題がありません(ホームアイコンがあり、これは後のコードで処理されます)。これが最新のリリースの問題であることを確認します。

19
Shalmezad

1

ActionBar actionBar = getSupportActionBar();
actionBar.setDisplayShowHomeEnabled(false);
actionBar.setDisplayShowCustomEnabled(true);
actionBar.setDisplayShowTitleEnabled(false);
View view = getLayoutInflater().inflate(R.layout.actionbar_title_back,
            null);
LayoutParams layoutParams = new LayoutParams(LayoutParams.MATCH_PARENT,
            LayoutParams.MATCH_PARENT);
actionBar.setCustomView(view, layoutParams);
Toolbar parent = (Toolbar) view.getParent();
parent.setContentInsetsAbsolute(0, 0);

2ツールバーを使用する

toolbar = (Toolbar) findViewById(R.id.toolbar);
toolbar.setTitle("");
mTitle = (TextView) toolbar.findViewById(R.id.toolbar_title);
mTitle.setText(title);
setSupportActionBar(toolbar);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
getSupportActionBar().setDisplayShowHomeEnabled(true);

XML

<?xml version="1.0" encoding="utf-8"?>       
<LinearLayout 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:orientation="vertical" >

    <Android.support.v7.widget.Toolbar
        Android:id="@+id/toolbar"
        Android:layout_width="match_parent"
        Android:layout_height="?attr/actionBarSize"
        Android:popupBackground="@color/red"
        app:popupTheme="@style/PopupTheme"
        app:theme="@style/ToolbarTheme" >

        <TextView
            Android:id="@+id/toolbar_title"
            Android:layout_width="wrap_content"
            Android:layout_height="wrap_content"
            Android:layout_gravity="center"
            Android:text="Toolbar Title"
            Android:textColor="@color/white"
            Android:textSize="17.0sp" />
    </Android.support.v7.widget.Toolbar>
</LinearLayout>
29
tuder

ツールバーの親を使用する=(ツールバー)customNav.getParent(); parent.setContentInsetsAbsolute(0、0);それが動作します

7
jesto paul

このようにonCreateメソッドに追加します

 ActionBar action = getSupportActionBar();
        action.setDisplayOptions(ActionBar.DISPLAY_SHOW_CUSTOM);

 Toolbar toolbar=(Toolbar)action.getCustomView().getParent();
        toolbar.setContentInsetsAbsolute(0, 0);
        toolbar.getContentInsetEnd();
        toolbar.setPadding(0, 0, 0, 0);
6

XMLコードに次の属性を追加します。

<Android.support.v7.widget.Toolbar xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:app="http://schemas.Android.com/apk/res-auto"
    Android:id="@+id/re_app_toolbar"
    Android:layout_width="match_parent"
    Android:layout_height="?attr/actionBarSize"
    Android:contentInsetEnd="0dp"
    Android:contentInsetLeft="0dp"
    Android:contentInsetRight="0dp"
    Android:contentInsetStart="0dp"
    app:contentInsetEnd="0dp"
    app:contentInsetLeft="0dp"
    app:contentInsetRight="0dp"
    app:contentInsetStart="0dp">

ビューのすべての幅に適合します。

2
Fakher