| 
 | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||
java.lang.Objectde.grogra.vecmath.geom.VolumeBase
de.grogra.vecmath.geom.TransformableVolume
public abstract class TransformableVolume
This class represents the base class for volumes whose
 geometry is specified
 in local coordinates. The transformation from global
 world coordinates to local object coordinates is stored in the
 fields m00 to m22 and t0 to t2,
 the transformation is computed by
 
t represents the location of the
 object origin in world coordinates.
 This representation has been chosen instead of 
 an instance of Matrix4d for memory and speed
 (faster instantiation) reasons. After modification of
 matrix components and other geometric parameters declared
 by subclasses, invalidate() has to be invoked.
| Field Summary | |
|---|---|
| protected  double | m0000-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m0101-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m0202-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m1010-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m1111-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m1212-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m2020-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m2121-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | m2222-component of the rotation matrix from world coordinates to object coordinates. | 
| protected  double | t00-component of the translation from object coordinates to world coordinates. | 
| protected  double | t11-component of the translation from object coordinates to world coordinates. | 
| protected  double | t22-component of the translation from object coordinates to world coordinates. | 
| Constructor Summary | |
|---|---|
| TransformableVolume() | |
| Method Summary | |
|---|---|
|  void | getDiscExtent(double z,
              double radius,
              Tuple3d min,
              Tuple3d max) | 
|  void | getDiscsExtent(double z1,
               double radius1,
               double z2,
               double radius2,
               Tuple3d min,
               Tuple3d max) | 
|  double | getFrobeniusNorm()Returns the Frobenius norm of the upper 3x3 values of the world-to-object transformation, i.e., the square root of m00 * m00 + ... + m22 * m22. | 
|  Matrix3d | getObjectToWorldRotationScale()Computes the rotational component of the transformation from local object coordinates to global world coordinates. | 
|  void | getTransformation(Matrix3d rot,
                  Tuple3d trans)gets the transformation from world to object coordinates to the specified matrix and vector: o = rot * (w - trans) | 
|  void | invalidate()Invalidates cached information about this volume. | 
|  void | invTransformPoint(Tuple3d in,
                  Tuple3d out)Transforms the point in, specified in local
 object coordinates, tooutin global world
 coordinates. | 
|  void | scale(double sx,
      double sy,
      double sz)Multiplies the current world-to-object transformation from left by a scaling matrix. | 
|  void | setTransformation(Matrix3d rot,
                  Tuple3d trans)Sets the transformation from world to object coordinates to the specified matrix and vector: o = rot * (w - trans) | 
|  void | setTransformation(Tuple3d origin,
                  Tuple3d axis)Sets the transformation from world to object coordinates to an orthonormal transformation which transforms the originpoint to (0,0,0) and
 the normalizedaxisvector
 to (0,0,1). | 
|  void | transformPoint(Tuple3d in,
               Tuple3d out)Transforms the point in, specified in global
 world coordinates, tooutin local object
 coordinates. | 
|  void | transformTranspose(Tuple3d in,
                   Tuple3d out)Multiplies the vector inby the transpose of the upper
 3x3 values of the world-to-object transformation and stores
 the result inout. | 
|  void | transformVector(Tuple3d in,
                Tuple3d out)Transforms the direction in, specified in global
 world coordinates, tooutin local object
 coordinates. | 
|  void | translate(double dx,
          double dy,
          double dz)Multiplies the current world-to-object transformation from right by a translation matrix using the negated values. | 
| Methods inherited from class de.grogra.vecmath.geom.VolumeBase | 
|---|
| addConvexIntersections, getId, operator$and, operator$com, operator$or, operator$sub, setId | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait | 
| Methods inherited from interface de.grogra.vecmath.geom.Volume | 
|---|
| boxContainsBoundary, computeIntersections, computeNormal, computeTangents, computeUV, contains, getExtent | 
| Field Detail | 
|---|
protected double m00
protected double m01
protected double m02
protected double m10
protected double m11
protected double m12
protected double m20
protected double m21
protected double m22
protected double t0
protected double t1
protected double t2
| Constructor Detail | 
|---|
public TransformableVolume()
| Method Detail | 
|---|
public void getDiscExtent(double z,
                          double radius,
                          Tuple3d min,
                          Tuple3d max)
public void getDiscsExtent(double z1,
                           double radius1,
                           double z2,
                           double radius2,
                           Tuple3d min,
                           Tuple3d max)
public double getFrobeniusNorm()
m00 * m00 + ... + m22 * m22. Note that the length
 of a vector in object coordinates is less than or equal to the
 length of this vector in world coordinates multplied by the
 Frobenius norm of the transformation.
public Matrix3d getObjectToWorldRotationScale()
public void getTransformation(Matrix3d rot,
                              Tuple3d trans)
o = rot * (w - trans)
rot - rotational component is stored in rottrans - translational component is stored in transpublic void invalidate()
public void invTransformPoint(Tuple3d in,
                              Tuple3d out)
in, specified in local
 object coordinates, to out in global world
 coordinates. in and out may be the
 same instance.
in - point in object coordinatesout - point in world coordinates
public void scale(double sx,
                  double sy,
                  double sz)
sx - scaling factor in x-directionsy - scaling factor in y-directionsz - scaling factor in z-direction
public void setTransformation(Matrix3d rot,
                              Tuple3d trans)
o = rot * (w - trans)
rot - rotational component of new transformationtrans - translational component of new transformation
public void setTransformation(Tuple3d origin,
                              Tuple3d axis)
origin point to (0,0,0) and
 the normalized axis vector
 to (0,0,1).
origin - origin in world coordinatesaxis - axis (local z-direction) in world coordinates
public void transformPoint(Tuple3d in,
                           Tuple3d out)
in, specified in global
 world coordinates, to out in local object
 coordinates. in and out may be the
 same instance.
in - point in world coordinatesout - point in object coordinates
public void transformTranspose(Tuple3d in,
                               Tuple3d out)
in by the transpose of the upper
 3x3 values of the world-to-object transformation and stores
 the result in out. This can be used to transform
 normal vectors from object coordinates to world coordinates.
 in and out may be the same instance.
in - direction in world coordinatesout - direction in object coordinates
public void transformVector(Tuple3d in,
                            Tuple3d out)
in, specified in global
 world coordinates, to out in local object
 coordinates. in and out may be the
 same instance.
in - direction in world coordinatesout - direction in object coordinates
public void translate(double dx,
                      double dy,
                      double dz)
dx - translation in x-directiondy - translation in y-directiondz - translation in z-direction| 
 | ||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||