2017-08-27 13 views
1

ツールバーでハンバーガーアイコンの位置をVertically Centerとして設定しようとしていますが、そうすることができません。Android Toolbarのサイズに基づいてハンバーガーのアイコン位置を変更します

レイアウトの重さに基づいてToolBarの高さを設定しました。私は、顧客の要求のためにToolBarのデフォルトの高さを使用することはできません。以下は

enter image description here

私の主な活動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> 

は、私ができるのいずれかの方法があります:

  1. いずれかの垂直いくつかの左側に中心にこのActionBarDrawerToggleボタンを作成しますアイコンが白い領域の中央に収まるように余白を設定します。

  2. このActionBarDrawerToggleボタンの代わりにカスタムコントロールを作成するには、

私はAndroid開発に慣れていないと助けてください。垂直ツールバー上のminHeight属性を使用Hamburger Icon

をalligningするため

+0

試してみてください:あなたの' android.support.v7.widget.Toolbar'..thenそれは、ツールバーの真ん中にして整列する中minHeightの=「100dp」 '...を。 – rafsanahmad007

+0

@ rafsanahmad007素早く対応してくれてありがとう。最小の高さを100dpに設定しようとしました。トグルボタンが垂直に中央に表示されるようになりました。このトグルボタンにLeft Marginを設定する方法はありますか? –

答えて

1

例でツールバーの右側/左側にMargin | paddingにアクセスするため

<android.support.v7.widget.Toolbar 
     android:minHeight="100dp" //your value 

</android.support.v7.widget.Toolbar> 

使用contentInset

例:

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
toolbar.setContentInsetsAbsolute(toolbar.getContentInsetLeft(), 200); //here 200 is set for padding left 
+0

回答を追加しました.... – rafsanahmad007

+0

ありがとうございますが、左パディングのsetContentInsetsAbsoluteは何の効果も表示していません。パディング/マージンは追加されません。 –

+0

これはApi 21で動作します... https://stackoverflow.com/questions/29447043/unexplained-gap-padding-to-the-left-between-toolbar-and-linearlayout – rafsanahmad007

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; 
    } 
} 
関連する問題