黑暗工具栏上的灯光动作模式

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

我正在尝试在黑暗的工具栏上显示灯光动作模式(白色背景,黑色文本,黑色图标)(通过原色,白色文本,白色图标自定义彩色背景)。

这是我的活动布局中我的Toolbar的定义:

<android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/activity_press_toolbar_background"
        android:theme="@style/AppTheme.MainToolbar"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>

这是提到的AppTheme.MainToolbar

<style name="AppTheme.MainToolbar" parent="@style/ThemeOverlay.AppCompat.ActionBar"/>

使用这些样式定义,一切都像我想要的那样,除了“默认”工具栏(非动作模式)上的溢出图标,它是黑色而不是白色。如果我从@style/ThemeOverlay.AppCompat.Dark.ActionBar继承Toolbar主题,溢出是白色的,但动作模式也变暗:深灰色背景,白色文字和图标。

我尝试在动作模式样式中重新定义几乎所有内容:

<style name="AppTheme.ActionMode" parent="Widget.AppCompat.ActionMode">
    <item name="background">@android:color/white</item>
    <item name="android:titleTextStyle">@style/AppTheme.ActionMode.Title</item>
    <item name="titleTextStyle">@style/AppTheme.ActionMode.Title</item>
    <item name="actionOverflowButtonStyle">@style/AppTheme.ActionMode.Overflow</item>
    <item name="android:actionOverflowButtonStyle">@style/AppTheme.ActionMode.Overflow</item>
</style>

<style name="AppTheme.ActionMode.Title" parent="TextAppearance.Widget.AppCompat.Toolbar.Title">
    <item name="android:textColor">@android:color/black</item>
</style>

<style name="AppTheme.ActionMode.Overflow" parent="Widget.AppCompat.ActionButton.Overflow">
    <item name="android:tint">#000000</item>
</style>

我在我的主要风格中使用了这种ActionMode风格:

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
    <!-- ... -->
    <item name="actionModeStyle">@style/AppTheme.ActionMode</item>
    <item name="android:actionModeStyle">@style/AppTheme.ActionMode</item>
</style>

一切正常......除了溢出的颜色。在动作模式中,它是白色的(白色,所以......)。如果我在主要样式上设置actionOverflowButtonStyle属性,溢出会正确着色 - 但在整个应用程序中,包括动作模式。

重新定义整个风格听起来不对 - 并且无论如何都不起作用,至少对于溢出来说。但我找不到在暗动作条上定义灯光动作模式的方法。有没有办法这样做?

android android-toolbar android-styles android-actionmode
1个回答
0
投票

这是解决这个问题的方法,但我确信有更好的方法。如果您有更好的解决方案,请发布。如果您没有并且遇到同样的问题,请随意使用它,但要注意它依赖于支持库固有的溢出按钮和内容描述的实现。它适用于v26,它可能不适用于其他版本。更新支持库时,请检查此项。

private static void setOverflowButtonColor(@ColorRes final int color, @NonNull final Activity activity) {
    final String contentDescription = activity.getResources().getString(R.string.abc_action_menu_overflow_description);
    final ViewGroup decorView = (ViewGroup) activity.getWindow().getDecorView();
    decorView.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
        @Override
        public void onGlobalLayout() {
            final ArrayList outViews = new ArrayList(1);
            decorView.findViewsWithText(outViews, contentDescription, View.FIND_VIEWS_WITH_CONTENT_DESCRIPTION);
            if (!outViews.isEmpty()) {
                if (outViews.get(0) instanceof AppCompatImageView) {
                ((AppCompatImageView) outViews.get(0)).setColorFilter(ContextCompat.getColor(activity, color));
                decorView.getViewTreeObserver().removeOnGlobalLayoutListener(this);
                }
            }
        }
    });
}
© www.soinside.com 2019 - 2024. All rights reserved.