


Speichern eines Bildes mit angewendeten CSS-Filtern auf der Leinwand ohne Backend
Um ein Bild mit angewendeten CSS-Filtern auf der Clientseite zu speichern, führen Sie die folgenden Schritte aus:
In Leinwand konvertieren und Bilddaten extrahieren
- Konvertieren Sie das Bild in eine Leinwand mit document.getElementById("myCanvas").getContext("2d").drawImage(image, 0, 0, canvas.width, canvas.height);.
- Extrahieren Sie die Bilddaten mit angewendeten Filtern mit myCanvas. toDataURL("image/png").
CSS-Filter auf Kontext anwenden
Allerdings Das Bild wird ohne Effekte gespeichert, wenn die Kontextfiltereigenschaft nicht unterstützt wird. Um dieses Problem zu beheben:
- Überprüfen Sie die Existenz der context.filter-Eigenschaft mit typeof ctx.filter === "undefiniert".
- Wenn unterstützt, wenden Sie CSS-Filter mit ctx an. filter = "filterValue", bevor Sie das Bild auf die Leinwand zeichnen.
- Wenn dies nicht unterstützt wird, wenden Sie Filter manuell mit einer alternativen Methode an, die nicht angezeigt wird hier.
Beispiel
In diesem Beispiel wird mithilfe der Filtereigenschaft ein Sepiafilter auf ein Bild angewendet. Wenn dies nicht unterstützt wird, wird ein Fallback verwendet (nicht angezeigt).
var img = new Image(); img.crossOrigin = ""; img.onload = draw; img.src = "//i.imgur.com/WblO1jx.jpg"; function draw() { var canvas = document.querySelector("canvas"), ctx = canvas.getContext("2d"); canvas.width = this.width; canvas.height = this.height; // filter if (typeof ctx.filter === "undefined") { ctx.filter = "sepia(0.8)"; ctx.drawImage(this, 0, 0); } else { ctx.drawImage(this, 0, 0); // TODO: manually apply filter here. } document.querySelector("img").src = canvas.toDataURL(); }
Denken Sie daran, dass CSS-Filter nur auf das Erscheinungsbild der Elemente angewendet werden, nicht auf die tatsächlichen Bitmap-Daten. Um tatsächliche Filter anzuwenden, arbeiten Sie mit der Bitmap auf Pixelebene, wenn die Filtereigenschaft nicht verfügbar ist.
Das obige ist der detaillierte Inhalt vonWie kann ich ein Bild mit auf die Leinwand angewendeten CSS-Filtern ohne Server speichern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die CSS-Box-Shadow- und Umrisseigenschaften haben Thema gewonnen. JSON-Unterstützung in WordPress 6.1. Sei ein paar Beispiele für die Funktionsweise in realen Themen und welche Optionen wir diese Stile auf WordPress -Blöcke und Elemente anwenden müssen.

Wenn Sie kürzlich mit GraphQL gearbeitet oder seine Vor- und Nachteile überprüft haben, haben Sie zweifellos Dinge wie "GraphQL nicht unterstützen Caching" oder gehört

Die Sufelte Transition -API bietet eine Möglichkeit, Komponenten zu beleben, wenn sie das Dokument eingeben oder verlassen, einschließlich benutzerdefinierter Svelte -Übergänge.

In diesem Artikel werden wir in die Welt der Scrollbars eintauchen. Ich weiß, es klingt nicht zu glamourös, aber vertrau mir, eine gut gestaltete Seite geht Hand in Hand

Wie viel Zeit damit, die Inhaltspräsentation für Ihre Websites zu entwerfen? Wenn Sie einen neuen Blog -Beitrag schreiben oder eine neue Seite erstellen, denken Sie darüber nach

Mit dem jüngsten Aufstieg von Bitcoins Preis über 20.000 USD und kürzlich von 30.000, dachte ich, es lohnt

NPM-Befehle führen verschiedene Aufgaben für Sie aus, entweder als einmalige oder als kontinuierlich ausgeführter Vorgang für Dinge wie das Starten eines Servers oder das Kompilieren von Code.

Ich habe mich neulich mit Eric Meyer unterhalten und erinnerte mich an eine Eric Meyer -Geschichte aus meinen prägenden Jahren. Ich habe einen Blog -Beitrag über CSS -Spezifität geschrieben, und


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Dreamweaver Mac
Visuelle Webentwicklungstools

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version