gpt4 book ai didi

javascript - 如何在不同方向多次绘制一张图像?

转载 作者:行者123 更新时间:2023-11-28 10:46:11 28 4
gpt4 key购买 nike

我有一个这样的数组,其想法是在不同方向输出图像,并通过缩放在 Canvas 上垂直和水平翻转它们。

[{  
"pos":{
"x":411,
"y":401.5
},
"scale":{
"x":1,
"y":1
}
},{
"pos":{
"x":411,
"y":271.59625
},
"scale":{
"x":-1,
"y":1
}
}]

问题是我正在缩放 Canvas 而不是图像, Canvas 比我放置在其上的图像大几倍。

  images.forEach((image) => {
// center borde köars innan loopen egentligen
let pos = center(image.pos)
cc.save()
cc.scale(image.scale.x, image.scale.y)
cc.drawImage(window.video, pos.x, pos.y)
cc.restore()
})

如何缩放图像(称为 window.video)而不是整个 Canvas ?

最佳答案

在 Canvas 上渲染缩放图像。

function drawImage(image,x,y,scaleX,scaleY){
ctx.setTransform(scaleX, 0, 0, scaleY, x, y); // set scale and translation
ctx.drawImage(image,0,0);
}

// when done drawing images you need to reset the transformation back to default
ctx.setTransform(1,0,0,1,0,0); // set default transform

如果您希望图像翻转但仍绘制在相同的左上角位置,请使用

function drawImage(image, x, y, scaleX, scaleY){
ctx.setTransform(scaleX, 0, 0, scaleY, x, y); // set scale and translation
x = scaleX < 0 ? -image.width : 0; // move drawing position if flipped
y = scaleY < 0 ? -image.height : 0;
ctx.drawImage(image, x, y);
}

并围绕图像的中心进行绘制

function drawImage(image, x, y, scaleX, scaleY){  // x y define center
ctx.setTransform(scaleX, 0, 0, scaleY, x, y); // set scale and translation
ctx.drawImage(image, -image.width / 2, -image.height / 2);
}

关于javascript - 如何在不同方向多次绘制一张图像?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42492692/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com