En este artículo, veremos cómo bloquear el volteo escalando 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 volteo escalando la elipse del lienzo usando la propiedad lockScalingFlip y representaremos la elipse en el lienzo como se muestra en el siguiente ejemplo.
Sintaxis:
fabric.Ellipse({ rx: number, ry: number, lockScalingFlip: boolean });
Parámetros: esta función acepta tres parámetros, como se mencionó anteriormente y se describe a continuación:
- rx: este parámetro contiene el valor del radio horizontal.
- ry: este parámetro contiene el valor del radio vertical.
- lockScalingFlip: este parámetro verifica si bloquear el volteo escalando el lienzo.
Programa: este ejemplo usa FabricJS para bloquear el volteo escalando la elipse similar a un lienzo como se indica a continuación.
<!DOCTYPE html> <html> <head> <title> Fabric.js | Ellipse lockScalingFlip Property </title> <!-- Loading the FabricJS library --> <script src= "https://cdnjs.cloudflare.com/ajax/libs/fabric.js/3.6.2/fabric.min.js"> </script> </head> <body> <center> <h1 style="color: green;"> GeeksforGeeks </h1> <b> Lock flipping by scaling of the canvas-type ellipse with JavaScript. </b> <canvas id="canvas" width="600" height="200" style="border:1px solid #000000"> </canvas> </center> <script> // Initiate a Canvas instance var canvas = new fabric.Canvas("canvas"); // Initiate a Ellipse instance var ellipse = new fabric.Ellipse({ rx: 80, ry: 40, lockScalingFlip: true }); // Render the Ellipse in canvas canvas.add(ellipse); </script> </body> </html>
Producción: