Compare commits
5 Commits
b564b42ade
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
92c83c7b30 | ||
|
|
711250d87a | ||
|
|
122e09a6a9 | ||
|
|
8a3b485ece | ||
|
|
cf4beb0b9a |
2
.gitignore
vendored
2
.gitignore
vendored
@@ -1 +1,3 @@
|
|||||||
|
*.DS_Store
|
||||||
|
|
||||||
/target
|
/target
|
||||||
|
|||||||
91
src/main.rs
91
src/main.rs
@@ -18,10 +18,26 @@ struct InputState {
|
|||||||
y: f32,
|
y: f32,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Component, Default)]
|
||||||
|
struct SailboatState {
|
||||||
|
sail_extension: f32,
|
||||||
|
rudder_dir: f32,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Default, Resource)]
|
||||||
|
struct WindConditions {
|
||||||
|
direction: f32,
|
||||||
|
strength: f32,
|
||||||
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let mut app = App::new();
|
let mut app = App::new();
|
||||||
|
|
||||||
app.add_plugins((DefaultPlugins, Wireframe2dPlugin::default()))
|
app.add_plugins((DefaultPlugins, Wireframe2dPlugin::default()))
|
||||||
|
.insert_resource(WindConditions {
|
||||||
|
strength: 1.0,
|
||||||
|
..default()
|
||||||
|
})
|
||||||
.add_systems(Startup, (hello_world, camera_setup, sprite_setup).chain())
|
.add_systems(Startup, (hello_world, camera_setup, sprite_setup).chain())
|
||||||
.add_systems(Update, (handle_keys, player_physics).chain());
|
.add_systems(Update, (handle_keys, player_physics).chain());
|
||||||
|
|
||||||
@@ -50,6 +66,7 @@ fn sprite_setup(assets: Res<AssetServer>, mut commands: Commands) {
|
|||||||
},
|
},
|
||||||
EntityPhysics::default(),
|
EntityPhysics::default(),
|
||||||
InputState::default(),
|
InputState::default(),
|
||||||
|
SailboatState::default(),
|
||||||
))
|
))
|
||||||
.with_child((
|
.with_child((
|
||||||
Sprite {
|
Sprite {
|
||||||
@@ -93,32 +110,74 @@ fn handle_keys(mut q_player: Query<&mut InputState>, keys: Res<ButtonInput<KeyCo
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn player_physics(mut q_player: Query<(&InputState, &mut EntityPhysics, &mut Transform)>) {
|
fn player_physics(
|
||||||
let Ok((input, mut physics, mut transform)) = q_player.single_mut() else {
|
mut q_player: Query<(
|
||||||
|
&InputState,
|
||||||
|
&mut SailboatState,
|
||||||
|
&mut EntityPhysics,
|
||||||
|
&mut Transform,
|
||||||
|
)>,
|
||||||
|
wind_conditions: Res<WindConditions>,
|
||||||
|
) {
|
||||||
|
let Ok((input, mut boat_state, mut physics, mut transform)) = q_player.single_mut() else {
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
|
|
||||||
if input.x < 0. {
|
if input.y > 0. {
|
||||||
physics.turn_speed -= 0.1;
|
boat_state.sail_extension = (1.0 + boat_state.sail_extension) * 0.5;
|
||||||
} else if input.x > 0. {
|
} else if input.y < 0. {
|
||||||
physics.turn_speed += 0.1;
|
boat_state.sail_extension *= 0.5;
|
||||||
} else {
|
|
||||||
physics.turn_speed *= 0.99;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
physics.turn_speed = physics.turn_speed.clamp(-MAX_TURN_SPEED, MAX_TURN_SPEED);
|
boat_state.sail_extension = boat_state.sail_extension.clamp(0., 1.);
|
||||||
physics.heading += physics.turn_speed * 0.1;
|
|
||||||
|
|
||||||
if input.y > 0. {
|
physics.speed *= 0.99;
|
||||||
physics.speed += 0.1;
|
|
||||||
} else if input.y < 0. {
|
// using just the heading is incorrect, as the sail adjusts based on heading vs wind
|
||||||
physics.speed -= 0.1;
|
let sail_dir_x = physics.heading.sin();
|
||||||
} else {
|
let sail_dir_y = physics.heading.cos();
|
||||||
physics.speed *= 0.999;
|
|
||||||
|
let wind_dir_x = wind_conditions.direction.sin();
|
||||||
|
let wind_dir_y = wind_conditions.direction.cos();
|
||||||
|
|
||||||
|
let sail_dir_vec = Vec2 {
|
||||||
|
x: sail_dir_x,
|
||||||
|
y: sail_dir_y,
|
||||||
|
};
|
||||||
|
let wind_dir_vec = Vec2 {
|
||||||
|
x: wind_dir_x,
|
||||||
|
y: wind_dir_y,
|
||||||
|
};
|
||||||
|
|
||||||
|
// technically you could put your sail out and try to go backwards but..
|
||||||
|
// let's not tackle that (Yet?)
|
||||||
|
let sail_strength = sail_dir_vec
|
||||||
|
.dot(wind_dir_vec)
|
||||||
|
.clamp(-0.8, 1.)
|
||||||
|
.remap(-0.8, 1., 0., 1.)
|
||||||
|
* wind_conditions.strength;
|
||||||
|
|
||||||
|
if boat_state.sail_extension > 0. {
|
||||||
|
physics.speed += 0.01 * boat_state.sail_extension * sail_strength;
|
||||||
}
|
}
|
||||||
|
|
||||||
physics.speed = physics.speed.clamp(-MAX_SAILING_SPEED, MAX_SAILING_SPEED);
|
physics.speed = physics.speed.clamp(-MAX_SAILING_SPEED, MAX_SAILING_SPEED);
|
||||||
|
|
||||||
|
if input.x < 0. {
|
||||||
|
boat_state.rudder_dir = (-1.0 + boat_state.rudder_dir) * 0.5;
|
||||||
|
} else if input.x > 0. {
|
||||||
|
boat_state.rudder_dir = (1.0 + boat_state.rudder_dir) * 0.5;
|
||||||
|
} else {
|
||||||
|
boat_state.rudder_dir *= 0.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
physics.turn_speed *= 0.1;
|
||||||
|
|
||||||
|
physics.turn_speed += boat_state.rudder_dir * (physics.speed.abs() / MAX_SAILING_SPEED);
|
||||||
|
|
||||||
|
physics.turn_speed = physics.turn_speed.clamp(-MAX_TURN_SPEED, MAX_TURN_SPEED);
|
||||||
|
physics.heading += physics.turn_speed * 0.1;
|
||||||
|
|
||||||
let x_speed = physics.heading.sin() * physics.speed;
|
let x_speed = physics.heading.sin() * physics.speed;
|
||||||
let y_speed = physics.heading.cos() * physics.speed;
|
let y_speed = physics.heading.cos() * physics.speed;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user