Maison > Article > interface Web > Comment redresser une image avec animation à l'aide de FabricJS ?
Dans ce tutoriel, nous allons apprendre à redresser une image à l'aide de l'animation TissuJS. Nous pouvons créer un objet Image en créant une instance de fabric.Image. depuis C'est l'un des éléments de base de FabricJS et nous pouvons également le personnaliser facilement via l'application Angle, opacité et autres propriétés. Pour redresser l'image avec l'animation, nous utilisons Méthode fxStraighten.
fxStraighten(callbacks: Object): fabric.Object
callbacks - Ce paramètre est un objet avec une fonction de rappel qui peut être utilisé Modifiez certaines propriétés liées à l'animation.
Regardons un exemple de code pour comprendre comment un objet Image est affiché lors de l'utilisation de la méthode straighten Utilisé à la place de fxstraighten. Cela nous aidera à réaliser la différence entre eux. La méthode redresser simplement redresser fait pivoter l'objet de l'angle actuel vers 0, 90,180, 270, etc. selon celui qui est le plus proche. Cependant, fxstraighten fonctionne pour De la même manière, mais avec animation.
<!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 Straighten method</h2> <p> You can see that there is no animation but the image has been straightened </p> <canvas id="canvas"></canvas> <img src="https://www.tutorialspoint.com/images/logo.png" id="img1" style="display: none" /> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); // Initiating the image element var imageElement = document.getElementById("img1"); // Initiate an Image object var image = new fabric.Image(imageElement, { top: 10, left: 110, skewX: 15, angle: 45, }); // Add it to the canvas canvas.add(image); // Using the straighten method image.straighten(); </script> </body> </html>
Dans cet exemple, nous avons utilisé la méthode fxstraighten pour redresser l'objet image et affiche une animation simple. L'objet image a un angle de 45 degrés, Redressez en retournant à 0 degré. En dehors de cela, la fonction onChange est Elle est appelée à chaque étape de l'animation, et la fonction onComplete n'est appelée qu'à L'animation est terminée, c'est pourquoi notre objet image finit par être mis à l'échelle Déplacez-vous horizontalement 1,5 fois et partez d'une valeur de 130.
<!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 fxStraighten method</h2> <p> You can see that the image gets straightened while also displaying an animation </p> <canvas id="canvas"></canvas> <img src="https://www.tutorialspoint.com/images/logo.png" id="img1" style="display: none" /> <script> // Initiate a canvas instance var canvas = new fabric.Canvas("canvas"); canvas.setWidth(document.body.scrollWidth); canvas.setHeight(250); // Initiating the image element var imageElement = document.getElementById("img1"); // Initiate an Image object var image = new fabric.Image(imageElement, { top: 10, left: 110, skewX: 15, angle: 45, }); // Add it to the canvas canvas.add(image); // Using fxStraighten method image.fxStraighten({ onChange() { canvas.renderAll(); }, onComplete() { image.set("left", 130); image.set("scaleX", 1.5); canvas.renderAll(); }, }); </script> </body> </html>
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!