2014-05-26 17:10:04 +00:00
|
|
|
// Copyright 2013-2014 The CGMath Developers. For a full listing of the authors,
|
2015-03-14 02:49:46 +00:00
|
|
|
// refer to the Cargo.toml file at the top-level directory of this distribution.
|
2013-09-05 07:19:31 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
//! View frustum for visibility determination
|
|
|
|
|
2014-05-28 01:59:03 +00:00
|
|
|
use array::Array2;
|
2015-03-13 22:31:29 +00:00
|
|
|
use bound::*;
|
2014-05-28 01:59:03 +00:00
|
|
|
use matrix::Matrix4;
|
2014-05-26 17:10:04 +00:00
|
|
|
use num::BaseFloat;
|
2013-09-07 14:43:32 +00:00
|
|
|
use plane::Plane;
|
2013-09-05 07:19:31 +00:00
|
|
|
use point::Point3;
|
2013-09-19 04:52:40 +00:00
|
|
|
use vector::{Vector, EuclideanVector};
|
2013-09-05 07:19:31 +00:00
|
|
|
|
2015-03-13 22:31:29 +00:00
|
|
|
#[derive(Copy, Clone, Debug, PartialEq, RustcEncodable, RustcDecodable)]
|
|
|
|
pub struct Frustum<S: BaseFloat> {
|
2014-04-01 11:00:17 +00:00
|
|
|
pub left: Plane<S>,
|
|
|
|
pub right: Plane<S>,
|
|
|
|
pub bottom: Plane<S>,
|
|
|
|
pub top: Plane<S>,
|
|
|
|
pub near: Plane<S>,
|
|
|
|
pub far: Plane<S>,
|
2013-09-05 07:19:31 +00:00
|
|
|
}
|
|
|
|
|
2014-09-18 14:19:26 +00:00
|
|
|
impl<S: BaseFloat + 'static>
|
2014-01-09 00:26:50 +00:00
|
|
|
Frustum<S> {
|
2015-03-13 22:31:29 +00:00
|
|
|
/// Construct a frustum.
|
2013-09-19 04:52:40 +00:00
|
|
|
pub fn new(left: Plane<S>, right: Plane<S>,
|
|
|
|
bottom: Plane<S>, top: Plane<S>,
|
|
|
|
near: Plane<S>, far: Plane<S>) -> Frustum<S> {
|
|
|
|
Frustum {
|
|
|
|
left: left,
|
|
|
|
right: right,
|
|
|
|
bottom: bottom,
|
|
|
|
top: top,
|
|
|
|
near: near,
|
|
|
|
far: far,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-03-13 22:31:29 +00:00
|
|
|
/// Extract frustum planes from a projection matrix.
|
|
|
|
pub fn from_matrix4(mat: Matrix4<S>) -> Option<Frustum<S>> {
|
|
|
|
Some(Frustum::new(
|
|
|
|
match Plane::from_vector4_alt(mat.row(3).add_v(&mat.row(0))).normalize()
|
|
|
|
{ Some(p) => p, None => return None },
|
|
|
|
match Plane::from_vector4_alt(mat.row(3).sub_v(&mat.row(0))).normalize()
|
|
|
|
{ Some(p) => p, None => return None },
|
|
|
|
match Plane::from_vector4_alt(mat.row(3).add_v(&mat.row(1))).normalize()
|
|
|
|
{ Some(p) => p, None => return None },
|
|
|
|
match Plane::from_vector4_alt(mat.row(3).sub_v(&mat.row(1))).normalize()
|
|
|
|
{ Some(p) => p, None => return None },
|
|
|
|
match Plane::from_vector4_alt(mat.row(3).add_v(&mat.row(2))).normalize()
|
|
|
|
{ Some(p) => p, None => return None },
|
|
|
|
match Plane::from_vector4_alt(mat.row(3).sub_v(&mat.row(2))).normalize()
|
|
|
|
{ Some(p) => p, None => return None }
|
|
|
|
))
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Find the spatial relation of a bound inside this frustum.
|
|
|
|
pub fn contains<B: Bound<S>>(&self, bound: &B) -> Relation {
|
|
|
|
[&self.left, &self.right, &self.top, &self.bottom, &self.near, &self.far]
|
|
|
|
.iter().fold(Relation::In, |cur, p| {
|
2015-03-15 20:21:07 +00:00
|
|
|
use std::cmp::max;
|
2015-03-14 20:41:15 +00:00
|
|
|
let r = bound.relate_plane(p);
|
2015-03-15 20:21:07 +00:00
|
|
|
// If any of the planes are `Out`, the bound is outside.
|
|
|
|
// Otherwise, if any are `Cross`, the bound is crossing.
|
|
|
|
// Otherwise, the bound is fully inside.
|
|
|
|
max(cur, r)
|
2015-03-13 22:31:29 +00:00
|
|
|
})
|
2013-09-19 04:52:40 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-03 21:29:26 +00:00
|
|
|
#[derive(Copy, Clone, PartialEq, RustcEncodable, RustcDecodable)]
|
2013-09-05 07:19:31 +00:00
|
|
|
pub struct FrustumPoints<S> {
|
2014-04-01 11:00:17 +00:00
|
|
|
pub near_top_left: Point3<S>,
|
|
|
|
pub near_top_right: Point3<S>,
|
|
|
|
pub near_bottom_left: Point3<S>,
|
|
|
|
pub near_bottom_right: Point3<S>,
|
|
|
|
pub far_top_left: Point3<S>,
|
|
|
|
pub far_top_right: Point3<S>,
|
|
|
|
pub far_bottom_left: Point3<S>,
|
|
|
|
pub far_bottom_right: Point3<S>,
|
2013-09-05 07:19:31 +00:00
|
|
|
}
|