Android 给应用程序的icon添加未读消息个数提示(红圈内数字)

最近在做一个可以查看未读消息的功能,需要在界面中的Tab页的标签icon的右上角添加一个未读消息提示的功能。

先上个效果图出来,比较直观明白需求:

思路上似乎有两种:

1. 直接把底图和红圆圈的图片用相对布局进行排列,在代码中动态更改红圆中的TextView的数字,并且识别一下各种情况下红圆的显示或者隐藏。这种方法比较直观。

2. 采用canvas画出圆和数字。

由于项目采用的是Tab页的形式,其中的RadioButton不适合采用相对布局。故我采用了第二种方式。将绘制的过程写成了工具方法。在需要的时候调用。便于以后的技术迁移。

直接上代码:

/** * 绘制图标右上角的未读消息数量显示 * * @param context * 上下文 * @param icon * 需要被添加的icon的资源ID * @param news * 未读的消息数量 * @return drawable */ @SuppressWarnings("unused") public static Drawable displayNewsNumber(Context context, int icon, int news) { // 初始化画布 int iconSize = (int) context.getResources().getDimension( android.R.dimen.app_icon_size); // Bitmap contactIcon = Bitmap.createBitmap(iconSize, iconSize, // Config.ARGB_8888); Bitmap iconBitmap = BitmapFactory.decodeResource( context.getResources(), icon); Canvas canvas = new Canvas(iconBitmap); // 拷贝图片 Paint iconPaint = new Paint(); iconPaint.setDither(true);// 防抖动 iconPaint.setFilterBitmap(true);// 用来对Bitmap进行滤波处理 Rect src = new Rect(0, 0, iconBitmap.getWidth(), iconBitmap.getHeight()); Rect dst = new Rect(0, 0, iconBitmap.getWidth(), iconBitmap.getHeight()); canvas.drawBitmap(iconBitmap, src, dst, iconPaint); // 启用抗锯齿和使用设备的文本字距 Paint countPaint = new Paint(Paint.ANTI_ALIAS_FLAG | Paint.DEV_KERN_TEXT_FLAG); countPaint.setColor(Color.RED); canvas.drawCircle(iconSize - 13, 20, 10, countPaint); Paint textPaint = new Paint(); textPaint.setColor(Color.WHITE); // textPaint.setTypeface(Typeface.DEFAULT_BOLD); textPaint.setTextSize(19f); canvas.drawText(String.valueOf(news), iconSize - 18, 27, textPaint); return new BitmapDrawable(iconBitmap); }

调用语句:

if (count > 0) {//显示右上角未读消息提示 Drawable mineDrawable = BitmapUtil.displayNewsNumber(this, R.drawable.icon_mine, count); mineButton.setCompoundDrawablesWithIntrinsicBounds(null, null, null, mineDrawable);//这里就是设置背景,自行发挥。 } else {//隐藏 Drawable defaultDrawable = getResources().getDrawable( R.drawable.icon_mine); mineButton.setCompoundDrawablesWithIntrinsicBounds(null, null, null, defaultDrawable); }

注:

1.count是未读消息的数量。

2.setCompoundDrawablesWithIntrinsicBounds(Drawable left, Drawable top, Drawable right, Drawable bottom)可以在上、下、左、右设置图标,如果不想在某个地方显示,则设置为null。图标的宽高将会设置为固有宽高,既自动通过getIntrinsicWidth和getIntrinsicHeight获取。该方法是和在xml中设置 Android:drawableTop="@drawable/icon_mine"的效果一样。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持脚本之家!

时间: 2024-09-12 17:00:12

Android 给应用程序的icon添加未读消息个数提示(红圈内数字)的相关文章

iOS 如何获取我的所有好友列表 还有相对的未读消息个数 及最后一条聊天信息

问题描述 iOS  如何获取我的所有好友列表 还有相对的未读消息个数 及最后一条聊天信息 解决方案 获取好友列表:http://docs.easemob.com/doku.php?id=start:300iosclientintegration:90buddymgmt#获取好友列表获取未读消息数:- (EMConversation *)conversationForChatter:(NSString *)chatter                          conversationT

Android仿微信底部菜单栏功能显示未读消息数量_Android

底部菜单栏很重要,我看了一下很多应用软件都是用了底部菜单栏,这里使用了tabhost做了一种通用的(就是可以像微信那样显示未读消息数量的,虽然之前也做过但是layout下的xml写的太臃肿,这里去掉了很多不必要的层,个人看起来还是不错的,所以贴出来方便以后使用). 先看一下做出来之后的效果: 以后使用的时候就可以换成自己项目的图片和字体了,主框架不用变哈哈, 首先是要布局layout下xml文件 main.xml: <?xml version="1.0" encoding=&qu

未读消息个数

问题描述 我集成了easeui 3.0的demo,对于未读消息,如果是别人发起的会话,则是会显示未读消息的,但如果我保留未读消息,关掉程序在开,则没有未读消息.跟踪之后发现,本地数据库是由未读消息的.但NSArray *conversations = [[[EaseMob sharedInstance] chatManager] conversations];没数据,没有会话所以没有未读消息.但NSInteger unreadCount = [[[EaseMob sharedInstance]

我把环信demo移植到我的代码中,发送消息时真机给模拟器发,模拟器上应用图标有未读消息数提示,但是真机向另一台真机发应用图标上却没有消息数提示,为什么?

问题描述 急求 解决方案 你真机调试下,看看未读数回调和未读数的统计走的都对不对.解决方案二:走的对,模拟器上也能显示,可是真机上无法显示解决方案三:你真机调着看了吗?该显示的未读数也是对的,但是就是UI不显示是么?解决方案四:这个应该是一样的啊,你再仔细看下代码,是不是哪里加了模拟器和真机的判断.解决方案五:楼主,问题解决了么?真机测试的时候需要添加另外的设置么?

Android 未读消息的红点显示

在很多APP里面,经常会看到未读消息的小红点,如下图: 这个功能用到的是一个控件,叫做BadgeView. BadgeView的用法很简单,直接把jar文件导入包中就可以使用,使用也很简单, badgeView = new BadgeView(this); //btn是控件 badgeView.setTargetView(btn); //设置相对位置 badgeView.setBadgeMargin(0, 5, 15, 0); //设置显示未读消息条数 badgeView.setBadgeCou

Android 桌面图标右上角显示未读消息数字

背景: 在Android原生系统中,众所周知不支持桌面图标显示未读消息提醒的数字,虽然第三方控件BadgeView可以实现应用内的数字提醒.但对于系统的图标,特别是app的logo图标很难实现数字标志,即使是绘图的方式不断修改,但这种方式天生弊端,实用性很差.但幸运的是,一些强大的手机厂商(小米,三星,索尼)提供了私有的API,但也带来了难度,API的不同就意味着代码量的增加和兼容性问题更加突出. 现在我们来看看他们是如何实现的: 实现原理: 首先我们要明白 并不是应用本身处理对启动图标进行修改

Android自定义控件:类QQ未读消息拖拽效果

QQ的未读消息,算是一个比较好玩的效果,趁着最近时间比较多,参考了网上的一些资料之后,本次实现一个仿照QQ未读消息的拖拽小红点: 首先我们从最基本的原理开始分析,看一张图: 这个图该怎么绘制呢?实际上我们这里是先绘制两个圆,然后将两个圆的切点通过贝塞尔曲线连接起来就达到这个效果了.至于贝塞尔曲线的概念,这里就不多做解释了,百度一下就知道了. 切点怎么算呢,这里我们稍微复习一些初中的数学知识.看了这个图之后,求出四个切点应该是轻而易举了. 现在思路已经很清晰了,按照我们的思路,开撸. 首先是我们计

Android贝塞尔曲线初步学习第二课 仿QQ未读消息气泡拖拽黏连效果

上一节初步了解了Android端的贝塞尔曲线,这一节就举个栗子练习一下,仿QQ未读消息气泡,是最经典的练习贝塞尔曲线的东东,效果如下 附上github源码地址:https://github.com/MonkeyMushroom/DragBubbleView 欢迎star~ 大体思路就是画两个圆,一个黏连小球固定在一个点上,一个气泡小球跟随手指的滑动改变坐标.随着两个圆间距越来越大,黏连小球半径越来越小.当间距小于一定值,松开手指气泡小球会恢复原来位置:当间距超过一定值之后,黏连小球消失,气泡小球

Android 端,首次登录或者退出重新登录时有提示音是为什么,也没有未读消息和其他的提示。

问题描述 Android 端,首次登录或者退出重新登录时有提示音是为什么,也没有未读消息和其他的提示.莫名奇妙的有提示音,重新注册账号也是如此,求大神赐教. 解决方案 没有遇到过你说的这种现象,你测试的是demo吗解决方案二:是的.修改了一些东西,不知道改了哪里的代码就这个样子了.解决方案三:检查代码,这也猜不出来,调试