欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

canvas绘制圆角头像的实现方法

程序员文章站 2023-02-15 11:42:24
这篇文章主要介绍了canvas绘制圆角头像的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 19-01-17...

如果你想绘制的网页包含一个圆弧形的头像的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();
} 

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