summaryrefslogtreecommitdiff
path: root/src/tesseract/forces/CircularXZ.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/tesseract/forces/CircularXZ.java')
-rw-r--r--src/tesseract/forces/CircularXZ.java27
1 files changed, 27 insertions, 0 deletions
diff --git a/src/tesseract/forces/CircularXZ.java b/src/tesseract/forces/CircularXZ.java
new file mode 100644
index 0000000..3601676
--- /dev/null
+++ b/src/tesseract/forces/CircularXZ.java
@@ -0,0 +1,27 @@
+package tesseract.forces;
+
+import javax.vecmath.Vector3f;
+
+import tesseract.objects.PhysicalObject;
+
+@SuppressWarnings("restriction")
+public class CircularXZ extends Force {
+ private float strength;
+
+ public CircularXZ(float strength) {
+ this.strength = strength;
+ }
+
+ public Vector3f calculateForce(final PhysicalObject obj) {
+ Vector3f force = new Vector3f(-obj.getPosition().z, 0, obj.getPosition().x);
+ if (force.length() > 0) {
+ force.normalize();
+ force.scale(strength);
+ }
+ return force;
+ }
+
+ public String toString() {
+ return "Tangential force in the XZ plane";
+ }
+}