Android中给图标加上数字(用于未接来电等等功能的提醒)

简介:
在我们开发一些如短消息、应用商店等应用时,会考虑在短消息的图标上加上未读短信的数量,在应用商店上加上可以升级的应用数量,这样不占太大空间还能达到提示的目的。

本节就以一个展示手机内联系人数量的例子来演示怎么在一个图标的上面加上数字的例子,也就是一个数字overlay..做过google map开发的知道overlay这个东西。

 一:你可学到

  1. 手机内依据Uri查看联系人
  2. 权限的添加
  3. 获取手机内任意一款应用的应用图标
  4. 对图形的处理,如复制,为图片加上覆盖层--数字。
  5. 使用RemoteView自定义Notification

二:开始行动

  1. 新建名为NotificationIconCount的Android Project。附件中有最终版本的项目工程
  2. 首先修改AndroidManifest.xml,加入权限<uses-permission android:name="android.permission.READ_CONTACTS"></uses-permission>,因为我们要读取联系人。
  3. 修改main.xml如下,这里定义一个ImageView,勇于预览我们处理好的加上数字的图标。
<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    >  
    <ImageView   
        android:id="@+id/icon"  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:scaleType="center"  
        android:adjustViewBounds="true"/>  
</LinearLayout>  

4.  先来获取手机内通讯录的图标,如果没有获取到,则使用该应用的图标.
super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
        mImageView=(ImageView)findViewById(R.id.icon);  
        //优先采用联系人的图标,如果不存在则采用该应用的图标  
        Drawable contactIcon;  
        try {  
            contactIcon = getPackageManager().getApplicationIcon("com.android.contacts");  
        } catch (NameNotFoundException e) {  
            contactIcon=null;  
        }  
        Bitmap icon;  
        if(contactIcon instanceof BitmapDrawable){  
            icon=((BitmapDrawable)contactIcon).getBitmap();  
        }else{  
            icon=getResIcon(getResources(), R.id.icon);  
        }  

这里用到一个自定义的根据资源图标id获取图片的函数,很简单,代码如下:
/** 
    * 根据id获取一个图片 
    * @param res 
    * @param resId 
    * @return 
    */  
   private Bitmap getResIcon(Resources res,int resId){  
    Drawable icon=res.getDrawable(resId);  
    if(icon instanceof BitmapDrawable){  
        BitmapDrawable bd=(BitmapDrawable)icon;  
        return bd.getBitmap();  
    }else{  
        return null;  
    }  
   }  
 5.  获取到图标之后就要对这个图标进行处理了,要为该图标加上联系人数量的覆盖,首先我们看获取联系人个数的函数。

/** 
     * 获取联系人的个数 
     * @return 手里通讯录中联系人的个数 
     */  
    private int getContactCount(){  
        Cursor c=getContentResolver().query(ContactsContract.Contacts.CONTENT_URI, new String[]{ContactsContract.Contacts._COUNT}, null, null, null);  
        try{  
            c.moveToFirst();  
            return c.getInt(0);  
        }catch(Exception e){  
            return 0;  
        }finally{  
            c.close();  
        }  
    }  

这里采用Uri的方式获取联系人的cursor,然后获取个数。

 6.  有了图标和联系人个数就可以生成带联系人个数的图标了,我们看下生成的这个函数。

/** 
     * 在给定的图片的右上角加上联系人数量。数量用红色表示 
     * @param icon 给定的图片 
     * @return 带联系人数量的图片 
     */  
    private Bitmap generatorContactCountIcon(Bitmap icon){  
        //初始化画布  
        int iconSize=(int)getResources().getDimension(android.R.dimen.app_icon_size);  
        Log.d(TAG, "the icon size is "+iconSize);  
        Bitmap contactIcon=Bitmap.createBitmap(iconSize, iconSize, Config.ARGB_8888);  
        Canvas canvas=new Canvas(contactIcon);  
          
        //拷贝图片  
        Paint iconPaint=new Paint();  
        iconPaint.setDither(true);//防抖动  
        iconPaint.setFilterBitmap(true);//用来对Bitmap进行滤波处理,这样,当你选择Drawable时,会有抗锯齿的效果  
        Rect src=new Rect(0, 0, icon.getWidth(), icon.getHeight());  
        Rect dst=new Rect(0, 0, iconSize, iconSize);  
        canvas.drawBitmap(icon, src, dst, iconPaint);  
          
        //在图片上创建一个覆盖的联系人个数  
        int contacyCount=getContactCount();  
        //启用抗锯齿和使用设备的文本字距  
        Paint countPaint=new Paint(Paint.ANTI_ALIAS_FLAG|Paint.DEV_KERN_TEXT_FLAG);  
        countPaint.setColor(Color.RED);  
        countPaint.setTextSize(20f);  
        countPaint.setTypeface(Typeface.DEFAULT_BOLD);  
        canvas.drawText(String.valueOf(contacyCount), iconSize-18, 25, countPaint);  
        return contactIcon;  
    }  

注释的很详细,就不解释了,无非就是定义一个画布(Canvas),然后在上面画图标,画数字文本。

7.  然后我们把得到的这个处理过的Bitmap放在我们在main.xml里定义的ImageView里展示就可以看到效果了.

mImageView.setImageBitmap(contactCountIcon); 

8.   我们启动应用看看效果.


 我们看到了,右上角红色的1代表我手机中有一个联系人

http://blog.csdn.net/listening_music/article/details/7172438

相关文章
|
20天前
|
Java Android开发
Android 开发获取通知栏权限时会出现两个应用图标
Android 开发获取通知栏权限时会出现两个应用图标
12 0
|
1月前
|
XML 缓存 Android开发
Android开发,使用kotlin学习多媒体功能(详细)
Android开发,使用kotlin学习多媒体功能(详细)
94 0
|
3月前
|
安全 Linux Android开发
Android 安全功能
Android 安全功能
37 0
|
6月前
|
安全 Android开发 开发者
Android 原生 Picture in Picture 画中画功能避坑指南(下)
Android 原生 Picture in Picture 画中画功能避坑指南(下)
100 0
|
4月前
|
XML 前端开发 Java
Android App实战项目之实现手写签名APP功能(附源码,简单易懂 可直接实用)
Android App实战项目之实现手写签名APP功能(附源码,简单易懂 可直接实用)
45 0
|
4月前
|
传感器 物联网 Android开发
【Android App】物联网中查看手机支持的传感器及实现摇一摇功能-加速度传感器(附源码和演示 超详细)
【Android App】物联网中查看手机支持的传感器及实现摇一摇功能-加速度传感器(附源码和演示 超详细)
62 1
|
4月前
|
XML Java 定位技术
【Android App】定位导航GPS中开启手机定位功能讲解及实战(附源码和演示 超详细)
【Android App】定位导航GPS中开启手机定位功能讲解及实战(附源码和演示 超详细)
109 0
|
4月前
|
XML 前端开发 Java
【Android App】三维处理中三维投影OpenGL功能的讲解及实战(附源码和演示 超详细必看)
【Android App】三维处理中三维投影OpenGL功能的讲解及实战(附源码和演示 超详细必看)
33 1
|
4月前
|
JSON 语音技术 Android开发
【Android App】在线语音识别功能实现(使用云知声平台与WebSocket 超详细 附源码)
【Android App】在线语音识别功能实现(使用云知声平台与WebSocket 超详细 附源码)
34 0
|
4月前
|
JSON Java 语音技术
【Android App】实现在线语音合成功能(使用云知声平台和WebSocket 超详细 附源码)
【Android App】实现在线语音合成功能(使用云知声平台和WebSocket 超详细 附源码)
43 0