从Android工具栏中删除左边距

问题描述 投票:0回答:1

我正在开发一个Android应用,其中有导航抽屉,可以导航到我应用的其他部分。我已将ActionBarDrawerToggle默认汉堡包图标更改为我自己的图标。我想将切换图标放置在其最左侧。因此,我想删除默认的16dp空间。

I want to remove that red bordered space to the left of the toggle icon

我想删除切换图标左侧的红色边框

我已经在互联网上搜索了4个多小时,但没有任何反应。我已经尝试了在StackOverflow中找到的所有内容,但是没有任何工作。我还尝试将图标资源更改为其他图像,以确保使用的图像没有任何错误。

[此外,如果我从工具栏中删除切换图标,则工具栏的其他内容会自动移到最左端,而没有16dp的空白,但是如果我添加切换图标,则会再次显示16dp空间。

此外,由于我的最低sdk版本为18,所以我认为需要最低sdk版本21的某些解决方案将不起作用。

唯一对我有用的是

    toolbar.setPadding(-16, 0, 0, 0);
    toolbar.setX(-16);

但是存在一个问题,对于平板电脑这样的大屏幕设备,切换图标会完全隐藏。所以任何人都可以帮我这个忙,下面是我正在使用的代码。

非常感谢

    Toolbar toolbar = findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);
    fm = getSupportFragmentManager();

    final DrawerLayout drawer = findViewById(R.id.drawer_layout);
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
            this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close) {

        @Override
        public void onDrawerSlide(View drawerView, float slideOffset) {
            super.onDrawerSlide(drawerView, slideOffset);
        }
    };

    drawer.addDrawerListener(toggle);
    toggle.setToolbarNavigationClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if (drawer.isDrawerVisible(GravityCompat.START)) {
                drawer.closeDrawer(GravityCompat.START);
            } else {
                drawer.openDrawer(GravityCompat.START);
            }
        }
    });
    toolbar.setContentInsetsAbsolute(0, 0);
    toggle.setDrawerIndicatorEnabled(false);
    toggle.setHomeAsUpIndicator(R.mipmap.toggle);// my icon resource
    toggle.syncState();

我的工具栏的xml文件是

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 
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:background="@drawable/bg_gradient">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <androidx.appcompat.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="@color/white"
        android:theme="@style/ThemeOverlay.AppCompat.Light"
        app:contentInsetLeft="0dp"
        app:contentInsetStart="0dp"
        app:contentInsetStartWithNavigation="0dp"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
        app:subtitleTextColor="@color/black"
        app:titleTextColor="@color/black" />

    <RelativeLayout
        android:id="@+id/fragment"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>
</RelativeLayout>
java android xml toolbar android-togglebutton
1个回答
1
投票

我认为您的代码:

    toolbar.setPadding(-16, 0, 0, 0);
    toolbar.setX(-16);

对于不同的屏幕它有所不同,因为您使用的是像素(px),并且它可以在不同的屏幕中改变,所以密度可以尝试以下方法:

toolbar.setPadding(-toPixels(betterValue), 0, 0, 0);
toolbar.setX(-toPixels(betterValue));
/*
.
.
.
*/
static int toPixels(float dip, Context context){
        Resources r=context.getResources();
        float densidade = r.getDisplayMetrics().density;
        return (int)(dip*densidade+0.5f);
}

我不知道这是否是更好的方法,但我希望这会有所帮助。

© www.soinside.com 2019 - 2024. All rights reserved.