summaryrefslogtreecommitdiff
path: root/src/sims/geometry/Projection.scala
diff options
context:
space:
mode:
Diffstat (limited to 'src/sims/geometry/Projection.scala')
-rw-r--r--src/sims/geometry/Projection.scala34
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
+ }
+}