Android:菜单中的圆角

BEAGLE ENTERTAIN

在我的MainActivityonCreateOptionsMenu方法中,我为基本菜单添加了四个项目(请参阅menu_main.xml)。
由于DialogFragments中可能有圆角,因此如何获得此菜单的圆角?

正如您在屏幕截图中所看到的,该菜单显示为整个活动顶部的溢出菜单(是的,点击三个点时Android为您提供的基本菜单)。
截图在这里:MainActivity与打开的菜单

是我的尝试
为对话框,我添加android:background="@drawable/basic_rounded_corners到菜单和menu_main.xml项目节点都--->不工作(因为我不知道如何设置菜单的backgroundDrawable以编程方式(如果像DialogFragments一样)

我想
我想知道如何让我的菜单上的圆角。

menu_main.xml

<menu 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"
tools:context="com.beagleentertain.pillreminder.MainActivity"
android:background="@drawable/basic_rounded_corners">
<item
    android:id="@+id/action_settings"
    android:orderInCategory="100"
    android:title="@string/checkable_make7dayspause"
    android:checkable="true"
    android:checked="false"
    app:showAsAction="ifRoom"
    />
<item
    android:id="@+id/about_settings"
    android:orderInCategory="100"
    android:title="@string/text_menu_about"
    app:showAsAction="ifRoom"
    />
<item
    android:id="@+id/settings_settings"
    android:orderInCategory="100"
    android:title="@string/action_settings"
    app:showAsAction="ifRoom"
    />
<item
    android:id="@+id/settings_share"
    android:orderInCategory="100"
    android:title="@string/action_share"
    app:showAsAction="ifRoom"
    />

Alaa AbuZarifa

首先,您需要在活动中使用工具栏,以便为popMenu设置样式。

<android.support.v7.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    android:background="@color/colorPrimary"
    app:popupTheme="@style/ThemeOverlay.MyTheme"
    app:titleTextColor="#f0f0f0"/>

然后添加此样式,并确保将设置colorBackground为透明,以便正确显示圆角,然后使用任何可绘制的形状作为背景。

 <style name="ThemeOverlay.MyTheme" parent="ThemeOverlay.AppCompat.Light">
        <item name="android:colorBackground">@android:color/transparent</item>
        <item name="android:textColor">#000000</item>
        <item name="android:background">@drawable/rounded</item>
    </style>

如果你想建立一个完全自定义窗口,你可以按照本教程在本文章只要确保将圆角形状添加为根视图中的背景即可。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章