【问题标题】:Navigation Drawer: How to change the colour of item category? [duplicate]Navigation Drawer:如何更改项目类别的颜色? [复制]
【发布时间】:2018-06-10 12:19:47
【问题描述】:

我创建了一个默认项目并尝试更改颜色。我成功地改变了除项目类别之外的所有颜色(本例中为“通信”)。怎么改?

activity_main

<android.support.design.widget.NavigationView
    android:id="@+id/nav_view"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    app:itemTextColor="@color/colorAccent"
    app:itemIconTint="@color/colorAccent"
    android:backgroundTint="@color/colorPrimaryDark"
    android:fitsSystemWindows="true"
    app:headerLayout="@layout/nav_header_main"
    app:menu="@menu/activity_main_drawer"/>

nav_header_main

<LinearLayout
    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="@dimen/nav_header_height"
    android:background="#FF0000"
    android:gravity="bottom"
    android:orientation="vertical"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    android:theme="@style/ThemeOverlay.AppCompat.Dark">

【问题讨论】:

  • 请发布您的完整 activity_main 和 nav_header_main 以及您的风格。
  • 链接的问题及其答案是关于更改项目颜色,而不是类别颜色,但 an answer 解释了如何做到这一点。它正在使用样式更改android:textColorSecondary

标签: android android-layout navigation-drawer


【解决方案1】:

试试这个

创建一个这样的主题

<style name="MyTheme">
    <item name="android:textColor">#0000ff</item>
</style>

比让你的菜单像这样

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

    <group android:checkableBehavior="single">
        <item
            android:id="@+id/nav_camera"
            android:icon="@drawable/ic_menu_camera"
            android:title="Import" />
        <item
            android:id="@+id/nav_gallery"
            android:icon="@drawable/ic_menu_gallery"
            android:title="Gallery" />
        <item
            android:id="@+id/nav_slideshow"
            android:icon="@drawable/ic_menu_slideshow"
            android:title="Slideshow" />
        <item
            android:id="@+id/nav_manage"
            android:icon="@drawable/ic_menu_manage"
            android:title="Tools" />
    </group>

    <item android:title="Communicate"
        android:id="@+id/communicate">
        <menu>
            <item
                android:id="@+id/nav_share"
                android:icon="@drawable/ic_menu_share"
                android:title="Share" />
            <item
                android:id="@+id/nav_send"
                android:icon="@drawable/ic_menu_send"
                android:title="Send" />
        </menu>
    </item>


</menu>

比Java代码

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main3);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();
            }
        });

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

        NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
        navigationView.setNavigationItemSelectedListener(this);


        // code for changes colour of Communicate
        Menu myMenu = navigationView.getMenu();    
        MenuItem tools= myMenu.findItem(R.id.communicate);
        SpannableString s = new SpannableString(tools.getTitle());
        s.setSpan(new TextAppearanceSpan(this, R.style.MyTheme), 0, s.length(), 0);
        tools.setTitle(s);
        navigationView.setNavigationItemSelectedListener(this);
    }

导航视图

<android.support.design.widget.NavigationView
    android:id="@+id/nav_view"
    android:layout_width="wrap_content"
    android:layout_height="match_parent"
    android:layout_gravity="start"
    app:itemTextColor="@android:color/holo_orange_light"
    android:fitsSystemWindows="true"
    app:headerLayout="@layout/nav_header_main3"
    app:menu="@menu/activity_main3_drawer" />

输出

【讨论】:

  • 你的答案是否改变了“沟通”的颜色?代码太长,我很容易判断是不是。
  • @DamnVegetables 是的,它会改变 Communicate 的颜色
  • @DamnVegetables 你看到输出图片了吗
  • 是的,我确实看到了图片,但我不确定“通信”的颜色是默认颜色还是更改颜色。无论如何,我将您的答案标记为解决方案。
  • @DamnVegetables 很乐意帮助您在我的设备上正常工作
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-11-26
  • 1970-01-01
相关资源
最近更新 更多