像Google一样的操作栏通知计数图标(徽章)


146

是否有一个android标准徽章或方法来显示带有类似Google例子中的计数的操作栏通知图标?

在图片上数3

如果没有,那么最好的方法是什么?
我是android新手,请帮忙。


我已经更新了答案,以链接到完整的通知图标实现。
pqn

Answers:


228

我不确定这是否是最佳解决方案,但这正是我所需要的。

请告诉我您是否需要更改以获得更好的性能或质量。就我而言,我有一个按钮。

我的菜单上的自定义项目-main.xml

<item
    android:id="@+id/badge"
    android:actionLayout="@layout/feed_update_count"
    android:icon="@drawable/shape_notification"
    android:showAsAction="always">
</item>

自定义形状可绘制(背景正方形)-shape_notification.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
   android:shape="rectangle">
    <stroke android:color="#22000000" android:width="2dp"/>
    <corners android:radius="5dp" />
    <solid android:color="#CC0001"/>
</shape>

我的视图的布局-feed_update_count.xml

<?xml version="1.0" encoding="utf-8"?>
<Button xmlns:android="http://schemas.android.com/apk/res/android"
     android:id="@+id/notif_count"
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:minWidth="32dp"
     android:minHeight="32dp"
     android:background="@drawable/shape_notification"
     android:text="0"
     android:textSize="16sp"
     android:textColor="@android:color/white"
     android:gravity="center"
     android:padding="2dp"
     android:singleLine="true">    
</Button>

MainActivity-设置和更新我的视图

static Button notifCount;
static int mNotifCount = 0;    

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    MenuInflater inflater = getSupportMenuInflater();
    inflater.inflate(R.menu.main, menu);

    View count = menu.findItem(R.id.badge).getActionView();
    notifCount = (Button) count.findViewById(R.id.notif_count);
    notifCount.setText(String.valueOf(mNotifCount));
    return super.onCreateOptionsMenu(menu);
}

private void setNotifCount(int count){
    mNotifCount = count;
    invalidateOptionsMenu();
}

53
这很棒 !但是,如果您使用AppCompat,则应在代码中设置ActionLayout:MenuItem item = menu.findItem(R.id.badge); MenuItemCompat.setActionView(item, R.layout.feed_update_count); notifCount = (Button) MenuItemCompat.getActionView(item);
Sylphe 2013年

7
如果您的目标API级别低于11,则需要使用supportInvalidateOptionsMenu()而不是invalidateOptionsMenu()
Balaji 2013年

10
+1帮助很大!但是:您不需要android:icon="..."菜单项XML中的。在android:actionLayout="..."有足够。对于Button布局XML,您可以使用自动关闭标签,<Button ... />因为该标签不能包含内容。您需要关闭<shape>标签(再次:自动关闭)。而且您不需要invalidateOptionsMenu()。对我来说,这甚至是行不通的,因为徽章总是会再次从XML膨胀。因此,整体setNotifCount(...)是没有用的。只需拨打setText(...)徽章即可。您可以直接投射getActionView()Button
2014年

4
另外,如果您使用AppCompat,则应更改徽章xml菜单<menu xmlns:android =“ schemas.android.com/apk/res/android ” xmlns:appcompat =“ schemas.android.com/apk/res-auto ”> <item android:id =“ @ + id / badge” android:actionLayout =“ @ layout / feed_update_count” android:icon =“ @ drawable / shape_notification” appcompat:showAsAction =“ always” /> </ item> </ menu>
ajdeguzman 2014年

4
@Webster notifCount.setOnClickListener(...); 全部都在里面
AndrewS

132

编辑从支持库(或androidx)的26版开始,您不再需要实现自定义OnLongClickListener来显示工具提示。只需调用:

TooltipCompat.setTooltipText(menu_hotlist, getString(R.string.hint_show_hot_message));

我只是分享我的代码,以防有人想要这样的东西: 在此处输入图片说明

  • 布局/菜单/menu_actionbar.xml

    <?xml version="1.0" encoding="utf-8"?>
    
    <menu xmlns:android="http://schemas.android.com/apk/res/android">
        ...
        <item android:id="@+id/menu_hotlist"
            android:actionLayout="@layout/action_bar_notifitcation_icon"
            android:showAsAction="always"
            android:icon="@drawable/ic_bell"
            android:title="@string/hotlist" />
        ...
    </menu>
  • 布局/action_bar_notifitcation_icon.xml

    注意样式android:clickable属性。这些使布局的大小与按钮的大小相同,并且在触摸时使背景变为灰色。

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="wrap_content"
        android:layout_height="fill_parent"
        android:orientation="vertical"
        android:gravity="center"
        android:layout_gravity="center"
        android:clickable="true"
        style="@android:style/Widget.ActionButton">
    
        <ImageView
            android:id="@+id/hotlist_bell"
            android:src="@drawable/ic_bell"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:layout_margin="0dp"
            android:contentDescription="bell"
            />
    
        <TextView xmlns:android="http://schemas.android.com/apk/res/android"
            android:id="@+id/hotlist_hot"
            android:layout_width="wrap_content"
            android:minWidth="17sp"
            android:textSize="12sp"
            android:textColor="#ffffffff"
            android:layout_height="wrap_content"
            android:gravity="center"
            android:text="@null"
            android:layout_alignTop="@id/hotlist_bell"
            android:layout_alignRight="@id/hotlist_bell"
            android:layout_marginRight="0dp"
            android:layout_marginTop="3dp"
            android:paddingBottom="1dp"
            android:paddingRight="4dp"
            android:paddingLeft="4dp"
            android:background="@drawable/rounded_square"/>
    </RelativeLayout>
  • drawable-xhdpi / ic_bell.png

    一个64x64像素的图像,从所有侧面起都有10像素宽的填充。您应该具有8像素宽的填充,但是我发现大多数默认项都比该填充项略小。当然,您需要针对不同的密度使用不同的大小。

  • drawable / rounded_square.xml

    在这里,#ff222222(带有Alpha #ff的颜色#222222(完全可见))是我的操作栏的背景颜色。

    <?xml version="1.0" encoding="utf-8"?>
    
    <shape
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:shape="rectangle">
        <corners android:radius="2dp" />
        <solid android:color="#ffff0000" />
        <stroke android:color="#ff222222" android:width="2dp"/>
    </shape>
  • com / ubergeek42 / WeechatAndroid / WeechatActivity.java

    在这里,我们使其可点击和可更新!我创建了一个抽象侦听器,该侦听器在onLongClick上提供了Toast的创建,该代码来自ActionBarSherlock的源代码。

    private int hot_number = 0;
    private TextView ui_hot = null;
    
    @Override public boolean onCreateOptionsMenu(final Menu menu) {
        MenuInflater menuInflater = getSupportMenuInflater();
        menuInflater.inflate(R.menu.menu_actionbar, menu);
        final View menu_hotlist = menu.findItem(R.id.menu_hotlist).getActionView();
        ui_hot = (TextView) menu_hotlist.findViewById(R.id.hotlist_hot);
        updateHotCount(hot_number);
        new MyMenuItemStuffListener(menu_hotlist, "Show hot message") {
            @Override
            public void onClick(View v) {
                onHotlistSelected();
            }
        };
        return super.onCreateOptionsMenu(menu);
    }
    
    // call the updating code on the main thread,
    // so we can call this asynchronously
    public void updateHotCount(final int new_hot_number) {
        hot_number = new_hot_number;
        if (ui_hot == null) return;
        runOnUiThread(new Runnable() {
            @Override
            public void run() {
                if (new_hot_number == 0)
                    ui_hot.setVisibility(View.INVISIBLE);
                else {
                    ui_hot.setVisibility(View.VISIBLE);
                    ui_hot.setText(Integer.toString(new_hot_number));
                }
            }
        });
    }
    
    static abstract class MyMenuItemStuffListener implements View.OnClickListener, View.OnLongClickListener {
        private String hint;
        private View view;
    
        MyMenuItemStuffListener(View view, String hint) {
            this.view = view;
            this.hint = hint;
            view.setOnClickListener(this);
            view.setOnLongClickListener(this);
        }
    
        @Override abstract public void onClick(View v);
    
        @Override public boolean onLongClick(View v) {
            final int[] screenPos = new int[2];
            final Rect displayFrame = new Rect();
            view.getLocationOnScreen(screenPos);
            view.getWindowVisibleDisplayFrame(displayFrame);
            final Context context = view.getContext();
            final int width = view.getWidth();
            final int height = view.getHeight();
            final int midy = screenPos[1] + height / 2;
            final int screenWidth = context.getResources().getDisplayMetrics().widthPixels;
            Toast cheatSheet = Toast.makeText(context, hint, Toast.LENGTH_SHORT);
            if (midy < displayFrame.height()) {
                cheatSheet.setGravity(Gravity.TOP | Gravity.RIGHT,
                        screenWidth - screenPos[0] - width / 2, height);
            } else {
                cheatSheet.setGravity(Gravity.BOTTOM | Gravity.CENTER_HORIZONTAL, 0, height);
            }
            cheatSheet.show();
            return true;
        }
    }

14
非常有用且具有描述性。谢谢!那才是我真正需要的。只是添加一些可能有用的主题。你已经把app:actionLayout="@layout/action_bar_notifitcation_icon"替代android:actionLayout="@layout/action_bar_notifitcation_icon",如果你已经使用MenuItemCompat.getActionView替代的menu.findItem(R.id.menu_hotlist).getActionView();兼容性问题。MenuItem.getActionView不与API级别<11兼容
雷阿兹穆尔希德

注意样式和android:clickable属性。这些使布局的大小与按钮的大小相同,并使选定的背景在触摸时变为彩色。很有用!
大卫

2
它就像一个魅力。特纳克斯兄弟 但就我而言,我使用默认工具栏,而应使用“ app:actionLayout =” @ layout / action_bar_notifitcation_icon“代替,否则我始终会为null。tnx
Omid Heshmatinia

3
提示,Android有一个可绘制的通知。因此,无需创建自定义形状,您可以将TextView的背景设置为@android:drawable / ic_notification_overlay“
。– androidevil

2
本机:android:actionLayout; AppCompat:app:actionLayout在菜单项中。
Benoit Duffez

61

只是添加。如果有人想要实现实心圆气泡,请在此处添加代码(将其命名为bage_circle.xml):

<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="ring"
    android:useLevel="false"
    android:thickness="9dp"
    android:innerRadius="0dp"
    >

    <solid
        android:color="#F00"
        />
    <stroke
        android:width="1dip"
        android:color="#FFF" />

    <padding
        android:top="2dp"
        android:bottom="2dp"/>

</shape>

您可能需要根据需要调整厚度。

在此处输入图片说明

编辑: 这是按钮的布局(命名为badge_layout.xml):

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content">

    <com.joanzapata.iconify.widget.IconButton
        android:layout_width="44dp"
        android:layout_height="44dp"
        android:textSize="24sp"
        android:textColor="@color/white"
        android:background="@drawable/action_bar_icon_bg"
        android:id="@+id/badge_icon_button"/>

    <TextView
        android:id="@+id/badge_textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignTop="@id/badge_icon_button"
        android:layout_alignRight="@id/badge_icon_button"
        android:layout_alignEnd="@id/badge_icon_button"
        android:text="10"
        android:paddingEnd="8dp"
        android:paddingRight="8dp"
        android:paddingLeft="8dp"
        android:gravity="center"
        android:textColor="#FFF"
        android:textSize="11sp"
        android:background="@drawable/badge_circle"/>
</RelativeLayout>

在菜单中创建项目:

<item
        android:id="@+id/menu_messages"
        android:showAsAction="always"
        android:actionLayout="@layout/badge_layout"/>

为了onCreateOptionsMenu获得对菜单项的引用:

    itemMessages = menu.findItem(R.id.menu_messages);

    badgeLayout = (RelativeLayout) itemMessages.getActionView();
    itemMessagesBadgeTextView = (TextView) badgeLayout.findViewById(R.id.badge_textView);
    itemMessagesBadgeTextView.setVisibility(View.GONE); // initially hidden

    iconButtonMessages = (IconButton) badgeLayout.findViewById(R.id.badge_icon_button);
    iconButtonMessages.setText("{fa-envelope}");
    iconButtonMessages.setTextColor(getResources().getColor(R.color.action_bar_icon_color_disabled));

    iconButtonMessages.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            if (HJSession.getSession().getSessionId() != null) {

                Intent intent = new Intent(getThis(), HJActivityMessagesContexts.class);
                startActivityForResult(intent, HJRequestCodes.kHJRequestCodeActivityMessages.ordinal());
            } else {
                showLoginActivity();
            }
        }
    });

收到消息通知后,设置计数:

itemMessagesBadgeTextView.setText("" + count);
itemMessagesBadgeTextView.setVisibility(View.VISIBLE);
iconButtonMessages.setTextColor(getResources().getColor(R.color.white));

此代码使用Iconify-fontawesome

compile 'com.joanzapata.iconify:android-iconify-fontawesome:2.1.+'

10
您能否提供上述操作栏的代码。看起来不错。
Nitesh Kumar 2014年

您能再详细一点吗?一些代码将非常有用
Joaquin Iurchuk '16

@NiteshKhatri很抱歉提供代码太晚了。我认为这很容易。但是您的评论获得了很多好评,这意味着其他开发人员也感到困难。
阿卜杜拉·乌默尔

1
iconify是一个伟大的库!
djdance,2013年

很好,但是数字,文本出现在圆中间(半径)的左侧。如何解决
Farruh Habibullaev'4

29

我不喜欢ActionView基于解决方案的解决方案,我的想法是:

  1. 使用创建一个布局TextView,该布局TextView将由应用填充
  2. 当您需要绘制时MenuItem

    2.1。膨胀布局

    2.2。呼叫measure()layout()(否则view将为0px x 0px,对于大多数使用情况来说太小了)

    2.3。设定TextView的文字

    2.4。对视图进行“截屏”

    2.6。MenuItem根据在2.4上创建的位图设置set 的图标

  3. 利润!

所以结果应该是 在此处输入图片说明

  1. 在这里创建布局是一个简单的示例
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/counterPanel"
    android:layout_width="32dp"
    android:layout_height="32dp"
    android:background="@drawable/ic_menu_gallery">
    <RelativeLayout
        android:id="@+id/counterValuePanel"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" >

        <ImageView
            android:id="@+id/counterBackground"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:background="@drawable/unread_background" />

        <TextView
            android:id="@+id/count"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="1"
            android:textSize="8sp"
            android:layout_centerInParent="true"
            android:textColor="#FFFFFF" />
    </RelativeLayout>
</FrameLayout>

@drawable/unread_background是绿色TextView的背景, @drawable/ic_menu_gallery在这里并不需要,只是在IDE中预览布局的结果。

  1. 将代码添加到onCreateOptionsMenu/onPrepareOptionsMenu

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu_main, menu);
    
        MenuItem menuItem = menu.findItem(R.id.testAction);
        menuItem.setIcon(buildCounterDrawable(count, R.drawable.ic_menu_gallery));
    
        return true;
    }
  2. 实现图标构建方法:

    private Drawable buildCounterDrawable(int count, int backgroundImageId) {
        LayoutInflater inflater = LayoutInflater.from(this);
        View view = inflater.inflate(R.layout.counter_menuitem_layout, null);
        view.setBackgroundResource(backgroundImageId);
    
        if (count == 0) {
            View counterTextPanel = view.findViewById(R.id.counterValuePanel);
            counterTextPanel.setVisibility(View.GONE);
        } else {
            TextView textView = (TextView) view.findViewById(R.id.count);
            textView.setText("" + count);
        }
    
        view.measure(
                View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED),
                View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED));
        view.layout(0, 0, view.getMeasuredWidth(), view.getMeasuredHeight());
    
        view.setDrawingCacheEnabled(true);
        view.setDrawingCacheQuality(View.DRAWING_CACHE_QUALITY_HIGH);
        Bitmap bitmap = Bitmap.createBitmap(view.getDrawingCache());
        view.setDrawingCacheEnabled(false);
    
        return new BitmapDrawable(getResources(), bitmap);
    }

完整的代码在这里:https : //github.com/cvoronin/ActionBarMenuItemCounter


1
camelCaseCoder,当您想将计数器图像的位置更改为右上角时,例如,可以将android:layout_gravity =“ top | right”添加到counterValuePanel的布局属性中
cVoronin

了解为什么您不喜欢基于动作视图的解决方案将对您有所帮助。是复杂性还是性能?
阿迪

26

好的,要让@AndrewS解决方案与v7 appCompat库一起使用

<menu 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:someNamespace="http://schemas.android.com/apk/res-auto" >

    <item
        android:id="@+id/saved_badge"
        someNamespace:showAsAction="always"
        android:icon="@drawable/shape_notification" />

</menu>

@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
    super.onCreateOptionsMenu(menu, inflater);
    menu.clear();
    inflater.inflate(R.menu.main, menu);

    MenuItem item = menu.findItem(R.id.saved_badge);
    MenuItemCompat.setActionView(item, R.layout.feed_update_count);
    View view = MenuItemCompat.getActionView(item);
    notifCount = (Button)view.findViewById(R.id.notif_count);
    notifCount.setText(String.valueOf(mNotifCount));
}

private void setNotifCount(int count){
    mNotifCount = count;
    supportInvalidateOptionsMenu();
}

其余代码相同。


7
如果您在xml布局中使用xmlns:app =“ schemas.android.com/apk/res-auto ”,请使用app:actionLayout =“ @ layout / shoppingcar_icon”代替android:actionLayout =“ @ layout / shoppingcar_icon”
Oscar Calderon 2015年

3
@OscarCalderon,是的。在获得NPE之前,更改android:actionLayout为NPE后,app:actionLayout它就像魅力一样工作。
Shashanth '16

3

尝试查看这些问题的答案,尤其是第二个具有示例代码的答案:

如何在Android中的菜单项上实现动态值

如何在ActionBar图标上获取文本?

据我所知,您将需要创建自己的自定义ActionView实现。另一种可能是自定义Drawable。请注意,似乎没有针对操作栏的通知计数的本机实现。

编辑:您正在寻找的答案,与代码:具有示例实现的自定义通知视图


tnx进行回复,但我不知道如何显示数字,而不是第一个链接上的图标。你能帮忙吗?
AndrewS

您阅读其他链接了吗?他们提供了一些选择。另外,你可以把文字Drawable:如被看见在以下两个链接小号stackoverflow.com/questions/6691818/...stackoverflow.com/questions/3972445/...
pqn

我对您的答案越来越了解...我有这段代码<layer-list xmlns:android =“ schemas.android.com/apk/res/android ”> <item android:drawable =“ @ drawable / shape_notification “ /> <item android:drawable =” @ drawable / ic_menu_preferences“ /> </ layer-list>,我需要用具有文本的drawable替换图标(ic_menu_preferences)。我怎样才能做到这一点?
AndrewS 2013年

我对此没有太多经验,但是我相信您可以Drawable通过类似于此处链接的内容为创建自定义XML属性,然后为自定义属性创建一个上面Drawable带有文本的属性,以便您可以创建整个内容以XML格式并按您的意愿进行调整。或者,如果太难了,可以用Java添加Drawable。
2013年

3

使用工具栏时:

....
private void InitToolbar() {
    toolbar = (Toolbar) findViewById(R.id.my_awesome_toolbar);
    toolbartitle = (TextView) findViewById(R.id.titletool);
    toolbar.inflateMenu(R.menu.show_post);
    toolbar.setOnMenuItemClickListener(this);
    Menu menu = toolbar.getMenu();
    MenuItem menu_comments = menu.findItem(R.id.action_comments);
    MenuItemCompat
            .setActionView(menu_comments, R.layout.menu_commentscount);
    View v = MenuItemCompat.getActionView(menu_comments);
    v.setOnClickListener(new OnClickListener() {

        @Override
        public void onClick(View arg0) {
            // Your Action
        }
    });
    comment_count = (TextView) v.findViewById(R.id.count);
}

并在您的加载数据中调用refreshMenu():

private void refreshMenu() {
    comment_count.setVisibility(View.VISIBLE);
    comment_count.setText("" + post_data.getComment_count());
}

1

我在这里找到了一个很好的解决方案,将其与kotlin一起使用。

首先,必须在drawable文件夹中创建item_count.xml

<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<corners android:radius="8dp" />
<solid android:color="#f20000" />
<stroke
    android:width="2dip"
    android:color="#FFF" />
<padding
    android:bottom="5dp"
    android:left="5dp"
    android:right="5dp"
    android:top="5dp" />
</shape>

在您的Activity_Main布局中,例如:

<RelativeLayout
                    android:id="@+id/badgeLayout"
                    android:layout_width="40dp"
                    android:layout_height="40dp"
                    android:layout_toRightOf="@+id/badge_layout1"
                    android:layout_gravity="end|center_vertical"
                    android:layout_marginEnd="5dp">

                <RelativeLayout
                        android:id="@+id/relative_layout1"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content">

                    <Button
                            android:id="@+id/btnBadge"
                            android:layout_width="match_parent"
                            android:layout_height="match_parent"
                            android:background="@mipmap/ic_notification" />

                </RelativeLayout>

                <TextView
                        android:id="@+id/txtBadge"
                        android:layout_width="18dp"
                        android:layout_height="18dp"
                        android:layout_alignRight="@id/relative_layout1"
                        android:background="@drawable/item_count"
                        android:text="22"
                        android:textColor="#FFF"
                        android:textSize="7sp"
                        android:textStyle="bold"
                        android:gravity="center"/>

            </RelativeLayout>

您可以像这样修改:

btnBadge.setOnClickListener { view ->
        Snackbar.make(view,"badge click", Snackbar.LENGTH_LONG) .setAction("Action", null).show()
        txtBadge.text = "0"
    }

0

我找到了更好的方法。如果你想使用这样的东西

在此处输入图片说明

使用此依赖

   compile 'com.nex3z:notification-badge:0.1.0'

在drawable中创建一个xml文件并将其另存为Badge.xml

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

<item>
    <shape android:shape="oval">
        <solid android:color="#66000000"/>
        <size android:width="30dp" android:height="40dp"/>
    </shape>
</item>
<item android:bottom="1dp" android:right="0.6dp">
    <shape android:shape="oval">
        <solid android:color="@color/Error_color"/>
        <size android:width="20dp" android:height="20dp"/>
    </shape>
</item>
</layer-list>

现在,无论您想在哪个地方使用该徽章,都可以在xml中使用以下代码。借助此功能,您将能够在图片或任何其他内容的右上角看到该徽章。

  <com.nex3z.notificationbadge.NotificationBadge
    android:id="@+id/badge"
    android:layout_toRightOf="@id/Your_ICON/IMAGE"
    android:layout_alignTop="@id/Your_ICON/IMAGE"
    android:layout_marginLeft="-16dp"
    android:layout_marginTop="-8dp"
    android:layout_width="28dp"
    android:layout_height="28dp"
    app:badgeBackground="@drawable/Badge"
    app:maxTextLength="2"
    ></com.nex3z.notificationbadge.NotificationBadge>

现在,最后在yourFile.java上使用这2个简单的东西。1)定义

 NotificationBadge mBadge;

2)在您的循环或任何正在计算此数字的地方使用以下代码:

 mBadge.setNumber(your_LoopCount);

在这里, mBadge.setNumber(0)将不会显示任何内容。

希望能有所帮助。

By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.