class_occluder.rst 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. :github_url: hide
  2. .. Generated automatically by doc/tools/make_rst.py in Godot's source tree.
  3. .. DO NOT EDIT THIS FILE, but the Occluder.xml source instead.
  4. .. The source is found in doc/classes or modules/<name>/doc_classes.
  5. .. _class_Occluder:
  6. Occluder
  7. ========
  8. **Inherits:** :ref:`Spatial<class_Spatial>` **<** :ref:`Node<class_Node>` **<** :ref:`Object<class_Object>`
  9. Allows :ref:`OccluderShape<class_OccluderShape>`\ s to be used for occlusion culling.
  10. Description
  11. -----------
  12. ``Occluder``\ s that are placed within your scene will automatically cull objects that are hidden from view by the occluder. This can increase performance by decreasing the amount of objects drawn.
  13. ``Occluder``\ s are totally dynamic, you can move them as you wish. This means you can for example, place occluders on a moving spaceship, and have it occlude objects as it flies past.
  14. You can place a large number of ``Occluder``\ s within a scene. As it would be counterproductive to cull against hundreds of occluders, the system will automatically choose a selection of these for active use during any given frame, based a screen space metric. Larger occluders are favored, as well as those close to the camera. Note that a small occluder close to the camera may be a better occluder in terms of screen space than a large occluder far in the distance.
  15. The type of occlusion primitive is determined by the :ref:`OccluderShape<class_OccluderShape>` that you add to the ``Occluder``. Some :ref:`OccluderShape<class_OccluderShape>`\ s may allow more than one primitive in a single, node, for greater efficiency.
  16. Although ``Occluder``\ s work in general use, they also become even more powerful when used in conjunction with the portal system. Occluders are placed in rooms (based on their origin), and can block portals (and thus entire rooms) as well as objects from rendering.
  17. Properties
  18. ----------
  19. +-------------------------------------------+---------------------------------------------+
  20. | :ref:`OccluderShape<class_OccluderShape>` | :ref:`shape<class_Occluder_property_shape>` |
  21. +-------------------------------------------+---------------------------------------------+
  22. Methods
  23. -------
  24. +------+----------------------------------------------------------------------------------------------------------------------+
  25. | void | :ref:`resource_changed<class_Occluder_method_resource_changed>` **(** :ref:`Resource<class_Resource>` resource **)** |
  26. +------+----------------------------------------------------------------------------------------------------------------------+
  27. Property Descriptions
  28. ---------------------
  29. .. _class_Occluder_property_shape:
  30. - :ref:`OccluderShape<class_OccluderShape>` **shape**
  31. +----------+------------------+
  32. | *Setter* | set_shape(value) |
  33. +----------+------------------+
  34. | *Getter* | get_shape() |
  35. +----------+------------------+
  36. Method Descriptions
  37. -------------------
  38. .. _class_Occluder_method_resource_changed:
  39. - void **resource_changed** **(** :ref:`Resource<class_Resource>` resource **)**
  40. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  41. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  42. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`