class_camerafeed.rst 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442
  1. :github_url: hide
  2. .. DO NOT EDIT THIS FILE!!!
  3. .. Generated automatically from Godot engine sources.
  4. .. Generator: https://github.com/godotengine/godot/tree/master/doc/tools/make_rst.py.
  5. .. XML source: https://github.com/godotengine/godot/tree/master/doc/classes/CameraFeed.xml.
  6. .. _class_CameraFeed:
  7. CameraFeed
  8. ==========
  9. **Inherits:** :ref:`RefCounted<class_RefCounted>` **<** :ref:`Object<class_Object>`
  10. A camera feed gives you access to a single physical camera attached to your device.
  11. .. rst-class:: classref-introduction-group
  12. Description
  13. -----------
  14. A camera feed gives you access to a single physical camera attached to your device. When enabled, Godot will start capturing frames from the camera which can then be used. See also :ref:`CameraServer<class_CameraServer>`.
  15. \ **Note:** Many cameras will return YCbCr images which are split into two textures and need to be combined in a shader. Godot does this automatically for you if you set the environment to show the camera image in the background.
  16. \ **Note:** This class is currently only implemented on Linux, Android, macOS, and iOS. On other platforms no **CameraFeed**\ s will be available. To get a **CameraFeed** on iOS, the camera plugin from `godot-ios-plugins <https://github.com/godotengine/godot-ios-plugins>`__ is required.
  17. .. rst-class:: classref-reftable-group
  18. Properties
  19. ----------
  20. .. table::
  21. :widths: auto
  22. +---------------------------------------+-----------------------------------------------------------------+------------------------------------+
  23. | :ref:`bool<class_bool>` | :ref:`feed_is_active<class_CameraFeed_property_feed_is_active>` | ``false`` |
  24. +---------------------------------------+-----------------------------------------------------------------+------------------------------------+
  25. | :ref:`Transform2D<class_Transform2D>` | :ref:`feed_transform<class_CameraFeed_property_feed_transform>` | ``Transform2D(1, 0, 0, -1, 0, 1)`` |
  26. +---------------------------------------+-----------------------------------------------------------------+------------------------------------+
  27. | :ref:`Array<class_Array>` | :ref:`formats<class_CameraFeed_property_formats>` | ``[]`` |
  28. +---------------------------------------+-----------------------------------------------------------------+------------------------------------+
  29. .. rst-class:: classref-reftable-group
  30. Methods
  31. -------
  32. .. table::
  33. :widths: auto
  34. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  35. | :ref:`bool<class_bool>` | :ref:`_activate_feed<class_CameraFeed_private_method__activate_feed>`\ (\ ) |virtual| |
  36. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  37. | |void| | :ref:`_deactivate_feed<class_CameraFeed_private_method__deactivate_feed>`\ (\ ) |virtual| |
  38. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  39. | :ref:`FeedDataType<enum_CameraFeed_FeedDataType>` | :ref:`get_datatype<class_CameraFeed_method_get_datatype>`\ (\ ) |const| |
  40. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  41. | :ref:`int<class_int>` | :ref:`get_id<class_CameraFeed_method_get_id>`\ (\ ) |const| |
  42. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  43. | :ref:`String<class_String>` | :ref:`get_name<class_CameraFeed_method_get_name>`\ (\ ) |const| |
  44. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  45. | :ref:`FeedPosition<enum_CameraFeed_FeedPosition>` | :ref:`get_position<class_CameraFeed_method_get_position>`\ (\ ) |const| |
  46. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  47. | :ref:`int<class_int>` | :ref:`get_texture_tex_id<class_CameraFeed_method_get_texture_tex_id>`\ (\ feed_image_type\: :ref:`FeedImage<enum_CameraServer_FeedImage>`\ ) |
  48. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  49. | |void| | :ref:`set_external<class_CameraFeed_method_set_external>`\ (\ width\: :ref:`int<class_int>`, height\: :ref:`int<class_int>`\ ) |
  50. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  51. | :ref:`bool<class_bool>` | :ref:`set_format<class_CameraFeed_method_set_format>`\ (\ index\: :ref:`int<class_int>`, parameters\: :ref:`Dictionary<class_Dictionary>`\ ) |
  52. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  53. | |void| | :ref:`set_name<class_CameraFeed_method_set_name>`\ (\ name\: :ref:`String<class_String>`\ ) |
  54. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  55. | |void| | :ref:`set_position<class_CameraFeed_method_set_position>`\ (\ position\: :ref:`FeedPosition<enum_CameraFeed_FeedPosition>`\ ) |
  56. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  57. | |void| | :ref:`set_rgb_image<class_CameraFeed_method_set_rgb_image>`\ (\ rgb_image\: :ref:`Image<class_Image>`\ ) |
  58. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  59. | |void| | :ref:`set_ycbcr_image<class_CameraFeed_method_set_ycbcr_image>`\ (\ ycbcr_image\: :ref:`Image<class_Image>`\ ) |
  60. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  61. | |void| | :ref:`set_ycbcr_images<class_CameraFeed_method_set_ycbcr_images>`\ (\ y_image\: :ref:`Image<class_Image>`, cbcr_image\: :ref:`Image<class_Image>`\ ) |
  62. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------+
  63. .. rst-class:: classref-section-separator
  64. ----
  65. .. rst-class:: classref-descriptions-group
  66. Signals
  67. -------
  68. .. _class_CameraFeed_signal_format_changed:
  69. .. rst-class:: classref-signal
  70. **format_changed**\ (\ ) :ref:`🔗<class_CameraFeed_signal_format_changed>`
  71. Emitted when the format has changed.
  72. .. rst-class:: classref-item-separator
  73. ----
  74. .. _class_CameraFeed_signal_frame_changed:
  75. .. rst-class:: classref-signal
  76. **frame_changed**\ (\ ) :ref:`🔗<class_CameraFeed_signal_frame_changed>`
  77. Emitted when a new frame is available.
  78. .. rst-class:: classref-section-separator
  79. ----
  80. .. rst-class:: classref-descriptions-group
  81. Enumerations
  82. ------------
  83. .. _enum_CameraFeed_FeedDataType:
  84. .. rst-class:: classref-enumeration
  85. enum **FeedDataType**: :ref:`🔗<enum_CameraFeed_FeedDataType>`
  86. .. _class_CameraFeed_constant_FEED_NOIMAGE:
  87. .. rst-class:: classref-enumeration-constant
  88. :ref:`FeedDataType<enum_CameraFeed_FeedDataType>` **FEED_NOIMAGE** = ``0``
  89. No image set for the feed.
  90. .. _class_CameraFeed_constant_FEED_RGB:
  91. .. rst-class:: classref-enumeration-constant
  92. :ref:`FeedDataType<enum_CameraFeed_FeedDataType>` **FEED_RGB** = ``1``
  93. Feed supplies RGB images.
  94. .. _class_CameraFeed_constant_FEED_YCBCR:
  95. .. rst-class:: classref-enumeration-constant
  96. :ref:`FeedDataType<enum_CameraFeed_FeedDataType>` **FEED_YCBCR** = ``2``
  97. Feed supplies YCbCr images that need to be converted to RGB.
  98. .. _class_CameraFeed_constant_FEED_YCBCR_SEP:
  99. .. rst-class:: classref-enumeration-constant
  100. :ref:`FeedDataType<enum_CameraFeed_FeedDataType>` **FEED_YCBCR_SEP** = ``3``
  101. Feed supplies separate Y and CbCr images that need to be combined and converted to RGB.
  102. .. _class_CameraFeed_constant_FEED_EXTERNAL:
  103. .. rst-class:: classref-enumeration-constant
  104. :ref:`FeedDataType<enum_CameraFeed_FeedDataType>` **FEED_EXTERNAL** = ``4``
  105. Feed supplies external image.
  106. .. rst-class:: classref-item-separator
  107. ----
  108. .. _enum_CameraFeed_FeedPosition:
  109. .. rst-class:: classref-enumeration
  110. enum **FeedPosition**: :ref:`🔗<enum_CameraFeed_FeedPosition>`
  111. .. _class_CameraFeed_constant_FEED_UNSPECIFIED:
  112. .. rst-class:: classref-enumeration-constant
  113. :ref:`FeedPosition<enum_CameraFeed_FeedPosition>` **FEED_UNSPECIFIED** = ``0``
  114. Unspecified position.
  115. .. _class_CameraFeed_constant_FEED_FRONT:
  116. .. rst-class:: classref-enumeration-constant
  117. :ref:`FeedPosition<enum_CameraFeed_FeedPosition>` **FEED_FRONT** = ``1``
  118. Camera is mounted at the front of the device.
  119. .. _class_CameraFeed_constant_FEED_BACK:
  120. .. rst-class:: classref-enumeration-constant
  121. :ref:`FeedPosition<enum_CameraFeed_FeedPosition>` **FEED_BACK** = ``2``
  122. Camera is mounted at the back of the device.
  123. .. rst-class:: classref-section-separator
  124. ----
  125. .. rst-class:: classref-descriptions-group
  126. Property Descriptions
  127. ---------------------
  128. .. _class_CameraFeed_property_feed_is_active:
  129. .. rst-class:: classref-property
  130. :ref:`bool<class_bool>` **feed_is_active** = ``false`` :ref:`🔗<class_CameraFeed_property_feed_is_active>`
  131. .. rst-class:: classref-property-setget
  132. - |void| **set_active**\ (\ value\: :ref:`bool<class_bool>`\ )
  133. - :ref:`bool<class_bool>` **is_active**\ (\ )
  134. If ``true``, the feed is active.
  135. .. rst-class:: classref-item-separator
  136. ----
  137. .. _class_CameraFeed_property_feed_transform:
  138. .. rst-class:: classref-property
  139. :ref:`Transform2D<class_Transform2D>` **feed_transform** = ``Transform2D(1, 0, 0, -1, 0, 1)`` :ref:`🔗<class_CameraFeed_property_feed_transform>`
  140. .. rst-class:: classref-property-setget
  141. - |void| **set_transform**\ (\ value\: :ref:`Transform2D<class_Transform2D>`\ )
  142. - :ref:`Transform2D<class_Transform2D>` **get_transform**\ (\ )
  143. The transform applied to the camera's image.
  144. .. rst-class:: classref-item-separator
  145. ----
  146. .. _class_CameraFeed_property_formats:
  147. .. rst-class:: classref-property
  148. :ref:`Array<class_Array>` **formats** = ``[]`` :ref:`🔗<class_CameraFeed_property_formats>`
  149. .. rst-class:: classref-property-setget
  150. - :ref:`Array<class_Array>` **get_formats**\ (\ )
  151. Formats supported by the feed. Each entry is a :ref:`Dictionary<class_Dictionary>` describing format parameters.
  152. .. rst-class:: classref-section-separator
  153. ----
  154. .. rst-class:: classref-descriptions-group
  155. Method Descriptions
  156. -------------------
  157. .. _class_CameraFeed_private_method__activate_feed:
  158. .. rst-class:: classref-method
  159. :ref:`bool<class_bool>` **_activate_feed**\ (\ ) |virtual| :ref:`🔗<class_CameraFeed_private_method__activate_feed>`
  160. Called when the camera feed is activated.
  161. .. rst-class:: classref-item-separator
  162. ----
  163. .. _class_CameraFeed_private_method__deactivate_feed:
  164. .. rst-class:: classref-method
  165. |void| **_deactivate_feed**\ (\ ) |virtual| :ref:`🔗<class_CameraFeed_private_method__deactivate_feed>`
  166. Called when the camera feed is deactivated.
  167. .. rst-class:: classref-item-separator
  168. ----
  169. .. _class_CameraFeed_method_get_datatype:
  170. .. rst-class:: classref-method
  171. :ref:`FeedDataType<enum_CameraFeed_FeedDataType>` **get_datatype**\ (\ ) |const| :ref:`🔗<class_CameraFeed_method_get_datatype>`
  172. Returns feed image data type.
  173. .. rst-class:: classref-item-separator
  174. ----
  175. .. _class_CameraFeed_method_get_id:
  176. .. rst-class:: classref-method
  177. :ref:`int<class_int>` **get_id**\ (\ ) |const| :ref:`🔗<class_CameraFeed_method_get_id>`
  178. Returns the unique ID for this feed.
  179. .. rst-class:: classref-item-separator
  180. ----
  181. .. _class_CameraFeed_method_get_name:
  182. .. rst-class:: classref-method
  183. :ref:`String<class_String>` **get_name**\ (\ ) |const| :ref:`🔗<class_CameraFeed_method_get_name>`
  184. Returns the camera's name.
  185. .. rst-class:: classref-item-separator
  186. ----
  187. .. _class_CameraFeed_method_get_position:
  188. .. rst-class:: classref-method
  189. :ref:`FeedPosition<enum_CameraFeed_FeedPosition>` **get_position**\ (\ ) |const| :ref:`🔗<class_CameraFeed_method_get_position>`
  190. Returns the position of camera on the device.
  191. .. rst-class:: classref-item-separator
  192. ----
  193. .. _class_CameraFeed_method_get_texture_tex_id:
  194. .. rst-class:: classref-method
  195. :ref:`int<class_int>` **get_texture_tex_id**\ (\ feed_image_type\: :ref:`FeedImage<enum_CameraServer_FeedImage>`\ ) :ref:`🔗<class_CameraFeed_method_get_texture_tex_id>`
  196. Returns the texture backend ID (usable by some external libraries that need a handle to a texture to write data).
  197. .. rst-class:: classref-item-separator
  198. ----
  199. .. _class_CameraFeed_method_set_external:
  200. .. rst-class:: classref-method
  201. |void| **set_external**\ (\ width\: :ref:`int<class_int>`, height\: :ref:`int<class_int>`\ ) :ref:`🔗<class_CameraFeed_method_set_external>`
  202. Sets the feed as external feed provided by another library.
  203. .. rst-class:: classref-item-separator
  204. ----
  205. .. _class_CameraFeed_method_set_format:
  206. .. rst-class:: classref-method
  207. :ref:`bool<class_bool>` **set_format**\ (\ index\: :ref:`int<class_int>`, parameters\: :ref:`Dictionary<class_Dictionary>`\ ) :ref:`🔗<class_CameraFeed_method_set_format>`
  208. Sets the feed format parameters for the given ``index`` in the :ref:`formats<class_CameraFeed_property_formats>` array. Returns ``true`` on success. By default, the YUYV encoded stream is transformed to :ref:`FEED_RGB<class_CameraFeed_constant_FEED_RGB>`. The YUYV encoded stream output format can be changed by setting ``parameters``'s ``output`` entry to one of the following:
  209. - ``"separate"`` will result in :ref:`FEED_YCBCR_SEP<class_CameraFeed_constant_FEED_YCBCR_SEP>`;
  210. - ``"grayscale"`` will result in desaturated :ref:`FEED_RGB<class_CameraFeed_constant_FEED_RGB>`;
  211. - ``"copy"`` will result in :ref:`FEED_YCBCR<class_CameraFeed_constant_FEED_YCBCR>`.
  212. .. rst-class:: classref-item-separator
  213. ----
  214. .. _class_CameraFeed_method_set_name:
  215. .. rst-class:: classref-method
  216. |void| **set_name**\ (\ name\: :ref:`String<class_String>`\ ) :ref:`🔗<class_CameraFeed_method_set_name>`
  217. Sets the camera's name.
  218. .. rst-class:: classref-item-separator
  219. ----
  220. .. _class_CameraFeed_method_set_position:
  221. .. rst-class:: classref-method
  222. |void| **set_position**\ (\ position\: :ref:`FeedPosition<enum_CameraFeed_FeedPosition>`\ ) :ref:`🔗<class_CameraFeed_method_set_position>`
  223. Sets the position of this camera.
  224. .. rst-class:: classref-item-separator
  225. ----
  226. .. _class_CameraFeed_method_set_rgb_image:
  227. .. rst-class:: classref-method
  228. |void| **set_rgb_image**\ (\ rgb_image\: :ref:`Image<class_Image>`\ ) :ref:`🔗<class_CameraFeed_method_set_rgb_image>`
  229. Sets RGB image for this feed.
  230. .. rst-class:: classref-item-separator
  231. ----
  232. .. _class_CameraFeed_method_set_ycbcr_image:
  233. .. rst-class:: classref-method
  234. |void| **set_ycbcr_image**\ (\ ycbcr_image\: :ref:`Image<class_Image>`\ ) :ref:`🔗<class_CameraFeed_method_set_ycbcr_image>`
  235. Sets YCbCr image for this feed.
  236. .. rst-class:: classref-item-separator
  237. ----
  238. .. _class_CameraFeed_method_set_ycbcr_images:
  239. .. rst-class:: classref-method
  240. |void| **set_ycbcr_images**\ (\ y_image\: :ref:`Image<class_Image>`, cbcr_image\: :ref:`Image<class_Image>`\ ) :ref:`🔗<class_CameraFeed_method_set_ycbcr_images>`
  241. Sets Y and CbCr images for this feed.
  242. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  243. .. |required| replace:: :abbr:`required (This method is required to be overridden when extending its base class.)`
  244. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  245. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
  246. .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
  247. .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
  248. .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
  249. .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`
  250. .. |void| replace:: :abbr:`void (No return value.)`