文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

android实现在图标上显示数字

2024-04-02 19:55

关注

本文实例为大家分享了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;
 

 
public class QNotifacationIcon {
    
    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));

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-移动开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯