h5 canvas html 合成,图片合成以及canvas的应用

使用 canvas 在前端实现图片合成

基本API

// 绘制图片常用 API

const canvas = document.createElement('canvas');

const ctx = canvas.getContext('2d');

ctx.drawImage(imgage: HTMLCanvasElement | HTMLImageElement | HTMLVideoElement | ImageBitmap, distX: number, distY: number)

// 绘制文本常用API

const ctx = document.getElementById('canvas').getContext('2d')

ctx.font = "48px serif"

ctx.fillText("Hello world", 10, 50)

各个参数的用途已在代码中标出。image是将要渲染的图片,distX 和 distY 分别代表着图片与原点 x 轴和 y 轴方向上的距离。

先来一个最简单的例子。

Canvas DrawImage

canvas {

border: 1px black dashed;

}

效果如下图:

ee1cebbd4bf01f9a84606078b6cad305.png

绘制步骤

使用 Canvas 实现图片合成通常需要以下三个步骤:

根据设计稿量出页面中个元素的位置

计算文本相对于图片中元素的距离,设置字体大小和自身样式

调用 API 绘制图片

针对第一点,以实际项目为例,先对要合成页的页面元素进行拆分,随后拉取参考线,对各个元素的位置进行测量并记录对应位置

针对第二点,先设置要渲染文字的字号,以及样式。

ctx.font = "48px serif"

ctx.fillStyle = "#dfe0e7"

ctx.fillText("Hello world", 10, 50)

其中的10,和50分别代表距离 x 轴和 y 轴的距离。

第三点,调用 API 绘制图片。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值