Compare commits

..

2 commits

Author SHA1 Message Date
Joe Ardent
cacb322fac checkpoint 2025-01-26 11:28:17 -08:00
Joe Ardent
180070c5af checkpoint 2025-01-25 17:36:01 -08:00
5 changed files with 1383 additions and 766 deletions

2109
Cargo.lock generated

File diff suppressed because it is too large Load diff

View file

@ -1,13 +1,13 @@
[package] [package]
name = "cyber_rider" name = "cyber_rider"
version = "0.1.0" version = "0.1.0"
edition = "2021" edition = "2024"
[dependencies] [dependencies]
rand = "0.8" rand = "0.8"
# bevy_polyline = "0.4" # bevy_polyline = "0.4"
noise = "0.9" noise = "0.9"
hexasphere = "14" hexasphere = "15"
#wgpu = "0.20" #wgpu = "0.20"
# bevy-inspector-egui = "0.18" # bevy-inspector-egui = "0.18"
@ -15,13 +15,13 @@ hexasphere = "14"
inspector = [] inspector = []
[dependencies.bevy] [dependencies.bevy]
version = "0.14" version = "0.15"
default-features = true default-features = true
features = ["bevy_dev_tools"] features = ["bevy_dev_tools"]
[dependencies.avian3d] [dependencies.avian3d]
default-features = false default-features = false
version = "0.1" version = "0.2"
features = ["3d", "f32", "parry-f32", "debug-plugin", "default-collider", "collider-from-mesh"] features = ["3d", "f32", "parry-f32", "debug-plugin", "default-collider", "collider-from-mesh"]
# Maybe also enable only a small amount of optimization for our code: # Maybe also enable only a small amount of optimization for our code:

View file

@ -100,7 +100,7 @@ pub(super) fn apply_inputs(
// steering // steering
let mut steering = steering.single_mut(); let mut steering = steering.single_mut();
let angle = yaw_to_angle(input.yaw); let angle = yaw_to_angle(input.yaw);
let angle = if angle.is_normal() { angle } else { 0.0 }; let angle = if angle.is_normal() { -angle } else { 0.0 };
let limit = AngleLimit::new(angle - 0.01, angle + 0.01); let limit = AngleLimit::new(angle - 0.01, angle + 0.01);
steering.angle_limit = Some(limit); steering.angle_limit = Some(limit);
} }

View file

@ -1,4 +1,8 @@
use avian3d::prelude::*; use avian3d::prelude::{
AngularDamping, AngularVelocity, CoefficientCombine, Collider, ColliderDensity,
CollisionLayers, ExternalTorque, Friction, LinearDamping, LinearVelocity, Restitution,
RigidBody, SleepingDisabled,
};
use bevy::{ use bevy::{
core::Name, core::Name,
prelude::{AssetServer, BuildChildren, Commands, Quat, Res, SpatialBundle, Transform, Vec3}, prelude::{AssetServer, BuildChildren, Commands, Quat, Res, SpatialBundle, Transform, Vec3},

View file

@ -1,5 +1,14 @@
use avian3d::{math::FRAC_PI_2, prelude::*}; use avian3d::{
use bevy::prelude::*; math::FRAC_PI_2,
prelude::{
Collider, ColliderDensity, CollisionLayers, CollisionMargin, ExternalTorque, FixedJoint,
Friction, Joint, MassPropertiesBundle, Restitution, RevoluteJoint, RigidBody, SweptCcd,
},
};
use bevy::prelude::{
AlphaMode, Assets, Color, Commands, Entity, Mesh, Name, PbrBundle, Quat, ResMut, Sphere,
StandardMaterial, Torus, Transform, Vec3,
};
use super::{CyberSteering, CyberWheel, Meshterial, WheelConfig}; use super::{CyberSteering, CyberWheel, Meshterial, WheelConfig};
use crate::ColliderGroups; use crate::ColliderGroups;
@ -50,6 +59,7 @@ pub fn spawn_wheels(
mesh.clone(), mesh.clone(),
collider.clone(), collider.clone(),
conf, conf,
steering.is_some(),
); );
if let Some(steering) = steering { if let Some(steering) = steering {
@ -75,6 +85,7 @@ fn wheels_helper(
tire_mesh: Mesh, tire_mesh: Mesh,
collider: Collider, collider: Collider,
conf: &WheelConfig, conf: &WheelConfig,
is_front: bool,
) -> Entity { ) -> Entity {
let wheel_material = &StandardMaterial { let wheel_material = &StandardMaterial {
base_color: Color::srgb(0.01, 0.01, 0.01), base_color: Color::srgb(0.01, 0.01, 0.01),
@ -83,14 +94,17 @@ fn wheels_helper(
..Default::default() ..Default::default()
}; };
let pos_name = if is_front { "front" } else { "rear" };
let xform = Transform::from_translation(position); let xform = Transform::from_translation(position);
let hub_mesh: Mesh = Sphere::new(0.1).into(); let hub_mesh: Mesh = Sphere::new(0.1).into();
let hub = commands let hub = commands
.spawn(( .spawn((
Name::new("hub"), Name::new(format!("{pos_name} hub")),
RigidBody::Dynamic, RigidBody::Dynamic,
MassPropertiesBundle::new_computed(&Collider::sphere(0.1), 200.0), MassPropertiesBundle::new_computed(&Collider::sphere(0.1), 1000.0),
CollisionLayers::NONE,
PbrBundle { PbrBundle {
mesh: meshes.add(hub_mesh), mesh: meshes.add(hub_mesh),
material: materials.add(wheel_material.clone()), material: materials.add(wheel_material.clone()),
@ -102,7 +116,7 @@ fn wheels_helper(
let tire = commands let tire = commands
.spawn(( .spawn((
Name::new("tire"), Name::new(format!("{pos_name} tire")),
PbrBundle { PbrBundle {
mesh: meshes.add(tire_mesh), mesh: meshes.add(tire_mesh),
material: materials.add(wheel_material.clone()), material: materials.add(wheel_material.clone()),