En este artículo, veremos cómo bloquear el ancho del trazo al escalar la elipse del lienzo usando FabricJS. El lienzo significa que la elipse es móvil y se puede estirar según los requisitos. Además, la elipse se puede personalizar en lo que respecta al color del trazo inicial, el color de relleno, el ancho del trazo o el radio.
Para hacerlo posible, vamos a utilizar una biblioteca de JavaScript llamada FabricJS. Después de importar la biblioteca mediante CDN, crearemos un bloque de lienzo en la etiqueta del cuerpo que contendrá nuestra elipse. Después de esto, inicializaremos las instancias de Canvas y Ellipse proporcionadas por FabricJS y bloquearemos el ancho del trazo mientras escalamos una elipse del lienzo usando la propiedad strokeUniform y representaremos la elipse en el lienzo como se muestra en el ejemplo a continuación.
Sintaxis:
fabric.Ellipse({ rx: number, ry: number, stroke: string, strokeUniform: boolean });
Parámetros: esta función acepta cuatro parámetros, como se mencionó anteriormente y se describe a continuación:
- rx: Especifica el radio horizontal.
- ry: Especifica el radio vertical.
- trazo: Especifica el color del trazo.
- strokeUniform: especifica si se bloquea el ancho del trazo al escalar.
Ejemplo: este ejemplo usa FabricJS para bloquear el ancho del trazo al escalar una elipse de lienzo.
<!DOCTYPE hyml> <html> <head> <title> Fabric.js | Ellipse strokeUniform Property </title> <!-- FabricJS CDN --> <script src= "https://cdnjs.cloudflare.com/ajax/libs/fabric.js/3.6.2/fabric.min.js"> </script> </head> <body> <div style="text-align: center;width: 600px;"> <h1 style="color: green;"> GeeksforGeeks </h1> <b> Fabric.js | Ellipse strokeUniform Property </b> </div> <div style="text-align: center;"> <canvas id="canvas" width="600" height="200" style="border:1px solid #000000;"> </canvas> </div> <script> // Initiate a Canvas instance var canvas = new fabric.Canvas("canvas"); // Initiate a Ellipse instance var ellipse = new fabric.Ellipse({ rx: 80, ry: 40, stroke: 'red', strokeUniform: true }); // Render the Ellipse in canvas canvas.add(ellipse); </script> </body> </html>
Producción: