summaryrefslogtreecommitdiffstats
path: root/doc/classes/Line2D.xml
diff options
context:
space:
mode:
authorMewPurPur <mew.pur.pur@gmail.com>2023-08-28 21:44:06 +0300
committerMewPurPur <mew.pur.pur@gmail.com>2023-08-29 15:02:26 +0300
commit39f50da2caf88617594449eb761cb7f1031f795a (patch)
treea5f7de8f9993e55aae5b81d5f619fd06a3f3c8a0 /doc/classes/Line2D.xml
parent6758a7f8c07d1f4c8ec4f052ded6d26402967ebe (diff)
downloadredot-engine-39f50da2caf88617594449eb761cb7f1031f795a.tar.gz
Improve Line2D documentation
Diffstat (limited to 'doc/classes/Line2D.xml')
-rw-r--r--doc/classes/Line2D.xml63
1 files changed, 32 insertions, 31 deletions
diff --git a/doc/classes/Line2D.xml b/doc/classes/Line2D.xml
index c055603bcd..7e02a520a0 100644
--- a/doc/classes/Line2D.xml
+++ b/doc/classes/Line2D.xml
@@ -1,10 +1,12 @@
<?xml version="1.0" encoding="UTF-8" ?>
<class name="Line2D" inherits="Node2D" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../class.xsd">
<brief_description>
- A 2D line.
+ A 2D polyline that can optionally be textured.
</brief_description>
<description>
- A line through several points in 2D space.
+ This node draws a 2D polyline, i.e. a shape consisting of several points connected by segments. [Line2D] is not a mathematical polyline, i.e. the segments are not infinitely thin. It is intended for rendering and it can be colored and optionally textured.
+ [b]Warning:[/b] Certain configurations may be impossible to draw nicely, such as very sharp angles. In these situations, the node uses fallback drawing logic to look decent.
+ [b]Note:[/b] [Line2D] is drawn using a 2D mesh.
</description>
<tutorials>
<link title="Matrix Transform Demo">https://godotengine.org/asset-library/asset/584</link>
@@ -16,20 +18,20 @@
<param index="0" name="position" type="Vector2" />
<param index="1" name="index" type="int" default="-1" />
<description>
- Adds a point with the specified [param position] relative to the line's own position. Appends the new point at the end of the point list.
- If [param index] is given, the new point is inserted before the existing point identified by index [param index]. Every existing point starting from [param index] is shifted further down the list of points. The index must be greater than or equal to [code]0[/code] and must not exceed the number of existing points in the line. See [method get_point_count].
+ Adds a point with the specified [param position] relative to the polyline's own position. If no [param index] is provided, the new point will be added to the end of the points array.
+ If [param index] is given, the new point is inserted before the existing point identified by index [param index]. The indices of the points after the new point get increased by 1. The provided [param index] must not exceed the number of existing points in the polyline. See [method get_point_count].
</description>
</method>
<method name="clear_points">
<return type="void" />
<description>
- Removes all points from the line.
+ Removes all points from the polyline, making it empty.
</description>
</method>
<method name="get_point_count" qualifiers="const">
<return type="int" />
<description>
- Returns the number of points in the line.
+ Returns the number of points in the polyline.
</description>
</method>
<method name="get_point_position" qualifiers="const">
@@ -43,7 +45,7 @@
<return type="void" />
<param index="0" name="index" type="int" />
<description>
- Removes the point at index [param index] from the line.
+ Removes the point at index [param index] from the polyline.
</description>
</method>
<method name="set_point_position">
@@ -51,80 +53,79 @@
<param index="0" name="index" type="int" />
<param index="1" name="position" type="Vector2" />
<description>
- Overwrites the position of the point at index [param index] with the supplied [param position].
+ Overwrites the position of the point at the given [param index] with the supplied [param position].
</description>
</method>
</methods>
<members>
<member name="antialiased" type="bool" setter="set_antialiased" getter="get_antialiased" default="false">
- If [code]true[/code], the line's border will be anti-aliased.
- [b]Note:[/b] Line2D is not accelerated by batching when being anti-aliased.
+ If [code]true[/code], the polyline's border will be anti-aliased.
+ [b]Note:[/b] [Line2D] is not accelerated by batching when being anti-aliased.
</member>
<member name="begin_cap_mode" type="int" setter="set_begin_cap_mode" getter="get_begin_cap_mode" enum="Line2D.LineCapMode" default="0">
- Controls the style of the line's first point. Use [enum LineCapMode] constants.
+ The style of the beginning of the polyline. Use [enum LineCapMode] constants.
</member>
<member name="default_color" type="Color" setter="set_default_color" getter="get_default_color" default="Color(1, 1, 1, 1)">
- The line's color. Will not be used if a gradient is set.
+ The color of the polyline. Will not be used if a gradient is set.
</member>
<member name="end_cap_mode" type="int" setter="set_end_cap_mode" getter="get_end_cap_mode" enum="Line2D.LineCapMode" default="0">
- Controls the style of the line's last point. Use [enum LineCapMode] constants.
+ The style of the end of the polyline. Use [enum LineCapMode] constants.
</member>
<member name="gradient" type="Gradient" setter="set_gradient" getter="get_gradient">
The gradient is drawn through the whole line from start to finish. The default color will not be used if a gradient is set.
</member>
<member name="joint_mode" type="int" setter="set_joint_mode" getter="get_joint_mode" enum="Line2D.LineJointMode" default="0">
- The style for the points between the start and the end.
+ The style of the connections between segments of the polyline. Use [enum LineJointMode] constants.
</member>
<member name="points" type="PackedVector2Array" setter="set_points" getter="get_points" default="PackedVector2Array()">
- The points that form the lines. The line is drawn between every point set in this array. Points are interpreted as local vectors.
+ The points of the polyline, interpreted in local 2D coordinates. Segments are drawn between the adjacent points in this array.
</member>
<member name="round_precision" type="int" setter="set_round_precision" getter="get_round_precision" default="8">
- The smoothness of the rounded joints and caps. Higher values result in smoother corners, but are more demanding to render and update. This is only used if a cap or joint is set as round.
- [b]Note:[/b] The default value is tuned for lines with the default [member width]. For thin lines, this value should be reduced to a number between [code]2[/code] and [code]4[/code] to improve performance.
+ The smoothness used for rounded joints and caps. Higher values result in smoother corners, but are more demanding to render and update.
</member>
<member name="sharp_limit" type="float" setter="set_sharp_limit" getter="get_sharp_limit" default="2.0">
- The direction difference in radians between vector points. This value is only used if [member joint_mode] is set to [constant LINE_JOINT_SHARP].
+ Determines the miter limit of the polyline. Normally, when [member joint_mode] is set to [constant LINE_JOINT_SHARP], sharp angles fall back to using the logic of [constant LINE_JOINT_BEVEL] joints to prevent very long miters. Higher values of this property mean that the fallback to a bevel joint will happen at sharper angles.
</member>
<member name="texture" type="Texture2D" setter="set_texture" getter="get_texture">
- The texture used for the line's texture. Uses [code]texture_mode[/code] for drawing style.
+ The texture used for the polyline. Uses [code]texture_mode[/code] for drawing style.
</member>
<member name="texture_mode" type="int" setter="set_texture_mode" getter="get_texture_mode" enum="Line2D.LineTextureMode" default="0">
- The style to render the [code]texture[/code] on the line. Use [enum LineTextureMode] constants.
+ The style to render the [member texture] of the polyline. Use [enum LineTextureMode] constants.
</member>
<member name="width" type="float" setter="set_width" getter="get_width" default="10.0">
- The line's width.
+ The polyline's width
</member>
<member name="width_curve" type="Curve" setter="set_curve" getter="get_curve">
- The line's width varies with the curve. The original width is simply multiply by the value of the Curve.
+ The polyline's width curve. The width of the polyline over its length will be equivalent to the value of the width curve over its domain.
</member>
</members>
<constants>
<constant name="LINE_JOINT_SHARP" value="0" enum="LineJointMode">
- The line's joints will be pointy. If [code]sharp_limit[/code] is greater than the rotation of a joint, it becomes a bevel joint instead.
+ Makes the polyline's joints pointy, connecting the sides of the two segments by extending them until they intersect. If the rotation of a joint is too big (based on [member sharp_limit]), the joint falls back to [constant LINE_JOINT_BEVEL] to prevent very long miters.
</constant>
<constant name="LINE_JOINT_BEVEL" value="1" enum="LineJointMode">
- The line's joints will be bevelled/chamfered.
+ Makes the polyline's joints bevelled/chamfered, connecting the sides of the two segments with a simple line.
</constant>
<constant name="LINE_JOINT_ROUND" value="2" enum="LineJointMode">
- The line's joints will be rounded.
+ Makes the polyline's joints rounded, connecting the sides of the two segments with an arc. The detail of this arc depends on [member round_precision].
</constant>
<constant name="LINE_CAP_NONE" value="0" enum="LineCapMode">
- Don't draw a line cap.
+ Draws no line cap.
</constant>
<constant name="LINE_CAP_BOX" value="1" enum="LineCapMode">
- Draws the line cap as a box.
+ Draws the line cap as a box, slightly extending the first/last segment.
</constant>
<constant name="LINE_CAP_ROUND" value="2" enum="LineCapMode">
- Draws the line cap as a circle.
+ Draws the line cap as a semicircle attached to the first/last segment.
</constant>
<constant name="LINE_TEXTURE_NONE" value="0" enum="LineTextureMode">
- Takes the left pixels of the texture and renders it over the whole line.
+ Takes the left pixels of the texture and renders them over the whole polyline.
</constant>
<constant name="LINE_TEXTURE_TILE" value="1" enum="LineTextureMode">
- Tiles the texture over the line. [member CanvasItem.texture_repeat] of the [Line2D] node must be [constant CanvasItem.TEXTURE_REPEAT_ENABLED] or [constant CanvasItem.TEXTURE_REPEAT_MIRROR] for it to work properly.
+ Tiles the texture over the polyline. [member CanvasItem.texture_repeat] of the [Line2D] node must be [constant CanvasItem.TEXTURE_REPEAT_ENABLED] or [constant CanvasItem.TEXTURE_REPEAT_MIRROR] for it to work properly.
</constant>
<constant name="LINE_TEXTURE_STRETCH" value="2" enum="LineTextureMode">
- Stretches the texture across the line. [member CanvasItem.texture_repeat] of the [Line2D] node must be [constant CanvasItem.TEXTURE_REPEAT_DISABLED] for best results.
+ Stretches the texture across the polyline. [member CanvasItem.texture_repeat] of the [Line2D] node must be [constant CanvasItem.TEXTURE_REPEAT_DISABLED] for best results.
</constant>
</constants>
</class>