2017-09-12 20:42:36 +00:00
<?xml version="1.0" encoding="UTF-8" ?>
2021-03-23 12:40:34 +00:00
<class name= "ImmediateGeometry" inherits= "GeometryInstance" version= "3.3" >
2017-09-12 20:42:36 +00:00
<brief_description >
2017-10-09 10:49:12 +00:00
Draws simple geometry from code.
2017-09-12 20:42:36 +00:00
</brief_description>
<description >
2017-10-09 10:49:12 +00:00
Draws simple geometry from code. Uses a drawing mode similar to OpenGL 1.x.
2020-04-19 21:21:42 +00:00
See also [ArrayMesh], [MeshDataTool] and [SurfaceTool] for procedural geometry generation.
[b]Note:[/b] ImmediateGeometry3D is best suited to small amounts of mesh data that change every frame. It will be slow when handling large amounts of mesh data. If mesh data doesn't change often, use [ArrayMesh], [MeshDataTool] or [SurfaceTool] instead.
[b]Note:[/b] Godot uses clockwise [url=https://learnopengl.com/Advanced-OpenGL/Face-culling]winding order[/url] for front faces of triangle primitive modes.
2020-10-30 11:13:48 +00:00
[b]Note:[/b] In case of missing points when handling large amounts of mesh data, try increasing its buffer size limit under [member ProjectSettings.rendering/limits/buffers/immediate_buffer_size_kb].
2017-09-12 20:42:36 +00:00
</description>
<tutorials >
</tutorials>
<methods >
<method name= "add_sphere" >
<return type= "void" >
</return>
<argument index= "0" name= "lats" type= "int" >
</argument>
<argument index= "1" name= "lons" type= "int" >
</argument>
<argument index= "2" name= "radius" type= "float" >
</argument>
<argument index= "3" name= "add_uv" type= "bool" default= "true" >
</argument>
<description >
2019-06-21 23:04:47 +00:00
Simple helper to draw an UV sphere with given latitude, longitude and radius.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "add_vertex" >
<return type= "void" >
</return>
2017-09-10 13:37:49 +00:00
<argument index= "0" name= "position" type= "Vector3" >
2017-09-12 20:42:36 +00:00
</argument>
<description >
2019-12-24 04:20:32 +00:00
Adds a vertex in local coordinate space with the currently set color/uv/etc.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "begin" >
<return type= "void" >
</return>
<argument index= "0" name= "primitive" type= "int" enum= "Mesh.PrimitiveType" >
</argument>
<argument index= "1" name= "texture" type= "Texture" default= "null" >
</argument>
<description >
2019-12-06 22:09:20 +00:00
Begin drawing (and optionally pass a texture override). When done call [method end]. For more information on how this works, search for [code]glBegin()[/code] and [code]glEnd()[/code] references.
For the type of primitive, see the [enum Mesh.PrimitiveType] enum.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "clear" >
<return type= "void" >
</return>
<description >
2017-10-09 10:49:12 +00:00
Clears everything that was drawn using begin/end.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "end" >
<return type= "void" >
</return>
<description >
2017-10-09 10:49:12 +00:00
Ends a drawing context and displays the results.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "set_color" >
<return type= "void" >
</return>
<argument index= "0" name= "color" type= "Color" >
</argument>
<description >
2017-10-09 10:49:12 +00:00
The current drawing color.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "set_normal" >
<return type= "void" >
</return>
<argument index= "0" name= "normal" type= "Vector3" >
</argument>
<description >
2017-10-09 10:49:12 +00:00
The next vertex's normal.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "set_tangent" >
<return type= "void" >
</return>
<argument index= "0" name= "tangent" type= "Plane" >
</argument>
<description >
2017-10-09 10:49:12 +00:00
The next vertex's tangent (and binormal facing).
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "set_uv" >
<return type= "void" >
</return>
<argument index= "0" name= "uv" type= "Vector2" >
</argument>
<description >
2017-10-09 10:49:12 +00:00
The next vertex's UV.
2017-09-12 20:42:36 +00:00
</description>
</method>
<method name= "set_uv2" >
<return type= "void" >
</return>
<argument index= "0" name= "uv" type= "Vector2" >
</argument>
<description >
2017-10-09 10:49:12 +00:00
The next vertex's second layer UV.
2017-09-12 20:42:36 +00:00
</description>
</method>
</methods>
<constants >
</constants>
</class>