diff options
Diffstat (limited to 'src/sims/geometry/Projection.scala')
-rw-r--r-- | src/sims/geometry/Projection.scala | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/sims/geometry/Projection.scala b/src/sims/geometry/Projection.scala new file mode 100644 index 0000000..5f2d0f0 --- /dev/null +++ b/src/sims/geometry/Projection.scala @@ -0,0 +1,34 @@ +/* + * Simple Mechanics Simulator (SiMS) + * copyright (c) 2009 Jakob Odersky + * made available under the MIT License +*/ + +package sims.geometry + +import sims.math._ + +/**Projektion auf eine Achse. + * <p> + * Ueblicherweise werden Projektionen in SiMS fuer Kollisionserkennung benutzt. + * @param axis Achse der Projektion + * @param lower unterer Wert der Projektion + * @param upper oberer Wert der Projektion*/ +case class Projection(axis: Vector2D, + lower: Double, + upper: Double) { + require(axis != Vector2D.Null) + + /**Ueberprueft ob sich diese Projektion mit der Projektion <code>other</code> ueberschneidet.*/ + def overlaps(other: Projection): Boolean = { + require(axis == other.axis, "Cannot compare two projections on different axes!") + !((other.lower - this.upper) > 0 || (this.lower - other.upper) > 0) + } + + + /**Ergibt die Ueberlappung dieser Projektion und der Projektion <code>other</code>.*/ + def overlap(other: Projection): Double = { + require(axis == other.axis, "Cannot compare two projections on different axes!") + (Math.max(lower, other.lower) - Math.min(upper, other.upper)).abs + } +} |