หากหน้าเว็บที่คุณต้องการวาดมีภาพผืนผ้าใบของอวตารที่มีรูปร่างโค้ง แต่ตัวอวตารนั้นเป็นรูปสี่เหลี่ยมจัตุรัส วิธีการที่จำเป็นจะเป็นดังนี้:
ขั้นแรก รับพิกัด ความกว้าง และความสูงของอวตารบนผืนผ้าใบ: (ฉันจะไม่ลงรายละเอียดเกี่ยวกับวิธีการรับมันที่นี่)
ให้ {avatarX, avatarY, avatarW, avatarH} = {20, 20, 80, 80};
จากนั้นเพียงเรียกใช้ฟังก์ชันต่อไปนี้:
ให้ Canvas = document.createElement('canvas');let ctx = Canvas.getContext(2d);let avatar = new Image();avatar.src = '../src/xx.png';avatar.onload = ( scaleBy = 2) => { วงกลมImg (ctx, avatar, avatarX * scaleBy, avatarY * scaleBy, avatarW * scaleBy / 2);}// r: ฟังก์ชันรัศมี วงกลมImg(ctx, img, x, y, r) { ctx.save(); var d =2 * r; var cx = x + r; ctx.arc(cx, cy, r, 0, 2 * Math.PI); ctx.drawImage(img, x, y, ง, ง); ctx.restore();}
ข้างต้นคือเนื้อหาทั้งหมดของบทความนี้ ฉันหวังว่ามันจะเป็นประโยชน์ต่อการศึกษาของทุกคน ฉันหวังว่าทุกคนจะสนับสนุน VeVb Wulin Network