pbox2d 0.9.1-java → 1.0.0-java

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +1 -5
  3. data/CHANGELOG.md +4 -0
  4. data/README.md +6 -6
  5. data/docs/.gitignore +6 -0
  6. data/docs/_classes/pbox2d.md +375 -0
  7. data/docs/_classes/world_builder.md +7 -0
  8. data/docs/_config.yml +32 -0
  9. data/docs/_includes/footer.html +55 -0
  10. data/docs/_includes/head.html +18 -0
  11. data/docs/_includes/header.html +27 -0
  12. data/docs/_includes/menu.html +8 -0
  13. data/docs/_includes/navigation.html +24 -0
  14. data/docs/_layouts/default.html +20 -0
  15. data/docs/_layouts/page.html +14 -0
  16. data/docs/_layouts/post.html +15 -0
  17. data/docs/_methods/init_options.md +28 -0
  18. data/docs/_methods/processing_to_world.md +29 -0
  19. data/docs/_methods/scale_to_processing.md +24 -0
  20. data/docs/_methods/scale_to_world.md +29 -0
  21. data/docs/_methods/step_options.md +25 -0
  22. data/docs/_methods/world_to_processing.md +30 -0
  23. data/docs/_modules/pb.md +25 -0
  24. data/docs/_modules/world_builder.md +26 -0
  25. data/docs/_posts/2016-10-14-welcome.md +183 -0
  26. data/docs/_sass/_base.scss +204 -0
  27. data/docs/_sass/_layout.scss +236 -0
  28. data/docs/_sass/_syntax-highlighting.scss +67 -0
  29. data/docs/about.md +20 -0
  30. data/docs/classes.html +9 -0
  31. data/docs/css/main.scss +52 -0
  32. data/docs/favicon.ico +0 -0
  33. data/docs/index.html +38 -0
  34. data/docs/methods.html +9 -0
  35. data/docs/modules.html +12 -0
  36. data/lib/pbox2d/version.rb +1 -1
  37. data/pbox2d.gemspec +4 -7
  38. data/pom.rb +8 -6
  39. data/pom.xml +3 -3
  40. data/src/org/jbox2d/collision/AABB.java +2 -2
  41. data/src/org/jbox2d/collision/Manifold.java +2 -2
  42. data/src/org/jbox2d/collision/ManifoldPoint.java +2 -2
  43. data/src/org/jbox2d/collision/shapes/MassData.java +1 -1
  44. data/src/org/jbox2d/common/Mat22.java +6 -13
  45. data/src/org/jbox2d/common/Mat33.java +253 -233
  46. data/src/org/jbox2d/common/MathUtils.java +5 -5
  47. data/src/org/jbox2d/common/Rot.java +16 -19
  48. data/src/org/jbox2d/common/Transform.java +4 -4
  49. data/src/org/jbox2d/common/Vec2.java +6 -12
  50. data/src/org/jbox2d/common/Vec3.java +147 -142
  51. data/src/org/jbox2d/dynamics/joints/DistanceJoint.java +4 -2
  52. metadata +62 -25
@@ -69,11 +69,11 @@ public class MathUtils extends PlatformMathUtils {
69
69
  */
70
70
  public static final float RAD2DEG = 180 / PI;
71
71
 
72
- public static final float[] sinLUT = new float[Settings.SINCOS_LUT_LENGTH];
72
+ public static final float[] SIN_LUT = new float[Settings.SINCOS_LUT_LENGTH];
73
73
 
74
74
  static {
75
75
  for (int i = 0; i < Settings.SINCOS_LUT_LENGTH; i++) {
76
- sinLUT[i] = (float) Math.sin(i * Settings.SINCOS_LUT_PRECISION);
76
+ SIN_LUT[i] = (float) Math.sin(i * Settings.SINCOS_LUT_PRECISION);
77
77
  }
78
78
  }
79
79
 
@@ -104,13 +104,13 @@ public class MathUtils extends PlatformMathUtils {
104
104
 
105
105
  // the next index is 0
106
106
  if (index == Settings.SINCOS_LUT_LENGTH - 1) {
107
- return ((1 - x) * sinLUT[index] + x * sinLUT[0]);
107
+ return ((1 - x) * SIN_LUT[index] + x * SIN_LUT[0]);
108
108
  } else {
109
- return ((1 - x) * sinLUT[index] + x * sinLUT[index + 1]);
109
+ return ((1 - x) * SIN_LUT[index] + x * SIN_LUT[index + 1]);
110
110
  }
111
111
 
112
112
  } else {
113
- return sinLUT[MathUtils.round(x / Settings.SINCOS_LUT_PRECISION) % Settings.SINCOS_LUT_LENGTH];
113
+ return SIN_LUT[MathUtils.round(x / Settings.SINCOS_LUT_PRECISION) % Settings.SINCOS_LUT_LENGTH];
114
114
  }
115
115
  }
116
116
 
@@ -1,7 +1,7 @@
1
1
  /*******************************************************************************
2
2
  * Copyright (c) 2013, Daniel Murphy
3
3
  * All rights reserved.
4
- *
4
+ *
5
5
  * Redistribution and use in source and binary forms, with or without modification,
6
6
  * are permitted provided that the following conditions are met:
7
7
  * * Redistributions of source code must retain the above copyright notice,
@@ -9,7 +9,7 @@
9
9
  * * Redistributions in binary form must reproduce the above copyright notice,
10
10
  * this list of conditions and the following disclaimer in the documentation
11
11
  * and/or other materials provided with the distribution.
12
- *
12
+ *
13
13
  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
14
14
  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15
15
  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
@@ -27,7 +27,7 @@ import java.io.Serializable;
27
27
 
28
28
  /**
29
29
  * Represents a rotation
30
- *
30
+ *
31
31
  * @author Daniel
32
32
  */
33
33
  public class Rot implements Serializable {
@@ -35,13 +35,18 @@ public class Rot implements Serializable {
35
35
 
36
36
  public float s, c; // sin and cos
37
37
 
38
- public Rot() {
39
- setIdentity();
40
- }
38
+ public Rot() {
39
+ setIdentity();
40
+ }
41
41
 
42
- public Rot(float angle) {
43
- set(angle);
44
- }
42
+ public Rot(float angle) {
43
+ set(angle);
44
+ }
45
+
46
+ public Rot(Rot rot) {
47
+ c = rot.c;
48
+ s = rot.s;
49
+ }
45
50
 
46
51
  public float getSin() {
47
52
  return s;
@@ -56,7 +61,7 @@ public class Rot implements Serializable {
56
61
  return c;
57
62
  }
58
63
 
59
- public Rot set(float angle) {
64
+ public final Rot set(float angle) {
60
65
  s = MathUtils.sin(angle);
61
66
  c = MathUtils.cos(angle);
62
67
  return this;
@@ -68,7 +73,7 @@ public class Rot implements Serializable {
68
73
  return this;
69
74
  }
70
75
 
71
- public Rot setIdentity() {
76
+ public final Rot setIdentity() {
72
77
  s = 0;
73
78
  c = 1;
74
79
  return this;
@@ -86,14 +91,6 @@ public class Rot implements Serializable {
86
91
  yAxis.set(-s, c);
87
92
  }
88
93
 
89
- // @Override // annotation omitted for GWT-compatibility
90
- public Rot clone() {
91
- Rot copy = new Rot();
92
- copy.s = s;
93
- copy.c = c;
94
- return copy;
95
- }
96
-
97
94
  public static final void mul(Rot q, Rot r, Rot out) {
98
95
  float tempc = q.c * r.c - q.s * r.s;
99
96
  out.s = q.s * r.c + q.c * r.s;
@@ -60,8 +60,8 @@ public class Transform implements Serializable {
60
60
  * @param xf
61
61
  */
62
62
  public Transform(final Transform xf) {
63
- p = xf.p.clone();
64
- q = xf.q.clone();
63
+ p = new Vec2(xf.p);
64
+ q = new Rot(xf.q);
65
65
  }
66
66
 
67
67
  /**
@@ -71,8 +71,8 @@ public class Transform implements Serializable {
71
71
  * @param _R
72
72
  */
73
73
  public Transform(final Vec2 _position, final Rot _R) {
74
- p = _position.clone();
75
- q = _R.clone();
74
+ p = new Vec2(_position);
75
+ q = new Rot(_R);
76
76
  }
77
77
 
78
78
  /**
@@ -32,7 +32,9 @@ import java.io.Serializable;
32
32
  */
33
33
  public class Vec2 implements Serializable {
34
34
 
35
- private static final long serialVersionUID = 1L;
35
+ private static final long serialVersionUID = -8868057637176265779L;
36
+
37
+
36
38
 
37
39
  public float x, y;
38
40
 
@@ -262,17 +264,6 @@ public class Vec2 implements Serializable {
262
264
  y = MathUtils.abs(y);
263
265
  }
264
266
 
265
- // @Override // annotation omitted for GWT-compatibility
266
- /**
267
- * Return a copy of this vector.
268
- *
269
- * @return
270
- */
271
- @Override
272
- public final Vec2 clone() {
273
- return new Vec2(x, y);
274
- }
275
-
276
267
  @Override
277
268
  public final String toString() {
278
269
  return "(" + x + "," + y + ")";
@@ -354,6 +345,7 @@ public class Vec2 implements Serializable {
354
345
  }
355
346
 
356
347
  /**
348
+ * @return
357
349
  * @see java.lang.Object#hashCode()
358
350
  */
359
351
  @Override
@@ -366,6 +358,8 @@ public class Vec2 implements Serializable {
366
358
  }
367
359
 
368
360
  /**
361
+ * @param obj
362
+ * @return
369
363
  * @see java.lang.Object#equals(java.lang.Object)
370
364
  */
371
365
  @Override
@@ -1,7 +1,7 @@
1
- /*******************************************************************************
1
+ /** *****************************************************************************
2
2
  * Copyright (c) 2013, Daniel Murphy
3
3
  * All rights reserved.
4
- *
4
+ *
5
5
  * Redistribution and use in source and binary forms, with or without modification,
6
6
  * are permitted provided that the following conditions are met:
7
7
  * * Redistributions of source code must retain the above copyright notice,
@@ -9,7 +9,7 @@
9
9
  * * Redistributions in binary form must reproduce the above copyright notice,
10
10
  * this list of conditions and the following disclaimer in the documentation
11
11
  * and/or other materials provided with the distribution.
12
- *
12
+ *
13
13
  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
14
14
  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
15
15
  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
@@ -20,7 +20,7 @@
20
20
  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
21
21
  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
22
22
  * POSSIBILITY OF SUCH DAMAGE.
23
- ******************************************************************************/
23
+ ***************************************************************************** */
24
24
  package org.jbox2d.common;
25
25
 
26
26
  import java.io.Serializable;
@@ -29,142 +29,147 @@ import java.io.Serializable;
29
29
  * @author Daniel Murphy
30
30
  */
31
31
  public class Vec3 implements Serializable {
32
- private static final long serialVersionUID = 1L;
33
-
34
- public float x, y, z;
35
-
36
- public Vec3() {
37
- x = y = z = 0f;
38
- }
39
-
40
- public Vec3(float argX, float argY, float argZ) {
41
- x = argX;
42
- y = argY;
43
- z = argZ;
44
- }
45
-
46
- public Vec3(Vec3 copy) {
47
- x = copy.x;
48
- y = copy.y;
49
- z = copy.z;
50
- }
51
-
52
- public Vec3 set(Vec3 vec) {
53
- x = vec.x;
54
- y = vec.y;
55
- z = vec.z;
56
- return this;
57
- }
58
-
59
- public Vec3 set(float argX, float argY, float argZ) {
60
- x = argX;
61
- y = argY;
62
- z = argZ;
63
- return this;
64
- }
65
-
66
- public Vec3 addLocal(Vec3 argVec) {
67
- x += argVec.x;
68
- y += argVec.y;
69
- z += argVec.z;
70
- return this;
71
- }
72
-
73
- public Vec3 add(Vec3 argVec) {
74
- return new Vec3(x + argVec.x, y + argVec.y, z + argVec.z);
75
- }
76
-
77
- public Vec3 subLocal(Vec3 argVec) {
78
- x -= argVec.x;
79
- y -= argVec.y;
80
- z -= argVec.z;
81
- return this;
82
- }
83
-
84
- public Vec3 sub(Vec3 argVec) {
85
- return new Vec3(x - argVec.x, y - argVec.y, z - argVec.z);
86
- }
87
-
88
- public Vec3 mulLocal(float argScalar) {
89
- x *= argScalar;
90
- y *= argScalar;
91
- z *= argScalar;
92
- return this;
93
- }
94
-
95
- public Vec3 mul(float argScalar) {
96
- return new Vec3(x * argScalar, y * argScalar, z * argScalar);
97
- }
98
-
99
- public Vec3 negate() {
100
- return new Vec3(-x, -y, -z);
101
- }
102
-
103
- public Vec3 negateLocal() {
104
- x = -x;
105
- y = -y;
106
- z = -z;
107
- return this;
108
- }
109
-
110
- public void setZero() {
111
- x = 0;
112
- y = 0;
113
- z = 0;
114
- }
115
-
116
- @Override
117
- public Vec3 clone() {
118
- return new Vec3(this);
119
- }
120
-
121
- @Override
122
- public String toString() {
123
- return "(" + x + "," + y + "," + z + ")";
124
- }
125
-
126
- @Override
127
- public int hashCode() {
128
- final int prime = 31;
129
- int result = 1;
130
- result = prime * result + Float.floatToIntBits(x);
131
- result = prime * result + Float.floatToIntBits(y);
132
- result = prime * result + Float.floatToIntBits(z);
133
- return result;
134
- }
135
-
136
- @Override
137
- public boolean equals(Object obj) {
138
- if (this == obj) return true;
139
- if (obj == null) return false;
140
- if (getClass() != obj.getClass()) return false;
141
- Vec3 other = (Vec3) obj;
142
- if (Float.floatToIntBits(x) != Float.floatToIntBits(other.x)) return false;
143
- if (Float.floatToIntBits(y) != Float.floatToIntBits(other.y)) return false;
144
- return (Float.floatToIntBits(z) == Float.floatToIntBits(other.z));
145
- }
146
-
147
- public final static float dot(Vec3 a, Vec3 b) {
148
- return a.x * b.x + a.y * b.y + a.z * b.z;
149
- }
150
-
151
- public final static Vec3 cross(Vec3 a, Vec3 b) {
152
- return new Vec3(a.y * b.z - a.z * b.y, a.z * b.x - a.x * b.z, a.x * b.y - a.y * b.x);
153
- }
154
-
155
- public final static void crossToOut(Vec3 a, Vec3 b, Vec3 out) {
156
- final float tempy = a.z * b.x - a.x * b.z;
157
- final float tempz = a.x * b.y - a.y * b.x;
158
- out.x = a.y * b.z - a.z * b.y;
159
- out.y = tempy;
160
- out.z = tempz;
161
- }
162
-
163
- public final static void crossToOutUnsafe(Vec3 a, Vec3 b, Vec3 out) {
164
- assert(out != b);
165
- assert(out != a);
166
- out.x = a.y * b.z - a.z * b.y;
167
- out.y = a.z * b.x - a.x * b.z;
168
- out.z = a.x * b.y - a.y * b.x;
169
- }
32
+
33
+ private static final long serialVersionUID = 102913558223451982L;
34
+ public float x, y, z;
35
+
36
+ public Vec3() {
37
+ x = y = z = 0f;
38
+ }
39
+
40
+ public Vec3(float argX, float argY, float argZ) {
41
+ x = argX;
42
+ y = argY;
43
+ z = argZ;
44
+ }
45
+
46
+ public Vec3(Vec3 copy) {
47
+ x = copy.x;
48
+ y = copy.y;
49
+ z = copy.z;
50
+ }
51
+
52
+ public Vec3 set(Vec3 vec) {
53
+ x = vec.x;
54
+ y = vec.y;
55
+ z = vec.z;
56
+ return this;
57
+ }
58
+
59
+ public Vec3 set(float argX, float argY, float argZ) {
60
+ x = argX;
61
+ y = argY;
62
+ z = argZ;
63
+ return this;
64
+ }
65
+
66
+ public Vec3 addLocal(Vec3 argVec) {
67
+ x += argVec.x;
68
+ y += argVec.y;
69
+ z += argVec.z;
70
+ return this;
71
+ }
72
+
73
+ public Vec3 add(Vec3 argVec) {
74
+ return new Vec3(x + argVec.x, y + argVec.y, z + argVec.z);
75
+ }
76
+
77
+ public Vec3 subLocal(Vec3 argVec) {
78
+ x -= argVec.x;
79
+ y -= argVec.y;
80
+ z -= argVec.z;
81
+ return this;
82
+ }
83
+
84
+ public Vec3 sub(Vec3 argVec) {
85
+ return new Vec3(x - argVec.x, y - argVec.y, z - argVec.z);
86
+ }
87
+
88
+ public Vec3 mulLocal(float argScalar) {
89
+ x *= argScalar;
90
+ y *= argScalar;
91
+ z *= argScalar;
92
+ return this;
93
+ }
94
+
95
+ public Vec3 mul(float argScalar) {
96
+ return new Vec3(x * argScalar, y * argScalar, z * argScalar);
97
+ }
98
+
99
+ public Vec3 negate() {
100
+ return new Vec3(-x, -y, -z);
101
+ }
102
+
103
+ public Vec3 negateLocal() {
104
+ x = -x;
105
+ y = -y;
106
+ z = -z;
107
+ return this;
108
+ }
109
+
110
+ public void setZero() {
111
+ x = 0;
112
+ y = 0;
113
+ z = 0;
114
+ }
115
+
116
+ @Override
117
+ public String toString() {
118
+ return "(" + x + "," + y + "," + z + ")";
119
+ }
120
+
121
+ @Override
122
+ public int hashCode() {
123
+ final int prime = 31;
124
+ int result = 1;
125
+ result = prime * result + Float.floatToIntBits(x);
126
+ result = prime * result + Float.floatToIntBits(y);
127
+ result = prime * result + Float.floatToIntBits(z);
128
+ return result;
129
+ }
130
+
131
+ @Override
132
+ public boolean equals(Object obj) {
133
+ if (this == obj) {
134
+ return true;
135
+ }
136
+ if (obj == null) {
137
+ return false;
138
+ }
139
+ if (getClass() != obj.getClass()) {
140
+ return false;
141
+ }
142
+ Vec3 other = (Vec3) obj;
143
+ if (Float.floatToIntBits(x) != Float.floatToIntBits(other.x)) {
144
+ return false;
145
+ }
146
+ if (Float.floatToIntBits(y) != Float.floatToIntBits(other.y)) {
147
+ return false;
148
+ }
149
+ return (Float.floatToIntBits(z) == Float.floatToIntBits(other.z));
150
+ }
151
+
152
+ public final static float dot(Vec3 a, Vec3 b) {
153
+ return a.x * b.x + a.y * b.y + a.z * b.z;
154
+ }
155
+
156
+ public final static Vec3 cross(Vec3 a, Vec3 b) {
157
+ return new Vec3(a.y * b.z - a.z * b.y, a.z * b.x - a.x * b.z, a.x * b.y - a.y * b.x);
158
+ }
159
+
160
+ public final static void crossToOut(Vec3 a, Vec3 b, Vec3 out) {
161
+ final float tempy = a.z * b.x - a.x * b.z;
162
+ final float tempz = a.x * b.y - a.y * b.x;
163
+ out.x = a.y * b.z - a.z * b.y;
164
+ out.y = tempy;
165
+ out.z = tempz;
166
+ }
167
+
168
+ public final static void crossToOutUnsafe(Vec3 a, Vec3 b, Vec3 out) {
169
+ assert (out != b);
170
+ assert (out != a);
171
+ out.x = a.y * b.z - a.z * b.y;
172
+ out.y = a.z * b.x - a.x * b.z;
173
+ out.z = a.x * b.y - a.y * b.x;
174
+ }
170
175
  }