mirror of
https://github.com/lisk77/comet.git
synced 2025-10-23 21:38:50 +00:00
159 lines
No EOL
3.3 KiB
Markdown
159 lines
No EOL
3.3 KiB
Markdown
# ☄️ Comet
|
|
a free and open source games framework
|
|
|
|
> [!WARNING]
|
|
> This project is in early development and is not yet ready for use.
|
|
>
|
|
> It could be potentially used to make something very basic in a very hacky way but it is not a good experience
|
|
>
|
|
> Installation is manual as of right now but if it reaches an exaptable state I will publish the crate
|
|
|
|
## Recommended setup
|
|
|
|
The project structure should look like this:
|
|
|
|
```
|
|
project
|
|
│ Cargo.toml
|
|
│ build.rs
|
|
│ crates
|
|
│ └── comet
|
|
│ resources
|
|
│ └── shaders
|
|
│ └── textures
|
|
│ src
|
|
│ └── main.rs
|
|
```
|
|
|
|
```toml
|
|
# Cargo.toml
|
|
# ...
|
|
[dependencies]
|
|
comet = { path = "crates/comet" }
|
|
# ...
|
|
```
|
|
|
|
```rust
|
|
// main.rs
|
|
|
|
// This will be cleaned up in the future
|
|
// but for now I don't have a prelude.
|
|
use comet::{
|
|
app::{
|
|
App,
|
|
ApplicationType::*
|
|
},
|
|
renderer::renderer2d::Renderer2D,
|
|
};
|
|
|
|
struct GameState {}
|
|
|
|
impl GameState {
|
|
pub fn new() -> Self {
|
|
Self {}
|
|
}
|
|
}
|
|
|
|
// This function will be called once before the event loop starts
|
|
fn setup(app: &mut App, renderer: &mut Renderer2D) {}
|
|
// This function will be called every tick
|
|
fn update(app: &mut App, renderer: &mut Renderer2D) {}
|
|
|
|
fn main() {
|
|
App::new(App2D) // Generate a basic 2D app
|
|
.with_title("Comet App") // Sets the window title
|
|
.with_icon(r"resources/textures/comet_icon.png") // Sets the window icon
|
|
.with_size(1920, 1080) // Sets the window size
|
|
.with_game_state(GameState::new()) // Adds a custom game state struct
|
|
.run::<Renderer2D>(setup, update) // Starts app
|
|
}
|
|
```
|
|
|
|
```rust
|
|
// build.rs
|
|
|
|
use anyhow::*;
|
|
use fs_extra::copy_items;
|
|
use fs_extra::dir::CopyOptions;
|
|
use std::env;
|
|
|
|
fn main() -> Result<()> {
|
|
// This tells cargo to rerun this script if something in /resources/ changes.
|
|
println!("cargo:rerun-if-changed=resources/textures/*");
|
|
println!("cargo:rerun-if-changed=resources/shaders/*");
|
|
|
|
let out_dir = env::var("OUT_DIR")?;
|
|
let mut copy_options = CopyOptions::new();
|
|
copy_options.overwrite = true;
|
|
let mut paths_to_copy = Vec::new();
|
|
paths_to_copy.push("resources/textures/");
|
|
paths_to_copy.push("resources/shaders/");
|
|
|
|
copy_items(&paths_to_copy, out_dir, ©_options)?;
|
|
|
|
Ok(())
|
|
}
|
|
```
|
|
|
|
## Todo
|
|
(not ordered by importance)
|
|
|
|
- [x] Fixed update steps (60 updates per second right now)
|
|
- [ ] Rendering
|
|
- [x] 2D
|
|
- [x] Textures
|
|
- [ ] 3D
|
|
- [ ] Meshes
|
|
- [ ] Normal maps
|
|
- [x] Texture Atlas
|
|
- [x] Shaders
|
|
- [ ] Materials
|
|
- [ ] Text
|
|
- [ ] Particles
|
|
- [ ] Animations
|
|
- [ ] Lighting
|
|
- [ ] UI
|
|
- [ ] Buttons
|
|
- [ ] Input
|
|
- [ ] Post-processing
|
|
- [ ] Multiple render passes
|
|
- [ ] Individual effects
|
|
- [ ] Sound
|
|
- [ ] Input
|
|
- [ ] Universal input manager
|
|
- [x] Keyboard
|
|
- [x] Mouse
|
|
- [ ] Gamepad
|
|
- [x] ECS
|
|
- [x] Components
|
|
- [x] Entities
|
|
- [x] Archetypes
|
|
- [x] World
|
|
- [ ] Scene
|
|
- [ ] loading
|
|
- [ ] saving
|
|
- [ ] Physics
|
|
- [ ] 2D
|
|
- [ ] 3D
|
|
- [x] Plugin System (at least right now)
|
|
- [x] Adding custom game state struct
|
|
- [x] Adding custom renderer
|
|
- [ ] Math
|
|
- [x] Vectors
|
|
- [x] Matrices
|
|
- [ ] Quaternions
|
|
- [x] Interpolation
|
|
- [ ] Bezier curves
|
|
- [x] Easing functions
|
|
- [ ] Noise
|
|
- [ ] White
|
|
- [ ] Perlin
|
|
- [ ] Simplex
|
|
- [ ] Worley
|
|
- [ ] Fractal
|
|
- [ ] Cellular
|
|
- [ ] Gradient
|
|
- [ ] Value
|
|
- [ ] Cubic
|
|
- [ ] Ray-casting
|
|
- [ ] Pathfinding |