mirror of
https://github.com/Relintai/pandemonium_demo_projects.git
synced 2025-01-21 15:17:23 +01:00
Rework steering ai's readme.
This commit is contained in:
parent
aeff6f56e4
commit
21a8a0a702
@ -1,70 +1,43 @@
|
||||
# Godot Steering AI Framework
|
||||
# Steering AI Framework
|
||||
|
||||
![Project banner](./assets/banner.svg)
|
||||
This demo shows the usage of [GDQuest's Godot Steering AI Framework](https://github.com/GDQuest/godot-steering-ai-framework)'s
|
||||
c++ port that is built into the engine. [See here](https://github.com/Relintai/pandemonium_engine/tree/master/modules/steering_ai)
|
||||
|
||||
This project is a framework to code complex and smooth AI movement in the [Godot game engine](https://godotengine.org/), in GDScript, using steering behaviors. It works in **both 2D and 3D games**.
|
||||
|
||||
➡ Follow us on [Twitter](https://twitter.com/NathanGDQuest) and [YouTube](https://www.youtube.com/c/gdquest/) for free game creation tutorials, tips, and news! Get one of our [Godot game creation courses](https://gdquest.mavenseed.com/) to support our work on Free Software.
|
||||
|
||||
It supports all essential steering behaviors like flee, follow, look at, but also blended behaviors, group behaviors, avoiding neighbors, following a path, following the leader, and much more.
|
||||
|
||||
- [Godot Steering AI Framework](#godot-steering-ai-framework)
|
||||
- [Getting the framework](#getting-the-framework)
|
||||
- [Introduction](#introduction)
|
||||
- [The framework](#the-framework)
|
||||
- [How it works](#how-it-works)
|
||||
- [Documentation](#documentation)
|
||||
- [Contributing](#contributing)
|
||||
- [Support us](#support-us)
|
||||
- [Join the community](#join-the-community)
|
||||
|
||||
## Getting the framework
|
||||
|
||||
This repository contains the framework and some demos for learning purposes.
|
||||
|
||||
If you want just the framework with nothing else to get in the way or to create a Git submodule, use the [Godot Steering AI Framework Submodules](https://github.com/GDQuest/godot-steering-ai-framework-submodule) repository.
|
||||
It supports all essential steering behaviors like flee, follow, look at, but also blended behaviors, group behaviors,
|
||||
avoiding neighbors, following a path, following the leader, and much more.
|
||||
|
||||
## Introduction
|
||||
|
||||
In the 1990s, [Craig Reynolds](http://www.red3d.com/cwr/) developed algorithms for common AI behaviors. They allowed AI agents to seek out or flee from a target, follow a pre-defined path, or face in a particular direction. They were simple, repeatable tasks that could be broken down into programming algorithms, which made them easy to reuse, maintain, combine, and extend.
|
||||
In the 1990s, [Craig Reynolds](http://www.red3d.com/cwr/) developed algorithms for common AI behaviors. They allowed
|
||||
AI agents to seek out or flee from a target, follow a pre-defined path, or face in a particular direction. They were simple,
|
||||
repeatable tasks that could be broken down into programming algorithms, which made them easy to reuse, maintain, combine, and extend.
|
||||
|
||||
While an AI agent's next action is based on decision making and planning algorithms, steering behaviors dictate how it will move from one frame to the next. They use available information and calculate where to move at that moment.
|
||||
While an AI agent's next action is based on decision making and planning algorithms, steering behaviors dictate
|
||||
how it will move from one frame to the next. They use available information and calculate where to move at that moment.
|
||||
|
||||
Joining these systems together can give sophisticated and graceful movement while also being more efficient than complex pathfinding algorithms like A\*.
|
||||
Joining these systems together can give sophisticated and graceful movement while also being more
|
||||
efficient than complex pathfinding algorithms like A\*.
|
||||
|
||||
## The framework
|
||||
|
||||
This project is a framework for the [Godot game engine](https://godotengine.org/). It takes inspiration from the excellent [GDX-AI](https://github.com/libgdx/gdx-ai) framework for the [LibGDX](https://libgdx.badlogicgames.com/) java-based framework.
|
||||
|
||||
Every class in the framework extends Godot's [Reference](https://docs.godotengine.org/en/latest/classes/class_reference.html) type. There is no need to have a complex scene tree; you can contain that has to do with the AI's movement inside GDScript classes.
|
||||
Every class in the framework extends Godot's [Reference](https://docs.godotengine.org/en/latest/classes/class_reference.html) type.
|
||||
There is no need to have a complex scene tree; you can contain that has to do with the AI's movement inside GDScript classes.
|
||||
|
||||
### How it works
|
||||
|
||||
In GSAI, a steering agent represents a character or a vehicle. The agent stores its position, orientation, maximum speeds, and current velocity. The agent stores a steering behavior that calculates a linear or angular change in velocity based on its information.
|
||||
In GSAI, a steering agent represents a character or a vehicle. The agent stores its position, orientation,
|
||||
maximum speeds, and current velocity. The agent stores a steering behavior that calculates a linear or
|
||||
angular change in velocity based on its information.
|
||||
|
||||
The coder then applies that acceleration in whatever ways is appropriate to the character to change its velocities, like RigidBody's `apply_impulse`, or a KinematicBody's `move_and_slide`.
|
||||
The coder then applies that acceleration in whatever ways is appropriate to the character to change its v
|
||||
elocities, like RigidBody's `apply_impulse`, or a KinematicBody's `move_and_slide`.
|
||||
|
||||
## Documentation
|
||||
|
||||
The framework's documentation and code reference are available here: [Godot steering AI framework documentation](https://gdquest.gitbook.io/godot-3-steering-ai-framework-reference/)
|
||||
The documentation is available in-engine. Search for classes which names start with the word "GSAI".
|
||||
|
||||
## Contributing
|
||||
The original framework's original documentation and code reference are available here:
|
||||
[Godot steering AI framework documentation](https://gdquest.gitbook.io/godot-3-steering-ai-framework-reference/)
|
||||
|
||||
If you encounter a bug or you have an idea to improve the tool, please [open an issue](https://github.com/GDQuest/gdscript-docs-maker/issues/new).
|
||||
|
||||
If you want to contribute to the project, for instance by fixing a bug or adding a feature, check out our:
|
||||
|
||||
1. [Contributor's guidelines](https://www.gdquest.com/docs/guidelines/contributing-to/gdquest-projects/).
|
||||
1. [GDScript style guide](https://www.gdquest.com/docs/guidelines/best-practices/godot-gdscript/)
|
||||
|
||||
## Support us
|
||||
|
||||
Our work on Free Software is sponsored by our [Godot game creation courses](https://gdquest.mavenseed.com/). Consider getting one to support us!
|
||||
|
||||
_If you like our work, please star the repository! This helps more people find it._
|
||||
|
||||
## Join the community
|
||||
|
||||
- You can join the GDQuest community and come chat with us on [Discord](https://discord.gg/CHYVgar)
|
||||
- For quick news, follow us on [Twitter](https://twitter.com/nathangdquest)
|
||||
- We release video tutorials and major updates on [YouTube](https://youtube.com/c/gdquest)
|
||||
|
Loading…
Reference in New Issue
Block a user