android实现在图标上显示数字

 更新时间:2022年04月19日 09:45:29   作者:球球_2014  
这篇文章主要为大家详细介绍了android实现在图标上显示数字,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了android实现在图标上显示数字的具体代码,供大家参考,具体内容如下

效果图:

动态显示当天的号数。

主要代码如下:

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Bitmap.Config;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Rect;
import android.graphics.Typeface;
import android.graphics.drawable.BitmapDrawable;
 
/**
 * 图片上画文字
 * 
 * @author qhg
 * @date 2014年3月5日
 * 
 */
 
public class QNotifacationIcon {
    /**
     * 在给定的图片上添加文字
     * 
     * @param context
     *            上下文对象
     * @param resId
     *            图片资源ID
     * @param text
     *            需要显示的文字
     * @param textSize
     *            文字大小
     * @param color
     *            文字颜色
     * @param typeface
     *            文字字体
     * @param offsetX
     *            文字x的偏移量
     * @param offsetY
     *            文字y的偏移量
     * @return 带文字的图片
     */
    public static Bitmap generatorContactIcon(Context context, int resId,
            String text, float textSize, int color, Typeface typeface,
            float offsetX, float offsetY) {
        // 根据id获取需要处理的图片
        Bitmap icon = ((BitmapDrawable) (context.getResources()
                .getDrawable(resId))).getBitmap();
        int iconWidth = icon.getWidth();
        int iconHeight = icon.getHeight();
        // 初始化画布
        Bitmap contactIcon = Bitmap.createBitmap(iconWidth, iconHeight,
                Config.ARGB_8888);
        // 构建
        Canvas canvas = new Canvas(contactIcon);
 
        // 创建画笔
        Paint paint = new Paint();
        // 设定是否使用图像抖动处理,会使绘制出来的图片颜色更加平滑和饱满,图像更加清晰
        paint.setDither(true);
        // 如果该项设置为true,则图像在动画进行中会滤掉对Bitmap图像的优化操作,加快显示
        // 速度,本设置项依赖于dither和xfermode的设置
        paint.setFilterBitmap(true);
 
        // 截取整个图片,从左上角到右下角
        Rect src = new Rect(0, 0, iconWidth, iconHeight);
        // 截取的图片放在画布上的位置
        Rect dst = new Rect(0, 0, iconWidth, iconHeight);
        canvas.drawBitmap(icon, src, dst, paint);
 
        // 抗锯齿和使用本身的文本字距
        Paint numPaint = new Paint(Paint.ANTI_ALIAS_FLAG
                | Paint.DEV_KERN_TEXT_FLAG);
        // 设置文字颜色
        numPaint.setColor(color);
        // 设置文字大小
        numPaint.setTextSize(textSize);
        // 设置文字字体
        numPaint.setTypeface(typeface);
 
        // 将文字内容画在图片上,x和y的坐标这里直接计算了文字在图片上的宽高偏移比例
        canvas.drawText(text, iconWidth * offsetX, iconHeight * offsetY,
                numPaint);
        return contactIcon;
    }
}

数字字体大小会随屏幕大小而不适应,可以根据屏幕宽度然后动态缩放字体比例。
调用方式:

// 动态在图片上画日期数字
((ImageView) convertView.findViewById(R.id.iv_leftImage))
    .setImageBitmap(QNotifacationIcon.generatorContactIcon(
    context, list_left_iamge_array[position],
    String.valueOf(new Date().getDate()), 30f, Color.GRAY,
    Typeface.DEFAULT_BOLD, 0.35f, 0.75f));

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

最新评论