add jumping
This commit is contained in:
parent
68702e358f
commit
1176a8ec08
3 changed files with 104 additions and 76 deletions
77
src/main.rs
77
src/main.rs
|
@ -8,6 +8,7 @@ const METER: f32 = 48.;
|
||||||
fn main() {
|
fn main() {
|
||||||
App::new()
|
App::new()
|
||||||
.add_plugins(DefaultPlugins)
|
.add_plugins(DefaultPlugins)
|
||||||
|
.insert_resource(RapierConfiguration::new(METER * 2.5))
|
||||||
.add_plugins(RapierPhysicsPlugin::<NoUserData>::pixels_per_meter(METER))
|
.add_plugins(RapierPhysicsPlugin::<NoUserData>::pixels_per_meter(METER))
|
||||||
.add_plugins(RapierDebugRenderPlugin::default())
|
.add_plugins(RapierDebugRenderPlugin::default())
|
||||||
.add_systems(Startup, (scene::setup_scene, setup_cam, player::add_player))
|
.add_systems(Startup, (scene::setup_scene, setup_cam, player::add_player))
|
||||||
|
@ -25,79 +26,5 @@ fn setup_cam(mut commands: Commands) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
mod player;
|
||||||
mod scene;
|
mod scene;
|
||||||
mod player {
|
|
||||||
use bevy::{
|
|
||||||
prelude::*,
|
|
||||||
sprite::{MaterialMesh2dBundle, Mesh2dHandle},
|
|
||||||
};
|
|
||||||
use bevy_rapier2d::prelude::*;
|
|
||||||
|
|
||||||
use crate::METER;
|
|
||||||
|
|
||||||
#[derive(Component)]
|
|
||||||
pub struct Player {
|
|
||||||
move_cooldown: Timer,
|
|
||||||
grounded: bool,
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn add_player(
|
|
||||||
mut commands: Commands,
|
|
||||||
mut meshes: ResMut<Assets<Mesh>>,
|
|
||||||
mut materials: ResMut<Assets<ColorMaterial>>,
|
|
||||||
) {
|
|
||||||
let shape = Mesh2dHandle(meshes.add(Rectangle::new(0.8 * METER, 1.8 * METER)));
|
|
||||||
commands
|
|
||||||
.spawn(Player {
|
|
||||||
move_cooldown: Timer::from_seconds(0.01, TimerMode::Repeating),
|
|
||||||
grounded: false,
|
|
||||||
})
|
|
||||||
.insert(MaterialMesh2dBundle {
|
|
||||||
mesh: shape,
|
|
||||||
material: materials.add(Color::rgb(0.2, 0.9, 0.2)),
|
|
||||||
transform: Transform::from_xyz(0., 0., 0.),
|
|
||||||
..default()
|
|
||||||
})
|
|
||||||
.insert((
|
|
||||||
RigidBody::Dynamic,
|
|
||||||
Collider::cuboid(0.4 * METER, 0.9 * METER),
|
|
||||||
))
|
|
||||||
.insert(KinematicCharacterController { ..default() });
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn player_ground_collision(
|
|
||||||
player: Query<Entity, With<Player>>,
|
|
||||||
mut collision_events: EventReader<CollisionEvent>,
|
|
||||||
) {
|
|
||||||
let p = player.single();
|
|
||||||
for collision_event in collision_events.read() {
|
|
||||||
dbg!(p);
|
|
||||||
dbg!(collision_event);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn move_player(
|
|
||||||
kb_input: Res<ButtonInput<KeyCode>>,
|
|
||||||
mut query: Query<(&mut Player, &mut KinematicCharacterController)>,
|
|
||||||
time: Res<Time>,
|
|
||||||
) {
|
|
||||||
let (mut player, mut controller) = query.single_mut();
|
|
||||||
if player.move_cooldown.tick(time.delta()).finished() {
|
|
||||||
let mut moved = false;
|
|
||||||
let mut mv = 0;
|
|
||||||
|
|
||||||
if kb_input.pressed(KeyCode::KeyA) {
|
|
||||||
moved = true;
|
|
||||||
mv += 1;
|
|
||||||
}
|
|
||||||
if kb_input.pressed(KeyCode::KeyD) {
|
|
||||||
moved = true;
|
|
||||||
mv -= 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if moved {
|
|
||||||
controller.translation = Some(Vec2::new(mv as f32 * 6., 0.));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
101
src/player.rs
Normal file
101
src/player.rs
Normal file
|
@ -0,0 +1,101 @@
|
||||||
|
use bevy::{
|
||||||
|
prelude::*,
|
||||||
|
sprite::{MaterialMesh2dBundle, Mesh2dHandle},
|
||||||
|
};
|
||||||
|
use bevy_rapier2d::prelude::*;
|
||||||
|
|
||||||
|
use crate::METER;
|
||||||
|
|
||||||
|
#[derive(Component)]
|
||||||
|
pub struct Player {
|
||||||
|
move_cooldown: Timer,
|
||||||
|
grounded: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn add_player(
|
||||||
|
mut commands: Commands,
|
||||||
|
mut meshes: ResMut<Assets<Mesh>>,
|
||||||
|
mut materials: ResMut<Assets<ColorMaterial>>,
|
||||||
|
) {
|
||||||
|
let shape = Mesh2dHandle(meshes.add(Rectangle::new(0.8 * METER, 1.8 * METER)));
|
||||||
|
commands
|
||||||
|
.spawn(Player {
|
||||||
|
move_cooldown: Timer::from_seconds(0.01, TimerMode::Repeating),
|
||||||
|
// move_cooldown: Timer::from_seconds(0.01, TimerMode::Repeating),
|
||||||
|
grounded: false,
|
||||||
|
})
|
||||||
|
.insert(MaterialMesh2dBundle {
|
||||||
|
mesh: shape,
|
||||||
|
material: materials.add(Color::rgb(0.2, 0.9, 0.2)),
|
||||||
|
transform: Transform::from_xyz(0., 0., 0.),
|
||||||
|
..default()
|
||||||
|
})
|
||||||
|
.insert((
|
||||||
|
RigidBody::Dynamic,
|
||||||
|
Collider::cuboid(0.4 * METER, 0.9 * METER),
|
||||||
|
Velocity::default(),
|
||||||
|
))
|
||||||
|
// .insert(ActiveCollisionTypes::default() | ActiveCollisionTypes::DYNAMIC_STATIC)
|
||||||
|
.insert(ActiveEvents::COLLISION_EVENTS)
|
||||||
|
.insert(KinematicCharacterController { ..default() });
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn player_ground_collision(
|
||||||
|
mut player: Query<(Entity, &mut Player)>,
|
||||||
|
scene_objs: Query<Entity, With<super::scene::SceneObj>>,
|
||||||
|
mut collision_events: EventReader<CollisionEvent>,
|
||||||
|
) {
|
||||||
|
let (p, mut player) = player.single_mut();
|
||||||
|
for collision_event in collision_events.read() {
|
||||||
|
match collision_event {
|
||||||
|
CollisionEvent::Started(e1, e2, _) => {
|
||||||
|
if (e1 == &p && scene_objs.iter().any(|obj| *e2 == obj))
|
||||||
|
|| (e2 == &p && scene_objs.iter().any(|obj| *e1 == obj))
|
||||||
|
{
|
||||||
|
player.grounded = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
CollisionEvent::Stopped(e1, e2, _) => {
|
||||||
|
if (e1 == &p && scene_objs.iter().any(|obj| *e2 == obj))
|
||||||
|
|| (e2 == &p && scene_objs.iter().any(|obj| *e1 == obj))
|
||||||
|
{
|
||||||
|
player.grounded = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn move_player(
|
||||||
|
kb_input: Res<ButtonInput<KeyCode>>,
|
||||||
|
mut query: Query<(
|
||||||
|
&mut Velocity,
|
||||||
|
&mut Player,
|
||||||
|
&mut KinematicCharacterController,
|
||||||
|
)>,
|
||||||
|
time: Res<Time>,
|
||||||
|
) {
|
||||||
|
let (mut vel, mut player, mut controller) = query.single_mut();
|
||||||
|
if player.move_cooldown.tick(time.delta()).finished() {
|
||||||
|
let mut moved = false;
|
||||||
|
let mut mv = 0;
|
||||||
|
|
||||||
|
if kb_input.pressed(KeyCode::KeyA) {
|
||||||
|
moved = true;
|
||||||
|
mv -= 1;
|
||||||
|
}
|
||||||
|
if kb_input.pressed(KeyCode::KeyD) {
|
||||||
|
moved = true;
|
||||||
|
mv += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if kb_input.pressed(KeyCode::KeyW) && player.grounded {
|
||||||
|
moved = true;
|
||||||
|
*vel = Velocity::linear(Vec2::new(0., 9. * METER));
|
||||||
|
}
|
||||||
|
|
||||||
|
if moved {
|
||||||
|
controller.translation = Some(Vec2::new(mv as f32 * 6., 0.));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -7,7 +7,7 @@ use bevy_rapier2d::prelude::*;
|
||||||
use crate::METER;
|
use crate::METER;
|
||||||
|
|
||||||
#[derive(Component)]
|
#[derive(Component)]
|
||||||
struct SceneObj;
|
pub struct SceneObj;
|
||||||
pub fn setup_scene(
|
pub fn setup_scene(
|
||||||
mut commands: Commands,
|
mut commands: Commands,
|
||||||
mut meshes: ResMut<Assets<Mesh>>,
|
mut meshes: ResMut<Assets<Mesh>>,
|
||||||
|
|
Loading…
Reference in a new issue