Heim  >  Artikel  >  Web-Frontend  >  JS+canvas betreibt GIF-Animationen

JS+canvas betreibt GIF-Animationen

php中世界最好的语言
php中世界最好的语言Original
2018-04-18 15:11:465173Durchsuche

Dieses Mal bringe ich Ihnen JS+Canvas zum Betreiben von GIF-Animationen. Was sind die Vorsichtsmaßnahmen zum Betreiben von GIF-Animationen mit JS+Canvas? Im Folgenden sind praktische Fälle aufgeführt. 1 Steh auf und schau es dir an.

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

HTML-Code:

<imgid="testImg"src="xxx.gif"width="224"height="126">
<p><inputtype="button"id="testBtn"value="停止"></p>

JS-Code:

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

Der obige Code wurde nicht im Detail getestet und mögliche Erfahrungsprobleme (IE-Flackern) wurden nicht speziell behandelt (das Auswirkungsprinzip wird gezeigt). Wenn Sie ihn tatsächlich verwenden möchten, müssen Sie ihn selbst optimieren.

Nachteile:

1. IE9+-Unterstützung. IE7/IE8 unterstützt kein Canvas.

2. Sie können nur das GIF stoppen, nicht 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.                                        

Ich glaube, dass Sie die Methode zum Lesen dieses Artikels beherrschen. Weitere spannende Artikel finden Sie auf der chinesischen PHP-Website.

Empfohlene Lektüre:

HTML-Tags mit DOM-Knoten kombinieren

js verbietet Browser-Back-Events

Das obige ist der detaillierte Inhalt vonJS+canvas betreibt GIF-Animationen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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