In this tutorial, we will learn how to remove the current object transformation (scale, angle, flip, skew) from the URL string of an IText object using FabricJS. The IText class was introduced in FabricJS version 1.4, which extends Fabric.Text and is used to create IText instances. IText instances give us the freedom to select, cut, paste or add new text without additional configuration. There are also various supported key combinations and mouse/touch combinations to make text interactive that are not available in Text.
However, IText-based Textbox allows us to resize the text rectangle and wrap it automatically. This is not the case for IText, as the height does not adjust based on line breaks. We can manipulate IText objects by using various properties. Similarly, we can use the withoutTransform property to remove the transform of the current object in the URL string of the IText object.
toDataURL({ withoutTransform: Boolean }: Object): String
Options (optional)- This parameter is anobjectthat provides additional customization for the URL representation of the IText object. Height, quality, format, and many other properties can be changed using this parameter, where withoutTransform is a property.
withoutTransform- This property accepts aBooleanvalue which allows us to get rid of the current object transformation. By passing it a true value, there will be no scale, angle, flip, or tilt in the final output image.
Use the withoutTransform attribute and pass it a false value
Let's look at a code example to see the output image when passing a false value to the withoutTransform property. Once we open the console from the development tools, we can see the URL representation of the IText object. We can copy the URL and paste it into the address bar of a new tab to see the final output. In this example, we pass the IText object a scaleY property that specifies the vertical scale factor. So our output will be scaled vertically. However, since we also passed a false value to the withoutTransform property, our final output image will still contain the scaleY property.
Using the withoutTransform property and passing it a false value
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 vertical scaling
Use the withoutTransform attribute and pass it a true value
Let's look at a code example to see what the final output image of an IText object looks like when using the withoutTransform property and passing a true value to it. In this case, our final output image will not contain any object transformations.
Using the withoutTransform property and passing it a true value
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 vertical scaling
The above is the detailed content of How to remove current object cast from URL string of IText object using FabricJS?. For more information, please follow other related articles on the PHP Chinese website!