Maison >interface Web >Tutoriel H5 >Pratique de programmation HTML5, partie 2 – Utiliser l'animation pour changer de cas de code d'image
Cet article utilise principalement CanvasLa méthode drawImage dans l'API est brièvement présentée ci-dessous
La méthode drawImage est utilisée pour dessiner des images dans l'API Canvas. Il s'agit d'une méthode surchargée . défini comme suit :
context.drawImage(image,x,y); context.drawImage(image,x,y,w,h); context.drawImage(image,sx,sy,sw,sh,dx,dy,dw,dh);
La première méthode a trois paramètres Le premier paramètre est l'image à dessiner (cela peut aussi être un élément vidéo), x et y sont les points de départ de l'image dans. la toile. Coordonnées.
La deuxième méthode a cinq paramètres. Les trois premiers ont la même signification que la première méthode w et h font référence à la largeur et à la hauteur de l'image lors du dessin. mise à l'échelle de l'image.
La troisième méthode a neuf paramètres. Le premier paramètre a la même signification que les deux premières méthodes. Les quatre premiers des huit derniers paramètres prennent un rectangle sur l'image source, et les quatre derniers paramètres sont utilisés pour. définir sur le canevas. Un rectangle, la fonction de la méthode entière est de copier une partie de l'image source (la partie définie par les deuxième à cinquième paramètres) sur le canevas (la partie définie par les quatre derniers paramètres) Cet article utilise principalement la première. Trois méthodes pour terminer le dessin<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>用动画的形式切换图片</title> <script type="text/javascript"> var width, height; var context, image, functionId; var drawLeft, drawWidth; var drawTop, drawHeight; var spaceWidth, spaceHeight; var speed=5000; var images = ["http://i.6.cn/cvbnm/4e/7e/bb/75f251a8e2ae935d598f17b4f8275060.jpg", "http://i.6.cn/cvbnm/4a/6e/fb/805175016e502c483b75276f29801df3.jpg", "http://i.6.cn/cvbnm/6a/72/18/1787a3b2754ef48e374bbd14635f5c36.jpg", "http://i.6.cn/cvbnm/94/55/6c/b1ba743ba617be2891fa06b67d795511.jpg", "http://i.6.cn/cvbnm/02/1b/04/8018ee9e5756ac6b30f27d7ad6396b03.jpg", "http://i.6.cn/cvbnm/85/ea/d1/65f15857b971afb3b6e38b5fcdadc9c0.jpg"]; function selectFrom(iFirstValue, iLastValue) { var iChoices = iLastValue - iFirstValue + 1; return Math.floor(Math.random() * iChoices + iFirstValue); } function showPicture(effects) { var count = 0; for (var o in effects) { count++; } var canvas = document.getElementById('canvas'); context = canvas.getContext('2d'); width = canvas.width; height = canvas.height; var currImage = 0; image = new Image(); image.src = images[currImage]; context.drawImage(image, 0, 0, width, height); currImage++; if (count > 0) { setInterval(function () { var rand = selectFrom(0, count - 1); image.src = images[currImage]; currImage++; if (currImage == images.length) { currImage = 0; } var index = 0; for (var effect in effects) { if (index++ == rand) { effects[effect](); break; } } }, speed); } } window.onload=function(){ showPicture({ leftToRight: function () { context.fillStyle = "#EEEEFF"; context.fillRect(0, 0, width, height); drawWidth = 0; functionId = self.setInterval("drawleftToRight()", 10); }, topToBottom: function () { context.fillStyle = "#EEEEFF"; context.fillRect(0, 0, width, height); drawHeight = 0; functionId = self.setInterval("drawtopToBottom()", 10); }, hcenter: function () { context.fillStyle = "#EEEEFF"; context.fillRect(0, 0, width, height); drawLeft = width / 2; drawWidth = 0; functionId = self.setInterval("drawhcenter()", 10); }, vcenter: function () { context.fillStyle = "#EEEEFF"; context.fillRect(0, 0, width, height); drawTop = height / 2; drawHeight = 0; functionId = self.setInterval("drawvcenter()", 10); }, hwindow: function () { context.fillStyle = "#EEEEFF"; context.fillRect(0, 0, width, height); spaceWidth = width / 10; drawWidth = 0; functionId = self.setInterval("drawhwindow()", 50); }, vwindow: function () { context.fillStyle = "#EEEEFF"; context.fillRect(0, 0, width, height); spaceHeight = height / 10; drawHeight = 0; functionId = self.setInterval("drawvwindow()", 50); }, hvwindow: function () { context.fillStyle = "#EEEEFF"; context.fillRect(0, 0, width, height); spaceHeight = height / 10; spaceWidth = width / 10; drawWidth = 0; drawHeight = 0; functionId = self.setInterval("drawhvwindow()", 50); } }); } function drawleftToRight() { context.drawImage(image, 0, 0, drawWidth, image.height, 0, 0, drawWidth, image.height); drawWidth = drawWidth + 2; if (drawWidth > width) { window.clearInterval(functionId); } } function drawtopToBottom() { context.save(); context.drawImage(image, 0, 0, image.width, drawHeight, 0, 0, image.width, drawHeight); drawHeight = drawHeight + 2; if (drawHeight > height) { window.clearInterval(functionId); } context.restore(); } function drawhcenter() { context.save(); context.drawImage(image, drawLeft, 0, drawWidth, image.height, drawLeft, 0, drawWidth, image.height); drawLeft = drawLeft - 1; drawWidth = drawWidth + 2; if (drawLeft <= 0) { window.clearInterval(functionId); } context.restore(); } function drawvcenter() { context.save(); context.drawImage(image, 0, drawTop, image.width, drawHeight, 0, drawTop, image.width, drawHeight); drawTop = drawTop - 1; drawHeight = drawHeight + 2; if (drawTop <= 0) { window.clearInterval(functionId); } context.restore(); } function drawhwindow() { for (i = 0; i < 10; i++) { context.drawImage(image, 0 + i * spaceWidth, 0, drawWidth, image.height, 0 + i * spaceWidth, 0, drawWidth, image.height); } drawWidth += 1; if (drawWidth - 1 > spaceWidth) { window.clearInterval(functionId); } } function drawvwindow() { context.save(); context.clearRect(0, 0, width, height); for (i = 0; i < 10; i++) { context.drawImage(image, 0, 0 + i * spaceHeight, image.width, drawHeight, 0, 0 + i * spaceHeight, image.width, drawHeight); } drawHeight += 1; if (drawHeight - 1 > spaceHeight) { window.clearInterval(functionId); } context.restore(); } function drawhvwindow() { context.save(); context.clearRect(0, 0, width, height); for (i = 0; i < 10; i++) { for (j = 0; j < 10; j++) { context.drawImage(image, 0 + j * spaceWidth, 0 + i * spaceHeight, drawWidth, drawHeight, 0 + j * spaceWidth, 0 + i * spaceHeight, drawWidth, drawHeight); } } drawHeight += height / width; drawWidth += 1; if (drawHeight > spaceHeight) { context.drawImage(image, 0, 0, width, height); window.clearInterval(functionId); } context.restore(); } </script></head><body> <h1>用动画的形式切换图片</h1> <canvas id="canvas" width="192px" height="255px"></canvas></body></html>Analyse du code drawleftToRight() : L'effet est de afficher de gauche à droite, principalement le quatrième. Le premier paramètre et le huitième paramètre augmentent progressivement de 0 jusqu'à la largeur de l'image drawtopToBottom() : L'effet est d'afficher de haut en bas, principalement par augmenter progressivement le cinquième paramètre et le neuvième paramètre de 0 à l'image La hauteur de drawhcenter() : L'effet est d'afficher horizontalement du milieu vers les deux côtés, réduisant principalement les deuxième et sixième paramètres de la moitié de la largeur de l'image à 0, et augmenter les quatrième et huitième paramètres de 0 à la largeur de l'image drawvcenter() : L'effet est d'afficher du milieu vers les deux côtés, similaire au précédent
drawhwindow() : L'effet est celui des stores horizontaux, similaire au principe de la méthode drawhcenter, sauf qu'ici, il s'agit de Réalisé à plusieurs endroits drawvwindow() : L'effet est celui des stores verticaux, similaire au principe de la méthode drawvcenter, sauf qu'elle est effectuée à partir de plusieurs endroits drawhvwindow() : L'effet est aveugle, c'est une combinaison de drawhwindow() et drawvwindow() Tout le monde est invité à ajoutez-le et améliorez-le Étant donné que l'image est placée sur d'autres sites Web, elle se charge lentement et n'est pas si fluide. Veuillez l'utiliser. Vous pouvez la remplacer par cette
carte pour de meilleurs résultats .
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!