博客
关于我
Android - 利用扩展函数为Bitmap添加文字水印
阅读量:401 次
发布时间:2019-03-05

本文共 2339 字,大约阅读时间需要 7 分钟。

<异空间>项目技术分享系列——扩展函数为Bitmap添加文字水印

对图片Bitmap绘制文字水印还是比较常见的需求,毕竟版权意识都在增强(用户可以给自己图片加上用户名),还可以为用户提供更多的信息(例如视频缩略图)

先上效果图(比较简单的效果,可继续扩展实现),以下代码使用Kotlin语言编写

给Bitmap添加文字水印

首先注意不能对进行拉伸或缩放前的Bitmap进行绘制水印,否则水印也会一起被拉伸缩放

应该提前将Bimap拉伸,再进行绘制操作

示例代码:

//将Bitmap进行缩放,获得缩放完成后的Bitmap后,再绘制文字水印bitmap?.let {thumb ->    bitmap = Bitmap.createScaledBitmap( //缩放      thumb , ConvertUtils.dp2px(140F),      ConvertUtils.dp2px(100F),false     )    .addTextWatermark(length , ConvertUtils.dp2px(16F) , Color.WHITE ,0F,0F,false)}

addTextWatermark 方法是对Bitmap类的一个扩展方法(Kotlin)

下面示例代码目前只实现了在右下角绘制,可继续扩展:

/**     * 给一张Bitmap添加水印文字。     *     * @param content  水印文本     * @param textSize 水印字体大小 ,单位pix。     * @param color    水印字体颜色。     * @param x        起始坐标x     * @param y        起始坐标y     * @param recycle  是否回收     * @return 已经添加水印后的Bitmap     */    fun Bitmap.addTextWatermark(        content: String?,//文字内容        textSize: Int, //文字大小        color: Int, //文字颜色        x: Float, //x,y暂时比较难用,因为要指定具体位置,难以在外部直接测量文字的坐标        y: Float,        recycle: Boolean //Bitmap内存是否回收    ): Bitmap? {        if ( content == null)            return null        val ret = this.copy(this.config, true)        val paint = Paint(Paint.ANTI_ALIAS_FLAG)        val canvas = Canvas(ret)        paint.color = color        paint.textSize = textSize.toFloat()        //绘制文字        val bounds = Rect()        paint.getTextBounds(content, 0, content.length, bounds)        //默认在 Bitmap的 右下角位置开始绘制文字        canvas.drawText(content, this.width.toFloat()-bounds.width() - 20F , this.height.toFloat() - bounds.height() + 20F, paint)        if (recycle && !this.isRecycled)            this.recycle()        return ret    }

补充

Bitmap加载进ImageView,为什么会形状各异,是因为设置了不同的缩放方式

设置ImageView填充方式的前提是使用src作为设置图片的来源,否则的话,会导致图片填充方式设置无效的情况。

  • scaleType=“matrix” 是保持原图大小、从左上角的点开始,以矩阵形式绘图。
  • scaleType=“fitXY” 是将原图进行横方向(即XY方向)的拉伸后绘制的。
  • scaleType=“fitStart” 是将原图沿左上角的点(即matrix方式绘图开始的点),按比例缩放原图绘制而成的。
  • scaleType=“fitCenter” 是将原图沿上方居中的点(即matrix方式绘图第一行的居中的点),按比例缩放原图绘制而成的。
  • scaleType=“fitEnd” 是将原图沿下方居中的点(即matrix方式绘图最后一行的居中的点),按比例缩放原图绘制而成的。
  • scaleType=“Center” 是保持原图大小,以原图的几何中心点和ImagView的几何中心点为基准,只绘制ImagView大小的图像。
  • scaleType=“centerCrop” 不保持原图大小,以原图的几何中心点和ImagView的几何中心点为基准,只绘制ImagView大小的图像(以填满ImagView为目标,对原图进行裁剪)。
  • scaleType=“centerInside” 不保持原图大小,以原图的几何中心点和ImagView的几何中心点为基准,只绘制ImagView大小的图像(以显示完整图片为目标,对原图进行缩放)。

希望对有需要的人有帮助~😊

转载地址:http://uymzz.baihongyu.com/

你可能感兴趣的文章
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>