gpt4 book ai didi

android - 选项菜单,选项之间有线条。就像菜单中显示的选项之间的分隔线

转载 作者:塔克拉玛干 更新时间:2023-11-03 00:20:34 25 4
gpt4 key购买 nike

在我的应用程序中,我有一个默认位于顶部的选项菜单。当我们按下该菜单时,该菜单将在该菜单中打开,它们之间的选项之间没有线条。我想像分隔线一样显示它们之间的线条。

我尝试更改它的主题,但我不会使用其他解决方案,因为如果我更改主题,它将完全影响我的应用程序。

它在 AppTheme 中工作,而不是在 AppTheme.AppCompat 中工作。

我希望它能在不改变主题的情况下工作。

如果有人想要代码,我会发布。

 <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
<item name="android:showDividers">beginning</item>
<item name="android:divider">@color/action_bar_divider</item>
</style>

最佳答案

有很多方法可以实现这一点。

解决方案 1 ==> 您可以像下面这样在菜单 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=".MainActivity">

<group android:id="@+id/grp1">
<item
android:id="@+id/navigation_item_1"
android:checked="true"
android:icon="@drawable/ic_home"
android:title="@string/navigation_item_1" /></group>

<group android:id="@+id/grp2">
<item
android:id="@+id/navigation_item_2"
android:icon="@drawable/ic_home"
android:title="@string/navigation_item_2" /></group></menu>

解决方案 2==> 您可以像下面这样自定义操作布局

<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">
<item
android:id="@+id/action_cart"
android:title="cart"
android:actionLayout="@layout/custom_layout"
android:icon="@drawable/shape_notification"
app:showAsAction="always"/>

和 actionLayout 文件如下所示

<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:orientation="vertical">

<View
android:id="@+id/divider"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/divider"/>

<TextView
android:id="@android:id/text"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?android:attr/selectableItemBackground"
android:gravity="center_vertical"
android:textAppearance="?attr/textAppearanceListItemSmall"/>

解决方案 3 ==> 您可以为特定 Activity 制作自定义主题

<style name="CustomTheme" parent="android:Theme.Holo.Light">
<item name="android:actionBarStyle">@style/ActionBar</item></style>


<style name="ActionBar"parent="android:style/Widget.Holo.Light.ActionBar">
<item name="android:background">@color/action_bar_background</item>
<item name="android:showDividers">beginning</item>
<item name="android:divider">@color/action_bar_divider</item></style>

解决方案 4==> 可以为 DropdownlistView 自定义 View

<style name="PopupMenuListView" parent="@style/Widget.AppCompat.ListView.DropDown">
<item name="android:divider">#000000</item>
<item name="android:dividerHeight">1dp</item>
</style>
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">


<item name="android:dropDownListViewStyle">@style/PopupMenuListView</item></style>

你可以引用这个链接add divider in menu item

关于android - 选项菜单,选项之间有线条。就像菜单中显示的选项之间的分隔线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38494892/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com