Dieses Mal erkläre ich Ihnen, wie Sie mit dem canvas.toDataURL-Bild-/PNG-Fehler umgehen Das Folgende ist ein praktischer Fall. Schauen wir uns das an. Problemhintergrund:
Es wurde die Anforderung festgestellt, einen Screenshot des wiedergegebenen
Videos zu erstellen. Verwenden Sie das Video-Tag, um das Video abzuspielen, und erfassen Sie dann das Echtzeitvideo beim Klicken auf den Videowiedergabebereich FrameBild. Der Code ist sehr einfach wie folgt:
Problemtipp:var video = document.getElementById('video'); var canvas = document.getElementById('canvas'); var ctx = canvas.getContext('2d'); var img = document.getElementById('img'); function snapshot() { ctx.drawImage(video,0,0); img.src = canvas.toDataURL('image/png'); } video.addEventListener('click', snapshot, false);
Uncaught SecurityError: Fehler beim Ausführen von „toDataURL“ auf „HTMLCanvasElement“: Befleckte Leinwände möglicherweise nicht exportiert werden.
Nach Überprüfung und Analyse wurde festgestellt, dass dies tatsächlich daran liegt, dass sich die Domäne, in der sich die Videodatei befindet, von der Domäne unterscheidet, in der sich das Bild und die Seite befinden, was zu einem Problem bei der domänenübergreifenden Übertragung.
Lösung:
Fügen Sie die Videodatei unter der Domain der Seite ein.
Ich glaube, dass Sie die Methoden beherrschen, nachdem Sie diese Fälle gelesen haben. Weitere spannende Informationen finden Sie in anderen verwandten Artikeln auf der chinesischen PHP-Website!
Verwandte Lektüre:
Wie man mobile Webseiteninhalte adaptiv machtWie man mit Inhaltsüberlauf in Tabellentabellen umgeht So erhalten Sie die dynamische verbleibende Wortanzahl von textareaDas obige ist der detaillierte Inhalt vonSo gehen Sie mit dem Bild-/PNG-Fehler „canvas.toDataURL' um. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!