Как я могу выровнять меню/значки панели инструментов Android слева, как в приложении Google Maps?
вот скриншот панели инструментов Google Maps.

Как вы можете видеть, значки выровнены слева, а не справа (поведение по умолчанию). Я попытался добавить android: layout_gravity= "left"и android:gravity=" left " на панель инструментов, но это не сработало. Также попытался добавить внутренний LinearLayout (с одинаковыми значениями гравитации) на панель инструментов, но тоже не работал. Есть идеи? Я хочу иметь возможность использовать обычное меню Android с виджетом панели инструментов вместо воссоздание всего с нуля.
2 ответов:
после некоторых усилий и копания в коде панели инструментов Android мне удалось заставить его работать. В основном, идея состоит в том, чтобы добавить новый android.поддержка.v7.штучка.ActionMenuView как дочерний элемент панели инструментов, установите его гравитацию в top / start, а затем добавьте меню в этот вид меню действий в своей активности. Вот код:
my_toolbar.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/tToolbar" android:layout_height="?attr/actionBarSize" android:layout_width="match_parent" android:background="?attr/colorPrimary" android:gravity="center_vertical|start" app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" app:popupTheme="@style/ThemeOverlay.AppCompat.Light"> <android.support.v7.widget.ActionMenuView android:id="@+id/amvMenu" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize"/> </android.support.v7.widget.Toolbar>my_activity.xml
<RelativeLayout 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"> <!--Toolbar--> <include android:id="@+id/tToolbar" android:layout_height="wrap_content" android:layout_width="match_parent" layout="@layout/my_toolbar" /> </RelativeLayout>MyActivity.java
import android.os.Bundle; import android.support.v7.app.ActionBarActivity; import android.support.v7.widget.ActionMenuView; import android.support.v7.widget.Toolbar; import android.view.Menu; import android.view.MenuInflater; import android.view.MenuItem; public final class MyActivity extends ActionBarActivity { private ActionMenuView amvMenu; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // this layout includes the custom toolbar my_toolbar.xml setContentView(R.layout.my_activity); Toolbar t = (Toolbar) findViewById(R.id.tToolbar); amvMenu = (ActionMenuView) t.findViewById(R.id.amvMenu); amvMenu.setOnMenuItemClickListener(new ActionMenuView.OnMenuItemClickListener() { @Override public boolean onMenuItemClick(MenuItem menuItem) { return onOptionsItemSelected(menuItem); } }); setSupportActionBar(t); getSupportActionBar().setTitle(null); getSupportActionBar().setDisplayHomeAsUpEnabled(true); } @Override public boolean onCreateOptionsMenu(Menu menu) { MenuInflater inflater = getMenuInflater(); // use amvMenu here inflater.inflate(R.menu.my_activity_menu, amvMenu.getMenu()); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Do your actions here return true; } }
Если нет особых причин для добавления элементов панели инструментов в качестве действий меню, элементы управления пользовательского интерфейса могут быть непосредственно добавлены на панель инструментов и выровнены аналогично выравниванию любого другого элемента внутри макета.
например, следующая панель инструментов имеет выравнивание по левому краю
Spinnerи выровненный по правому краю EditText.<android.support.v7.widget.Toolbar android:id="@+id/toolbar_actionbar" android:layout_width="match_parent" android:layout_height="wrap_content" android:background="@color/tab_background" android:gravity="center_vertical"> <Spinner android:id="@+id/categorySpinner" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="10dp" /> <EditText android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="right" android:hint="Name" /> </android.support.v7.widget.Toolbar>
Comments