class_multiplayerpeerextension.rst 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  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/MultiplayerPeerExtension.xml.
  6. .. _class_MultiplayerPeerExtension:
  7. MultiplayerPeerExtension
  8. ========================
  9. **Inherits:** :ref:`MultiplayerPeer<class_MultiplayerPeer>` **<** :ref:`PacketPeer<class_PacketPeer>` **<** :ref:`RefCounted<class_RefCounted>` **<** :ref:`Object<class_Object>`
  10. Class that can be inherited to implement custom multiplayer API networking layers via GDExtension.
  11. Description
  12. -----------
  13. This class is designed to be inherited from a GDExtension plugin to implement custom networking layers for the multiplayer API (such as WebRTC). All the methods below **must** be implemented to have a working custom multiplayer implementation. See also :ref:`MultiplayerAPI<class_MultiplayerAPI>`.
  14. Methods
  15. -------
  16. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  17. | :ref:`int<class_int>` | :ref:`_get_available_packet_count<class_MultiplayerPeerExtension_method__get_available_packet_count>` **(** **)** |virtual| |const| |
  18. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  19. | :ref:`int<class_int>` | :ref:`_get_connection_status<class_MultiplayerPeerExtension_method__get_connection_status>` **(** **)** |virtual| |const| |
  20. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  21. | :ref:`int<class_int>` | :ref:`_get_max_packet_size<class_MultiplayerPeerExtension_method__get_max_packet_size>` **(** **)** |virtual| |const| |
  22. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  23. | :ref:`int<class_int>` | :ref:`_get_packet<class_MultiplayerPeerExtension_method__get_packet>` **(** const uint8_t ** r_buffer, int32_t* r_buffer_size **)** |virtual| |
  24. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  25. | :ref:`int<class_int>` | :ref:`_get_packet_peer<class_MultiplayerPeerExtension_method__get_packet_peer>` **(** **)** |virtual| |const| |
  26. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  27. | :ref:`PackedByteArray<class_PackedByteArray>` | :ref:`_get_packet_script<class_MultiplayerPeerExtension_method__get_packet_script>` **(** **)** |virtual| |
  28. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  29. | :ref:`int<class_int>` | :ref:`_get_transfer_channel<class_MultiplayerPeerExtension_method__get_transfer_channel>` **(** **)** |virtual| |const| |
  30. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  31. | :ref:`int<class_int>` | :ref:`_get_transfer_mode<class_MultiplayerPeerExtension_method__get_transfer_mode>` **(** **)** |virtual| |const| |
  32. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  33. | :ref:`int<class_int>` | :ref:`_get_unique_id<class_MultiplayerPeerExtension_method__get_unique_id>` **(** **)** |virtual| |const| |
  34. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  35. | :ref:`bool<class_bool>` | :ref:`_is_refusing_new_connections<class_MultiplayerPeerExtension_method__is_refusing_new_connections>` **(** **)** |virtual| |const| |
  36. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  37. | :ref:`bool<class_bool>` | :ref:`_is_server<class_MultiplayerPeerExtension_method__is_server>` **(** **)** |virtual| |const| |
  38. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  39. | :ref:`int<class_int>` | :ref:`_poll<class_MultiplayerPeerExtension_method__poll>` **(** **)** |virtual| |
  40. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  41. | :ref:`int<class_int>` | :ref:`_put_packet<class_MultiplayerPeerExtension_method__put_packet>` **(** const uint8_t* p_buffer, :ref:`int<class_int>` p_buffer_size **)** |virtual| |
  42. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  43. | :ref:`int<class_int>` | :ref:`_put_packet_script<class_MultiplayerPeerExtension_method__put_packet_script>` **(** :ref:`PackedByteArray<class_PackedByteArray>` p_buffer **)** |virtual| |
  44. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  45. | void | :ref:`_set_refuse_new_connections<class_MultiplayerPeerExtension_method__set_refuse_new_connections>` **(** :ref:`bool<class_bool>` p_enable **)** |virtual| |
  46. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  47. | void | :ref:`_set_target_peer<class_MultiplayerPeerExtension_method__set_target_peer>` **(** :ref:`int<class_int>` p_peer **)** |virtual| |
  48. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  49. | void | :ref:`_set_transfer_channel<class_MultiplayerPeerExtension_method__set_transfer_channel>` **(** :ref:`int<class_int>` p_channel **)** |virtual| |
  50. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  51. | void | :ref:`_set_transfer_mode<class_MultiplayerPeerExtension_method__set_transfer_mode>` **(** :ref:`int<class_int>` p_mode **)** |virtual| |
  52. +-----------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  53. Method Descriptions
  54. -------------------
  55. .. _class_MultiplayerPeerExtension_method__get_available_packet_count:
  56. - :ref:`int<class_int>` **_get_available_packet_count** **(** **)** |virtual| |const|
  57. Called when the available packet count is internally requested by the :ref:`MultiplayerAPI<class_MultiplayerAPI>`.
  58. ----
  59. .. _class_MultiplayerPeerExtension_method__get_connection_status:
  60. - :ref:`int<class_int>` **_get_connection_status** **(** **)** |virtual| |const|
  61. Called when the connection status is requested on the :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.get_connection_status<class_MultiplayerPeer_method_get_connection_status>`).
  62. ----
  63. .. _class_MultiplayerPeerExtension_method__get_max_packet_size:
  64. - :ref:`int<class_int>` **_get_max_packet_size** **(** **)** |virtual| |const|
  65. Called when the maximum allowed packet size (in bytes) is requested by the :ref:`MultiplayerAPI<class_MultiplayerAPI>`.
  66. ----
  67. .. _class_MultiplayerPeerExtension_method__get_packet:
  68. - :ref:`int<class_int>` **_get_packet** **(** const uint8_t ** r_buffer, int32_t* r_buffer_size **)** |virtual|
  69. Called when a packet needs to be received by the :ref:`MultiplayerAPI<class_MultiplayerAPI>`, with ``p_buffer_size`` being the size of the binary ``p_buffer`` in bytes.
  70. ----
  71. .. _class_MultiplayerPeerExtension_method__get_packet_peer:
  72. - :ref:`int<class_int>` **_get_packet_peer** **(** **)** |virtual| |const|
  73. Called when the ID of the :ref:`MultiplayerPeer<class_MultiplayerPeer>` who sent the most recent packet is requested (see :ref:`MultiplayerPeer.get_packet_peer<class_MultiplayerPeer_method_get_packet_peer>`).
  74. ----
  75. .. _class_MultiplayerPeerExtension_method__get_packet_script:
  76. - :ref:`PackedByteArray<class_PackedByteArray>` **_get_packet_script** **(** **)** |virtual|
  77. Called when a packet needs to be received by the :ref:`MultiplayerAPI<class_MultiplayerAPI>`, if :ref:`_get_packet<class_MultiplayerPeerExtension_method__get_packet>` isn't implemented. Use this when extending this class via GDScript.
  78. ----
  79. .. _class_MultiplayerPeerExtension_method__get_transfer_channel:
  80. - :ref:`int<class_int>` **_get_transfer_channel** **(** **)** |virtual| |const|
  81. Called when the transfer channel to use is read on this :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.transfer_channel<class_MultiplayerPeer_property_transfer_channel>`).
  82. ----
  83. .. _class_MultiplayerPeerExtension_method__get_transfer_mode:
  84. - :ref:`int<class_int>` **_get_transfer_mode** **(** **)** |virtual| |const|
  85. Called when the transfer mode to use is read on this :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.transfer_mode<class_MultiplayerPeer_property_transfer_mode>`).
  86. ----
  87. .. _class_MultiplayerPeerExtension_method__get_unique_id:
  88. - :ref:`int<class_int>` **_get_unique_id** **(** **)** |virtual| |const|
  89. Called when the unique ID of this :ref:`MultiplayerPeer<class_MultiplayerPeer>` is requested (see :ref:`MultiplayerPeer.get_unique_id<class_MultiplayerPeer_method_get_unique_id>`).
  90. ----
  91. .. _class_MultiplayerPeerExtension_method__is_refusing_new_connections:
  92. - :ref:`bool<class_bool>` **_is_refusing_new_connections** **(** **)** |virtual| |const|
  93. Called when the "refuse new connections" status is requested on this :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.refuse_new_connections<class_MultiplayerPeer_property_refuse_new_connections>`).
  94. ----
  95. .. _class_MultiplayerPeerExtension_method__is_server:
  96. - :ref:`bool<class_bool>` **_is_server** **(** **)** |virtual| |const|
  97. Called when the "is server" status is requested on the :ref:`MultiplayerAPI<class_MultiplayerAPI>`. See :ref:`MultiplayerAPI.is_server<class_MultiplayerAPI_method_is_server>`.
  98. ----
  99. .. _class_MultiplayerPeerExtension_method__poll:
  100. - :ref:`int<class_int>` **_poll** **(** **)** |virtual|
  101. Called when the :ref:`MultiplayerAPI<class_MultiplayerAPI>` is polled. See :ref:`MultiplayerAPI.poll<class_MultiplayerAPI_method_poll>`.
  102. ----
  103. .. _class_MultiplayerPeerExtension_method__put_packet:
  104. - :ref:`int<class_int>` **_put_packet** **(** const uint8_t* p_buffer, :ref:`int<class_int>` p_buffer_size **)** |virtual|
  105. Called when a packet needs to be sent by the :ref:`MultiplayerAPI<class_MultiplayerAPI>`, with ``p_buffer_size`` being the size of the binary ``p_buffer`` in bytes.
  106. ----
  107. .. _class_MultiplayerPeerExtension_method__put_packet_script:
  108. - :ref:`int<class_int>` **_put_packet_script** **(** :ref:`PackedByteArray<class_PackedByteArray>` p_buffer **)** |virtual|
  109. Called when a packet needs to be sent by the :ref:`MultiplayerAPI<class_MultiplayerAPI>`, if :ref:`_put_packet<class_MultiplayerPeerExtension_method__put_packet>` isn't implemented. Use this when extending this class via GDScript.
  110. ----
  111. .. _class_MultiplayerPeerExtension_method__set_refuse_new_connections:
  112. - void **_set_refuse_new_connections** **(** :ref:`bool<class_bool>` p_enable **)** |virtual|
  113. Called when the "refuse new connections" status is set on this :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.refuse_new_connections<class_MultiplayerPeer_property_refuse_new_connections>`).
  114. ----
  115. .. _class_MultiplayerPeerExtension_method__set_target_peer:
  116. - void **_set_target_peer** **(** :ref:`int<class_int>` p_peer **)** |virtual|
  117. Called when the target peer to use is set for this :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.set_target_peer<class_MultiplayerPeer_method_set_target_peer>`).
  118. ----
  119. .. _class_MultiplayerPeerExtension_method__set_transfer_channel:
  120. - void **_set_transfer_channel** **(** :ref:`int<class_int>` p_channel **)** |virtual|
  121. Called when the channel to use is set for this :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.transfer_channel<class_MultiplayerPeer_property_transfer_channel>`).
  122. ----
  123. .. _class_MultiplayerPeerExtension_method__set_transfer_mode:
  124. - void **_set_transfer_mode** **(** :ref:`int<class_int>` p_mode **)** |virtual|
  125. Called when the transfer mode is set on this :ref:`MultiplayerPeer<class_MultiplayerPeer>` (see :ref:`MultiplayerPeer.transfer_mode<class_MultiplayerPeer_property_transfer_mode>`).
  126. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  127. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  128. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
  129. .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
  130. .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
  131. .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`