更改为Android SDK 26后,工具栏中的图标被压缩

时间:2017-07-27 03:16:50

标签: java android xml

将我的应用从编译/定位SDK v25更改为SDK v26后,我应用工具栏中的所有菜单图标现在都被压扁/压扁/拉伸。

以下是相关的布局代码:

            <android.support.design.widget.AppBarLayout
            android:id="@+id/appbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

            <RelativeLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content">

                <android.support.v7.widget.Toolbar
                    android:id="@+id/toolbar"
                    android:layout_width="match_parent"
                    android:layout_height="?attr/actionBarSize"
                    android:background="?attr/colorPrimary"
                    android:theme="@style/AppTheme.AppBarOverlay" />

                <br.com.mauker.materialsearchview.MaterialSearchView
                    android:id="@+id/search_view"
                    android:layout_width="match_parent"
                    android:layout_height="match_parent" />

            </RelativeLayout>

        </android.support.design.widget.AppBarLayout>

这是一个收集的菜单:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">

<item android:id="@+id/action_search"
    android:title="@string/search"
    android:icon="@drawable/ic_search_white_48dp"
    app:showAsAction="ifRoom" />

<item
    android:id="@+id/advanced_search"
    android:enabled="true"
    android:title="@string/advanced_search"
    app:showAsAction="never" />

</menu>

这是另一个收集的菜单(他们都这样做):

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">

<item
    android:id="@+id/add_photo"
    android:enabled="true"
    android:title="@string/add_photo"
    android:icon="@drawable/ic_add_a_photo_white_48dp"
    app:showAsAction="ifRoom" />

</menu>

How it looks on SDK v25

How it looks on SDK v26

3 个答案:

答案 0 :(得分:12)

问题是图标大小比预期大。显然,SDK 26中的扩展机制已经改变,现在它导致了这个UI错误。确保以下列大小提供工具栏图标资源。

<强>更新

由于工具栏最小高度abc_action_bar_default_height_material56dpabc_action_bar_icon_vertical_padding_material16dp,因此工具栏图标的最小尺寸为24dp MDPI:

drawable-mdpi - 24 x 24 px
drawable-hdpi - 36 x 36 px
drawable-xhdpi - 48 x 48 px
drawable-xxhdpi - 72 x 72 px
drawable-xxxhdpi - 96 x 96 px

答案 1 :(得分:6)

我在appcompat-v7支持库的26.0.0版本中遇到此问题。更新到26.0.2修复了它:)

见这里:https://issuetracker.google.com/issues/64207386

答案 2 :(得分:1)

您需要生成不同的可绘制图标并放置在相应的文件夹中才能工作。您可以使用this link生成不同大小的图标。

相关问题