如果你想绘制的网页包含一个圆弧形的头像的canvas图片,但是头像本身是正方形的,需要的方法如下:
首先, 拿到头像在画布上的坐标和宽高:(具体怎么获取不在此做具体介绍)
let {avatarx, avatary, avatarw, avatarh} = {20, 20, 80, 80};
然后 只需要调用以下函数即可:
let canvas = document.createelement('canvas'); let ctx = canvas.getcontext("2d"); let avatar = new image(); avatar.src = '../src/xx.png'; avatar.onload = (scaleby = 2) => { circleimg(ctx, avatar, avatarx * scaleby, avatary * scaleby, avatarw * scaleby / 2); } // r: 半径 function circleimg(ctx, img, x, y, r) { ctx.save(); var d =2 * r; var cx = x + r; var cy = y + r; ctx.arc(cx, cy, r, 0, 2 * math.pi); ctx.clip(); ctx.drawimage(img, x, y, d, d); ctx.restore(); }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。