Maison  >  Article  >  interface Web  >  Le canevas HTML5 implémente une simple double mise en mémoire tampon

Le canevas HTML5 implémente une simple double mise en mémoire tampon

不言
不言original
2018-11-07 10:16:104716parcourir

Il y a beaucoup de choses intéressantes sur le canevas HTML5, telles que la demande de frameworks d'animation et la création d'animations avec JavaScript. L'article d'aujourd'hui vous explique comment implémenter une double mise en mémoire tampon simple dans le canevas HTML5. Les amis dans le besoin peuvent jeter un œil aux méthodes. article.

Pour un contenu plus avancé, vous souhaiterez peut-être utiliser Canvas, qui est généralement accéléré par GPU et permet des fréquences d'images assez élevées et stables à l'aide de window.request.tionFrame. (Cours recommandé : Tutoriel vidéo HTML5)

Si vous avez besoin de doubler la mémoire tampon sur le canevas, une approche populaire consiste à créer un deuxième élément de canevas et à dessiner sur cet élément de canevas, puis à utiliser drawImage. pour dessiner l'image finie sur le canevas principal, et le résultat est le suivant :

var primaryCtx = document.getElementById("canvas").getContext("2d");
var secondaryCanvas = document.createElement("canvas"),
      secondaryCtx = secondaryCanvas.getContext("2d");
      (function drawFrame() {
    requestAnimationFrame(drawFrame);
    secondaryCtx.fillStyle = "#f00";
    secondaryCtx.fillRect(10,10,20,20);
    primaryCtx.drawImage(secondaryCanvas);
    })();

Entrez CTX.SAVER() et CTX.Rebug()

Aujourd'hui, j'ai découvert que il existe un moyen de faire plus de Clean, qui fonctionne aussi bien que la méthode ci-dessus :

(function drawFrame() {
    requestAnimationFrame(drawFrame);
    primaryCtx.save(); //Freeze redraw
    primaryCtx.fillStyle = "#f00";
    primaryCtx.fillRect(10,10,20,20);
    primaryCtx.restore(); //And now do the redraw
    })();

Malgré le nom étrange, il fige simplement le rendu du contexte, puis reprend le rendu une fois le dessin terminé.

Cet article se termine ici. Pour un contenu plus passionnant, vous pouvez faire attention à la colonne Tutoriel vidéo associée sur le site Web php chinois ! ! !

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn