Cleanups.

This commit is contained in:
Relintai 2024-04-21 00:35:10 +02:00
parent ff5a3c2bc4
commit 9a17898d09
18 changed files with 101 additions and 222 deletions

View File

@ -1,7 +1,6 @@
Introduction to Pandemonium # Introduction to Pandemonium
=====================
This article is here to help you figure out whether Pandemonium might be a good fit This article is here to help you figure out whether Pandemonium might be a good fit
for you. We will introduce some broad features of the engine to give you a feel for you. We will introduce some broad features of the engine to give you a feel
@ -11,8 +10,7 @@ know to get started?".
This is by no means an exhaustive overview. We will introduce many more features This is by no means an exhaustive overview. We will introduce many more features
in this getting started series. in this getting started series.
What is Pandemonium? ## What is Pandemonium?
--------------
Pandemonium is a general-purpose 2D and 3D game engine designed to support all sorts Pandemonium is a general-purpose 2D and 3D game engine designed to support all sorts
of projects. You can use it to create games or applications you can then release of projects. You can use it to create games or applications you can then release
@ -22,13 +20,13 @@ You can also create console games with it, although you either need strong
programming skills or a developer to port the game for you. programming skills or a developer to port the game for you.
Note: Note:
The Pandemonium team can't provide an open-source console export due to the
licensing terms imposed by console manufacturers. Regardless of the - The Pandemonium team can't provide an open-source console export due to the licensing
terms imposed by console manufacturers. Regardless of the
engine you use, though, releasing games on consoles is always a lot of engine you use, though, releasing games on consoles is always a lot of
work. You can read more on that here: `doc_consoles`. work. You can read more on that here: `doc_consoles`.
What can the engine do? ## What can the engine do?
-----------------------
Pandemonium was initially developed in-house by an Argentinan game studio. Its Pandemonium was initially developed in-house by an Argentinan game studio. Its
development started in 2001, and the engine was rewritten and improved development started in 2001, and the engine was rewritten and improved
@ -38,7 +36,7 @@ Some examples of games created with Pandemonium include Ex-Zodiac and Helms of F
![](img/introduction_ex_zodiac.png) ![](img/introduction_ex_zodiac.png)
![](img/introduction_helms_of_fury.jpg ![](img/introduction_helms_of_fury.jpg)
As for applications, the open-source pixel art drawing program Pixelorama is As for applications, the open-source pixel art drawing program Pixelorama is
powered by Pandemonium, and so is the voxel RPG creator RPG in a box. powered by Pandemonium, and so is the voxel RPG creator RPG in a box.
@ -47,8 +45,7 @@ powered by Pandemonium, and so is the voxel RPG creator RPG in a box.
You can find many more examples in the `official showcase videos`. You can find many more examples in the `official showcase videos`.
How does it work and look? ## How does it work and look?
--------------------------
Pandemonium comes with a fully-fledged game editor with integrated tools to answer the Pandemonium comes with a fully-fledged game editor with integrated tools to answer the
most common needs. It includes a code editor, an animation editor, a tilemap most common needs. It includes a code editor, an animation editor, a tilemap
@ -67,20 +64,16 @@ Windows.
![](img/introduction_vscode.png) ![](img/introduction_vscode.png)
Programming languages ## Programming languages
---------------------
Let's talk about the available programming languages. Let's talk about the available programming languages.
You can code your games using `GDScript <toc-learn-scripting-gdscript )`, a You can code your games using [GDScript](toc-learn-scripting-gdscript), a
Pandemonium-specific and tightly integrated language with a lightweight syntax, or Pandemonium-specific and tightly integrated language with a lightweight syntax, or
`C# <toc-learn-scripting-C# )`, which is popular in the games industry. [C#](toc-learn-scripting-C#), which is popular in the games industry.
These are the two main scripting languages we support. These are the two main scripting languages we support.
Pandemonium also supports a node-based visual programming language named With the [GDNative](toc-tutorials-gdnative) technology, you can also write
`VisualScript <toc-learn-scripting-visual_script )`.
With the `GDNative <toc-tutorials-gdnative )` technology, you can also write
gameplay or high-performance algorithms in C or C++ without recompiling the gameplay or high-performance algorithms in C or C++ without recompiling the
engine. You can use this technology to integrate third-party libraries and other engine. You can use this technology to integrate third-party libraries and other
Software Development Kits (SDK) in the engine. Software Development Kits (SDK) in the engine.
@ -89,13 +82,12 @@ Of course, you can also directly add modules and features to the engine, as it's
completely free and open-source. completely free and open-source.
See also: See also:
These are the five officially supported programming languages. The
community maintains support for many more. For more information,
see `GDNative third-party bindings
( doc_what_is_gdnative_third_party_bindings )`.
What do I need to know to use Pandemonium? - These are the five officially supported programming languages. The
------------------------------------ community maintains support for many more. For more information,
see [GDNative third-party bindings](doc_what_is_gdnative_third_party_bindings).
## What do I need to know to use Pandemonium?
Pandemonium is a feature-packed game engine. With its thousands of features, there is Pandemonium is a feature-packed game engine. With its thousands of features, there is
a lot to learn. To make the most of it, you need good programming foundations. a lot to learn. To make the most of it, you need good programming foundations.
@ -111,7 +103,7 @@ you everything you need to know to be off to a good start. It will save you
countless hours and hurdles learning any game engine afterward. countless hours and hurdles learning any game engine afterward.
Note: Note:
In CS50, you will learn multiple programming languages. Don't be - In CS50, you will learn multiple programming languages. Don't be
afraid of that: programming languages have many similarities. The afraid of that: programming languages have many similarities. The
skills you learn with one language transfer well to others. skills you learn with one language transfer well to others.
@ -120,8 +112,8 @@ We will provide you with more Pandemonium-specific learning resources in
In the next part, you will get an overview of the engine's essential concepts. In the next part, you will get an overview of the engine's essential concepts.
.. _Blender: https://www.blender.org/ [Blender](https://www.blender.org/)
.. _VSCode: https://github.com/Relintai/pandemonium_engine-vscode-plugin [VSCode](https://github.com/Relintai/pandemonium_engine-vscode-plugin)
.. _Emacs: https://github.com/pandemoniumengine/emacs-gdscript-mode [Emacs](https://github.com/pandemoniumengine/emacs-gdscript-mode)
.. _official showcase videos: https://www.youtube.com/playlist?list=PLeG_dAglpVo6EpaO9A1nkwJZOwrfiLdQ8 [official showcase videos](https://www.youtube.com/playlist?list=PLeG_dAglpVo6EpaO9A1nkwJZOwrfiLdQ8)
.. _CS50 open courseware: https://cs50.harvard.edu/x [CS50 open courseware](https://cs50.harvard.edu/x)

View File

@ -1,7 +1,6 @@
Pandemonium's design philosophy # Pandemonium's design philosophy
=========================
Now that you've gotten your feet wet, let's talk about Pandemonium's design. Now that you've gotten your feet wet, let's talk about Pandemonium's design.
@ -20,8 +19,7 @@ Please watch
`Pandemonium explained in 5 minutes ( https://www.youtube.com/watch?v=KjX5llYZ5eQ )` `Pandemonium explained in 5 minutes ( https://www.youtube.com/watch?v=KjX5llYZ5eQ )`
if you're looking for an overview of the engine's features. if you're looking for an overview of the engine's features.
Object-oriented design and composition ## Object-oriented design and composition
--------------------------------------
Pandemonium embraces object-oriented design at its core with its flexible Pandemonium embraces object-oriented design at its core with its flexible
scene system and Node hierarchy. It tries to stay away from strict scene system and Node hierarchy. It tries to stay away from strict
@ -47,7 +45,7 @@ that extends your Character. Modify the Character in the editor and the Magician
will update as well. It helps you build your projects so that their will update as well. It helps you build your projects so that their
structure matches the game's design. structure matches the game's design.
|image0| ![](img/engine_design_01.png)
Also note that Pandemonium offers many different types of objects called Also note that Pandemonium offers many different types of objects called
nodes, each with a specific purpose. Nodes are part of a tree and always nodes, each with a specific purpose. Nodes are part of a tree and always
@ -58,26 +56,25 @@ body will use, most nodes work independently from one another.
In other words, Pandemonium's nodes do not work like components in some In other words, Pandemonium's nodes do not work like components in some
other game engines. other game engines.
|image1| ![](img/engine_design_02.png)
Sprite is a Node2D, a CanvasItem and a Node. It has all the properties Sprite is a Node2D, a CanvasItem and a Node. It has all the properties
and features of its three parent classes, like transforms or the ability and features of its three parent classes, like transforms or the ability
to draw custom shapes and render with a custom shader. to draw custom shapes and render with a custom shader.
All-inclusive package ## All-inclusive package
---------------------
Pandemonium tries to provide its own tools to answer most common Pandemonium tries to provide its own tools to answer most common
needs. It has a dedicated scripting workspace, an animation editor, a needs. It has a dedicated scripting workspace, an animation editor, a
tilemap editor, a shader editor, a debugger, a profiler, tilemap editor, a shader editor, a debugger, a profiler,
the ability to hot-reload locally and on remote devices, etc. the ability to hot-reload locally and on remote devices, etc.
|image2| ![](img/engine_design_03.png)
The goal is to offer a full package to create games and a continuous The goal is to offer a full package to create games and a continuous
user experience. You can still work with external programs as long as user experience. You can still work with external programs as long as
there is an import plugin for it. Or you can create one, like the `Tiled there is an import plugin for it. Or you can create one, like the
Map Importer ( https://github.com/vnen/pandemonium-tiled-importer )`. [Tiled Map Importer](https://github.com/vnen/pandemonium-tiled-importer).
That is also partly why Pandemonium offers its own programming languages That is also partly why Pandemonium offers its own programming languages
GDScript and VisualScript, along with C#. They're designed for the needs GDScript and VisualScript, along with C#. They're designed for the needs
@ -92,7 +89,7 @@ Note that with GDNative, you can write high-performance code using compiled
languages like C, C++, Rust, or Python (using the Cython compiler) languages like C, C++, Rust, or Python (using the Cython compiler)
without recompiling the engine. without recompiling the engine.
|image3| ![](img/engine_design_visual_script.png)
*VisualScript is a node-based programming language that integrates well *VisualScript is a node-based programming language that integrates well
in the editor. You can drag and drop nodes or resources into the graph in the editor. You can drag and drop nodes or resources into the graph
@ -103,25 +100,12 @@ You'll need external programs or add-ons to edit terrains, animate complex chara
Pandemonium provides a complete API to extend the editor's functionality using Pandemonium provides a complete API to extend the editor's functionality using
game code. See `The Pandemonium editor is a Pandemonium game` below. game code. See `The Pandemonium editor is a Pandemonium game` below.
|image4| ![](img/engine_design_fsm_plugin.png)
*A State Machine editor plugin in Pandemonium 2 by kubecz3k. It lets you *A State Machine editor plugin in Pandemonium 2 by kubecz3k. It lets you
manage states and transitions visually.* manage states and transitions visually.*
## Open source
Warning:
`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.
While Pandemonium 3.x will keep VisualScript supported, we recommend
`trying out GDScript <toc-learn-scripting-gdscript )` instead,
especially if you intend to migrate your project to Pandemonium 4.
Open source
-----------
Pandemonium offers a fully open source codebase under the **MIT license**. Pandemonium offers a fully open source codebase under the **MIT license**.
This means all the technologies that ship with it have to be Free This means all the technologies that ship with it have to be Free
@ -139,12 +123,10 @@ as Pandemonium will print errors with a stack trace, even if they come from the
Note: Note:
- This **does not affect the work you do with Pandemonium** in any way: there's
This **does not affect the work you do with Pandemonium** in any way: there's
no strings attached to the engine or anything you make with it. no strings attached to the engine or anything you make with it.
Community-driven ## Community-driven
----------------
**Pandemonium is made by its community, for the community, and for all game **Pandemonium is made by its community, for the community, and for all game
creators out there.** It's the needs of the users and open discussions creators out there.** It's the needs of the users and open discussions
@ -157,8 +139,7 @@ programmers work on features they may need themselves, so you'll see
improvements in all corners of the engine at the same time in every improvements in all corners of the engine at the same time in every
major release. major release.
The Pandemonium editor is a Pandemonium game ## The Pandemonium editor is a Pandemonium game
--------------------------------
The Pandemonium editor runs on the game engine. It uses the engine's own UI The Pandemonium editor runs on the game engine. It uses the engine's own UI
system, it can hot-reload code and scenes when you test your projects, system, it can hot-reload code and scenes when you test your projects,
@ -168,7 +149,7 @@ and scenes for your games, or **build plugins and extend the editor.**
This leads to a reliable and flexible UI system, as it powers the editor This leads to a reliable and flexible UI system, as it powers the editor
itself. With the `tool` keyword, you can run any game code in the editor. itself. With the `tool` keyword, you can run any game code in the editor.
|image5| ![](img/engine_design_rpg_in_a_box.png)
*RPG in a Box is a voxel RPG editor made with Pandemonium 2. It uses Pandemonium's *RPG in a Box is a voxel RPG editor made with Pandemonium 2. It uses Pandemonium's
UI tools for its node-based programming system and for the rest of the UI tools for its node-based programming system and for the rest of the
@ -181,22 +162,13 @@ you use in your projects.
Note: Note:
- The editor is fully written in C++ and is statically compiled into the
The editor is fully written in C++ and is statically compiled into the
binary. This means you can't import it as a typical project that would have a binary. This means you can't import it as a typical project that would have a
`project.pandemonium` file. `project.pandemonium` file.
Separate 2D and 3D engines ## Separate 2D and 3D engines
--------------------------
Pandemonium offers dedicated 2D and 3D rendering engines. As a result, **the Pandemonium offers dedicated 2D and 3D rendering engines. As a result, **the
base unit for 2D scenes is pixels.** Even though the engines are base unit for 2D scenes is pixels.** Even though the engines are
separate, you can render 2D in 3D, 3D in 2D, and overlay 2D sprites and separate, you can render 2D in 3D, 3D in 2D, and overlay 2D sprites and
interfaces over your 3D world. interfaces over your 3D world.
.. |image0| image:: img/engine_design_01.png)
.. |image1| image:: img/engine_design_02.png)
.. |image2| image:: img/engine_design_03.png)
.. |image3| image:: img/engine_design_visual_script.png)
.. |image4| image:: img/engine_design_fsm_plugin.png)
.. |image5| image:: img/engine_design_rpg_in_a_box.png)

View File

@ -1,18 +1,11 @@
.. Keep this page short and sweet! We want users to read it to the end, so they
know where to find information, how to get help, and how to maximize chances
of getting answers.
# Learning new features
Learning new features
=====================
Pandemonium is a feature-rich game engine. There is a lot to learn about it. This page Pandemonium is a feature-rich game engine. There is a lot to learn about it. This page
explains how you can use the online manual, built-in code reference, and join explains how you can use the online manual, built-in code reference, and join
online communities to learn new features and techniques. online communities to learn new features and techniques.
Making the most of this manual ## Making the most of this manual
------------------------------
What you are reading now is the user manual. It documents each of the engine's What you are reading now is the user manual. It documents each of the engine's
concepts and available features. When learning a new topic, you can start by concepts and available features. When learning a new topic, you can start by
@ -29,11 +22,11 @@ general features, concepts, and how to use the editor, the reference is all
about using Pandemonium's scripting API (Application Programming Interface). You can about using Pandemonium's scripting API (Application Programming Interface). You can
access it both online and offline. We recommend browsing the reference offline, access it both online and offline. We recommend browsing the reference offline,
from within the Pandemonium editor. To do so, go to Help -> Search or press from within the Pandemonium editor. To do so, go to Help -> Search or press
:kbd:`F1`. `F1`.
![](img/manual_class_reference_search.png) ![](img/manual_class_reference_search.png)
To browse it online, head to the manual's `Class Reference <toc-class-ref )` To browse it online, head to the manual's `Class Reference`
section. section.
A class reference's page tells you: A class reference's page tells you:
@ -52,16 +45,16 @@ A class reference's page tells you:
4. Links to manual pages further detailing the class. 4. Links to manual pages further detailing the class.
Note: Note:
If the manual or class reference is missing or has insufficient
information, please open an Issue in the official `pandemonium-docs - If the manual or class reference is missing or has insufficient
( https://github.com/Relintai/pandemonium_engine-docs/issues )` GitHub repository information, please open an Issue in the official
[pandemonium-docs](https://github.com/Relintai/pandemonium_engine-docs/issues) GitHub repository
to report it. to report it.
You can Ctrl-click any underlined text like the name of a class, property, You can Ctrl-click any underlined text like the name of a class, property,
method, signal, or constant to jump to it. method, signal, or constant to jump to it.
Learning to think like a programmer ## Learning to think like a programmer
-----------------------------------
Teaching programming foundations and how to think like a game developer is Teaching programming foundations and how to think like a game developer is
beyond the scope of Pandemonium's documentation. If you're new to programming, we beyond the scope of Pandemonium's documentation. If you're new to programming, we
@ -77,8 +70,7 @@ recommend two excellent free resources to get you started:
2. If you prefer books, check out the free ebook `Automate The Boring Stuff With 2. If you prefer books, check out the free ebook `Automate The Boring Stuff With
Python ( https://automatetheboringstuff.com/ )` by Al Sweigart. Python ( https://automatetheboringstuff.com/ )` by Al Sweigart.
Learning with the community ## Learning with the community
---------------------------
Pandemonium has a growing community of users. If you're stuck on a problem or need Pandemonium has a growing community of users. If you're stuck on a problem or need
help to better understand how to achieve something, you can ask other users for help to better understand how to achieve something, you can ask other users for
@ -142,8 +134,7 @@ information:
Following these guidelines will maximize your chances of getting the answer Following these guidelines will maximize your chances of getting the answer
you're looking for. They will save time both to you and the persons helping you. you're looking for. They will save time both to you and the persons helping you.
Community tutorials ## Community tutorials
-------------------
This manual aims to provide a comprehensive reference of Pandemonium's features. Aside This manual aims to provide a comprehensive reference of Pandemonium's features. Aside
from the 2D and 3D getting started series, it does not contain tutorials to from the 2D and 3D getting started series, it does not contain tutorials to

View File

@ -1,7 +1,6 @@
Creating instances # Creating instances
==================
In the previous part, we saw that a scene is a collection of nodes organized in In the previous part, we saw that a scene is a collection of nodes organized in
a tree structure, with a single node as its root. You can split your project a tree structure, with a single node as its root. You can split your project
@ -35,12 +34,11 @@ as `Ball.tscn`. However, you can modify each independently, such as changing
how they bounce, how heavy they are, or any property exposed by the source how they bounce, how heavy they are, or any property exposed by the source
scene. scene.
In practice ## In practice
-----------
Let's use instancing in practice to see how it works in Pandemonium. We invite Let's use instancing in practice to see how it works in Pandemonium. We invite
you to download the ball's sample project we prepared for you: you to download the ball's sample project we prepared for you:
:download:`instancing.zip <files/instancing.zip )`. :download:`instancing.zip (files/instancing.zip )`.
Extract the archive on your computer. Then, open Pandemonium, and in the project Extract the archive on your computer. Then, open Pandemonium, and in the project
manager, click the Import button to import the project. manager, click the Import button to import the project.
@ -100,8 +98,7 @@ Play the game again. You should now see every ball fall independently from one
another. This is what instances do. Each is an independent reproduction of a another. This is what instances do. Each is an independent reproduction of a
template scene. template scene.
Editing scenes and instances ## Editing scenes and instances
----------------------------
There is more to instances. With this feature, you can: There is more to instances. With this feature, you can:
@ -160,8 +157,7 @@ Note:
Resources are another essential building block of Pandemonium games we will Resources are another essential building block of Pandemonium games we will
cover in a later lesson. cover in a later lesson.
Scene instances as a design language ## Scene instances as a design language
------------------------------------
Instances and scenes in Pandemonium offer an excellent design language, setting the Instances and scenes in Pandemonium offer an excellent design language, setting the
engine apart from others out there. We designed Pandemonium around this concept from engine apart from others out there. We designed Pandemonium around this concept from
@ -210,8 +206,7 @@ to programmers, designers, and artists alike. A typical team development process
can involve 2D or 3D artists, level designers, game designers, and animators, can involve 2D or 3D artists, level designers, game designers, and animators,
all working with the Pandemonium editor. all working with the Pandemonium editor.
Summary ## Summary
-------
Instancing, the process of producing an object from a blueprint has many handy Instancing, the process of producing an object from a blueprint has many handy
uses. With scenes, it gives you: uses. With scenes, it gives you:

View File

@ -1,26 +1,10 @@
..
Intention:
- Giving a *short* and sweet hands-on intro to GDScript. The page should
focus on working in the code editor.
- We assume the reader has programming foundations, as explained in
getting_started/introduction.
Techniques:
- Creating a sprite.
- Creating a script.
- _init() and _process().
- Moving an object on screen.
# Creating your first script
Creating your first script
==========================
In this lesson, you will code your first script to make the Pandemonium icon turn in In this lesson, you will code your first script to make the Pandemonium icon turn in
circles using GDScript. As we mentioned `in the introduction circles using GDScript. As we mentioned `in the introduction
<toc-learn-introduction )`, we assume you have programming foundations. (toc-learn-introduction )`, we assume you have programming foundations.
The equivalent C# code has been included in another tab for convenience. The equivalent C# code has been included in another tab for convenience.
![](img/scripting_first_script_rotating_pandemonium.gif) ![](img/scripting_first_script_rotating_pandemonium.gif)
@ -32,8 +16,7 @@ See also:
See also: See also:
To learn more about C#, head to the `C# basics ( doc_c_sharp )` page. To learn more about C#, head to the `C# basics ( doc_c_sharp )` page.
Project setup ## Project setup
-------------
Please create a new project to start with a clean slate. Your project should Please create a new project to start with a clean slate. Your project should
contain one picture: the Pandemonium icon, which we often use for prototyping in the contain one picture: the Pandemonium icon, which we often use for prototyping in the
@ -73,8 +56,7 @@ Then, click and drag the icon in the viewport to center it in the game view.
![](img/scripting_first_script_centering_sprite.png) ![](img/scripting_first_script_centering_sprite.png)
Creating a new script ## Creating a new script
---------------------
To create and attach a new script to our node, right-click on Sprite in the To create and attach a new script to our node, right-click on Sprite in the
scene dock and select "Attach Script". scene dock and select "Attach Script".
@ -122,8 +104,7 @@ Note:
You can hover any property's name in the Inspector to see a description and You can hover any property's name in the Inspector to see a description and
its identifier in code. its identifier in code.
Hello, world! ## Hello, world!
-------------
Our script currently doesn't do anything. Let's make it print the text "Hello, Our script currently doesn't do anything. Let's make it print the text "Hello,
world!" to the Output bottom panel to get started. world!" to the Output bottom panel to get started.
@ -158,8 +139,7 @@ It should display "Hello, world!".
Delete the `init()` function, so you're only left with the line `extends Delete the `init()` function, so you're only left with the line `extends
Sprite`. Sprite`.
Turning around ## Turning around
--------------
It's time to make our node move and rotate. To do so, we're going to add two It's time to make our node move and rotate. To do so, we're going to add two
member variables to our script: the movement speed in pixels per second and the member variables to our script: the movement speed in pixels per second and the
@ -236,8 +216,7 @@ Run the scene to see the Pandemonium icon turn in-place.
![](img/scripting_first_script_pandemonium_turning_in_place.gif) ![](img/scripting_first_script_pandemonium_turning_in_place.gif)
Moving forward ### Moving forward
~~~~~~~~~~~~~~
Let's now make the node move. Add the following two lines to the `process()` Let's now make the node move. Add the following two lines to the `process()`
function, ensuring the new lines are indented the same way as the one before function, ensuring the new lines are indented the same way as the one before
@ -278,8 +257,7 @@ Note:
Our node currently moves by itself. In the next part Our node currently moves by itself. In the next part
`doc_scripting_player_input`, we'll use player input to control it. `doc_scripting_player_input`, we'll use player input to control it.
Complete script ## Complete script
---------------
Here is the complete `Sprite.gd` file for reference. Here is the complete `Sprite.gd` file for reference.

View File

@ -1,10 +1,5 @@
.. Intention: only introduce what a script does in general and options for
scripting languages.
# Scripting languages
Scripting languages
===================
This lesson will give you an overview of the available scripting languages in This lesson will give you an overview of the available scripting languages in
Pandemonium. You will learn the pros and cons of each option. In the next part, you Pandemonium. You will learn the pros and cons of each option. In the next part, you
@ -20,8 +15,7 @@ to the Camera2D node and code the shake.
![](img/scripting_camera_shake.gif) ![](img/scripting_camera_shake.gif)
Available scripting languages ## Available scripting languages
-----------------------------
Pandemonium offers **five gameplay programming languages**: GDScript, C#, Pandemonium offers **five gameplay programming languages**: GDScript, C#,
VisualScript, and, via its GDNative technology, C and C++. There are more VisualScript, and, via its GDNative technology, C and C++. There are more
@ -45,11 +39,10 @@ Warning:
Future Pandemonium 4.x releases may have VisualScript reimplemented as an extension. Future Pandemonium 4.x releases may have VisualScript reimplemented as an extension.
While Pandemonium 3.x will keep VisualScript supported, we recommend While Pandemonium 3.x will keep VisualScript supported, we recommend
`trying out GDScript <toc-learn-scripting-gdscript )` instead, `trying out GDScript ( toc-learn-scripting-gdscript )` instead,
especially if you intend to migrate your project to Pandemonium 4. especially if you intend to migrate your project to Pandemonium 4.
Which language should I use? ## Which language should I use?
----------------------------
If you're a beginner, we recommend to **start with GDScript**. We made this If you're a beginner, we recommend to **start with GDScript**. We made this
language specifically for Pandemonium and the needs of game developers. It has a language specifically for Pandemonium and the needs of game developers. It has a
@ -66,8 +59,7 @@ with the language.
Let's look at each language's features, as well as its pros and cons. Let's look at each language's features, as well as its pros and cons.
GDScript ### GDScript
~~~~~~~~
`GDScript( doc_gdscript )` is an `GDScript( doc_gdscript )` is an
`object-oriented ( https://en.wikipedia.org/wiki/Object-oriented_programming )` and `object-oriented ( https://en.wikipedia.org/wiki/Object-oriented_programming )` and
@ -109,8 +101,7 @@ Note:
and features that would've been difficult to offer with third-party and features that would've been difficult to offer with third-party
languages. languages.
.NET / C# ### .NET / C#
~~~~~~~~~
As Microsoft's `C# As Microsoft's `C#
( https://en.wikipedia.org/wiki/C_Sharp_(programming_language) )` is a favorite ( https://en.wikipedia.org/wiki/C_Sharp_(programming_language) )` is a favorite
@ -140,42 +131,7 @@ Note:
in GDScript, C#, or C++ won't have a significant impact on in GDScript, C#, or C++ won't have a significant impact on
performance. performance.
VisualScript ### C and C++ via GDNative
~~~~~~~~~~~~
Warning:
`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.
While Pandemonium 3.x will keep VisualScript supported, we recommend
`trying out GDScript <toc-learn-scripting-gdscript )` instead,
especially if you intend to migrate your project to Pandemonium 4.
`Visual Scripting( doc_what_is_visual_script )` is a graph-based visual
programming language where you connect blocks. It can be a great tool for
non-programmers like game designers and artists.
![](img/scripting_visualscript.png)
You can use other languages to create custom blocks that are specific to your
game, for example, to script AIs, quests, or dialogues. That's where the
strength of VisualScript lies.
While it provides all the basic building blocks you need to code complete games,
we do not recommend to use VisualScript this way. Programming everything with it
is slow compared to using other programming languages.
See also:
For more information, see
`Getting started with VisualScript ( doc_getting_started_visual_script )`.
C and C++ via GDNative
~~~~~~~~~~~~~~~~~~~~~~
GDNative allows you to write game code in C or C++ without needing to recompile GDNative allows you to write game code in C or C++ without needing to recompile
or even restart Pandemonium. or even restart Pandemonium.
@ -192,8 +148,7 @@ VisualScript.
When working with GDNative, the available types, functions, and properties When working with GDNative, the available types, functions, and properties
closely resemble Pandemonium's actual C++ API. closely resemble Pandemonium's actual C++ API.
Summary ## Summary
-------
Scripts are files containing code that you attach to a node to extend its Scripts are files containing code that you attach to a node to extend its
functionality. functionality.

View File

@ -1,7 +1,6 @@
Your first 2D game # Your first 2D game
==================
In this step-by-step tutorial series, you will create your first complete 2D In this step-by-step tutorial series, you will create your first complete 2D
game with Pandemonium. By the end of the series, you will have a simple yet complete game with Pandemonium. By the end of the series, you will have a simple yet complete
@ -42,11 +41,10 @@ You can find a completed version of this project at this location:
- https://github.com/Relintai/pandemonium_engine-demo-projects - https://github.com/Relintai/pandemonium_engine-demo-projects
Prerequisites ## Prerequisites
-------------
This step-by-step tutorial is intended for beginners who followed the complete This step-by-step tutorial is intended for beginners who followed the complete
`Getting Started <toc-learn-step_by_step )`. `Getting Started (toc-learn-step_by_step )`.
If you're an experienced programmer, you can find the complete demo's source If you're an experienced programmer, you can find the complete demo's source
code here: `Pandemonium demo projects code here: `Pandemonium demo projects
@ -57,10 +55,9 @@ the code.
You can download them by clicking the link below. You can download them by clicking the link below.
:download:`dodge_assets.zip <files/dodge_assets.zip )`. :download:`dodge_assets.zip (files/dodge_assets.zip )`.
Contents ## Contents
--------
.. toctree:: .. toctree::
:maxdepth: 1 :maxdepth: 1

View File

@ -1,7 +1,6 @@
Setting up the project # Setting up the project
======================
In this short first part, we'll set up and organize the project. In this short first part, we'll set up and organize the project.
@ -12,7 +11,7 @@ Launch Pandemonium and create a new project.
GDScript GDScript
``` ```
Download :download:`dodge_assets.zip <files/dodge_assets.zip )`. Download :download:`dodge_assets.zip ( files/dodge_assets.zip )`.
The archive contains the images and sounds you'll be using The archive contains the images and sounds you'll be using
to make the game. Extract the archive and move the `art/` to make the game. Extract the archive and move the `art/`
and `fonts/` directories to your project's directory. and `fonts/` directories to your project's directory.

View File

@ -221,4 +221,4 @@ You may find these code samples useful as starting points for your own projects.
Feel free to use them and experiment with them to see what you can make. Feel free to use them and experiment with them to see what you can make.
You can download this sample project here: You can download this sample project here:
:download:`2D_movement_demo.zip <files/2D_movement_demo.zip )` :download:`2D_movement_demo.zip (files/2D_movement_demo.zip )`

View File

@ -30,7 +30,7 @@ animation:
![](img/2d_animation_run_preview.gif) ![](img/2d_animation_run_preview.gif)
You can download the images here: You can download the images here:
:download:`run_animation.zip <files/run_animation.zip )` :download:`run_animation.zip (files/run_animation.zip )`
Unzip the images and place them in your project folder. Set up your scene tree Unzip the images and place them in your project folder. Set up your scene tree
with the following nodes: with the following nodes:

View File

@ -62,7 +62,7 @@ Surface array
The surface array is an array of length `ArrayMesh.ARRAY_MAX`. Each position in the array is The surface array is an array of length `ArrayMesh.ARRAY_MAX`. Each position in the array is
filled with a sub-array containing per-vertex information. For example, the array located at filled with a sub-array containing per-vertex information. For example, the array located at
`ArrayMesh.ARRAY_NORMAL` is a `PoolVector3Array` of vertex normals. `ArrayMesh.ARRAY_NORMAL` is a `PoolVector3Array` of vertex normals.
See `Mesh.ArrayType <enum_Mesh_ArrayType )` for more information. See `Mesh.ArrayType (enum_Mesh_ArrayType )` for more information.
The surface array can be indexed or non-indexed. Creating a non-indexed array is as easy as not assigning The surface array can be indexed or non-indexed. Creating a non-indexed array is as easy as not assigning
an array at the index `ArrayMesh.ARRAY_INDEX`. A non-indexed array stores unique vertex information for an array at the index `ArrayMesh.ARRAY_INDEX`. A non-indexed array stores unique vertex information for

View File

@ -10,14 +10,14 @@ which takes up to four parameters. The first two are required, while the second
The first parameter is the `PrimitiveType`, an OpenGL concept that instructs the GPU The first parameter is the `PrimitiveType`, an OpenGL concept that instructs the GPU
how to arrange the primitive based on the vertices given, i.e. whether they represent triangles, how to arrange the primitive based on the vertices given, i.e. whether they represent triangles,
lines, points, etc. See `Mesh.PrimitiveType <enum_Mesh_PrimitiveType )` for the options available. lines, points, etc. See `Mesh.PrimitiveType (enum_Mesh_PrimitiveType )` for the options available.
The second parameter, `arrays`, is the actual Array that stores the mesh information. The array is a The second parameter, `arrays`, is the actual Array that stores the mesh information. The array is a
normal Pandemonium array that is constructed with empty brackets `[]`. It stores a `Pool**Array` normal Pandemonium array that is constructed with empty brackets `[]`. It stores a `Pool**Array`
(e.g. PoolVector3Array, PoolIntArray, etc.) for each type of information that will be used to build the surface. (e.g. PoolVector3Array, PoolIntArray, etc.) for each type of information that will be used to build the surface.
The possible elements of `arrays` are listed below, together with the position they must have within `arrays`. The possible elements of `arrays` are listed below, together with the position they must have within `arrays`.
See also `Mesh.ArrayType <enum_Mesh_ArrayType )`. See also `Mesh.ArrayType (enum_Mesh_ArrayType )`.
.. list-table:: .. list-table::

View File

@ -59,7 +59,7 @@ character, created by Andreas Esau.
![](img/tuto_cutout_walk.gif) ![](img/tuto_cutout_walk.gif)
Get your assets: :download:`gbot_resources.zip <files/gbot_resources.zip )`. Get your assets: :download:`gbot_resources.zip (files/gbot_resources.zip )`.
Setting up the rig Setting up the rig
~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~

View File

@ -37,13 +37,13 @@ See also:
animating within Pandemonium. animating within Pandemonium.
For this tutorial, we will be using a single image to construct our character. For this tutorial, we will be using a single image to construct our character.
Download it from :download:`gBot_pieces.png) <img/gBot_pieces.png) )` or save the Download it from :download:`gBot_pieces.png) (img/gBot_pieces.png) )` or save the
image below. image below.
![](img/gBot_pieces.png) ![](img/gBot_pieces.png)
It is also advised to download the final character image It is also advised to download the final character image
:download:`gBot_complete.png) <img/gBot_complete.png) )` to have a good reference :download:`gBot_complete.png) (img/gBot_complete.png) )` to have a good reference
for putting the different pieces together. for putting the different pieces together.
![](img/gBot_complete.png) ![](img/gBot_complete.png)

View File

@ -129,4 +129,4 @@ override.
![](img/area2d_override.gif) ![](img/area2d_override.gif)
You can download this project here: You can download this project here:
:download:`using_area_2d.zip <files/using_area_2d.zip )` :download:`using_area_2d.zip (files/using_area_2d.zip )`

View File

@ -188,7 +188,7 @@ Examples
-------- --------
To see these examples in action, download the sample project: To see these examples in action, download the sample project:
:download:`using_kinematic2d.zip <files/using_kinematic2d.zip )`. :download:`using_kinematic2d.zip (files/using_kinematic2d.zip )`.
Movement and walls Movement and walls
~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~

View File

@ -68,7 +68,7 @@ Scene setup
~~~~~~~~~~~ ~~~~~~~~~~~
To have something to test, here's the scene (from the tilemap tutorial): To have something to test, here's the scene (from the tilemap tutorial):
:download:`kbscene.zip <files/kbscene.zip )`. We'll be creating a new scene :download:`kbscene.zip (files/kbscene.zip )`. We'll be creating a new scene
for the character. Use the robot sprite and create a scene like this: for the character. Use the robot sprite and create a scene like this:
![](img/kbscene.png) ![](img/kbscene.png)

View File

@ -76,8 +76,8 @@ The 2D navigation meshes are defined with the following resources:
.. seealso:: .. seealso::
You can see how 2D navigation works in action using the You can see how 2D navigation works in action using the
`2D Navigation Polygon <https://github.com/Relintai/pandemonium_engine-demo-projects/tree/master/2d/navigation>`__ `2D Navigation Polygon (https://github.com/Relintai/pandemonium_engine-demo-projects/tree/master/2d/navigation>`__
and `Grid-based Navigation with AStarGrid2D <https://github.com/Relintai/pandemonium_engine-demo-projects/tree/master/2d/navigation_astar>`__ and `Grid-based Navigation with AStarGrid2D (https://github.com/Relintai/pandemonium_engine-demo-projects/tree/master/2d/navigation_astar>`__
demo projects. demo projects.
Setup for 2D scene Setup for 2D scene