gpt4 book ai didi

javascript - Canvas 图像动画(交叉淡入淡出)

转载 作者:行者123 更新时间:2023-11-28 15:16:45 25 4
gpt4 key购买 nike

使用 HTML5 Canvas ,我尝试加载图像并创建“交叉淡入淡出”效果,其中第一个图像淡入 View ,然后在短暂的延迟后,第二个图像淡入第一个图像的上方,等等。

在这个论坛上类似问题的答案的帮助下,我得到了两个独立的代码块......一个加载图像数组,第二个加载“淡入”效果动画。我的问题是,我不知道如何组合这两个脚本来加载图像数组,并且还让数组中的每个图像在加载时淡入。

这是我正在运行的两个单独的脚本:

将图像数组加载到 Canvas 中:

HTML

<canvas id="canvas" width=600 height=350></canvas>

JS

window.onload = function() {

var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
var cw=canvas.width;
var ch=canvas.height;

var delay=2000;
var nextTime=0;
var nextImage=0;

var imageURLs=[];
imageURLs.push("img/sunflower0.jpg");
imageURLs.push("img/sunflower1.jpg");
imageURLs.push("img/sunflower2.jpg");

var imgs=[];
var imagesOK=0;
loadAllImages(start);

function loadAllImages(callback){
for (var i=0; i<imageURLs.length; i++) {
var img = new Image();
imgs.push(img);
img.onload = function(){
imagesOK++;
if (imagesOK >= imageURLs.length ) {
callback();
}
};
img.src = imageURLs[i];
}
}

function start(){
requestAnimationFrame(animate);
}

function animate(currentTime){
requestAnimationFrame(animate);

if(currentTime<nextTime){return;}
ctx.clearRect(0,0,cw,ch);
ctx.drawImage(imgs[nextImage],0,0);
nextTime=currentTime+delay;
nextImage++;
if(nextImage>imgs.length-1){nextImage=0;}

}
} // close window.onload

图像加载到 Canvas 时淡入:

我设法使用 Canvas 和 Greensock TweenMax 获得了一段单独的代码来完成此操作:

<script     src="https://cdnjs.cloudflare.com/ajax/libs/gsap/1.18.0/TweenMax.min.js">     </script>

<script>

var ctx, img;

function init() {
ctx = document.getElementById("canvas").getContext("2d");

img = new Image();
img.src = "img/sunflower0.jpg";
img.xpos = 0;
img.ypos = 0;
img.globalAlpha = 0;

img.onload = function() {
TweenMax.ticker.addEventListener("tick",loop);
}

TweenMax.to(img, 5 ,{globalAlpha:1});
}

function loop(){
ctx.clearRect(0,0,500,336);
ctx.globalAlpha = img.globalAlpha;
ctx.drawImage(img, img.xpos, img.ypos);
}

init();

谁能告诉我如何组合这两个脚本来获得交叉淡入淡出效果?

非常感谢!

最佳答案

我会为此使用三个 Canvas :

var imgs = [];

var rand = Math.random;
var common = "http://lorempixel.com/500/300?";
var imageURLs = [common + rand(), common + rand(), common + rand(), common + rand(), common + rand()];

var imagesOK = 0;
function loadAllImages(callback) {
for (var i = 0; i < imageURLs.length; i++) {
var img = new Image();
imgs.push(img);
img.onload = function() {
imagesOK++;
if (imagesOK >= imageURLs.length) {
callback();
}
};
img.src = imageURLs[i];
}
}
var ctx = main.getContext('2d');
var last = main.cloneNode(true).getContext('2d');
var next = main.cloneNode(true).getContext('2d');

var current = 0;
var op = 1;

function nextImage() {
if (current++ >= imgs.length - 1) current = 0;
op = 1;
fade();
}

function fade() {
op -= .01;

last.clearRect(0, 0, main.width, main.height);
last.globalAlpha = op;
last.drawImage(imgs[current], 0, 0);

next.clearRect(0, 0, main.width, main.height);
next.globalAlpha = 1 - op;
next.drawImage(imgs[(current + 1) % (imgs.length)], 0, 0);

ctx.clearRect(0, 0, main.width, main.height);
ctx.drawImage(last.canvas, 0, 0);
ctx.drawImage(next.canvas, 0, 0);

if (op <= 0) setTimeout(nextImage, 1500);
else requestAnimationFrame(fade);
}
loadAllImages(fade);
<canvas id="main" width="500" height="300"></canvas>

关于javascript - Canvas 图像动画(交叉淡入淡出),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33558354/

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