android实现在图标上显示数字
短信预约 -IT技能 免费直播动态提醒
本文实例为大家分享了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 class="lazy" data-src = new Rect(0, 0, iconWidth, iconHeight);
// 截取的图片放在画布上的位置
Rect dst = new Rect(0, 0, iconWidth, iconHeight);
canvas.drawBitmap(icon, class="lazy" data-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