class_os.rst 74 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895
  1. .. Generated automatically by doc/tools/makerst.py in Godot's source tree.
  2. .. DO NOT EDIT THIS FILE, but the OS.xml source instead.
  3. .. The source is found in doc/classes or modules/<name>/doc_classes.
  4. .. _class_OS:
  5. OS
  6. ==
  7. **Inherits:** :ref:`Object<class_object>`
  8. **Category:** Core
  9. Brief Description
  10. -----------------
  11. Operating System functions.
  12. Member Functions
  13. ----------------
  14. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  15. | void | :ref:`alert<class_OS_alert>` **(** :ref:`String<class_string>` text, :ref:`String<class_string>` title="Alert!" **)** |
  16. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  17. | :ref:`bool<class_bool>` | :ref:`can_draw<class_OS_can_draw>` **(** **)** const |
  18. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  19. | :ref:`bool<class_bool>` | :ref:`can_use_threads<class_OS_can_use_threads>` **(** **)** const |
  20. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  21. | void | :ref:`delay_msec<class_OS_delay_msec>` **(** :ref:`int<class_int>` msec **)** const |
  22. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  23. | void | :ref:`delay_usec<class_OS_delay_usec>` **(** :ref:`int<class_int>` usec **)** const |
  24. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  25. | void | :ref:`dump_memory_to_file<class_OS_dump_memory_to_file>` **(** :ref:`String<class_string>` file **)** |
  26. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  27. | void | :ref:`dump_resources_to_file<class_OS_dump_resources_to_file>` **(** :ref:`String<class_string>` file **)** |
  28. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  29. | :ref:`int<class_int>` | :ref:`execute<class_OS_execute>` **(** :ref:`String<class_string>` path, :ref:`PoolStringArray<class_poolstringarray>` arguments, :ref:`bool<class_bool>` blocking, :ref:`Array<class_array>` output=[ ] **)** |
  30. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  31. | :ref:`int<class_int>` | :ref:`find_scancode_from_string<class_OS_find_scancode_from_string>` **(** :ref:`String<class_string>` string **)** const |
  32. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  33. | :ref:`bool<class_bool>` | :ref:`get_borderless_window<class_OS_get_borderless_window>` **(** **)** const |
  34. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  35. | :ref:`String<class_string>` | :ref:`get_clipboard<class_OS_get_clipboard>` **(** **)** const |
  36. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  37. | :ref:`PoolStringArray<class_poolstringarray>` | :ref:`get_cmdline_args<class_OS_get_cmdline_args>` **(** **)** |
  38. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  39. | :ref:`int<class_int>` | :ref:`get_current_screen<class_OS_get_current_screen>` **(** **)** const |
  40. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  41. | :ref:`String<class_string>` | :ref:`get_data_dir<class_OS_get_data_dir>` **(** **)** const |
  42. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  43. | :ref:`Dictionary<class_dictionary>` | :ref:`get_date<class_OS_get_date>` **(** :ref:`bool<class_bool>` utc=false **)** const |
  44. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  45. | :ref:`Dictionary<class_dictionary>` | :ref:`get_datetime<class_OS_get_datetime>` **(** :ref:`bool<class_bool>` utc=false **)** const |
  46. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  47. | :ref:`Dictionary<class_dictionary>` | :ref:`get_datetime_from_unix_time<class_OS_get_datetime_from_unix_time>` **(** :ref:`int<class_int>` unix_time_val **)** const |
  48. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  49. | :ref:`int<class_int>` | :ref:`get_dynamic_memory_usage<class_OS_get_dynamic_memory_usage>` **(** **)** const |
  50. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  51. | :ref:`String<class_string>` | :ref:`get_environment<class_OS_get_environment>` **(** :ref:`String<class_string>` environment **)** const |
  52. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  53. | :ref:`String<class_string>` | :ref:`get_executable_path<class_OS_get_executable_path>` **(** **)** const |
  54. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  55. | :ref:`int<class_int>` | :ref:`get_exit_code<class_OS_get_exit_code>` **(** **)** const |
  56. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  57. | :ref:`String<class_string>` | :ref:`get_latin_keyboard_variant<class_OS_get_latin_keyboard_variant>` **(** **)** const |
  58. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  59. | :ref:`String<class_string>` | :ref:`get_locale<class_OS_get_locale>` **(** **)** const |
  60. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  61. | :ref:`String<class_string>` | :ref:`get_model_name<class_OS_get_model_name>` **(** **)** const |
  62. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  63. | :ref:`String<class_string>` | :ref:`get_name<class_OS_get_name>` **(** **)** const |
  64. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  65. | :ref:`int<class_int>` | :ref:`get_power_percent_left<class_OS_get_power_percent_left>` **(** **)** |
  66. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  67. | :ref:`int<class_int>` | :ref:`get_power_seconds_left<class_OS_get_power_seconds_left>` **(** **)** |
  68. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  69. | :ref:`int<class_int>` | :ref:`get_power_state<class_OS_get_power_state>` **(** **)** |
  70. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  71. | :ref:`int<class_int>` | :ref:`get_process_id<class_OS_get_process_id>` **(** **)** const |
  72. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  73. | :ref:`int<class_int>` | :ref:`get_processor_count<class_OS_get_processor_count>` **(** **)** const |
  74. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  75. | :ref:`String<class_string>` | :ref:`get_scancode_string<class_OS_get_scancode_string>` **(** :ref:`int<class_int>` code **)** const |
  76. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  77. | :ref:`int<class_int>` | :ref:`get_screen_count<class_OS_get_screen_count>` **(** **)** const |
  78. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  79. | :ref:`int<class_int>` | :ref:`get_screen_dpi<class_OS_get_screen_dpi>` **(** :ref:`int<class_int>` screen=-1 **)** const |
  80. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  81. | :ref:`int<class_int>` | :ref:`get_screen_orientation<class_OS_get_screen_orientation>` **(** **)** const |
  82. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  83. | :ref:`Vector2<class_vector2>` | :ref:`get_screen_position<class_OS_get_screen_position>` **(** :ref:`int<class_int>` screen=-1 **)** const |
  84. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  85. | :ref:`Vector2<class_vector2>` | :ref:`get_screen_size<class_OS_get_screen_size>` **(** :ref:`int<class_int>` screen=-1 **)** const |
  86. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  87. | :ref:`int<class_int>` | :ref:`get_splash_tick_msec<class_OS_get_splash_tick_msec>` **(** **)** const |
  88. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  89. | :ref:`int<class_int>` | :ref:`get_static_memory_peak_usage<class_OS_get_static_memory_peak_usage>` **(** **)** const |
  90. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  91. | :ref:`int<class_int>` | :ref:`get_static_memory_usage<class_OS_get_static_memory_usage>` **(** **)** const |
  92. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  93. | :ref:`String<class_string>` | :ref:`get_system_dir<class_OS_get_system_dir>` **(** :ref:`int<class_int>` dir **)** const |
  94. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  95. | :ref:`int<class_int>` | :ref:`get_system_time_secs<class_OS_get_system_time_secs>` **(** **)** const |
  96. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  97. | :ref:`int<class_int>` | :ref:`get_ticks_msec<class_OS_get_ticks_msec>` **(** **)** const |
  98. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  99. | :ref:`Dictionary<class_dictionary>` | :ref:`get_time<class_OS_get_time>` **(** :ref:`bool<class_bool>` utc=false **)** const |
  100. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  101. | :ref:`Dictionary<class_dictionary>` | :ref:`get_time_zone_info<class_OS_get_time_zone_info>` **(** **)** const |
  102. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  103. | :ref:`String<class_string>` | :ref:`get_unique_id<class_OS_get_unique_id>` **(** **)** const |
  104. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  105. | :ref:`int<class_int>` | :ref:`get_unix_time<class_OS_get_unix_time>` **(** **)** const |
  106. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  107. | :ref:`int<class_int>` | :ref:`get_unix_time_from_datetime<class_OS_get_unix_time_from_datetime>` **(** :ref:`Dictionary<class_dictionary>` datetime **)** const |
  108. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  109. | :ref:`int<class_int>` | :ref:`get_virtual_keyboard_height<class_OS_get_virtual_keyboard_height>` **(** **)** |
  110. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  111. | :ref:`Vector2<class_vector2>` | :ref:`get_window_position<class_OS_get_window_position>` **(** **)** const |
  112. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  113. | :ref:`Vector2<class_vector2>` | :ref:`get_window_size<class_OS_get_window_size>` **(** **)** const |
  114. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  115. | :ref:`bool<class_bool>` | :ref:`has_environment<class_OS_has_environment>` **(** :ref:`String<class_string>` environment **)** const |
  116. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  117. | :ref:`bool<class_bool>` | :ref:`has_feature<class_OS_has_feature>` **(** :ref:`String<class_string>` tag_name **)** const |
  118. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  119. | :ref:`bool<class_bool>` | :ref:`has_touchscreen_ui_hint<class_OS_has_touchscreen_ui_hint>` **(** **)** const |
  120. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  121. | :ref:`bool<class_bool>` | :ref:`has_virtual_keyboard<class_OS_has_virtual_keyboard>` **(** **)** const |
  122. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  123. | void | :ref:`hide_virtual_keyboard<class_OS_hide_virtual_keyboard>` **(** **)** |
  124. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  125. | :ref:`bool<class_bool>` | :ref:`is_debug_build<class_OS_is_debug_build>` **(** **)** const |
  126. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  127. | :ref:`bool<class_bool>` | :ref:`is_in_low_processor_usage_mode<class_OS_is_in_low_processor_usage_mode>` **(** **)** const |
  128. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  129. | :ref:`bool<class_bool>` | :ref:`is_keep_screen_on<class_OS_is_keep_screen_on>` **(** **)** const |
  130. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  131. | :ref:`bool<class_bool>` | :ref:`is_ok_left_and_cancel_right<class_OS_is_ok_left_and_cancel_right>` **(** **)** const |
  132. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  133. | :ref:`bool<class_bool>` | :ref:`is_scancode_unicode<class_OS_is_scancode_unicode>` **(** :ref:`int<class_int>` code **)** const |
  134. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  135. | :ref:`bool<class_bool>` | :ref:`is_stdout_verbose<class_OS_is_stdout_verbose>` **(** **)** const |
  136. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  137. | :ref:`bool<class_bool>` | :ref:`is_userfs_persistent<class_OS_is_userfs_persistent>` **(** **)** const |
  138. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  139. | :ref:`bool<class_bool>` | :ref:`is_vsync_enabled<class_OS_is_vsync_enabled>` **(** **)** const |
  140. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  141. | :ref:`bool<class_bool>` | :ref:`is_window_fullscreen<class_OS_is_window_fullscreen>` **(** **)** const |
  142. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  143. | :ref:`bool<class_bool>` | :ref:`is_window_maximized<class_OS_is_window_maximized>` **(** **)** const |
  144. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  145. | :ref:`bool<class_bool>` | :ref:`is_window_minimized<class_OS_is_window_minimized>` **(** **)** const |
  146. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  147. | :ref:`bool<class_bool>` | :ref:`is_window_resizable<class_OS_is_window_resizable>` **(** **)** const |
  148. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  149. | :ref:`int<class_int>` | :ref:`kill<class_OS_kill>` **(** :ref:`int<class_int>` pid **)** |
  150. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  151. | :ref:`bool<class_bool>` | :ref:`native_video_is_playing<class_OS_native_video_is_playing>` **(** **)** |
  152. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  153. | void | :ref:`native_video_pause<class_OS_native_video_pause>` **(** **)** |
  154. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  155. | :ref:`int<class_int>` | :ref:`native_video_play<class_OS_native_video_play>` **(** :ref:`String<class_string>` path, :ref:`float<class_float>` volume, :ref:`String<class_string>` audio_track, :ref:`String<class_string>` subtitle_track **)** |
  156. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  157. | void | :ref:`native_video_stop<class_OS_native_video_stop>` **(** **)** |
  158. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  159. | void | :ref:`native_video_unpause<class_OS_native_video_unpause>` **(** **)** |
  160. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  161. | void | :ref:`print_all_resources<class_OS_print_all_resources>` **(** :ref:`String<class_string>` tofile="" **)** |
  162. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  163. | void | :ref:`print_all_textures_by_size<class_OS_print_all_textures_by_size>` **(** **)** |
  164. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  165. | void | :ref:`print_resources_by_type<class_OS_print_resources_by_type>` **(** :ref:`PoolStringArray<class_poolstringarray>` types **)** |
  166. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  167. | void | :ref:`print_resources_in_use<class_OS_print_resources_in_use>` **(** :ref:`bool<class_bool>` short=false **)** |
  168. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  169. | void | :ref:`request_attention<class_OS_request_attention>` **(** **)** |
  170. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  171. | void | :ref:`set_borderless_window<class_OS_set_borderless_window>` **(** :ref:`bool<class_bool>` borderless **)** |
  172. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  173. | void | :ref:`set_clipboard<class_OS_set_clipboard>` **(** :ref:`String<class_string>` clipboard **)** |
  174. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  175. | void | :ref:`set_current_screen<class_OS_set_current_screen>` **(** :ref:`int<class_int>` screen **)** |
  176. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  177. | void | :ref:`set_exit_code<class_OS_set_exit_code>` **(** :ref:`int<class_int>` code **)** |
  178. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  179. | void | :ref:`set_icon<class_OS_set_icon>` **(** :ref:`Image<class_image>` icon **)** |
  180. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  181. | void | :ref:`set_ime_position<class_OS_set_ime_position>` **(** :ref:`Vector2<class_vector2>` position **)** |
  182. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  183. | void | :ref:`set_keep_screen_on<class_OS_set_keep_screen_on>` **(** :ref:`bool<class_bool>` enabled **)** |
  184. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  185. | void | :ref:`set_low_processor_usage_mode<class_OS_set_low_processor_usage_mode>` **(** :ref:`bool<class_bool>` enable **)** |
  186. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  187. | void | :ref:`set_screen_orientation<class_OS_set_screen_orientation>` **(** :ref:`int<class_int>` orientation **)** |
  188. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  189. | :ref:`int<class_int>` | :ref:`set_thread_name<class_OS_set_thread_name>` **(** :ref:`String<class_string>` name **)** |
  190. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  191. | void | :ref:`set_use_file_access_save_and_swap<class_OS_set_use_file_access_save_and_swap>` **(** :ref:`bool<class_bool>` enabled **)** |
  192. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  193. | void | :ref:`set_use_vsync<class_OS_set_use_vsync>` **(** :ref:`bool<class_bool>` enable **)** |
  194. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  195. | void | :ref:`set_window_fullscreen<class_OS_set_window_fullscreen>` **(** :ref:`bool<class_bool>` enabled **)** |
  196. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  197. | void | :ref:`set_window_maximized<class_OS_set_window_maximized>` **(** :ref:`bool<class_bool>` enabled **)** |
  198. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  199. | void | :ref:`set_window_minimized<class_OS_set_window_minimized>` **(** :ref:`bool<class_bool>` enabled **)** |
  200. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  201. | void | :ref:`set_window_position<class_OS_set_window_position>` **(** :ref:`Vector2<class_vector2>` position **)** |
  202. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  203. | void | :ref:`set_window_resizable<class_OS_set_window_resizable>` **(** :ref:`bool<class_bool>` enabled **)** |
  204. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  205. | void | :ref:`set_window_size<class_OS_set_window_size>` **(** :ref:`Vector2<class_vector2>` size **)** |
  206. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  207. | void | :ref:`set_window_title<class_OS_set_window_title>` **(** :ref:`String<class_string>` title **)** |
  208. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  209. | :ref:`int<class_int>` | :ref:`shell_open<class_OS_shell_open>` **(** :ref:`String<class_string>` uri **)** |
  210. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  211. | void | :ref:`show_virtual_keyboard<class_OS_show_virtual_keyboard>` **(** :ref:`String<class_string>` existing_text="" **)** |
  212. +------------------------------------------------+----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  213. Numeric Constants
  214. -----------------
  215. - **DAY_SUNDAY** = **0**
  216. - **DAY_MONDAY** = **1**
  217. - **DAY_TUESDAY** = **2**
  218. - **DAY_WEDNESDAY** = **3**
  219. - **DAY_THURSDAY** = **4**
  220. - **DAY_FRIDAY** = **5**
  221. - **DAY_SATURDAY** = **6**
  222. - **MONTH_JANUARY** = **1**
  223. - **MONTH_FEBRUARY** = **2**
  224. - **MONTH_MARCH** = **3**
  225. - **MONTH_APRIL** = **4**
  226. - **MONTH_MAY** = **5**
  227. - **MONTH_JUNE** = **6**
  228. - **MONTH_JULY** = **7**
  229. - **MONTH_AUGUST** = **8**
  230. - **MONTH_SEPTEMBER** = **9**
  231. - **MONTH_OCTOBER** = **10**
  232. - **MONTH_NOVEMBER** = **11**
  233. - **MONTH_DECEMBER** = **12**
  234. - **SCREEN_ORIENTATION_LANDSCAPE** = **0**
  235. - **SCREEN_ORIENTATION_PORTRAIT** = **1**
  236. - **SCREEN_ORIENTATION_REVERSE_LANDSCAPE** = **2**
  237. - **SCREEN_ORIENTATION_REVERSE_PORTRAIT** = **3**
  238. - **SCREEN_ORIENTATION_SENSOR_LANDSCAPE** = **4**
  239. - **SCREEN_ORIENTATION_SENSOR_PORTRAIT** = **5**
  240. - **SCREEN_ORIENTATION_SENSOR** = **6**
  241. - **SYSTEM_DIR_DESKTOP** = **0**
  242. - **SYSTEM_DIR_DCIM** = **1**
  243. - **SYSTEM_DIR_DOCUMENTS** = **2**
  244. - **SYSTEM_DIR_DOWNLOADS** = **3**
  245. - **SYSTEM_DIR_MOVIES** = **4**
  246. - **SYSTEM_DIR_MUSIC** = **5**
  247. - **SYSTEM_DIR_PICTURES** = **6**
  248. - **SYSTEM_DIR_RINGTONES** = **7**
  249. - **POWERSTATE_UNKNOWN** = **0**
  250. - **POWERSTATE_ON_BATTERY** = **1**
  251. - **POWERSTATE_NO_BATTERY** = **2**
  252. - **POWERSTATE_CHARGING** = **3**
  253. - **POWERSTATE_CHARGED** = **4**
  254. Description
  255. -----------
  256. Operating System functions. OS Wraps the most common functionality to communicate with the host Operating System, such as: mouse grabbing, mouse cursors, clipboard, video mode, date and time, timers, environment variables, execution of binaries, command line, etc.
  257. Member Function Description
  258. ---------------------------
  259. .. _class_OS_alert:
  260. - void **alert** **(** :ref:`String<class_string>` text, :ref:`String<class_string>` title="Alert!" **)**
  261. Displays a modal dialog box utilizing the host OS.
  262. .. _class_OS_can_draw:
  263. - :ref:`bool<class_bool>` **can_draw** **(** **)** const
  264. Returns ``true`` if the host OS allows drawing.
  265. .. _class_OS_can_use_threads:
  266. - :ref:`bool<class_bool>` **can_use_threads** **(** **)** const
  267. Returns ``true`` if the current host platform is using multiple threads.
  268. .. _class_OS_delay_msec:
  269. - void **delay_msec** **(** :ref:`int<class_int>` msec **)** const
  270. Delay executing of the current thread by given milliseconds.
  271. .. _class_OS_delay_usec:
  272. - void **delay_usec** **(** :ref:`int<class_int>` usec **)** const
  273. Delay executing of the current thread by given microseconds.
  274. .. _class_OS_dump_memory_to_file:
  275. - void **dump_memory_to_file** **(** :ref:`String<class_string>` file **)**
  276. Dumps the memory allocation ringlist to a file (only works in debug).
  277. Entry format per line: "Address - Size - Description"
  278. .. _class_OS_dump_resources_to_file:
  279. - void **dump_resources_to_file** **(** :ref:`String<class_string>` file **)**
  280. Dumps all used resources to file (only works in debug).
  281. Entry format per line: "Resource Type : Resource Location"
  282. At the end of the file is a statistic of all used Resource Types.
  283. .. _class_OS_execute:
  284. - :ref:`int<class_int>` **execute** **(** :ref:`String<class_string>` path, :ref:`PoolStringArray<class_poolstringarray>` arguments, :ref:`bool<class_bool>` blocking, :ref:`Array<class_array>` output=[ ] **)**
  285. Execute the binary file in given path, optionally blocking until it returns. A process ID is returned.
  286. .. _class_OS_find_scancode_from_string:
  287. - :ref:`int<class_int>` **find_scancode_from_string** **(** :ref:`String<class_string>` string **)** const
  288. Returns the scancode of the given string (e.g. "Escape")
  289. .. _class_OS_get_borderless_window:
  290. - :ref:`bool<class_bool>` **get_borderless_window** **(** **)** const
  291. Returns true if the current window is borderless.
  292. .. _class_OS_get_clipboard:
  293. - :ref:`String<class_string>` **get_clipboard** **(** **)** const
  294. Get clipboard from the host OS.
  295. .. _class_OS_get_cmdline_args:
  296. - :ref:`PoolStringArray<class_poolstringarray>` **get_cmdline_args** **(** **)**
  297. Returns the command line arguments passed to the engine.
  298. .. _class_OS_get_current_screen:
  299. - :ref:`int<class_int>` **get_current_screen** **(** **)** const
  300. Returns the current screen index (0 padded).
  301. .. _class_OS_get_data_dir:
  302. - :ref:`String<class_string>` **get_data_dir** **(** **)** const
  303. Returns the absolute directory path of user data path(user://).
  304. .. _class_OS_get_date:
  305. - :ref:`Dictionary<class_dictionary>` **get_date** **(** :ref:`bool<class_bool>` utc=false **)** const
  306. Returns current date as a dictionary of keys: year, month, day, weekday, dst (daylight savings time).
  307. .. _class_OS_get_datetime:
  308. - :ref:`Dictionary<class_dictionary>` **get_datetime** **(** :ref:`bool<class_bool>` utc=false **)** const
  309. Returns current datetime as a dictionary of keys: year, month, day, weekday, dst (daylight savings time), hour, minute, second.
  310. .. _class_OS_get_datetime_from_unix_time:
  311. - :ref:`Dictionary<class_dictionary>` **get_datetime_from_unix_time** **(** :ref:`int<class_int>` unix_time_val **)** const
  312. Get a dictionary of time values when given epoch time.
  313. Dictionary Time values will be a union of values from :ref:`get_time<class_OS_get_time>` and :ref:`get_date<class_OS_get_date>` dictionaries (with the exception of dst = day light standard time, as it cannot be determined from epoch).
  314. .. _class_OS_get_dynamic_memory_usage:
  315. - :ref:`int<class_int>` **get_dynamic_memory_usage** **(** **)** const
  316. Returns the total amount of dynamic memory used (only works in debug).
  317. .. _class_OS_get_environment:
  318. - :ref:`String<class_string>` **get_environment** **(** :ref:`String<class_string>` environment **)** const
  319. Returns an environment variable.
  320. .. _class_OS_get_executable_path:
  321. - :ref:`String<class_string>` **get_executable_path** **(** **)** const
  322. Returns the path to the current engine executable.
  323. .. _class_OS_get_exit_code:
  324. - :ref:`int<class_int>` **get_exit_code** **(** **)** const
  325. .. _class_OS_get_latin_keyboard_variant:
  326. - :ref:`String<class_string>` **get_latin_keyboard_variant** **(** **)** const
  327. Returns the current latin keyboard variant as a String.
  328. Possible return values are: "QWERTY", "AZERTY", "QZERTY", "DVORAK", "NEO" or "ERROR"
  329. .. _class_OS_get_locale:
  330. - :ref:`String<class_string>` **get_locale** **(** **)** const
  331. Returns the host OS locale.
  332. .. _class_OS_get_model_name:
  333. - :ref:`String<class_string>` **get_model_name** **(** **)** const
  334. Returns the model name of the current device.
  335. .. _class_OS_get_name:
  336. - :ref:`String<class_string>` **get_name** **(** **)** const
  337. Returns the name of the host OS. Possible values are: "Android", "Haiku", "iOS", "HTML5", "OSX", "Server", "Windows", "UWP", "X11".
  338. .. _class_OS_get_power_percent_left:
  339. - :ref:`int<class_int>` **get_power_percent_left** **(** **)**
  340. Returns the amount of battery left in the device as a percentage.
  341. .. _class_OS_get_power_seconds_left:
  342. - :ref:`int<class_int>` **get_power_seconds_left** **(** **)**
  343. Returns the time in seconds before the device runs out of battery.
  344. .. _class_OS_get_power_state:
  345. - :ref:`int<class_int>` **get_power_state** **(** **)**
  346. Returns the current state of the device regarding battery and power. See ``POWERSTATE\_\*`` constants.
  347. .. _class_OS_get_process_id:
  348. - :ref:`int<class_int>` **get_process_id** **(** **)** const
  349. Returns the game process ID
  350. .. _class_OS_get_processor_count:
  351. - :ref:`int<class_int>` **get_processor_count** **(** **)** const
  352. Returns the number of cores available in the host machine.
  353. .. _class_OS_get_scancode_string:
  354. - :ref:`String<class_string>` **get_scancode_string** **(** :ref:`int<class_int>` code **)** const
  355. Returns the given scancode as a string (e.g. Return values: "Escape", "Shift+Escape").
  356. .. _class_OS_get_screen_count:
  357. - :ref:`int<class_int>` **get_screen_count** **(** **)** const
  358. Returns the number of displays attached to the host machine.
  359. .. _class_OS_get_screen_dpi:
  360. - :ref:`int<class_int>` **get_screen_dpi** **(** :ref:`int<class_int>` screen=-1 **)** const
  361. Returns the dots per inch density of the specified screen.
  362. On Android Devices, the actual screen densities are grouped into six generalized densities:
  363. ldpi - 120 dpi
  364. mdpi - 160 dpi
  365. hdpi - 240 dpi
  366. xhdpi - 320 dpi
  367. xxhdpi - 480 dpi
  368. xxxhdpi - 640 dpi
  369. .. _class_OS_get_screen_orientation:
  370. - :ref:`int<class_int>` **get_screen_orientation** **(** **)** const
  371. Returns the current screen orientation, the return value will be one of the SCREEN_ORIENTATION constants in this class.
  372. .. _class_OS_get_screen_position:
  373. - :ref:`Vector2<class_vector2>` **get_screen_position** **(** :ref:`int<class_int>` screen=-1 **)** const
  374. Returns the position of the specified screen by index. If no screen index is provided, the current screen will be used.
  375. .. _class_OS_get_screen_size:
  376. - :ref:`Vector2<class_vector2>` **get_screen_size** **(** :ref:`int<class_int>` screen=-1 **)** const
  377. Returns the dimensions in pixels of the specified screen.
  378. .. _class_OS_get_splash_tick_msec:
  379. - :ref:`int<class_int>` **get_splash_tick_msec** **(** **)** const
  380. .. _class_OS_get_static_memory_peak_usage:
  381. - :ref:`int<class_int>` **get_static_memory_peak_usage** **(** **)** const
  382. Returns the max amount of static memory used (only works in debug).
  383. .. _class_OS_get_static_memory_usage:
  384. - :ref:`int<class_int>` **get_static_memory_usage** **(** **)** const
  385. Returns the amount of static memory being used by the program in bytes.
  386. .. _class_OS_get_system_dir:
  387. - :ref:`String<class_string>` **get_system_dir** **(** :ref:`int<class_int>` dir **)** const
  388. Returns the actual path to commonly used folders across different platforms. Available locations are specified in OS.SystemDir.
  389. .. _class_OS_get_system_time_secs:
  390. - :ref:`int<class_int>` **get_system_time_secs** **(** **)** const
  391. Returns the epoch time of the operating system in seconds.
  392. .. _class_OS_get_ticks_msec:
  393. - :ref:`int<class_int>` **get_ticks_msec** **(** **)** const
  394. Returns the amount of time passed in milliseconds since the engine started.
  395. .. _class_OS_get_time:
  396. - :ref:`Dictionary<class_dictionary>` **get_time** **(** :ref:`bool<class_bool>` utc=false **)** const
  397. Returns current time as a dictionary of keys: hour, minute, second.
  398. .. _class_OS_get_time_zone_info:
  399. - :ref:`Dictionary<class_dictionary>` **get_time_zone_info** **(** **)** const
  400. Returns the current time zone as a dictionary with the keys: bias and name.
  401. .. _class_OS_get_unique_id:
  402. - :ref:`String<class_string>` **get_unique_id** **(** **)** const
  403. Returns a unique string.
  404. .. _class_OS_get_unix_time:
  405. - :ref:`int<class_int>` **get_unix_time** **(** **)** const
  406. Return the current unix timestamp.
  407. .. _class_OS_get_unix_time_from_datetime:
  408. - :ref:`int<class_int>` **get_unix_time_from_datetime** **(** :ref:`Dictionary<class_dictionary>` datetime **)** const
  409. Get an epoch time value from a dictionary of time values.
  410. ``datetime`` must be populated with the following keys: year, month, day, hour, minute, second.
  411. You can pass the output from :ref:`get_datetime_from_unix_time<class_OS_get_datetime_from_unix_time>` directly into this function. Daylight savings time (dst), if present, is ignored.
  412. .. _class_OS_get_virtual_keyboard_height:
  413. - :ref:`int<class_int>` **get_virtual_keyboard_height** **(** **)**
  414. .. _class_OS_get_window_position:
  415. - :ref:`Vector2<class_vector2>` **get_window_position** **(** **)** const
  416. Returns the window position relative to the screen, the origin is the top left corner, +Y axis goes to the bottom and +X axis goes to the right.
  417. .. _class_OS_get_window_size:
  418. - :ref:`Vector2<class_vector2>` **get_window_size** **(** **)** const
  419. Returns the size of the window (without counting window manager decorations).
  420. .. _class_OS_has_environment:
  421. - :ref:`bool<class_bool>` **has_environment** **(** :ref:`String<class_string>` environment **)** const
  422. Returns ``true`` if an environment variable exists.
  423. .. _class_OS_has_feature:
  424. - :ref:`bool<class_bool>` **has_feature** **(** :ref:`String<class_string>` tag_name **)** const
  425. .. _class_OS_has_touchscreen_ui_hint:
  426. - :ref:`bool<class_bool>` **has_touchscreen_ui_hint** **(** **)** const
  427. Returns ``true`` if the device has a touchscreen or emulates one.
  428. .. _class_OS_has_virtual_keyboard:
  429. - :ref:`bool<class_bool>` **has_virtual_keyboard** **(** **)** const
  430. Returns ``true`` if the platform has a virtual keyboard, ``false`` otherwise.
  431. .. _class_OS_hide_virtual_keyboard:
  432. - void **hide_virtual_keyboard** **(** **)**
  433. Hides the virtual keyboard if it is shown, does nothing otherwise.
  434. .. _class_OS_is_debug_build:
  435. - :ref:`bool<class_bool>` **is_debug_build** **(** **)** const
  436. Returns ``true`` if the build is a debug build.
  437. Returns ``true`` when running in the editor.
  438. Returns ``false`` if the build is a release build.
  439. .. _class_OS_is_in_low_processor_usage_mode:
  440. - :ref:`bool<class_bool>` **is_in_low_processor_usage_mode** **(** **)** const
  441. Returns ``true`` if low cpu usage mode is enabled.
  442. .. _class_OS_is_keep_screen_on:
  443. - :ref:`bool<class_bool>` **is_keep_screen_on** **(** **)** const
  444. Returns ``true`` if the screen is being kept on.
  445. .. _class_OS_is_ok_left_and_cancel_right:
  446. - :ref:`bool<class_bool>` **is_ok_left_and_cancel_right** **(** **)** const
  447. Returns ``true`` if the "Okay" button should appear on the left and "Cancel" on the right.
  448. .. _class_OS_is_scancode_unicode:
  449. - :ref:`bool<class_bool>` **is_scancode_unicode** **(** :ref:`int<class_int>` code **)** const
  450. Returns ``true`` if the input code has a unicode character.
  451. .. _class_OS_is_stdout_verbose:
  452. - :ref:`bool<class_bool>` **is_stdout_verbose** **(** **)** const
  453. Returns ``true`` if the engine was executed with -v (verbose stdout).
  454. .. _class_OS_is_userfs_persistent:
  455. - :ref:`bool<class_bool>` **is_userfs_persistent** **(** **)** const
  456. If ``true``, the ``user://`` file system is persistent, so that its state is the same after a player quits and starts the game again. Relevant to the HTML5 platform, where this persistence may be unavailable.
  457. .. _class_OS_is_vsync_enabled:
  458. - :ref:`bool<class_bool>` **is_vsync_enabled** **(** **)** const
  459. Returns ``true`` if synchronizing the framerate to the monitor's refresh rate is enabled.
  460. .. _class_OS_is_window_fullscreen:
  461. - :ref:`bool<class_bool>` **is_window_fullscreen** **(** **)** const
  462. Returns ``true`` if the window is in fullscreen mode.
  463. .. _class_OS_is_window_maximized:
  464. - :ref:`bool<class_bool>` **is_window_maximized** **(** **)** const
  465. Returns ``true`` if the window is maximized.
  466. .. _class_OS_is_window_minimized:
  467. - :ref:`bool<class_bool>` **is_window_minimized** **(** **)** const
  468. Returns ``true`` if the window is minimized.
  469. .. _class_OS_is_window_resizable:
  470. - :ref:`bool<class_bool>` **is_window_resizable** **(** **)** const
  471. Returns ``true`` if the window is resizable.
  472. .. _class_OS_kill:
  473. - :ref:`int<class_int>` **kill** **(** :ref:`int<class_int>` pid **)**
  474. Kill a process ID (this method can be used to kill processes that were not spawned by the game).
  475. .. _class_OS_native_video_is_playing:
  476. - :ref:`bool<class_bool>` **native_video_is_playing** **(** **)**
  477. Returns ``true`` if native video is playing.
  478. .. _class_OS_native_video_pause:
  479. - void **native_video_pause** **(** **)**
  480. Pauses native video playback.
  481. .. _class_OS_native_video_play:
  482. - :ref:`int<class_int>` **native_video_play** **(** :ref:`String<class_string>` path, :ref:`float<class_float>` volume, :ref:`String<class_string>` audio_track, :ref:`String<class_string>` subtitle_track **)**
  483. Plays native video from the specified path, at the given volume and with audio and subtitle tracks.
  484. .. _class_OS_native_video_stop:
  485. - void **native_video_stop** **(** **)**
  486. Stops native video playback.
  487. .. _class_OS_native_video_unpause:
  488. - void **native_video_unpause** **(** **)**
  489. Resumes native video playback.
  490. .. _class_OS_print_all_resources:
  491. - void **print_all_resources** **(** :ref:`String<class_string>` tofile="" **)**
  492. Shows all resources in the game. Optionally the list can be written to a file.
  493. .. _class_OS_print_all_textures_by_size:
  494. - void **print_all_textures_by_size** **(** **)**
  495. Shows the list of loaded textures sorted by size in memory.
  496. .. _class_OS_print_resources_by_type:
  497. - void **print_resources_by_type** **(** :ref:`PoolStringArray<class_poolstringarray>` types **)**
  498. Shows the number of resources loaded by the game of the given types.
  499. .. _class_OS_print_resources_in_use:
  500. - void **print_resources_in_use** **(** :ref:`bool<class_bool>` short=false **)**
  501. Shows all resources currently used by the game.
  502. .. _class_OS_request_attention:
  503. - void **request_attention** **(** **)**
  504. Request the user attention to the window. It'll flash the taskbar button on Windows or bounce the dock icon on OSX.
  505. .. _class_OS_set_borderless_window:
  506. - void **set_borderless_window** **(** :ref:`bool<class_bool>` borderless **)**
  507. Removes the window frame.
  508. .. _class_OS_set_clipboard:
  509. - void **set_clipboard** **(** :ref:`String<class_string>` clipboard **)**
  510. Sets clipboard to the OS.
  511. .. _class_OS_set_current_screen:
  512. - void **set_current_screen** **(** :ref:`int<class_int>` screen **)**
  513. Sets the current screen by index.
  514. .. _class_OS_set_exit_code:
  515. - void **set_exit_code** **(** :ref:`int<class_int>` code **)**
  516. Sets the exit code that will be returned by the game.
  517. .. _class_OS_set_icon:
  518. - void **set_icon** **(** :ref:`Image<class_image>` icon **)**
  519. Sets the game's icon.
  520. .. _class_OS_set_ime_position:
  521. - void **set_ime_position** **(** :ref:`Vector2<class_vector2>` position **)**
  522. .. _class_OS_set_keep_screen_on:
  523. - void **set_keep_screen_on** **(** :ref:`bool<class_bool>` enabled **)**
  524. Sets keep screen on if true, or goes to sleep by device setting if false. (for Android/iOS)
  525. .. _class_OS_set_low_processor_usage_mode:
  526. - void **set_low_processor_usage_mode** **(** :ref:`bool<class_bool>` enable **)**
  527. Set to ``true`` to enable the low cpu usage mode. In this mode, the screen only redraws when there are changes, and a considerable sleep time is inserted between frames. Use this in tool mode to reduce CPU usage.
  528. .. _class_OS_set_screen_orientation:
  529. - void **set_screen_orientation** **(** :ref:`int<class_int>` orientation **)**
  530. Sets the current screen orientation, the argument value must be one of the SCREEN_ORIENTATION constants in this class.
  531. .. _class_OS_set_thread_name:
  532. - :ref:`int<class_int>` **set_thread_name** **(** :ref:`String<class_string>` name **)**
  533. Sets the name of the current thread.
  534. .. _class_OS_set_use_file_access_save_and_swap:
  535. - void **set_use_file_access_save_and_swap** **(** :ref:`bool<class_bool>` enabled **)**
  536. Enables backup saves if ``enabled`` is ``true``.
  537. .. _class_OS_set_use_vsync:
  538. - void **set_use_vsync** **(** :ref:`bool<class_bool>` enable **)**
  539. If ``true`` the framerate will synchronize to the monitor's refresh rate.
  540. .. _class_OS_set_window_fullscreen:
  541. - void **set_window_fullscreen** **(** :ref:`bool<class_bool>` enabled **)**
  542. Sets window fullscreen mode to the *enabled* argument, *enabled* is a toggle for the fullscreen mode, calling the function with *enabled* true when the screen is not on fullscreen mode will cause the screen to go to fullscreen mode, calling the function with *enabled* false when the screen is in fullscreen mode will cause the window to exit the fullscreen mode.
  543. .. _class_OS_set_window_maximized:
  544. - void **set_window_maximized** **(** :ref:`bool<class_bool>` enabled **)**
  545. Set ``true`` to maximize the window.
  546. .. _class_OS_set_window_minimized:
  547. - void **set_window_minimized** **(** :ref:`bool<class_bool>` enabled **)**
  548. Set ``true`` to minimize the window.
  549. .. _class_OS_set_window_position:
  550. - void **set_window_position** **(** :ref:`Vector2<class_vector2>` position **)**
  551. Sets the position of the window to the specified position (this function could be restricted by the window manager, meaning that there could be some unreachable areas of the screen).
  552. .. _class_OS_set_window_resizable:
  553. - void **set_window_resizable** **(** :ref:`bool<class_bool>` enabled **)**
  554. Sets the window resizable state, if the window is not resizable it will preserve the dimensions specified in the project settings.
  555. .. _class_OS_set_window_size:
  556. - void **set_window_size** **(** :ref:`Vector2<class_vector2>` size **)**
  557. Sets the window size to the specified size.
  558. .. _class_OS_set_window_title:
  559. - void **set_window_title** **(** :ref:`String<class_string>` title **)**
  560. Sets the window title to the specified string.
  561. .. _class_OS_shell_open:
  562. - :ref:`int<class_int>` **shell_open** **(** :ref:`String<class_string>` uri **)**
  563. Requests the OS to open a resource with the most appropriate program. For example.
  564. ``OS.shell_open("C:\\Users\name\Downloads")`` on Windows opens the file explorer at the downloads folders of the user.
  565. ``OS.shell_open("http://godotengine.org")`` opens the default web browser on the official Godot website.
  566. .. _class_OS_show_virtual_keyboard:
  567. - void **show_virtual_keyboard** **(** :ref:`String<class_string>` existing_text="" **)**
  568. Shows the virtual keyboard if the platform has one. The *existing_text* parameter is useful for implementing your own LineEdit, as it tells the virtual keyboard what text has already been typed (the virtual keyboard uses it for auto-correct and predictions).