ToolBar MenuItem 中 BadgeDrawable 的 LiveData 更新

Ode*_*rik 5 android badge android-toolbar material-components-android

我想在工具栏操作上显示徽章。徽章编号由值更新LiveData

这就是我附加徽章的方式:

BadgeUtils.attachBadgeDrawable(inboxBadgeDrawable, toolbar, R.id.menu_inbox);
Run Code Online (Sandbox Code Playgroud)

我尝试了不同的地方进行该调用,包括Activity.onCreateOptionsMenu()Activity.onPrepareOptionsMenu()androidx.lifgecycle.Observer.onChanged()

当任何内容发生变化(工具栏或徽章内容)时,徽章就会错位,向左移动。或者它被复制到另一个动作中。

我想attachBadgeDrawable尝试找到R.id.menu_inbox工具栏内部的容器视图,插入徽章并更新其偏移量。如果菜单项的容器视图发生更改,旧的容器视图仍然具有旧的徽章,并且没有(明智的)方法将其删除。此外,偏移量的应用似乎是堆叠的。

那么,是否还有其他使用BadgeDrawable工具栏操作图标的预期方式?

据我了解,此功能仍处于实验阶段。这个问题会得到解决吗?如果是,大约需要多长时间?(我com.google.android.material:material:1.3.0-beta01现在就用。)

这个问题主要是针对组件的开发人员的,因为使用问题应该根据https://github.com/material-components/material-components-android在这里提出。

编辑:我还在项目的跟踪器上创建了一个问题(功能请求):https ://github.com/material-components/material-components-android/issues/1967

Var*_*ina 3

我不确定这是否是官方解决方案,但这仍然是一种解决方法。我最终将BadgeDrawable每个菜单项都分离了onPrepareOptionsMenu,以防菜单项被更改或重新排列

// This is an indicator of whether we need to show the badge or not
private var isFilterOn: Boolean = false

private var filterBadge: BadgeDrawable? = null

@SuppressLint("UnsafeExperimentalUsageError")
override fun onPrepareOptionsMenu(menu: Menu) {
    super.onPrepareOptionsMenu(menu)

    val filterItem = menu.findItem(R.id.action_filter)
    val toolbar = requireActivity().findViewById<Toolbar>(R.id.toolbar)

    if(filterBadge != null) {
        BadgeUtils.detachBadgeDrawable(filterBadge!!, toolbar, R.id.action_filter)
        filterBadge = null
    }

    if(isFilterOn) {
        filterBadge = BadgeDrawable.create(requireContext()).also {
            BadgeUtils.attachBadgeDrawable(it, toolbar, R.id.action_filter)
        }
    }
}
Run Code Online (Sandbox Code Playgroud)