我正在尝试将ToolBar中Hamburger图标的位置设置为垂直中心,但无法这样做。
我根据布局重量制作了ToolBar高度。由于客户要求,我无法使用ToolBar默认高度。
以下是我的主要活动XML:
<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:fitsSystemWindows="true"
android:orientation="vertical">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1.5"
app:titleTextColor="@color/vodafone_white"
android:background="@mipmap/img_appbar">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="horizontal">
<android.support.v4.widget.Space
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="3"
/>
<TextView
android:id="@+id/toolbar_title"
android:layout_width="0dp"
android:layout_height="match_parent"
android:layout_weight="7"
android:layout_marginLeft="15dp"
android:layout_marginRight="15dp"
android:textColor="@color/vodafone_white"
android:textSize="35sp"
android:textStyle="bold"
android:gravity="left|center_vertical"
android:text="@string/title_Vodafone" />
</LinearLayout>
</android.support.v7.widget.Toolbar>
<!--Contents-->
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="8.5"
android:background="@color/vodafone_lightGray">
<android.support.v4.widget.DrawerLayout 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:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:openDrawer="start">
<!-- Layout for content is here. This can be a RelativeLayout -->
<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:id="@+id/app_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.keybs.vodafoneqatar.views.MainActivity">
<android.support.constraint.ConstraintLayout 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"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:context="com.keybs.vodafoneqatar.views.MainActivity">
</android.support.constraint.ConstraintLayout>
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="bottom|end"
android:layout_margin="@dimen/fab_margin"
app:srcCompat="@android:drawable/ic_dialog_email" />
</android.support.design.widget.CoordinatorLayout>
<android.support.design.widget.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main2"
app:menu="@menu/activity_main2_drawer" />
</android.support.v4.widget.DrawerLayout>
</RelativeLayout>
</LinearLayout>
我有什么方法可以:
要么使此ActionBarDrawerToggle
按钮垂直居中,并留有一些左边距,以便图标适合白色区域的中心。
或者创建自定义控件作为此ActionBarDrawerToggle
按钮的替代?
需要帮助,因为我不熟悉Android开发。
答案 0 :(得分:2)
垂直对齐main
使用工具栏上的myapp-core/some-export
属性。
示例强>
Hamburger Icon
用于访问minHeight
在工具栏的左侧/右侧:
使用<android.support.v7.widget.Toolbar
android:minHeight="100dp" //your value
</android.support.v7.widget.Toolbar>
示例:强>
Margin | padding
答案 1 :(得分:0)
试试这个
ViewGroup.LayoutParams layoutParams = mToolbar.getLayoutParams();
for (int i = 0; i < mToolbar.getChildCount(); i++) {
if (mToolbar.getChildAt(i) instanceof ImageButton) {
Toolbar.LayoutParams lp = (Toolbar.LayoutParams) mToolbar.getChildAt(i).getLayoutParams();
layoutParams.gravity = Gravity.CENTER_VERTICAL;
}
}