質問 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);
幅全体を満たさないカスタムレイアウトになります。
これをもっと興味深くするために、私は別のアプリで同様の設定をしています:
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)にはこの問題がありません(ホームアイコンがあり、これは後のコードで処理されます)。これが最新のリリースの問題であることを確認します。
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>
ツールバーの親を使用する=(ツールバー)customNav.getParent(); parent.setContentInsetsAbsolute(0、0);それが動作します
このように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);
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">
ビューのすべての幅に適合します。