Heim > Web-Frontend > js-Tutorial > Ausführliche Erklärung, wie man JS und Canvas zum Stoppen und Abspielen von GIF-Animationen verwendet

Ausführliche Erklärung, wie man JS und Canvas zum Stoppen und Abspielen von GIF-Animationen verwendet

巴扎黑
Freigeben: 2017-09-02 14:12:05
Original
2136 Leute haben es durchsucht

In diesem Artikel wird hauptsächlich die Verwendung von JS und Canvas zum Implementieren des Stop-and-Play-Codes von GIF-Animationen vorgestellt. Er ist von großem praktischem Wert.

HTML5-Canvas kann Bildinformationen lesen und zeichne das aktuelle Bild. Dadurch können viele Spezialeffekte wie Bildmosaik, Unschärfe, Farbwertfilterung usw. realisiert werden. Wir müssen hier nicht so kompliziert sein, wir müssen nur unser Bild lesen und es neu zeichnen.


HTML-Code:


<img id="testImg" src="xxx.gif" width="224" height="126">
<p><input type="button" id="testBtn" value="停止"></p>
Nach dem Login kopieren

JS-Code:


if (&#39;getContext&#39; in document.createElement(&#39;canvas&#39;)) {
 HTMLImageElement.prototype.play = function() {
  if (this.storeCanvas) {
   // 移除存储的canvas
   this.storeCanvas.parentElement.removeChild(this.storeCanvas);
   this.storeCanvas = null;
   // 透明度还原
   image.style.opacity = &#39;&#39;;
  }
  if (this.storeUrl) {
   this.src = this.storeUrl; 
  }
 };
 HTMLImageElement.prototype.stop = function() {
  var canvas = document.createElement(&#39;canvas&#39;);
  // 尺寸
  var width = this.width, height = this.height;
  if (width && height) {
   // 存储之前的地址
   if (!this.storeUrl) {
    this.storeUrl = this.src;
   }
   // canvas大小
   canvas.width = width;
   canvas.height = height;
   // 绘制图片帧(第一帧)
   canvas.getContext(&#39;2d&#39;).drawImage(this, 0, 0, width, height);
   // 重置当前图片
   try {
    this.src = canvas.toDataURL("image/gif");
   } catch(e) {
    // 跨域
    this.removeAttribute(&#39;src&#39;);
    // 载入canvas元素
    canvas.style.position = &#39;absolute&#39;;
    // 前面插入图片
    this.parentElement.insertBefore(canvas, this);
    // 隐藏原图
    this.style.opacity = &#39;0&#39;;
    // 存储canvas
    this.storeCanvas = canvas;
   }
  }
 };
}
 
var image = document.getElementById("testImg"), 
 button = document.getElementById("testBtn");
 
if (image && button) {
 button.onclick = function() {
  if (this.value == &#39;停止&#39;) {
   image.stop();
   this.value = &#39;播放&#39;;
  } else {
   image.play();
   this.value = &#39;停止&#39;;
  }
 };
}
Nach dem Login kopieren

Der obige Code wurde nicht im Detail getestet und mögliche Erfahrungsprobleme (IE-Flashing) wurden nicht speziell behandelt (Veranschaulichung des Wirkungsprinzips) Wenn Sie es tatsächlich verwenden möchten, müssen Sie es selbst verfeinern, um es perfekt zu machen.

Unzulänglichkeit:

1. IE7/IE8 unterstützt kein Canvas.

2. Du kannst nur das GIF stoppen, nicht aber die echte Pause. Da es sich bei den von Canvas erhaltenen GIF-Bildinformationen um die Informationen des ersten Frames handelt, scheint es, dass die nachfolgenden nicht abgerufen werden können. Um eine Pause statt eines Stopps zu erreichen, ist weitere Forschung erforderlich. Wenn Sie eine Methode haben, können Sie diese gerne mit uns teilen.

Das obige ist der detaillierte Inhalt vonAusführliche Erklärung, wie man JS und Canvas zum Stoppen und Abspielen von GIF-Animationen verwendet. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage