<?xml version="1.0" encoding="UTF-8" ?>
<class name="ArrayOccluder3D" inherits="Occluder3D" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../class.xsd">
	<brief_description>
		3D polygon shape for use with occlusion culling in [OccluderInstance3D].
	</brief_description>
	<description>
		[ArrayOccluder3D] stores an arbitrary 3D polygon shape that can be used by the engine's occlusion culling system. This is analogous to [ArrayMesh], but for occluders.
		See [OccluderInstance3D]'s documentation for instructions on setting up occlusion culling.
	</description>
	<tutorials>
		<link title="Occlusion culling">$DOCS_URL/tutorials/3d/occlusion_culling.html</link>
	</tutorials>
	<methods>
		<method name="set_arrays">
			<return type="void" />
			<param index="0" name="vertices" type="PackedVector3Array" />
			<param index="1" name="indices" type="PackedInt32Array" />
			<description>
				Sets [member indices] and [member vertices], while updating the final occluder only once after both values are set.
			</description>
		</method>
	</methods>
	<members>
		<member name="indices" type="PackedInt32Array" setter="set_indices" getter="get_indices" default="PackedInt32Array()">
			The occluder's index position. Indices determine which points from the [member vertices] array should be drawn, and in which order.
			[b]Note:[/b] The occluder is always updated after setting this value. If creating occluders procedurally, consider using [method set_arrays] instead to avoid updating the occluder twice when it's created.
		</member>
		<member name="vertices" type="PackedVector3Array" setter="set_vertices" getter="get_vertices" default="PackedVector3Array()">
			The occluder's vertex positions in local 3D coordinates.
			[b]Note:[/b] The occluder is always updated after setting this value. If creating occluders procedurally, consider using [method set_arrays] instead to avoid updating the occluder twice when it's created.
		</member>
	</members>
</class>