2022-12-05 23:01:16 +01:00
|
|
|
use bevy::{prelude::*, math::bool, render::primitives::Frustum};
|
|
|
|
use rand::prelude::*;
|
|
|
|
use bevy::render::primitives::Plane;
|
|
|
|
|
2022-12-06 15:44:16 +01:00
|
|
|
// pub struct BuildScenePlugin;
|
2022-07-15 23:42:22 +02:00
|
|
|
|
2022-12-06 15:44:16 +01:00
|
|
|
// impl Plugin for BuildScenePlugin {
|
|
|
|
// fn build(&self, app: &mut App) {
|
|
|
|
// app.add_startup_system(build_scene) // actual scene
|
|
|
|
// .add_system(print_positions); // debugging
|
|
|
|
// }
|
|
|
|
// }
|
2022-11-17 23:18:30 +01:00
|
|
|
|
|
|
|
#[derive(Component)]
|
|
|
|
pub struct ProjectionScreen {
|
|
|
|
bottom_left: Vec3,
|
|
|
|
bottom_right: Vec3,
|
|
|
|
top_left: Vec3,
|
|
|
|
top_right: Vec3,
|
|
|
|
|
|
|
|
dir_right: Vec3,
|
|
|
|
dir_up: Vec3,
|
|
|
|
dir_normal: Vec3,
|
|
|
|
|
|
|
|
matrix: Mat4
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2022-12-05 23:01:16 +01:00
|
|
|
|
|
|
|
|
|
|
|
fn generalized_projection_stereo(eyePos : Vec3)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
fn generalized_projection (
|
2022-11-17 23:18:30 +01:00
|
|
|
projectionScreen: ProjectionScreen,
|
|
|
|
eyePos: Vec3,
|
|
|
|
mut camera: Camera3dBundle,
|
|
|
|
clampNearPlane: bool,
|
|
|
|
)
|
|
|
|
{
|
|
|
|
let pa = projectionScreen.bottom_left;
|
|
|
|
let pb = projectionScreen.bottom_right;
|
|
|
|
let pc = projectionScreen.top_left;
|
|
|
|
let pd = projectionScreen.top_right;
|
|
|
|
|
|
|
|
let vu = projectionScreen.dir_up;
|
|
|
|
let vr = projectionScreen.dir_right;
|
|
|
|
let vn = projectionScreen.dir_normal;
|
|
|
|
|
2022-12-05 23:01:16 +01:00
|
|
|
// let m = projectionScreen.matrix;
|
|
|
|
|
|
|
|
//let m = Mat4::from_cols(vu., y_axis, z_axis, w_axis)
|
2022-11-17 23:18:30 +01:00
|
|
|
|
|
|
|
let va = pa - eyePos;
|
|
|
|
let vb = pb - eyePos;
|
|
|
|
let vc = pc - eyePos;
|
|
|
|
let vd = pd - eyePos;
|
2022-07-15 23:42:22 +02:00
|
|
|
|
2022-11-17 23:18:30 +01:00
|
|
|
let viewDir = eyePos + va + vb + vc + vd;
|
2022-07-15 23:42:22 +02:00
|
|
|
|
2022-11-17 23:18:30 +01:00
|
|
|
let d = -va.dot(vn);
|
2022-11-16 23:32:35 +01:00
|
|
|
|
2022-12-05 23:01:16 +01:00
|
|
|
|
|
|
|
if clampNearPlane {
|
|
|
|
_ = 33;
|
2022-11-17 23:18:30 +01:00
|
|
|
// camera.frustum.planes[4]. // should be near
|
|
|
|
}
|
2022-12-06 21:12:15 +01:00
|
|
|
|
2022-11-17 23:18:30 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn build_scene(
|
|
|
|
mut commands: Commands,
|
|
|
|
mut meshes: ResMut<Assets<Mesh>>,
|
|
|
|
mut materials: ResMut<Assets<StandardMaterial>>,
|
|
|
|
) {
|
|
|
|
// plane
|
|
|
|
commands.spawn(PbrBundle {
|
|
|
|
mesh: meshes.add(Mesh::from(shape::Plane { size: 5.0 })),
|
|
|
|
material: materials.add(Color::rgb(0.3, 0.5, 0.3).into()),
|
|
|
|
..default()
|
|
|
|
});
|
|
|
|
// cube
|
|
|
|
commands.spawn(PbrBundle {
|
|
|
|
mesh: meshes.add(Mesh::from(shape::Cube { size: 1.0 })),
|
|
|
|
material: materials.add(Color::rgb(0.8, 0.7, 0.6).into()),
|
|
|
|
transform: Transform::from_xyz(0.0, 0.5, 0.0),
|
|
|
|
..default()
|
|
|
|
});
|
|
|
|
// light
|
|
|
|
commands.spawn(PointLightBundle {
|
|
|
|
point_light: PointLight {
|
|
|
|
intensity: 1500.0,
|
|
|
|
shadows_enabled: true,
|
|
|
|
..default()
|
|
|
|
},
|
2022-12-07 20:41:17 +01:00
|
|
|
transform: Transform::from_xyz(4.0, 8.0, -4.0),
|
2022-11-17 23:18:30 +01:00
|
|
|
..default()
|
|
|
|
});
|
|
|
|
|
2022-12-09 21:30:47 +01:00
|
|
|
}
|