Gizmo2D is inspired by Unity's Gizmo library. This library allows you to easily and quickly create visuals for debugging 2D information like lines, shapes, arrows and more. The library utilizes GuiObjects to render visual information.
Gizmo2D.mp4
The library consists of the following visual debugging features.
- Circles
- Squares
- Rectangles
- Lines
- Arrows
- Triangles
- Points
- TextLabels
To get your hands on the latest version of the library, go to the Releases page in the repository, select the latest release, download the Gizmo2D.rbxm binary. For a Rojo workflow, it is recommended to use wally, a package manager for roblox. If you have setup wally on your computer, put the following in your wally.toml
file and install the dependencies.
[dependencies]
Gizmo2D = "jaipack17/[email protected]"
After installing the dependencies, the library should be added to the Index of your Packages folder. You can then require the library and start using it.
Require the library by simply typing in the following and replacing path.to.gizmo2d
with the actual path in-game.
local Gizmo2D = require(path.to.gizmo2d)
Almost all tools for debugging have Fill
, Stroke
and StrokeWeight
properties. These properties refer to the BackgroundColor and BorderColor for the object. If you wish to create transparent objects, pass in Fill
as nil.
This method is used to draw circles with arbitrary radii on the screen.
-- Parameters - Position: Vector2, Parent: Instance, Properties: table
Gizmo2D.Circle(Vector2.new(50, 50), SomeParent, {
Radius = 25, -- number
Fill = Color3.new(1, 1, 1), -- Color3|nil
Stroke = Color3.new(1, 0, 0), -- Color3|nil
StrokeWeight = 2 -- number|nil
})
This method is used to draw squares with arbitrary side measurments on the screen.
-- Parameters - Position: Vector2, Parent: Instance, Properties: table
Gizmo2D.Square(Vector2.new(50, 50), SomeParent, {
Side = 50, -- number
Mode = "CENTER", -- string|nil. Refers to the anchor point of the square. Must be either CENTER or nil
Fill = Color3.new(1, 1, 1), -- Color3|nil
Stroke = Color3.new(1, 0, 0), -- Color3|nil
StrokeWeight = 2 -- number|nil
})
This method is used to draw rectangles with arbitrary width and height measurments on the screen.
-- Parameters - Position: Vector2, Parent: Instance, Properties: table
Gizmo2D.Rectangle(Vector2.new(50, 50), SomeParent, {
Width = 100, -- number
Height = 50, -- number
Mode = "CENTER", -- string|nil
Fill = Color3.new(1, 1, 1), -- Color3|nil
Stroke = Color3.new(1, 0, 0), -- Color3|nil
StrokeWeight = 2 -- number|nil
})
This method is used to draw a line segment given to points on the screen.
-- Parameters - Point1: Vector2, Point2: Vector2, Parent: Instance, Properties: table
Gizmo2D.Line(Vector2.new(50, 50), Vector2.new(100, 100), SomeParent, {
Thickness = 2, -- number|nil
Fill = Color3.new(1, 1, 1), -- Color3|nil
Stroke = Color3.new(1, 0, 0), -- Color3|nil
StrokeWeight = 2 -- number|nil
})
This method is used to draw an arrow/vector given to points on the screen.
-- Parameters - Point1: Vector2, Point2: Vector2, Parent: Instance, Properties: table
Gizmo2D.Arrow(Vector2.new(50, 50), Vector2.new(100, 100), SomeParent, {
Thickness = 2, -- number|nil
Fill = Color3.new(1, 1, 1), -- Color3
})
This method is used to draw triangles given 3 points on the screen.
-- Parameters - Point1: Vector2, Point2: Vector2, Point3: Vector2, Parent: Instance, Properties: table
Gizmo2D.Triangle(Vector2.new(50, 50), Vector2.new(100, 100), Vector2.new(50, 100), SomeParent, {
Fill = Color3.new(1, 1, 1), -- Color3
})
This method is used to draw points on the screen, with a default radius of 2.5.
-- Parameters - Position: Vector2, Parent: Instance, Properties: table
Gizmo2D.Point(Vector2.new(50, 50), SomeParent, {
Fill = Color3.new(1, 1, 1), -- Color3
})
This method is used to draw text on screen by utilizing TextLabels.
-- Parameters - Position: Vector2, Parent: Instance, Properties: table
Gizmo2D.Label(Vector2.new(50, 50), Vector2.new(100, 100), Vector2.new(50, 100), SomeParent, {
Text = "Some Text", -- string
Size = Vector2.new(30, 30), -- Vector2
TextSize = 15, -- number|nil
TextFill = Color3.new(1, 1, 1), -- Color3|nil
TextStroke = Color3.new(1, 0, 1), -- Color3|nil
TextStrokeWeight = 2, -- number|nil
TextScaled = false, -- boolean|nil
Font = Enum.Font.Gotham -- EnumItem|string|nil
})