Up to date

This page is up to date for Godot 4.3. If you still find outdated information, please open an issue.

Polygon2D

Inherits: Node2D < CanvasItem < Node < Object

A 2D polygon.

Description

A Polygon2D is defined by a set of points. Each point is connected to the next, with the final point being connected to the first, resulting in a closed polygon. Polygon2Ds can be filled with color (solid or gradient) or filled with a given texture.

Properties

bool

antialiased

false

Array

bones

[]

Color

color

Color(1, 1, 1, 1)

int

internal_vertex_count

0

float

invert_border

100.0

bool

invert_enabled

false

Vector2

offset

Vector2(0, 0)

PackedVector2Array

polygon

PackedVector2Array()

Array

polygons

[]

NodePath

skeleton

NodePath("")

Texture2D

texture

Vector2

texture_offset

Vector2(0, 0)

float

texture_rotation

0.0

Vector2

texture_scale

Vector2(1, 1)

PackedVector2Array

uv

PackedVector2Array()

PackedColorArray

vertex_colors

PackedColorArray()

Methods

void

add_bone(path: NodePath, weights: PackedFloat32Array)

void

clear_bones()

void

erase_bone(index: int)

int

get_bone_count() const

NodePath

get_bone_path(index: int) const

PackedFloat32Array

get_bone_weights(index: int) const

void

set_bone_path(index: int, path: NodePath)

void

set_bone_weights(index: int, weights: PackedFloat32Array)


Property Descriptions

bool antialiased = false 🔗

  • void set_antialiased(value: bool)

  • bool get_antialiased()

If true, polygon edges will be anti-aliased.


Array bones = [] 🔗

Internal list of Bone2D nodes used by the assigned skeleton. Edited using the Polygon2D editor ("UV" button on the top toolbar).


Color color = Color(1, 1, 1, 1) 🔗

The polygon's fill color. If texture is set, it will be multiplied by this color. It will also be the default color for vertices not set in vertex_colors.


int internal_vertex_count = 0 🔗

  • void set_internal_vertex_count(value: int)

  • int get_internal_vertex_count()

Number of internal vertices, used for UV mapping.


float invert_border = 100.0 🔗

  • void set_invert_border(value: float)

  • float get_invert_border()

Added padding applied to the bounding box when invert_enabled is set to true. Setting this value too small may result in a "Bad Polygon" error.


bool invert_enabled = false 🔗

  • void set_invert_enabled(value: bool)

  • bool get_invert_enabled()

If true, the polygon will be inverted, containing the area outside the defined points and extending to the invert_border.


Vector2 offset = Vector2(0, 0) 🔗

The offset applied to each vertex.


PackedVector2Array polygon = PackedVector2Array() 🔗

The polygon's list of vertices. The final point will be connected to the first.

Note: The returned array is copied and any changes to it will not update the original property value. See PackedVector2Array for more details.


Array polygons = [] 🔗

  • void set_polygons(value: Array)

  • Array get_polygons()

The list of polygons, in case more than one is being represented. Every individual polygon is stored as a PackedInt32Array where each int is an index to a point in polygon. If empty, this property will be ignored, and the resulting single polygon will be composed of all points in polygon, using the order they are stored in.


NodePath skeleton = NodePath("") 🔗

Path to a Skeleton2D node used for skeleton-based deformations of this polygon. If empty or invalid, skeletal deformations will not be used.


Texture2D texture 🔗

The polygon's fill texture. Use uv to set texture coordinates.


Vector2 texture_offset = Vector2(0, 0) 🔗

  • void set_texture_offset(value: Vector2)

  • Vector2 get_texture_offset()

Amount to offset the polygon's texture. If set to Vector2(0, 0), the texture's origin (its top-left corner) will be placed at the polygon's position.


float texture_rotation = 0.0 🔗

  • void set_texture_rotation(value: float)

  • float get_texture_rotation()

The texture's rotation in radians.


Vector2 texture_scale = Vector2(1, 1) 🔗

Amount to multiply the uv coordinates when using texture. Larger values make the texture smaller, and vice versa.


PackedVector2Array uv = PackedVector2Array() 🔗

Texture coordinates for each vertex of the polygon. There should be one UV value per polygon vertex. If there are fewer, undefined vertices will use Vector2(0, 0).

Note: The returned array is copied and any changes to it will not update the original property value. See PackedVector2Array for more details.


PackedColorArray vertex_colors = PackedColorArray() 🔗

Color for each vertex. Colors are interpolated between vertices, resulting in smooth gradients. There should be one per polygon vertex. If there are fewer, undefined vertices will use color.

Note: The returned array is copied and any changes to it will not update the original property value. See PackedColorArray for more details.


Method Descriptions

void add_bone(path: NodePath, weights: PackedFloat32Array) 🔗

Adds a bone with the specified path and weights.


void clear_bones() 🔗

Removes all bones from this Polygon2D.


void erase_bone(index: int) 🔗

Removes the specified bone from this Polygon2D.


int get_bone_count() const 🔗

Returns the number of bones in this Polygon2D.


NodePath get_bone_path(index: int) const 🔗

Returns the path to the node associated with the specified bone.


PackedFloat32Array get_bone_weights(index: int) const 🔗

Returns the weight values of the specified bone.


void set_bone_path(index: int, path: NodePath) 🔗

Sets the path to the node associated with the specified bone.


void set_bone_weights(index: int, weights: PackedFloat32Array) 🔗

Sets the weight values for the specified bone.