2023-01-12 20:49:14 +01:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
# List of features
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
This page aims to list all features currently supported by Pandemonium.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
Note:
|
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
This page lists features supported by the current stable version of
|
2024-03-16 20:56:52 +01:00
|
|
|
Pandemonium (3.5). `More features ( https://docs.pandemoniumengine.org/en/latest/about/list_of_features.html )`
|
2022-03-18 17:46:08 +01:00
|
|
|
are available in the latest development version (4.0).
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
## Features
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Platforms
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Can run both the editor and exported projects:**
|
|
|
|
|
|
|
|
- Windows 7 and later (64-bit and 32-bit).
|
|
|
|
- macOS 10.12 and later (64-bit, x86 and ARM).
|
|
|
|
- Linux (64-bit and 32-bit, x86 and ARM).
|
|
|
|
|
|
|
|
- Binaries are statically linked and can run on any distribution if compiled
|
|
|
|
on an old enough base distribution.
|
|
|
|
- Official binaries are compiled on Ubuntu 14.04.
|
|
|
|
|
|
|
|
- HTML5 via WebAssembly (Firefox, Chrome, Edge, Opera).
|
|
|
|
|
|
|
|
**Runs exported projects:**
|
|
|
|
|
|
|
|
- Android 4.4 and later.
|
|
|
|
- iOS 10.0 and later.
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Consoles ( doc_consoles )`.
|
|
|
|
- `Headless Linux and macOS servers ( doc_exporting_for_dedicated_servers )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
Pandemonium aims to be as platform-independent as possible and can be ported to new
|
2022-03-18 17:46:08 +01:00
|
|
|
platforms with relative ease.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Editor
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Features:**
|
|
|
|
|
|
|
|
- Scene tree editor.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Built-in script editor.
|
2023-01-12 20:47:54 +01:00
|
|
|
- Support for `external script editors ( doc_external_editor )` such as
|
2022-03-18 17:46:08 +01:00
|
|
|
Visual Studio Code or Vim.
|
2023-01-12 20:47:54 +01:00
|
|
|
- GDScript `debugger ( doc_debugger_panel )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- No support for debugging in threads yet.
|
|
|
|
- Performance monitoring tools.
|
|
|
|
- Live script reloading.
|
|
|
|
- Live scene editing.
|
|
|
|
|
|
|
|
- Changes will reflect in the editor and will be kept after closing the running project.
|
|
|
|
|
|
|
|
- Remote inspector.
|
|
|
|
|
|
|
|
- Changes won't reflect in the editor and won't be kept after closing the running project.
|
|
|
|
|
|
|
|
- Live camera replication.
|
|
|
|
|
|
|
|
- Move the in-editor camera and see the result in the running project.
|
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
- Built-in offline class reference documentation.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Use the editor in dozens of languages contributed by the community.
|
|
|
|
|
|
|
|
**Plugins:**
|
|
|
|
|
|
|
|
- Editor plugins can be downloaded from the
|
2023-01-12 20:47:54 +01:00
|
|
|
`asset library ( doc_what_is_assetlib )` to extend editor functionality.
|
|
|
|
- `Create your own plugins ( doc_making_plugins )` using GDScript to add new
|
2022-09-10 12:15:58 +02:00
|
|
|
features or speed up your workflow.
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Download projects from the asset library ( doc_using_assetlib_editor )`
|
2022-09-10 12:15:58 +02:00
|
|
|
in the project manager and import them directly.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### 2D graphics
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Two renderers available:**
|
|
|
|
|
|
|
|
- OpenGL ES 3.0 renderer (uses OpenGL 3.3 on desktop platforms).
|
|
|
|
|
|
|
|
- High-end visuals. Recommended on desktop platforms.
|
|
|
|
|
|
|
|
- OpenGL ES 2.0 renderer (uses OpenGL 2.1 on desktop platforms).
|
|
|
|
|
|
|
|
- Recommended on mobile and Web platforms.
|
|
|
|
|
|
|
|
**Features:**
|
|
|
|
|
|
|
|
- Sprite, polygon and line rendering.
|
|
|
|
|
|
|
|
- High-level tools to draw lines and polygons such as Polygon2D and Line2D.
|
|
|
|
|
|
|
|
- AnimatedSprite as a helper for creating animated sprites.
|
|
|
|
- Parallax layers.
|
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
- Pseudo-3D support including preview in the editor.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- 2D lighting with normal maps.
|
|
|
|
|
|
|
|
- Hard or soft shadows.
|
|
|
|
|
|
|
|
- Font rendering using bitmaps (BitmapFont) or rasterization using FreeType (DynamicFont).
|
|
|
|
|
|
|
|
- Bitmap fonts can be exported using tools like BMFont.
|
|
|
|
- DynamicFont supports monochrome fonts as well as colored fonts (e.g. for emoji).
|
2022-09-10 12:15:58 +02:00
|
|
|
Supported formats are TTF, OTF, WOFF1 and WOFF2.
|
2022-03-18 17:46:08 +01:00
|
|
|
- DynamicFont supports optional font outlines with adjustable width and color.
|
|
|
|
- Support for font oversampling to keep fonts sharp at higher resolutions.
|
|
|
|
|
|
|
|
- GPU-based particles with support for custom particle shaders.
|
|
|
|
- CPU-based particles.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### 2D tools
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- 2D camera with built-in smoothing and drag margins.
|
|
|
|
- Path2D node to represent a path in 2D space.
|
|
|
|
|
|
|
|
- Can be drawn in the editor or generated procedurally.
|
|
|
|
- PathFollow2D node to make nodes follow a Path2D.
|
|
|
|
|
|
|
|
- 2D geometry helper class.
|
|
|
|
- Line2D node to draw textured 2D lines.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### 2D physics
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Physics bodies:**
|
|
|
|
|
|
|
|
- Static bodies.
|
|
|
|
- Rigid bodies.
|
|
|
|
- Kinematic bodies.
|
|
|
|
- Joints.
|
|
|
|
- Areas to detect bodies entering or leaving it.
|
|
|
|
|
|
|
|
**Collision detection:**
|
|
|
|
|
|
|
|
- Built-in shapes: line, box, circle, capsule.
|
|
|
|
- Collision polygons (can be drawn manually or generated from a sprite in the editor).
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### 3D graphics
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Two renderers available:**
|
|
|
|
|
|
|
|
- OpenGL ES 3.0 renderer (uses OpenGL 3.3 on desktop platforms).
|
|
|
|
|
|
|
|
- High-end visuals. Recommended on desktop platforms.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Optional HDR rendering with sRGB (enabled by default).
|
|
|
|
- Uses an optional depth prepass (enabled by default) to reduce the cost of
|
|
|
|
overdraw, which speeds up complex scene rendering.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- OpenGL ES 2.0 renderer (uses OpenGL 2.1 on desktop platforms).
|
|
|
|
|
|
|
|
- Recommended on mobile and Web platforms.
|
|
|
|
- LDR rendering for greater compatibility.
|
|
|
|
- Not all features are available. Features available only when using
|
|
|
|
the OpenGL ES 3.0 renderer are marked *GLES3* below.
|
|
|
|
|
|
|
|
**Camera:**
|
|
|
|
|
|
|
|
- Perspective, orthographic and frustum-offset cameras.
|
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
**Physically-based rendering (built-in material features):**
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Follows the Disney PBR model.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Supports Lambert, Lambert Wrap (half-Lambert), Oren-Nayar and Toon diffuse shading modes.
|
|
|
|
- Supports Schlick-GGX, Blinn, Phong, Toon and Disabled specular shading modes.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Uses a roughness-metallic workflow with support for ORM textures.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Uses horizon specular occlusion (Filament model) to improve material appearance
|
2022-03-18 17:46:08 +01:00
|
|
|
- Normal mapping.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Detail mapping for the albedo and normal maps.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Distance fade which can use alpha blending or dithering to avoid going through
|
|
|
|
the transparent pipeline.
|
|
|
|
- Dithering can be determined on a per-pixel or per-object basis.
|
2022-09-10 12:15:58 +02:00
|
|
|
- *GLES3:* Parallax/relief mapping with automatic level of detail based on distance.
|
|
|
|
- *GLES3:* Sub-surface scattering and transmittance.
|
|
|
|
- *GLES3:* Refraction with support for material roughness (resulting in blurry refraction).
|
|
|
|
On GLES2, refraction is still functional but lacks support for material roughness.
|
|
|
|
- *GLES3:* Proximity fade (soft particles).
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Real-time lighting:**
|
|
|
|
|
|
|
|
- Directional lights (sun/moon). Up to 4 per scene.
|
|
|
|
- Omnidirectional lights.
|
|
|
|
- Spot lights with adjustable cone angle and attenuation.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Specular energy can be adjusted on a per-light basis.
|
|
|
|
- *GLES3:* Lighting is done with a single-pass forward approach.
|
|
|
|
By default, up to 32 omni light and 32 spot lights can be displayed per mesh resource.
|
|
|
|
If needed, this limit can be increased at the cost of increased shader compilation times and lower performance.
|
|
|
|
GLES2 uses a multi-pass forward approach to lighting, which doesn't have a
|
|
|
|
limit on the number of lights but is slower with many lights.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Shadow mapping:**
|
|
|
|
|
|
|
|
- *DirectionalLight:* Orthogonal (fastest), PSSM 2-split and 4-split.
|
|
|
|
Supports blending between splits.
|
|
|
|
- *OmniLight:* Dual paraboloid (fast) or cubemap (slower but more accurate).
|
|
|
|
Supports colored projector textures in the form of panoramas.
|
|
|
|
- *SpotLight:* Single texture.
|
|
|
|
|
|
|
|
**Global illumination with indirect lighting:**
|
|
|
|
|
|
|
|
- Baked lightmaps (fast, but can't be updated at run-time).
|
|
|
|
|
|
|
|
- Supports baking indirect light only or baking both direct and indirect lighting.
|
|
|
|
The bake mode can be adjusted on a per-light basis to allow for hybrid light
|
|
|
|
baking setups.
|
|
|
|
- Supports lighting dynamic objects using an automatic octree-based system.
|
|
|
|
No manual probe placement is required.
|
|
|
|
- Lightmaps are baked on the CPU.
|
|
|
|
|
|
|
|
- *GLES3:* GI probes (slower, semi-real-time). Supports reflections.
|
|
|
|
|
|
|
|
**Reflections:**
|
|
|
|
|
|
|
|
- Fast baked reflections or slow real-time reflections using ReflectionProbe.
|
2022-09-10 12:15:58 +02:00
|
|
|
Parallax box correction can optionally be enabled.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Reflection techniques can be mixed together for greater accuracy or scalability.
|
2022-09-10 12:15:58 +02:00
|
|
|
- *GLES3:* Voxel-based reflections (when using GI probes).
|
|
|
|
- *GLES3:* Screen-space reflections.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Sky:**
|
|
|
|
|
|
|
|
- Panorama sky (using an HDRI).
|
|
|
|
- Procedural sky.
|
|
|
|
|
|
|
|
**Fog:**
|
|
|
|
|
|
|
|
- Depth fog with an adjustable attenuation curve.
|
|
|
|
- Height fog (floor or ceiling) with adjustable attenuation.
|
|
|
|
- Support for automatic depth fog color depending on the camera direction
|
|
|
|
(to match the sun color).
|
|
|
|
- Optional transmittance to make lights more visible in the fog.
|
|
|
|
|
|
|
|
**Particles:**
|
|
|
|
|
|
|
|
- CPU-based particles.
|
2022-09-10 12:15:58 +02:00
|
|
|
- *GLES3:* GPU-based particles with support for custom particle shaders.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Post-processing:**
|
|
|
|
|
|
|
|
- Tonemapping (Linear, Reinhard, Filmic, ACES).
|
|
|
|
- Glow/bloom with optional bicubic upscaling and several blend modes available:
|
|
|
|
Screen, Soft Light, Add, Replace.
|
|
|
|
- Color correction using an one-dimensional ramp.
|
|
|
|
- Brightness, contrast and saturation adjustments.
|
2022-09-10 12:15:58 +02:00
|
|
|
- *GLES3:* Automatic exposure adjustments based on viewport brightness.
|
|
|
|
- *GLES3:* Near and far depth of field.
|
|
|
|
- *GLES3:* Screen-space ambient occlusion (SSAO).
|
|
|
|
- *GLES3:* Optional debanding to avoid color banding (effective when HDR rendering is enabled).
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Texture filtering:**
|
|
|
|
|
|
|
|
- Nearest, bilinear, trilinear or anisotropic filtering.
|
|
|
|
|
|
|
|
**Texture compression:**
|
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
- Lossless or lossy WebP (does not save VRAM; only reduces storage size).
|
|
|
|
- S3TC (only supported on desktop platforms).
|
|
|
|
- ETC1 (recommended when using the GLES2 renderer).
|
2022-03-18 17:46:08 +01:00
|
|
|
- *GLES3:* BPTC for high-quality compression (not supported on macOS).
|
|
|
|
- *GLES3:* ETC2 (not supported on macOS).
|
|
|
|
|
|
|
|
**Anti-aliasing:**
|
|
|
|
|
|
|
|
- Multi-sample antialiasing (MSAA).
|
|
|
|
- Fast approximate antialiasing (FXAA).
|
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
**Performance:**
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- Occlusion culling with `rooms and portals ( doc_rooms_and_portals )`.
|
2022-09-10 12:15:58 +02:00
|
|
|
Supports gameplay notifications with primary and secondary visibility to
|
|
|
|
disable AI/physics processing for nodes that don't need it.
|
|
|
|
- Real-time occluder shapes (sphere and polygon). Not as effective as rooms and portals
|
|
|
|
(and doesn't support gameplay notifications), but easier to set up.
|
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
Note:
|
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
Most of the effects listed above can be adjusted for better performance or
|
2024-03-16 20:56:52 +01:00
|
|
|
to further improve quality. This can be helpful when using Pandemonium for
|
2022-09-10 12:15:58 +02:00
|
|
|
offline rendering.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### 3D tools
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Built-in meshes: cube, cylinder/cone, (hemi)sphere, prism, plane, quad.
|
2023-01-12 20:47:54 +01:00
|
|
|
- Tools for `procedural geometry generation ( doc_procedural_geometry )`.
|
|
|
|
- `Constructive solid geometry ( doc_csg_tools )` (intended for prototyping).
|
2022-03-18 17:46:08 +01:00
|
|
|
- Path3D node to represent a path in 3D space.
|
|
|
|
|
|
|
|
- Can be drawn in the editor or generated procedurally.
|
|
|
|
- PathFollow3D node to make nodes follow a Path3D.
|
|
|
|
|
|
|
|
- 3D geometry helper class.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Support for exporting the current scene as a glTF 2.0 file from the editor.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### 3D physics
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Physics bodies:**
|
|
|
|
|
|
|
|
- Static bodies.
|
|
|
|
- Rigid bodies.
|
|
|
|
- Kinematic bodies.
|
|
|
|
- Vehicle bodies (intended for arcade physics, not simulation).
|
|
|
|
- Joints.
|
|
|
|
- Soft bodies.
|
|
|
|
- Ragdolls.
|
|
|
|
- Areas to detect bodies entering or leaving it.
|
|
|
|
|
|
|
|
**Collision detection:**
|
|
|
|
|
|
|
|
- Built-in shapes: cuboid, sphere, capsule, cylinder.
|
|
|
|
- Generate triangle collision shapes for any mesh from the editor.
|
|
|
|
- Generate one or several convex collision shapes for any mesh from the editor.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Shaders
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- *2D:* Custom vertex, fragment, and light shaders.
|
|
|
|
- *3D:* Custom vertex, fragment, light, and sky shaders.
|
2023-01-12 20:47:54 +01:00
|
|
|
- Text-based shaders using a `shader language inspired by GLSL ( doc_shading_language )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Visual shader editor.
|
|
|
|
|
|
|
|
- Support for visual shader plugins.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Scripting
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**General:**
|
|
|
|
|
|
|
|
- Object-oriented design pattern with scripts extending nodes.
|
|
|
|
- Signals and groups for communicating between scripts.
|
2023-01-12 20:47:54 +01:00
|
|
|
- Support for `cross-language scripting ( doc_cross_language_scripting )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Many 2D and 3D linear algebra data types such as vectors and transforms.
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
`GDScript: ( toc-learn-scripting-gdscript )`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- `High-level interpreted language ( doc_gdscript )` with
|
|
|
|
`optional static typing ( doc_gdscript_static_typing )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Syntax inspired by Python.
|
|
|
|
- Syntax highlighting is provided on GitHub.
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Use threads ( doc_using_multiple_threads )` to perform asynchronous actions
|
2022-03-18 17:46:08 +01:00
|
|
|
or make use of multiple processor cores.
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
`C#: ( toc-learn-scripting-C# )`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Packaged in a separate binary to keep file sizes and dependencies down.
|
|
|
|
- Uses Mono 6.x.
|
|
|
|
|
|
|
|
- Full support for the C# 7.0 syntax and features.
|
|
|
|
|
|
|
|
- Supports all platforms.
|
|
|
|
- Using an external editor is recommended to benefit from IDE functionality.
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
`VisualScript: ( toc-learn-scripting-visual_script )`
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Graph-based visual scripting language ( doc_what_is_visual_script )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Works best when used for specific purposes (such as level-specific logic)
|
|
|
|
rather than as a language to create entire projects.
|
|
|
|
|
|
|
|
**GDNative (C, C++, Rust, D, ...):**
|
|
|
|
|
|
|
|
- When you need it, link to native libraries for higher performance and third-party integrations.
|
|
|
|
|
|
|
|
- For scripting game logic, GDScript or C# are recommended if their
|
|
|
|
performance is suitable.
|
|
|
|
|
|
|
|
- Official bindings for C and C++.
|
|
|
|
|
|
|
|
- Use any build system and language features you wish.
|
|
|
|
|
|
|
|
- Maintained D, Kotlin, Python, Nim, and Rust bindings provided by the community.
|
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
Warning:
|
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
`Pandemonium 4.0 will remove VisualScript from core entirely. ( https://pandemoniumengine.org/article/pandemonium-4-will-discontinue-visual-scripting )`
|
|
|
|
As a result, creating new projects using visual scripting in Pandemonium is not recommended.
|
|
|
|
Future Pandemonium 4.x releases may have VisualScript reimplemented as an extension.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
While Pandemonium 3.x will keep VisualScript supported, we recommend
|
2023-01-12 20:47:54 +01:00
|
|
|
`trying out GDScript ( toc-learn-scripting-gdscript )` instead,
|
2024-03-16 20:56:52 +01:00
|
|
|
especially if you intend to migrate your project to Pandemonium 4.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Audio
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Features:**
|
|
|
|
|
|
|
|
- Mono, stereo, 5.1 and 7.1 output.
|
|
|
|
- Non-positional and positional playback in 2D and 3D.
|
|
|
|
|
|
|
|
- Optional Doppler effect in 2D and 3D.
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- Support for re-routable `audio buses ( doc_audio_buses )` and effects
|
2022-03-18 17:46:08 +01:00
|
|
|
with dozens of effects included.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Listener2D and Listener3D nodes to listen from a position different than the camera.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Audio input to record microphones with real-time access using the AudioEffectCapture class.
|
|
|
|
- MIDI input.
|
|
|
|
|
|
|
|
- No support for MIDI output yet.
|
|
|
|
|
|
|
|
**APIs used:**
|
|
|
|
|
|
|
|
- *Windows:* WASAPI.
|
|
|
|
- *macOS:* CoreAudio.
|
|
|
|
- *Linux:* PulseAudio or ALSA.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Import
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- Support for `custom import plugins ( doc_import_plugins )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Formats:**
|
|
|
|
|
2023-01-12 19:29:11 +01:00
|
|
|
- *Images:* See `doc_import_images`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- *Audio:*
|
|
|
|
|
|
|
|
- WAV with optional IMA-ADPCM compression.
|
|
|
|
- Ogg Vorbis.
|
|
|
|
- MP3.
|
|
|
|
|
|
|
|
- *3D scenes:*
|
|
|
|
|
|
|
|
- glTF 2.0 *(recommended)*.
|
2024-03-16 21:04:42 +01:00
|
|
|
- `ESCN ( https://github.com/Relintai/pandemonium_engine-blender-exporter )`
|
2022-03-18 17:46:08 +01:00
|
|
|
(direct export from Blender).
|
|
|
|
- FBX (experimental, static meshes only).
|
|
|
|
- Collada (.dae).
|
|
|
|
- Wavefront OBJ (static scenes only, can be loaded directly as a mesh).
|
|
|
|
|
2023-01-12 20:39:50 +01:00
|
|
|
- 3D meshes use `Mikktspace ( http://www.mikktspace.com/ )` to generate tangents
|
2022-09-10 12:15:58 +02:00
|
|
|
on import, which ensures consistency with other 3D applications such as Blender.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Input
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Input mapping system using hardcoded input events or remappable input actions.
|
|
|
|
|
|
|
|
- Axis values can be mapped to two different actions with a configurable deadzone.
|
|
|
|
- Use the same code to support both keyboards and gamepads.
|
|
|
|
|
|
|
|
- Keyboard input.
|
|
|
|
|
|
|
|
- Keys can be mapped in "physical" mode to be independent of the keyboard layout.
|
|
|
|
|
|
|
|
- Mouse input.
|
|
|
|
|
|
|
|
- The mouse cursor can be visible, hidden, captured or confined within the window.
|
|
|
|
- When captured, raw input will be used on Windows and Linux to
|
|
|
|
sidestep the OS' mouse acceleration settings.
|
|
|
|
|
|
|
|
- Gamepad input (up to 8 simultaneous controllers).
|
|
|
|
- Pen/tablet input with pressure support.
|
|
|
|
- Gamepad, keyboard and mouse input support are also available on Android.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Navigation
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- A* algorithm in 2D and 3D.
|
2022-09-10 12:15:58 +02:00
|
|
|
- Navigation meshes with dynamic obstacle avoidance.
|
|
|
|
- Generate navigation meshes from the editor or at run-time (including from an exported project).
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Networking
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Low-level TCP networking using StreamPeer and TCP_Server.
|
|
|
|
- Low-level UDP networking using PacketPeer and UDPServer.
|
|
|
|
- Low-level HTTP requests using HTTPClient.
|
|
|
|
- High-level HTTP requests using HTTPRequest.
|
|
|
|
|
|
|
|
- Supports HTTPS out of the box using bundled certificates.
|
|
|
|
|
|
|
|
- High-level multiplayer API using UDP and ENet.
|
|
|
|
|
|
|
|
- Automatic replication using remote procedure calls (RPCs).
|
|
|
|
- Supports unreliable, reliable and ordered transfers.
|
|
|
|
|
|
|
|
- WebSocket client and server, available on all platforms.
|
|
|
|
- WebRTC client and server, available on all platforms.
|
|
|
|
- Support for UPnP to sidestep the requirement to forward ports when hosting
|
|
|
|
a server behind a NAT.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Internationalization
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Full support for Unicode including emoji.
|
2023-01-12 20:47:54 +01:00
|
|
|
- Store localization strings using `CSV ( doc_internationalizing_games )`
|
|
|
|
or `gettext ( doc_localization_using_gettext )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Use localized strings in your project automatically in GUI elements or by
|
2023-01-12 19:43:03 +01:00
|
|
|
using the `tr()` function.
|
2024-03-16 20:56:52 +01:00
|
|
|
- Support for right-to-left typesetting and text shaping planned in Pandemonium 4.0.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Windowing and OS integration
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Move, resize, minimize, and maximize the window spawned by the project.
|
|
|
|
- Change the window title and icon.
|
|
|
|
- Request attention (will cause the title bar to blink on most platforms).
|
|
|
|
- Fullscreen mode.
|
|
|
|
|
|
|
|
- Doesn't use exclusive fullscreen, so the screen resolution can't be changed this way.
|
|
|
|
Use a Viewport with a different resolution instead.
|
|
|
|
|
|
|
|
- Borderless window (fullscreen or non-fullscreen).
|
|
|
|
- Ability to keep the window always on top.
|
|
|
|
- Transparent window with per-pixel transparency.
|
|
|
|
- Global menu integration on macOS.
|
|
|
|
- Execute commands in a blocking or non-blocking manner.
|
|
|
|
- Open file paths and URLs using default or custom protocol handlers (if registered on the system).
|
|
|
|
- Parse custom command line arguments.
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Headless/server binaries ( doc_exporting_for_dedicated_servers )` can be
|
|
|
|
downloaded for Linux and `compiled for macOS ( doc_compiling_for_osx )`.
|
2023-01-12 19:43:03 +01:00
|
|
|
Any binary can be used without a window using the `--no-window`
|
2023-01-12 20:47:54 +01:00
|
|
|
`command line argument ( doc_command_line_tutorial )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Mobile
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- In-app purchases on Android and iOS.
|
|
|
|
- Support for advertisements using third-party modules.
|
|
|
|
- Support for subview embedding on Android.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### XR support (AR and VR)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Support for ARKit on iOS out of the box.
|
|
|
|
- Support for the OpenXR APIs.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
- Includes support for popular headsets like the Meta Quest and the Valve Index.
|
2022-09-10 12:15:58 +02:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
- Support for the OpenVR APIs.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### GUI system
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
Pandemonium's GUI is built using the same Control nodes used to make games in Pandemonium.
|
2022-03-18 17:46:08 +01:00
|
|
|
The editor UI can easily be extended in many ways using add-ons.
|
|
|
|
|
|
|
|
**Nodes:**
|
|
|
|
|
|
|
|
- Buttons.
|
|
|
|
- Checkboxes, check buttons, radio buttons.
|
|
|
|
- Text entry using LineEdit (single line) and TextEdit (multiple lines).
|
|
|
|
- Dropdown menus using PopupMenu and OptionButton.
|
|
|
|
- Scrollbars.
|
|
|
|
- Labels.
|
2023-01-12 20:47:54 +01:00
|
|
|
- RichTextLabel for `text formatted using BBCode ( doc_bbcode_in_richtextlabel )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Trees (can also be used to represent tables).
|
2022-09-10 12:15:58 +02:00
|
|
|
- Color picker with RGB and HSV modes.
|
|
|
|
- Containers (horizontal, vertical, grid, flow, center, margin, aspect ratio, draggable splitter, ...).
|
2022-03-18 17:46:08 +01:00
|
|
|
- Controls can be rotated and scaled.
|
|
|
|
|
|
|
|
**Sizing:**
|
|
|
|
|
|
|
|
- Anchors to keep GUI elements in a specific corner, edge or centered.
|
|
|
|
- Containers to place GUI elements automatically following certain rules.
|
|
|
|
|
2023-01-12 19:30:47 +01:00
|
|
|
- `Stack` layouts.
|
|
|
|
- `Grid` layouts.
|
|
|
|
- `Margin`
|
2022-03-18 17:46:08 +01:00
|
|
|
layouts.
|
2023-01-12 19:30:47 +01:00
|
|
|
- `Draggable splitter` layouts.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:43:03 +01:00
|
|
|
- Scale to multiple resolutions using the `2d` or `viewport` stretch modes.
|
|
|
|
- Support any aspect ratio using anchors and the `expand` stretch aspect.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
**Theming:**
|
|
|
|
|
|
|
|
- Built-in theme editor.
|
|
|
|
|
|
|
|
- Generate a theme based on the current editor theme settings.
|
|
|
|
|
2023-01-12 19:32:38 +01:00
|
|
|
- Procedural vector-based theming using `StyleBoxFlat`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2022-09-10 12:15:58 +02:00
|
|
|
- Supports rounded/beveled corners, drop shadows, per-border widths and antialiasing.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:32:38 +01:00
|
|
|
- Texture-based theming using `StyleBoxTexture`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
Pandemonium's small distribution size can make it a suitable alternative to frameworks
|
2022-03-18 17:46:08 +01:00
|
|
|
like Electron or Qt.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Animation
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Direct kinematics and inverse kinematics.
|
2023-01-12 19:30:47 +01:00
|
|
|
- `Tween` node to easily perform procedural animations by code.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Support for animating any property with customizable interpolation.
|
|
|
|
- Support for calling methods in animation tracks.
|
|
|
|
- Support for playing sounds in animation tracks.
|
|
|
|
- Support for Bézier curves in animation.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### File formats
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- Scenes and resources can be saved in `text-based ( doc_tscn_file_format )` or binary formats.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Text-based formats are human-readable and more friendly to version control.
|
|
|
|
- Binary formats are faster to save/load for large scenes/resources.
|
|
|
|
|
2023-01-12 19:32:38 +01:00
|
|
|
- Read and write text or binary files using `File`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Can optionally be compressed or encrypted.
|
|
|
|
|
2023-01-12 19:32:38 +01:00
|
|
|
- Read and write `JSON` files.
|
|
|
|
- Read and write INI-style configuration files using `ConfigFile`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-03-16 20:56:52 +01:00
|
|
|
- Can (de)serialize any Pandemonium datatype, including Vector2/3, Color, ...
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 19:32:38 +01:00
|
|
|
- Read XML files using `XMLParser`.
|
2022-03-18 17:46:08 +01:00
|
|
|
- Pack game data into a PCK file (custom format optimized for fast seeking),
|
|
|
|
into a ZIP archive, or directly into the executable for single-file distribution.
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Export additional PCK files( doc_exporting_pcks )` that can be read
|
2022-03-18 17:46:08 +01:00
|
|
|
by the engine to support mods and DLCs.
|
|
|
|
|
2024-04-20 16:21:44 +02:00
|
|
|
### Miscellaneous
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Low-level access to servers ( doc_using_servers )` which allows bypassing
|
2022-03-18 17:46:08 +01:00
|
|
|
the scene tree's overhead when needed.
|
2023-01-12 20:47:54 +01:00
|
|
|
- `Command line interface ( doc_command_line_tutorial )` for automation.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Export and deploy projects using continuous integration platforms.
|
2024-03-16 21:04:42 +01:00
|
|
|
- `Shell completion scripts ( https://github.com/Relintai/pandemonium_engine/tree/master/misc/dist/shell )`
|
2022-03-18 17:46:08 +01:00
|
|
|
are available for Bash, zsh and fish.
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- Support for `C++ modules ( doc_custom_modules_in_c++ )` statically linked
|
2022-03-18 17:46:08 +01:00
|
|
|
into the engine binary.
|
|
|
|
- Engine and editor written in C++03.
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- Can be `compiled ( doc_introduction_to_the_buildsystem )` using GCC,
|
2022-03-18 17:46:08 +01:00
|
|
|
Clang and MSVC. MinGW is also supported.
|
|
|
|
- Friendly towards packagers. In most cases, system libraries can be used
|
2024-03-16 20:56:52 +01:00
|
|
|
instead of the ones provided by Pandemonium. The build system doesn't download anything.
|
2022-03-18 17:46:08 +01:00
|
|
|
Builds can be fully reproducible.
|
2024-03-16 20:56:52 +01:00
|
|
|
- Pandemonium 4.0 will be written in C++17.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
- Licensed under the permissive MIT license.
|
|
|
|
|
2023-01-12 20:47:54 +01:00
|
|
|
- Open developement process with `contributions welcome ( doc_ways_to_contribute )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
See also:
|
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2024-03-16 21:04:42 +01:00
|
|
|
The `Pandemonium proposals repository ( https://github.com/Relintai/pandemonium_engine-proposals )`
|
2022-03-18 17:46:08 +01:00
|
|
|
lists features that have been requested by the community and may be implemented
|
2024-03-16 20:56:52 +01:00
|
|
|
in future Pandemonium releases.
|