mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
Added sail boat
This commit is contained in:
parent
4aa8a6bb42
commit
bfbca3e517
@ -47,4 +47,26 @@
|
|||||||
central: ("air_balloon.rudder"),
|
central: ("air_balloon.rudder"),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
SailBoat: (
|
||||||
|
bone0: (
|
||||||
|
offset: (-6.5, -15.5, 0.0),
|
||||||
|
phys_offset: (0.0, 0.0, 0.0),
|
||||||
|
central: ("sail_boat.structure"),
|
||||||
|
),
|
||||||
|
bone1: (
|
||||||
|
offset: (0.0, 0.0, 0.0),
|
||||||
|
phys_offset: (0.0, 0.0, 0.0),
|
||||||
|
central: ("empty"),
|
||||||
|
),
|
||||||
|
bone2: (
|
||||||
|
offset: (0.0, 0.0, 0.0),
|
||||||
|
phys_offset: (0.0, 0.0, 0.0),
|
||||||
|
central: ("empty"),
|
||||||
|
),
|
||||||
|
bone3: (
|
||||||
|
offset: (-1.5, -6.0, -5.0),
|
||||||
|
phys_offset: (0.0, 0.0, 0.0),
|
||||||
|
central: ("empty"),
|
||||||
|
),
|
||||||
|
),
|
||||||
})
|
})
|
||||||
|
BIN
assets/server/voxel/sail_boat/structure.vox
(Stored with Git LFS)
Normal file
BIN
assets/server/voxel/sail_boat/structure.vox
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -7,26 +7,26 @@
|
|||||||
),
|
),
|
||||||
(
|
(
|
||||||
specifier: "world.shrub.jungle-bush-0",
|
specifier: "world.shrub.jungle-bush-0",
|
||||||
center: (5, 5, 1),
|
center: (5, 5, 3),
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
specifier: "world.shrub.jungle-bush-1",
|
specifier: "world.shrub.jungle-bush-1",
|
||||||
center: (5, 5, 1),
|
center: (5, 5, 2),
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
specifier: "world.shrub.jungle-bush-2",
|
specifier: "world.shrub.jungle-bush-2",
|
||||||
center: (5, 5, 1),
|
center: (5, 5, 3),
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
specifier: "world.shrub.jungle-bush-3",
|
specifier: "world.shrub.jungle-bush-3",
|
||||||
center: (5, 5, 1),
|
center: (5, 5, 3),
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
specifier: "world.shrub.jungle-bush-4",
|
specifier: "world.shrub.jungle-bush-4",
|
||||||
center: (5, 5, 1),
|
center: (5, 5, 4),
|
||||||
),
|
),
|
||||||
(
|
(
|
||||||
specifier: "world.shrub.jungle-bush-5",
|
specifier: "world.shrub.jungle-bush-5",
|
||||||
center: (5, 5, 1),
|
center: (5, 5, 5),
|
||||||
),
|
),
|
||||||
]
|
]
|
||||||
|
BIN
assets/world/shrub/jungle-bush-0.vox
(Stored with Git LFS)
BIN
assets/world/shrub/jungle-bush-0.vox
(Stored with Git LFS)
Binary file not shown.
BIN
assets/world/shrub/jungle-bush-1.vox
(Stored with Git LFS)
BIN
assets/world/shrub/jungle-bush-1.vox
(Stored with Git LFS)
Binary file not shown.
BIN
assets/world/shrub/jungle-bush-2.vox
(Stored with Git LFS)
BIN
assets/world/shrub/jungle-bush-2.vox
(Stored with Git LFS)
Binary file not shown.
BIN
assets/world/shrub/jungle-bush-3.vox
(Stored with Git LFS)
BIN
assets/world/shrub/jungle-bush-3.vox
(Stored with Git LFS)
Binary file not shown.
BIN
assets/world/shrub/jungle-bush-4.vox
(Stored with Git LFS)
BIN
assets/world/shrub/jungle-bush-4.vox
(Stored with Git LFS)
Binary file not shown.
BIN
assets/world/shrub/jungle-bush-5.vox
(Stored with Git LFS)
BIN
assets/world/shrub/jungle-bush-5.vox
(Stored with Git LFS)
Binary file not shown.
@ -854,6 +854,7 @@ impl Body {
|
|||||||
Body::Ship(ship) => match ship {
|
Body::Ship(ship) => match ship {
|
||||||
ship::Body::DefaultAirship => [0.0, 0.0, 10.0],
|
ship::Body::DefaultAirship => [0.0, 0.0, 10.0],
|
||||||
ship::Body::AirBalloon => [0.0, 0.0, 5.0],
|
ship::Body::AirBalloon => [0.0, 0.0, 5.0],
|
||||||
|
ship::Body::SailBoat => [-2.0, -5.0, 4.0],
|
||||||
},
|
},
|
||||||
_ => [0.0, 0.0, 0.0],
|
_ => [0.0, 0.0, 0.0],
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
use crate::{
|
use crate::{
|
||||||
comp::{Density, Mass},
|
comp::{Density, Mass},
|
||||||
consts::AIR_DENSITY,
|
consts::{AIR_DENSITY, WATER_DENSITY},
|
||||||
make_case_elim,
|
make_case_elim,
|
||||||
};
|
};
|
||||||
use rand::prelude::SliceRandom;
|
use rand::prelude::SliceRandom;
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use vek::Vec3;
|
use vek::Vec3;
|
||||||
|
|
||||||
pub const ALL_BODIES: [Body; 2] = [Body::DefaultAirship, Body::AirBalloon];
|
pub const ALL_BODIES: [Body; 3] = [Body::DefaultAirship, Body::AirBalloon, Body::SailBoat];
|
||||||
|
|
||||||
make_case_elim!(
|
make_case_elim!(
|
||||||
body,
|
body,
|
||||||
@ -16,6 +16,7 @@ make_case_elim!(
|
|||||||
pub enum Body {
|
pub enum Body {
|
||||||
DefaultAirship = 0,
|
DefaultAirship = 0,
|
||||||
AirBalloon = 1,
|
AirBalloon = 1,
|
||||||
|
SailBoat = 2,
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -35,6 +36,7 @@ impl Body {
|
|||||||
match self {
|
match self {
|
||||||
Body::DefaultAirship => "airship_human.structure",
|
Body::DefaultAirship => "airship_human.structure",
|
||||||
Body::AirBalloon => "air_balloon.structure",
|
Body::AirBalloon => "air_balloon.structure",
|
||||||
|
Body::SailBoat => "sail_boat.structure",
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -42,15 +44,21 @@ impl Body {
|
|||||||
match self {
|
match self {
|
||||||
Body::DefaultAirship => Vec3::new(25.0, 50.0, 40.0),
|
Body::DefaultAirship => Vec3::new(25.0, 50.0, 40.0),
|
||||||
Body::AirBalloon => Vec3::new(25.0, 50.0, 40.0),
|
Body::AirBalloon => Vec3::new(25.0, 50.0, 40.0),
|
||||||
|
Body::SailBoat => Vec3::new(13.0, 31.0, 6.0),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn balloon_vol(&self) -> f32 {
|
fn balloon_vol(&self) -> f32 {
|
||||||
let spheroid_vol = |equat_d: f32, polar_d: f32| -> f32 {
|
match self {
|
||||||
(std::f32::consts::PI / 6.0) * equat_d.powi(2) * polar_d
|
Body::DefaultAirship | Body::AirBalloon => {
|
||||||
};
|
let spheroid_vol = |equat_d: f32, polar_d: f32| -> f32 {
|
||||||
let dim = self.dimensions();
|
(std::f32::consts::PI / 6.0) * equat_d.powi(2) * polar_d
|
||||||
spheroid_vol(dim.z, dim.y)
|
};
|
||||||
|
let dim = self.dimensions();
|
||||||
|
spheroid_vol(dim.z, dim.y)
|
||||||
|
},
|
||||||
|
_ => 0.0,
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn hull_vol(&self) -> f32 {
|
fn hull_vol(&self) -> f32 {
|
||||||
@ -66,15 +74,25 @@ impl Body {
|
|||||||
Density(ratio * oak_density + (1.0 - ratio) * AIR_DENSITY)
|
Density(ratio * oak_density + (1.0 - ratio) * AIR_DENSITY)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn density(&self) -> Density { Density(AIR_DENSITY) }
|
pub fn density(&self) -> Density {
|
||||||
|
match self {
|
||||||
|
Body::DefaultAirship | Body::AirBalloon => Density(AIR_DENSITY),
|
||||||
|
_ => Density(AIR_DENSITY * 0.75 + WATER_DENSITY * 0.25), // Most boats should be buoyant
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
pub fn mass(&self) -> Mass { Mass((self.hull_vol() + self.balloon_vol()) * self.density().0) }
|
pub fn mass(&self) -> Mass { Mass((self.hull_vol() + self.balloon_vol()) * self.density().0) }
|
||||||
|
|
||||||
pub fn can_fly(&self) -> bool {
|
pub fn can_fly(&self) -> bool {
|
||||||
match self {
|
match self {
|
||||||
Body::DefaultAirship | Body::AirBalloon => true,
|
Body::DefaultAirship | Body::AirBalloon => true,
|
||||||
|
_ => false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn has_water_thrust(&self) -> bool {
|
||||||
|
!self.can_fly() // TODO: Differentiate this more carefully
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Terrain is 11.0 scale relative to small-scale voxels,
|
/// Terrain is 11.0 scale relative to small-scale voxels,
|
||||||
|
@ -200,6 +200,8 @@ impl Body {
|
|||||||
Body::QuadrupedLow(_) => Some(300.0 * self.mass().0),
|
Body::QuadrupedLow(_) => Some(300.0 * self.mass().0),
|
||||||
Body::QuadrupedMedium(_) => Some(300.0 * self.mass().0),
|
Body::QuadrupedMedium(_) => Some(300.0 * self.mass().0),
|
||||||
Body::QuadrupedSmall(_) => Some(300.0 * self.mass().0),
|
Body::QuadrupedSmall(_) => Some(300.0 * self.mass().0),
|
||||||
|
Body::Ship(ship) if ship.has_water_thrust() => Some(500.0 * self.mass().0),
|
||||||
|
_ => None,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -31,7 +31,9 @@ impl Skeleton for ShipSkeleton {
|
|||||||
buf: &mut [FigureBoneData; super::MAX_BONE_COUNT],
|
buf: &mut [FigureBoneData; super::MAX_BONE_COUNT],
|
||||||
body: Self::Body,
|
body: Self::Body,
|
||||||
) -> Offsets {
|
) -> Offsets {
|
||||||
let bone0_mat = base_mat * Mat4::scaling_3d(1.0 / 11.0) * Mat4::<f32>::from(self.bone0);
|
let scale_mat = Mat4::scaling_3d(1.0 / 11.0);
|
||||||
|
|
||||||
|
let bone0_mat = base_mat * scale_mat * Mat4::<f32>::from(self.bone0);
|
||||||
|
|
||||||
*(<&mut [_; Self::BONE_COUNT]>::try_from(&mut buf[0..Self::BONE_COUNT]).unwrap()) = [
|
*(<&mut [_; Self::BONE_COUNT]>::try_from(&mut buf[0..Self::BONE_COUNT]).unwrap()) = [
|
||||||
make_bone(bone0_mat),
|
make_bone(bone0_mat),
|
||||||
@ -43,10 +45,12 @@ impl Skeleton for ShipSkeleton {
|
|||||||
lantern: None,
|
lantern: None,
|
||||||
// TODO: see quadruped_medium for how to animate this
|
// TODO: see quadruped_medium for how to animate this
|
||||||
mount_bone: Transform {
|
mount_bone: Transform {
|
||||||
position: common::comp::Body::Ship(body)
|
position: (base_mat * scale_mat).mul_point(
|
||||||
.mountee_offset()
|
common::comp::Body::Ship(body)
|
||||||
.into_tuple()
|
.mountee_offset()
|
||||||
.into(),
|
.into_tuple()
|
||||||
|
.into(),
|
||||||
|
),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
@ -89,18 +93,22 @@ impl<'a> From<&'a Body> for SkeletonAttr {
|
|||||||
bone0: match body {
|
bone0: match body {
|
||||||
DefaultAirship => (0.0, 0.0, 0.0),
|
DefaultAirship => (0.0, 0.0, 0.0),
|
||||||
AirBalloon => (0.0, 0.0, 0.0),
|
AirBalloon => (0.0, 0.0, 0.0),
|
||||||
|
SailBoat => (0.0, 0.0, 0.0),
|
||||||
},
|
},
|
||||||
bone1: match body {
|
bone1: match body {
|
||||||
DefaultAirship => (-13.0, -25.0, 10.0),
|
DefaultAirship => (-13.0, -25.0, 10.0),
|
||||||
AirBalloon => (0.0, 0.0, 0.0),
|
AirBalloon => (0.0, 0.0, 0.0),
|
||||||
|
SailBoat => (0.0, 0.0, 0.0),
|
||||||
},
|
},
|
||||||
bone2: match body {
|
bone2: match body {
|
||||||
DefaultAirship => (13.0, -25.0, 10.0),
|
DefaultAirship => (13.0, -25.0, 10.0),
|
||||||
AirBalloon => (0.0, 0.0, 0.0),
|
AirBalloon => (0.0, 0.0, 0.0),
|
||||||
|
SailBoat => (0.0, 0.0, 0.0),
|
||||||
},
|
},
|
||||||
bone3: match body {
|
bone3: match body {
|
||||||
DefaultAirship => (0.0, -27.5, 8.5),
|
DefaultAirship => (0.0, -27.5, 8.5),
|
||||||
AirBalloon => (0.0, -9.0, 8.0),
|
AirBalloon => (0.0, -9.0, 8.0),
|
||||||
|
SailBoat => (0.0, 0.0, 0.0),
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user