Glade Reference
The dbTransform64 class contains functions to transform
coordinates in subcells placed with offset, rotation and magnification. It
differs from the dbTransform class in that internally it uses double precision
for the matrix elements, allowing any angle rotation and non-integer scaling.
Note that all coordinates after
transform are converted to integer database units; no grid snapping
is performed.
All of this code is based on the fact that a point with coordinates x, y can
be transformed by a transformation matrix T by:
[x', y', 1] = [x, y, 1]T
The transformation matrix for an offset (a,b) with no rotation or magnification can be described as
T = [ 1 0 0 ]
[ 0 1 0 ]
[ a b 1 ]
Rotations are e.g.
T90 = [ 0 1 0 ]
[ -1 0 0 ]
[ 0 0 1 ]
Construct a dbTransform with orientation angle, origin p and magnification scale . The orientation is specified in degrees.
Construct a dbTransform with orientation angle, origin p or x/y.The orientation is specified in degrees.
Construct a dbTransform with orientation angle, origin p and magnification scale . The orientation is specified in degrees.
Construct a dbTransform with orientation angle.
Construct a dbTransform with orientation R0.
Invert a transformation matrix
Transform a Rect by the inverse of the transformation matrix. Useful if you want to take a Rect and transform it into the coordinate space of an instance with a transform. For example if you want to find if any shapes in an instance overlap a search box for a top level cell, use the inverse transform of the search box on all the instance's shapes. This means doing just one transform of the search box rather than one transform for each shape in the instance.
Transform a Point by the inverse of the transformation matrix
Transform a Rect by the transformation matrix
Transform a Rect by the transformation matrix about a point origin.
Transform a Point by the transformation matrix
Transform a point by the transformation matrix about a point origin.
Transform an array of points of size size by the transformation matrix.
Transform an array of points of size size by the transformation matrix about a point origin.
Set the transformation origin.
Get the transformation origin.
Set the transformation matrix scale.
trans.setOrient(double angle)
Set the transformation angle. Any existing scale will be reset to 1.0
Returns True if the transformation is such that the objects XY coordinates would be swapped, e,g, if the object is R90.
Copyright © Peardrop Design 2016.