In diesem Tutorial erfahren Sie, wie Sie mithilfe von FabricJS den aktuellen Objektschatten aus der URL-Zeichenfolge eines IText-Objekts entfernen. Die IText-Klasse wurde in FabricJS Version 1.4 eingeführt, die Fabric.Text erweitert und zum Erstellen von IText-Instanzen verwendet wird. IText-Instanzen geben uns die Freiheit, ohne zusätzliche Konfiguration neuen Text auszuwählen, auszuschneiden, einzufügen oder hinzuzufügen. Es gibt auch verschiedene unterstützte Tastenkombinationen und Maus-/Touch-Kombinationen, um Text interaktiv zu gestalten, die in Text nicht verfügbar sind.
Mit der auf IText basierenden Textbox können wir jedoch die Größe des Textrechtecks ändern und es automatisch umbrechen. Dies ist bei IText nicht der Fall, da sich die Höhe nicht anhand von Zeilenumbrüchen anpasst. Wir können IText-Objekte mithilfe verschiedener Eigenschaften manipulieren. Ebenso können wir die Eigenschaft withoutShadow verwenden, um den Schatten des aktuellen Objekts aus der URL-Zeichenfolge des IText-Objekts zu entfernen.
toDataURL({ withoutShadow: Boolean }: Object): String
Optionen (optional) – Dieser Parameter ist ein Objekt, das zusätzliche Anpassungen an der URL-Darstellung des IText-Objekts ermöglicht. Verwenden Sie diesen Parameter, um Höhe, Qualität, Format und viele andere Eigenschaften zu ändern, zu denen auch withoutShadow gehört.
withoutShadow – Diese Eigenschaft akzeptiert einen Booleschen-Wert, der es uns ermöglicht, den Schatten des aktuellen Objekts zu entfernen.
Verwenden Sie das withoutShadow-Attribut und übergeben Sie ihm einen falschen Wert
Sehen wir uns ein Codebeispiel an, um das Ausgabebild zu sehen, wenn ein falscher Wert an die Eigenschaft withoutShadow übergeben wird. Sobald wir die Konsole über die Entwicklungstools öffnen, können wir die URL-Darstellung des IText-Objekts sehen. Wir können die URL kopieren und in die Adressleiste eines neuen Tabs einfügen, um die endgültige Ausgabe zu sehen. In diesem Beispiel übergeben wir die Shadow-Eigenschaft an das IText-Objekt. Da wir auch einen falschen Wert an die Eigenschaft withoutShadow übergeben haben, enthält unser endgültiges Ausgabebild immer noch einen Schatten.
<!DOCTYPE html> <html> <head> <!-- Adding the Fabric JS Library--> <script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/510/fabric.min.js"></script> </head> <body> <h2>Using the withoutShadow property and passing it a false value</h2> <p> You can open console from dev tools and see the output URL. You can copy that and paste it in the address bar of a new tab to see that the final image contains a shadow </p> <canvas id="canvas"></canvas> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); // Initiate a shadow object var shadow = new fabric.Shadow({ blur: 25, color: "grey", offsetX: 12, offsetY: 15, }); // Initiate an itext object var itext = new fabric.IText( "Add sample text here.Lorem ipsum dolor sit amet consectetur adipiscing.",{ width: 300, left: 50, top: 70, fill: "#c70039", backgroundColor: "#c1dfed", stroke: "#c70039", originX: "center", shadow: shadow, } ); // Add it to the canvas canvas.add(itext); // Using the toDataURL method console.log(itext.toDataURL({ withoutShadow: false })); </script> </body> </html>
Verwenden Sie das withoutShadow-Attribut und übergeben Sie ihm einen wahren Wert
Sehen wir uns ein Codebeispiel an, um zu sehen, wie das endgültige Ausgabebild eines IText-Objekts aussieht, wenn die Eigenschaft withoutShadow verwendet und ihr ein wahrer Wert übergeben wird. In diesem Fall enthält unser endgültiges Ausgabebild keine Schatten.
<!DOCTYPE html> <html> <head> <!-- Adding the Fabric JS Library--> <script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/510/fabric.min.js"></script> </head> <body> <h2>Using the withoutShadow property and passing it a true value</h2> <p> You can open console from dev tools and see the output URL. You can copy that and paste it in the address bar of a new tab to see that the final image does not contain a shadow </p> <canvas id="canvas"></canvas> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); // Initiate a shadow object var shadow = new fabric.Shadow({ blur: 25, color: "grey", offsetX: 12, offsetY: 15, }); // Initiate an itext object var itext = new fabric.IText( "Add sample text here.Lorem ipsum dolor sit amet consectetur adipiscing.",{ width: 300, left: 50, top: 70, fill: "#c70039", backgroundColor: "#c1dfed", stroke: "#c70039", originX: "center", shadow: shadow, } ); // Add it to the canvas canvas.add(itext); // Using the toDataURL method console.log(itext.toDataURL({ withoutShadow: true })); </script> </body> </html>
Das obige ist der detaillierte Inhalt vonWie entferne ich mit FabricJS den aktuellen Objektschatten aus der URL-Zeichenfolge eines IText-Objekts?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!