list_of_features.rst 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585
  1. .. _doc_list_of_features:
  2. List of features
  3. ================
  4. This page aims to list all features currently supported by Godot.
  5. .. note::
  6. This page lists features supported by the current stable version of
  7. Godot (3.2). `More features <https://docs.godotengine.org/en/latest/about/list_of_features.html>`__
  8. are available in the latest development version (4.0).
  9. Features
  10. --------
  11. Platforms
  12. ^^^^^^^^^
  13. **Can run both the editor and exported projects:**
  14. - Windows 7 and later (64-bit and 32-bit).
  15. - macOS 10.12 and later (64-bit, x86 and ARM).
  16. - Linux (64-bit and 32-bit, x86 and ARM).
  17. - Binaries are statically linked and can run on any distribution if compiled
  18. on an old enough base distribution.
  19. - Official binaries are compiled on Ubuntu 14.04.
  20. **Runs exported projects:**
  21. - Android 4.4 and later.
  22. - iOS 10.0 and later.
  23. - HTML5 via WebAssembly (Firefox, Chrome, Edge, Opera).
  24. - :ref:`Consoles <doc_consoles>`.
  25. Godot aims to be as platform-independent as possible and can be ported to new
  26. platforms with relative ease.
  27. Editor
  28. ^^^^^^
  29. **Features:**
  30. - Scene tree editor.
  31. - Script editor.
  32. - Support for :ref:`external script editors <doc_external_editor>` such as
  33. Visual Studio Code or Vim.
  34. - GDScript :ref:`debugger <doc_debugger_panel>`.
  35. - No support for debugging in threads yet.
  36. - Performance monitoring tools.
  37. - Live script reloading.
  38. - Live scene editing.
  39. - Changes will reflect in the editor and will be kept after closing the running project.
  40. - Remote inspector.
  41. - Changes won't reflect in the editor and won't be kept after closing the running project.
  42. - Live camera replication.
  43. - Move the in-editor camera and see the result in the running project.
  44. - Use the editor in dozens of languages contributed by the community.
  45. **Plugins:**
  46. - Editor plugins can be downloaded from the
  47. :ref:`asset library <doc_what_is_assetlib>` to extend editor functionality.
  48. - Create your own plugins using GDScript to add new features or speed up your workflow.
  49. - Download projects from the asset library in the project manager and import them directly.
  50. 2D graphics
  51. ^^^^^^^^^^^
  52. **Two renderers available:**
  53. - OpenGL ES 3.0 renderer (uses OpenGL 3.3 on desktop platforms).
  54. - High-end visuals. Recommended on desktop platforms.
  55. - OpenGL ES 2.0 renderer (uses OpenGL 2.1 on desktop platforms).
  56. - Recommended on mobile and Web platforms.
  57. **Features:**
  58. - Sprite, polygon and line rendering.
  59. - High-level tools to draw lines and polygons such as Polygon2D and Line2D.
  60. - AnimatedSprite as a helper for creating animated sprites.
  61. - Parallax layers.
  62. - Pseudo-3D support by automatically duplicating a layer several times.
  63. - 2D lighting with normal maps.
  64. - Hard or soft shadows.
  65. - Font rendering using bitmaps (BitmapFont) or rasterization using FreeType (DynamicFont).
  66. - Bitmap fonts can be exported using tools like BMFont.
  67. - DynamicFont supports monochrome fonts as well as colored fonts.
  68. Supported formats are TTF and OTF.
  69. - DynamicFont supports optional font outlines with adjustable width and color.
  70. - Support for font oversampling to keep fonts sharp at higher resolutions.
  71. - GPU-based particles with support for custom particle shaders.
  72. - CPU-based particles.
  73. 2D tools
  74. ^^^^^^^^
  75. - 2D camera with built-in smoothing and drag margins.
  76. - Path2D node to represent a path in 2D space.
  77. - Can be drawn in the editor or generated procedurally.
  78. - PathFollow2D node to make nodes follow a Path2D.
  79. - 2D geometry helper class.
  80. - Line2D node to draw textured 2D lines.
  81. 2D physics
  82. ^^^^^^^^^^
  83. **Physics bodies:**
  84. - Static bodies.
  85. - Rigid bodies.
  86. - Kinematic bodies.
  87. - Joints.
  88. - Areas to detect bodies entering or leaving it.
  89. **Collision detection:**
  90. - Built-in shapes: line, box, circle, capsule.
  91. - Collision polygons (can be drawn manually or generated from a sprite in the editor).
  92. 3D graphics
  93. ^^^^^^^^^^^
  94. **Two renderers available:**
  95. - OpenGL ES 3.0 renderer (uses OpenGL 3.3 on desktop platforms).
  96. - High-end visuals. Recommended on desktop platforms.
  97. - HDR rendering with sRGB.
  98. - OpenGL ES 2.0 renderer (uses OpenGL 2.1 on desktop platforms).
  99. - Recommended on mobile and Web platforms.
  100. - LDR rendering for greater compatibility.
  101. - Not all features are available. Features available only when using
  102. the OpenGL ES 3.0 renderer are marked *GLES3* below.
  103. **Camera:**
  104. - Perspective, orthographic and frustum-offset cameras.
  105. **Physically-based rendering:**
  106. - Follows the Disney PBR model.
  107. - Uses a roughness-metallic workflow with support for ORM textures.
  108. - Normal mapping.
  109. - *GLES3:* Parallax/relief mapping with automatic level of detail based on distance.
  110. - *GLES3:* Sub-surface scattering and transmittance.
  111. - *GLES3:* Proximity fade (soft particles).
  112. - Distance fade which can use alpha blending or dithering to avoid going through
  113. the transparent pipeline.
  114. - Dithering can be determined on a per-pixel or per-object basis.
  115. **Real-time lighting:**
  116. - Directional lights (sun/moon). Up to 4 per scene.
  117. - Omnidirectional lights.
  118. - Spot lights with adjustable cone angle and attenuation.
  119. **Shadow mapping:**
  120. - *DirectionalLight:* Orthogonal (fastest), PSSM 2-split and 4-split.
  121. Supports blending between splits.
  122. - *OmniLight:* Dual paraboloid (fast) or cubemap (slower but more accurate).
  123. Supports colored projector textures in the form of panoramas.
  124. - *SpotLight:* Single texture.
  125. **Global illumination with indirect lighting:**
  126. - Baked lightmaps (fast, but can't be updated at run-time).
  127. - Lightmaps are baked on the CPU.
  128. - *GLES3:* GI probes (slower, semi-real-time). Supports reflections.
  129. **Reflections:**
  130. - *GLES3:* Voxel-based reflections (when using GI probes).
  131. - Fast baked reflections or slow real-time reflections using ReflectionProbe.
  132. Parallax correction can optionally be enabled.
  133. - *GLES3:* Screen-space reflections.
  134. - Reflection techniques can be mixed together for greater accuracy.
  135. **Sky:**
  136. - Panorama sky (using an HDRI).
  137. - Procedural sky.
  138. **Fog:**
  139. - Depth fog with an adjustable attenuation curve.
  140. - Height fog (floor or ceiling) with adjustable attenuation.
  141. - Support for automatic depth fog color depending on the camera direction
  142. (to match the sun color).
  143. - Optional transmittance to make lights more visible in the fog.
  144. **Particles:**
  145. - *GLES3:* GPU-based particles with support for custom particle shaders.
  146. - CPU-based particles.
  147. **Post-processing:**
  148. - Tonemapping (Linear, Reinhard, Filmic, ACES).
  149. - *GLES3:* Automatic exposure adjustments based on viewport brightness.
  150. - *GLES3:* Near and far depth of field.
  151. - *GLES3:* Screen-space ambient occlusion.
  152. - Glow/bloom with optional bicubic upscaling and several blend modes available:
  153. Screen, Soft Light, Add, Replace.
  154. - Color correction using an one-dimensional ramp.
  155. - Brightness, contrast and saturation adjustments.
  156. **Texture filtering:**
  157. - Nearest, bilinear, trilinear or anisotropic filtering.
  158. **Texture compression:**
  159. - *GLES3:* BPTC for high-quality compression (not supported on macOS).
  160. - *GLES3:* ETC2 (not supported on macOS).
  161. - ETC1 (recommended when using the GLES2 renderer).
  162. - *GLES3:* S3TC (not supported on mobile/Web platforms).
  163. **Anti-aliasing:**
  164. - Multi-sample antialiasing (MSAA).
  165. Most of these effects can be adjusted for better performance or to further
  166. improve quality. This can be helpful when using Godot for offline rendering.
  167. 3D tools
  168. ^^^^^^^^
  169. - Built-in meshes: cube, cylinder/cone, (hemi)sphere, prism, plane, quad.
  170. - Tools for :ref:`procedural geometry generation <doc_procedural_geometry>`.
  171. - :ref:`Constructive solid geometry <doc_csg_tools>` (intended for prototyping).
  172. - Path3D node to represent a path in 3D space.
  173. - Can be drawn in the editor or generated procedurally.
  174. - PathFollow3D node to make nodes follow a Path3D.
  175. - 3D geometry helper class.
  176. 3D physics
  177. ^^^^^^^^^^
  178. **Physics bodies:**
  179. - Static bodies.
  180. - Rigid bodies.
  181. - Kinematic bodies.
  182. - Vehicle bodies (intended for arcade physics, not simulation).
  183. - Joints.
  184. - Soft bodies.
  185. - Ragdolls.
  186. - Areas to detect bodies entering or leaving it.
  187. **Collision detection:**
  188. - Built-in shapes: cuboid, sphere, capsule, cylinder (only with Bullet physics).
  189. - Generate triangle collision shapes for any mesh from the editor.
  190. - Generate one or several convex collision shapes for any mesh from the editor.
  191. Shaders
  192. ^^^^^^^
  193. - *2D:* Custom vertex, fragment, and light shaders.
  194. - *3D:* Custom vertex, fragment, light, and sky shaders.
  195. - Text-based shaders using a `shader language inspired by GLSL <doc_shading_language>`.
  196. - Visual shader editor.
  197. - Support for visual shader plugins.
  198. Scripting
  199. ^^^^^^^^^
  200. **General:**
  201. - Object-oriented design pattern with scripts extending nodes.
  202. - Signals and groups for communicating between scripts.
  203. - Support for :ref:`cross-language scripting <doc_cross_language_scripting>`.
  204. - Many 2D and 3D linear algebra data types such as vectors and transforms.
  205. :ref:`GDScript: <toc-learn-scripting-gdscript>`
  206. - :ref:`High-level interpreted language <doc_gdscript>` with
  207. :ref:`optional static typing <doc_gdscript_static_typing>`.
  208. - Syntax inspired by Python.
  209. - Syntax highlighting is provided on GitHub.
  210. - :ref:`Use threads <doc_using_multiple_threads>` to perform asynchronous actions
  211. or make use of multiple processor cores.
  212. :ref:`C#: <toc-learn-scripting-C#>`
  213. - Packaged in a separate binary to keep file sizes and dependencies down.
  214. - Uses Mono 6.x.
  215. - Full support for the C# 7.0 syntax and features.
  216. - Supports all platforms.
  217. - Using an external editor is recommended to benefit from IDE functionality.
  218. :ref:`VisualScript: <toc-learn-scripting-visual_script>`
  219. - :ref:`Graph-based visual scripting language <doc_what_is_visual_script>`.
  220. - Works best when used for specific purposes (such as level-specific logic)
  221. rather than as a language to create entire projects.
  222. **GDNative (C, C++, Rust, D, ...):**
  223. - When you need it, link to native libraries for higher performance and third-party integrations.
  224. - For scripting game logic, GDScript or C# are recommended if their
  225. performance is suitable.
  226. - Official bindings for C and C++.
  227. - Use any build system and language features you wish.
  228. - Maintained D, Kotlin, Python, Nim, and Rust bindings provided by the community.
  229. Audio
  230. ^^^^^
  231. **Features:**
  232. - Mono, stereo, 5.1 and 7.1 output.
  233. - Non-positional and positional playback in 2D and 3D.
  234. - Optional Doppler effect in 2D and 3D.
  235. - Support for re-routable :ref:`audio buses <doc_audio_buses>` and effects
  236. with dozens of effects included.
  237. - Listener3D node to listen from a position different than the camera in 3D.
  238. - Audio input to record microphones.
  239. - MIDI input.
  240. - No support for MIDI output yet.
  241. **APIs used:**
  242. - *Windows:* WASAPI.
  243. - *macOS:* CoreAudio.
  244. - *Linux:* PulseAudio or ALSA.
  245. Import
  246. ^^^^^^
  247. - Support for :ref:`custom import plugins <doc_import_plugins>`.
  248. **Formats:**
  249. - *Images:* See :ref:`doc_import_images`.
  250. - *Audio:*
  251. - WAV with optional IMA-ADPCM compression.
  252. - Ogg Vorbis.
  253. - *3D scenes:*
  254. - glTF 2.0 *(recommended)*.
  255. - `ESCN <https://github.com/godotengine/godot-blender-exporter>`__
  256. (direct export from Blender).
  257. - FBX (experimental).
  258. - Collada (.dae).
  259. - Wavefront OBJ (static scenes only, can be loaded directly as a mesh).
  260. Input
  261. ^^^^^
  262. - Input mapping system using hardcoded input events or remappable input actions.
  263. - Axis values can be mapped to two different actions with a configurable deadzone.
  264. - Use the same code to support both keyboards and gamepads.
  265. - Keyboard input.
  266. - Keys can be mapped in "physical" mode to be independent of the keyboard layout.
  267. - Mouse input.
  268. - The mouse cursor can be visible, hidden, captured or confined within the window.
  269. - When captured, raw input will be used on Windows and Linux to
  270. sidestep the OS' mouse acceleration settings.
  271. - Gamepad input (up to 8 simultaneous controllers).
  272. - Pen/tablet input with pressure support.
  273. Navigation
  274. ^^^^^^^^^^
  275. - A* algorithm in 2D and 3D.
  276. - Navigation meshes.
  277. - Support for dynamic obstacle avoidance planned in Godot 4.0.
  278. - Generate navigation meshes from the editor.
  279. Networking
  280. ^^^^^^^^^^
  281. - Low-level TCP networking using StreamPeer and TCP_Server.
  282. - Low-level UDP networking using PacketPeer and UDPServer.
  283. - Low-level HTTP requests using HTTPClient.
  284. - High-level HTTP requests using HTTPRequest.
  285. - Supports HTTPS out of the box using bundled certificates.
  286. - High-level multiplayer API using UDP and ENet.
  287. - Automatic replication using remote procedure calls (RPCs).
  288. - Supports unreliable, reliable and ordered transfers.
  289. - WebSocket client and server, available on all platforms.
  290. - WebRTC client and server, available on all platforms.
  291. - Support for UPnP to sidestep the requirement to forward ports when hosting
  292. a server behind a NAT.
  293. Internationalization
  294. ^^^^^^^^^^^^^^^^^^^^
  295. - Full support for Unicode including emoji.
  296. - Store localization strings using :ref:`CSV <doc_internationalizing_games>`
  297. or :ref:`gettext <doc_localization_using_gettext>`.
  298. - Use localized strings in your project automatically in GUI elements or by
  299. using the ``tr()`` function.
  300. - Support for right-to-left typesetting and text shaping planned in Godot 4.0.
  301. Windowing and OS integration
  302. ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
  303. - Move, resize, minimize, and maximize the window spawned by the project.
  304. - Change the window title and icon.
  305. - Request attention (will cause the title bar to blink on most platforms).
  306. - Fullscreen mode.
  307. - Doesn't use exclusive fullscreen, so the screen resolution can't be changed this way.
  308. Use a Viewport with a different resolution instead.
  309. - Borderless window (fullscreen or non-fullscreen).
  310. - Ability to keep the window always on top.
  311. - Transparent window with per-pixel transparency.
  312. - Global menu integration on macOS.
  313. - Execute commands in a blocking or non-blocking manner.
  314. - Open file paths and URLs using default or custom protocol handlers (if registered on the system).
  315. - Parse custom command line arguments.
  316. Mobile
  317. ^^^^^^
  318. - In-app purchases on Android and iOS.
  319. - Support for advertisements using third-party modules.
  320. XR support (AR and VR)
  321. ^^^^^^^^^^^^^^^^^^^^^^
  322. - Support for ARKit on iOS out of the box.
  323. - Support for the OpenXR and OpenVR APIs.
  324. - Popular VR headsets like the Oculus Quest and HTC Vive are supported thanks to plugins.
  325. GUI system
  326. ^^^^^^^^^^
  327. Godot's GUI is built using the same Control nodes used to make games in Godot.
  328. The editor UI can easily be extended in many ways using add-ons.
  329. **Nodes:**
  330. - Buttons.
  331. - Checkboxes, check buttons, radio buttons.
  332. - Text entry using LineEdit (single line) and TextEdit (multiple lines).
  333. - Dropdown menus using PopupMenu and OptionButton.
  334. - Scrollbars.
  335. - Labels.
  336. - RichTextLabel for :ref:`text formatted using BBCode <doc_bbcode_in_richtextlabel>`.
  337. - Trees (can also be used to represent tables).
  338. - Containers (horizontal, vertical, grid, center, margin, draggable splitter, ...).
  339. - Controls can be rotated and scaled.
  340. **Sizing:**
  341. - Anchors to keep GUI elements in a specific corner, edge or centered.
  342. - Containers to place GUI elements automatically following certain rules.
  343. - :ref:`Stack <class_BoxContainer>` layouts.
  344. - :ref:`Grid <class_GridContainer>` layouts.
  345. - :ref:`Margin <class_MarginContainer>` and :ref:`centered <class_CenterContainer>`
  346. layouts.
  347. - :ref:`Draggable splitter <class_SplitContainer>` layouts.
  348. - Scale to multiple resolutions using the ``2d`` or ``viewport`` stretch modes.
  349. - Support any aspect ratio using anchors and the ``expand`` stretch aspect.
  350. **Theming:**
  351. - Built-in theme editor.
  352. - Generate a theme based on the current editor theme settings.
  353. - Procedural vector-based theming using :ref:`class_StyleBoxFlat`.
  354. - Supports rounded/beveled corners, drop shadows and per-border widths.
  355. - Texture-based theming using :ref:`class_StyleBoxTexture`.
  356. Godot's small distribution size can make it a suitable alternative to frameworks
  357. like Electron or Qt.
  358. Animation
  359. ^^^^^^^^^
  360. - Direct kinematics and inverse kinematics.
  361. - Support for animating any property with customizable interpolation.
  362. - Support for calling methods in animation tracks.
  363. - Support for playing sounds in animation tracks.
  364. - Support for Bézier curves in animation.
  365. Formats
  366. ^^^^^^^
  367. - Scenes and resources can be saved in :ref:`text-based <doc_tscn_file_format>` or binary formats.
  368. - Text-based formats are human-readable and more friendly to version control.
  369. - Binary formats are faster to save/load for large scenes/resources.
  370. - Read and write text or binary files using :ref:`class_File`.
  371. - Can optionally be compressed or encrypted.
  372. - Read and write :ref:`class_JSON` files.
  373. - Read and write INI-style configuration files using :ref:`class_ConfigFile`.
  374. - Can (de)serialize any Godot datatype, including Vector, Color, ...
  375. - Read XML files using :ref:`class_XMLParser`.
  376. - Pack game data into a PCK file (custom format optimized for fast seeking),
  377. into a ZIP archive, or directly into the executable for single-file distribution.
  378. - :ref:`Export additional PCK files<doc_exporting_pcks>` that can be read
  379. by the engine to support mods and DLCs.
  380. Miscellaneous
  381. ^^^^^^^^^^^^^
  382. - :ref:`Low-level access to servers <doc_using_servers>` which allows bypassing
  383. the scene tree's overhead when needed.
  384. - Command line interface for automation.
  385. - Export and deploy projects using continuous integration platforms.
  386. - `Completion scripts <https://github.com/godotengine/godot/tree/master/misc/dist/shell>`__
  387. are available for Bash, zsh and fish.
  388. - Support for :ref:`C++ modules <doc_custom_modules_in_c++>` statically linked
  389. into the engine binary.
  390. - Engine and editor written in C++03.
  391. - Can be :ref:`compiled <doc_introduction_to_the_buildsystem>` using GCC,
  392. Clang and MSVC. MinGW is also supported.
  393. - Friendly towards packagers. In most cases, system libraries can be used
  394. instead of the ones provided by Godot. The build system doesn't download anything.
  395. Builds can be fully reproducible.
  396. - Godot 4.0 will be written in C++17.
  397. - Licensed under the permissive MIT license.
  398. - Open developement process with :ref:`contributions welcome <doc_ways_to_contribute>`.
  399. .. seealso::
  400. The `Godot proposals repository <https://github.com/godotengine/godot-proposals>`__
  401. lists features that have been requested by the community and may be implemented
  402. in future Godot releases.