FabricJS – How to move a Line object one step up in the stack of drawn objects?


In this tutorial, we are going to learn about how to move a Line object one step up in the stack of drawn objects using FabricJS. A Line element is one of the basic elements provided in FabricJS. It is used for creating straight lines. Because line elements are geometrically one-dimensional and do not contain an interior, they are never filled. We can create a line object by creating an instance of fabric.Line, specifying the x and y coordinates of the line and adding it to the canvas. In order to move a Line object one step up in the stack of drawn objects, we use the bringForward method.

Syntax

bringForward(intersecting: Boolean): fabric.Object

Parameters

  • Intersecting βˆ’ This parameter accepts a Boolean value which when assigned a β€˜true’ value, sends the object in front of the next upper intersecting object. In case of β€˜false’ value, it normally sends the object one step up the next object in stack. This parameter is optional.

Using bringForward method

Example

Let’s see a code example to see the output when the bringForward method is used. The bringForward method moves an object one-step up in the stack of drawn objects. In this case line1 is sent above line2, on using the bringForward method.

<!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 bringForward method</h2> <p> You can see that line1 (blue) has been moved up in the stack of drawn objects </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 Line object var line1 = new fabric.Line([200, 100, 100, 40], { stroke: "blue", strokeWidth: 20, }); // Initiate another Line object var line2 = new fabric.Line([200, 70, 70, 40], { stroke: "red", strokeWidth: 20, }); // Add both to the canvas canvas.add(line1); canvas.add(line2); // Using bringForward method line1.bringForward(); </script> </body> </html>

Using bringForward method with three objects and intersection key enabled

Example

In this example, we have used three line objects namely line1, line2 and line3. Although they have been added to the canvas according to their numerical order, line1 clearly lies above line3. This is because we have used the bringForward method with intersection key enabled, which sends line1 on top of its next upper intersecting object which is line3.

<!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 bringForward method with three objects and intersection key enabled</h2> <p> You can see that the blue line now lies above the green line which is line number 3 </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 Line object var line1 = new fabric.Line([200, 100, 100, 40], { stroke: "blue", strokeWidth: 20, }); // Initiate another Line object var line2 = new fabric.Line([500, 70, 400, 40], { stroke: "red", strokeWidth: 20, }); // Initiate another Line object var line3 = new fabric.Line([200, 30, 30, 90], { stroke: "green", strokeWidth: 20, }); // Add them all to the canvas canvas.add(line1); canvas.add(line2); canvas.add(line3); // Using bringForward method line1.bringForward(true); </script> </body> </html>

Updated on: 25-Oct-2022

108 Views

Kickstart Your Career

Get certified by completing the course

Get Started
Advertisements