API reference - Class DTrans

Notation used in Ruby API documentation

Description: A simple transformation

Simple transformations only provide rotations about angles which a multiples of 90 degree. Together with the mirror options, this results in 8 distinct orientations (fixpoint transformations). These can be combined with a displacement which is applied after the rotation/mirror. This version acts on floating-point coordinates. A version for integer coordinates is Trans.

Here are some examples for using the DTrans class:

t = RBA::DTrans::new(0, 100)  # displacement by 100 DBU in y direction
# the inverse: -> "r0 0,-100"
t.inverted.to_s
# concatenation: -> "r90 -100,0"
(RBA::DTrans::new(RBA::DTrans::R90) * t).to_s
# apply to a point: -> "0,100"
RBA::DTrans::new(RBA::DTrans::R90).trans(RBA::DPoint::new(100, 0))

See The Database API for more details about the database objects.

Public constructors

new DTransnewCreates a unit transformation
new DTransnew(int f)Conversion constructor from a fixpoint transformation
new DTransnew(int rot,
bool mirr,
DPoint u)
The standard constructor using angle and mirror flag
new DTransnew(int rot,
bool mirr,
double x,
double y)
The standard constructor using angle and mirror flag and two coordinate values for displacement
new DTransnew(int f,
const DPoint u)
The standard constructor using a code rather than angle and mirror
new DTransnew(int f,
double x,
double y)
The standard constructor using a code rather than angle and mirror and two coordinate values for displacement
new DTransnew(const DPoint u)The standard constructor using a displacement only
new DTransnew(double x,
double y)
The standard constructor using a displacement given as two coordinates

Public methods

[const]bool!=(const DTrans other)Inequality test
[const]DTrans*(const DTrans *)Multiplication (concatenation) of transformations
[const]bool<(const DTrans other)A sorting criterion
[const]bool==(const DTrans other)Equality test
[const]intangleGets the angle in units of 90 degree
voidangle=(int a)Sets the angle in units of 90 degree
[const]voidassign(const DTrans other)Assign the contents of another object to self
voidcreateEnsures the C++ object is created
[const]doublectrans(double d)The transformation of a distance
voiddestroyExplicitly destroy the object
[const]booldestroyed?Returns a value indicating whether the object was already destroyed
[const]DPointdispAccessor to the point
voiddisp=(const DPoint u)Sets the displacement
[const]DTransdupCreates a copy of self
DTransinvertIn-place inversion
[const]DTransinvertedInversion
[const]boolis_const_object?Returns a value indicating whether the reference is a const reference
[const]boolis_mirror?Gets the mirror flag
voidmirror=(bool m)Sets the mirror flag
[const]introtGets the angle/mirror code
voidrot=(int r)Sets the angle/mirror code
[const]stringto_sString conversion
[const]DPointtrans(const DPoint p)The transformation of a point

Public static methods and constants

intM0Angle/mirror code for the "mirrored at the x-axis" transformation
intM135Angle/mirror code for the "mirrored at the 135 degree axis" transformation
intM45Angle/mirror code for the "mirrored at the 45 degree axis" transformation
intM90Angle/mirror code for the "mirrored at the y (90 degree) axis" transformation
intR0Angle/mirror code for the "unrotated" transformation
intR180Angle/mirror code for the "rotated by 180 degree counterclockwise" transformation
intR270Angle/mirror code for the "rotated by 270 degree counterclockwise" transformation
intR90Angle/mirror code for the "rotated by 90 degree counterclockwise" transformation
DTransfrom_itrans(const Trans int_trans)Conversion constructor from an integer coordinate transformation
new DTransfrom_s(string s)Creates an object from a string

Deprecated methods (protected, public, static, non-static and constructors)

[static]intm0Use of this method is deprecated. Use M0 instead
[static]intm135Use of this method is deprecated. Use M135 instead
[static]intm45Use of this method is deprecated. Use M45 instead
[static]intm90Use of this method is deprecated. Use M90 instead
[static]new DTransnew_f(int f)Use of this method is deprecated. Use new instead
[static]new DTransnew_fu(int f,
const DPoint u)
Use of this method is deprecated. Use new instead
[static]new DTransnew_fxy(int f,
double x,
double y)
Use of this method is deprecated. Use new instead
[static]new DTransnew_rmu(int rot,
bool mirr,
DPoint u)
Use of this method is deprecated. Use new instead
[static]new DTransnew_rmxy(int rot,
bool mirr,
double x,
double y)
Use of this method is deprecated. Use new instead
[static]new DTransnew_u(const DPoint u)Use of this method is deprecated. Use new instead
[static]new DTransnew_xy(double x,
double y)
Use of this method is deprecated. Use new instead
[static]intr0Use of this method is deprecated. Use R0 instead
[static]intr180Use of this method is deprecated. Use R180 instead
[static]intr270Use of this method is deprecated. Use R270 instead
[static]intr90Use of this method is deprecated. Use R90 instead

Detailed description

[const] bool !=(const DTrans other)

Description: Inequality test

[const] DTrans *(const DTrans *)

Description: Multiplication (concatenation) of transformations

t:The transformation to apply before
Returns:The modified transformation

The * operator returns self*t ("t is applied before this transformation").

[const] bool <(const DTrans other)

Description: A sorting criterion

This method is provided to implement a sorting order. The definition of 'less' is opaque and might change in future versions.

[const] bool ==(const DTrans other)

Description: Equality test

[static] int M0

Description: Angle/mirror code for the "mirrored at the x-axis" transformation

[static] int M135

Description: Angle/mirror code for the "mirrored at the 135 degree axis" transformation

[static] int M45

Description: Angle/mirror code for the "mirrored at the 45 degree axis" transformation

[static] int M90

Description: Angle/mirror code for the "mirrored at the y (90 degree) axis" transformation

[static] int R0

Description: Angle/mirror code for the "unrotated" transformation

[static] int R180

Description: Angle/mirror code for the "rotated by 180 degree counterclockwise" transformation

[static] int R270

Description: Angle/mirror code for the "rotated by 270 degree counterclockwise" transformation

[static] int R90

Description: Angle/mirror code for the "rotated by 90 degree counterclockwise" transformation

[const] int angle

Description: Gets the angle in units of 90 degree

This value delivers the rotation component. In addition, a mirroring at the x axis may be applied before if the is_mirror? property is true.

void angle=(int a)

Description: Sets the angle in units of 90 degree

a:The new angle

This method was introduced in version 0.20.

[const] void assign(const DTrans other)

Description: Assign the contents of another object to self

This method assigns the contents of another object to self. This is a deep copy that does not only copy the reference but the actual content.

void create

Description: Ensures the C++ object is created

Use this method to ensure the C++ object is created, for example to ensure that resources are allocated. Usually C++ objects are created on demand and not necessarily when the script object is created.

[const] double ctrans(double d)

Description: The transformation of a distance

d:The distance to transform
Returns:The transformed distance

The "ctrans" method transforms the given distance. e = t(d). For the simple transformations, there is no magnification and no modification of the distance therefore.

void destroy

Description: Explicitly destroy the object

Explicitly destroy the object on C++ side if it was owned by the Ruby interpreter. Subsequent access to this object will throw an exception. If the object is not owned by Ruby, this method will do nothing.

[const] bool destroyed?

Description: Returns a value indicating whether the object was already destroyed

This method returns true, if the object was destroyed, either explicitly or by the C++ side. The latter may happen, if the object is owned by a C++ object which got destroyed itself.

[const] DPoint disp

Description: Accessor to the point

void disp=(const DPoint u)

Description: Sets the displacement

u:The new displacement

This method was introduced in version 0.20.

[const] DTrans dup

Description: Creates a copy of self

[static] DTrans from_itrans(const Trans int_trans)

Description: Conversion constructor from an integer coordinate transformation

[static] new DTrans from_s(string s)

Description: Creates an object from a string

Creates the object from a string representation (as returned by to_s)

This method has been added in version 0.23.

DTrans invert

Description: In-place inversion

Returns:The inverted transformation

Inverts the transformation and replaces this object by the inverted one.

[const] DTrans inverted

Description: Inversion

Returns:The inverted transformation

Returns the inverted transformation

[const] bool is_const_object?

Description: Returns a value indicating whether the reference is a const reference

This method returns true, if self is a const reference. In that case, only const methods may be called on self.

[const] bool is_mirror?

Description: Gets the mirror flag

If this property is true, the transformation is composed of a mirroring at the x-axis followed by a rotation by the angle given by the angle property.

[static] int m0

Description: Angle/mirror code for the "mirrored at the x-axis" transformation

This method is deprecated. Use method 'M0' instead

[static] int m135

Description: Angle/mirror code for the "mirrored at the 135 degree axis" transformation

This method is deprecated. Use method 'M135' instead

[static] int m45

Description: Angle/mirror code for the "mirrored at the 45 degree axis" transformation

This method is deprecated. Use method 'M45' instead

[static] int m90

Description: Angle/mirror code for the "mirrored at the y (90 degree) axis" transformation

This method is deprecated. Use method 'M90' instead

void mirror=(bool m)

Description: Sets the mirror flag

m:The new mirror flag

"mirroring" describes a reflection at the x-axis which is included in the transformation prior to rotation.

This method was introduced in version 0.20.

[static] new DTrans new

Description: Creates a unit transformation

[static] new DTrans new(int f)

Description: Conversion constructor from a fixpoint transformation

f:The rotation/mirror code (R0 .. M135 constants)

This constructor will create a transformation with a fixpoint transformation but no displacement.

[static] new DTrans new(int rot,bool mirr,DPoint u)

Description: The standard constructor using angle and mirror flag

rot:The rotation in units of 90 degree
mirrx:True, if mirrored at x axis
u:The displacement

The sequence of operations is: mirroring at x axis, rotation, application of displacement.

[static] new DTrans new(int rot,bool mirr,double x,double y)

Description: The standard constructor using angle and mirror flag and two coordinate values for displacement

rot:The rotation in units of 90 degree
mirrx:True, if mirrored at x axis
x:The horizontal displacement
y:The vertical displacement

The sequence of operations is: mirroring at x axis, rotation, application of displacement.

[static] new DTrans new(int f,const DPoint u)

Description: The standard constructor using a code rather than angle and mirror

f:The rotation/mirror code (R0 .. M135 constants)
u:The displacement

[static] new DTrans new(int f,double x,double y)

Description: The standard constructor using a code rather than angle and mirror and two coordinate values for displacement

f:The rotation/mirror code (R0 .. M135 constants)
x:The horizontal displacement
y:The vertical displacement

[static] new DTrans new(const DPoint u)

Description: The standard constructor using a displacement only

u:The displacement

[static] new DTrans new(double x,double y)

Description: The standard constructor using a displacement given as two coordinates

x:The horizontal displacement
y:The vertical displacement

[static] new DTrans new_f(int f)

Description: Conversion constructor from a fixpoint transformation

f:The rotation/mirror code (R0 .. M135 constants)

This method is deprecated. Use method 'new' instead

[static] new DTrans new_fu(int f,const DPoint u)

Description: The standard constructor using a code rather than angle and mirror

f:The rotation/mirror code (R0 .. M135 constants)
u:The displacement

This method is deprecated. Use method 'new' instead

[static] new DTrans new_fxy(int f,double x,double y)

Description: The standard constructor using a code rather than angle and mirror and two coordinate values for displacement

f:The rotation/mirror code (R0 .. M135 constants)
x:The horizontal displacement
y:The vertical displacement

This method is deprecated. Use method 'new' instead

[static] new DTrans new_rmu(int rot,bool mirr,DPoint u)

Description: The standard constructor using angle and mirror flag

rot:The rotation in units of 90 degree
mirrx:True, if mirrored at x axis
u:The displacement

This method is deprecated. Use method 'new' instead

[static] new DTrans new_rmxy(int rot,bool mirr,double x,double y)

Description: The standard constructor using angle and mirror flag and two coordinate values for displacement

rot:The rotation in units of 90 degree
mirrx:True, if mirrored at x axis
x:The horizontal displacement
y:The vertical displacement

This method is deprecated. Use method 'new' instead

[static] new DTrans new_u(const DPoint u)

Description: The standard constructor using a displacement only

u:The displacement

This method is deprecated. Use method 'new' instead

[static] new DTrans new_xy(double x,double y)

Description: The standard constructor using a displacement given as two coordinates

x:The horizontal displacement
y:The vertical displacement

This method is deprecated. Use method 'new' instead

[static] int r0

Description: Angle/mirror code for the "unrotated" transformation

This method is deprecated. Use method 'R0' instead

[static] int r180

Description: Angle/mirror code for the "rotated by 180 degree counterclockwise" transformation

This method is deprecated. Use method 'R180' instead

[static] int r270

Description: Angle/mirror code for the "rotated by 270 degree counterclockwise" transformation

This method is deprecated. Use method 'R270' instead

[static] int r90

Description: Angle/mirror code for the "rotated by 90 degree counterclockwise" transformation

This method is deprecated. Use method 'R90' instead

[const] int rot

Description: Gets the angle/mirror code

The angle/mirror code is one of the constants R0, R90, R180, R270, M0, M45, M90 and M135. rx is the rotation by an angle of x counter clockwise. mx is the mirroring at the axis given by the angle x (to the x-axis).

void rot=(int r)

Description: Sets the angle/mirror code

r:The new angle/rotation code (see rot property)

This method was introduced in version 0.20.

[const] string to_s

Description: String conversion

[const] DPoint trans(const DPoint p)

Description: The transformation of a point

p:The point to transform
Returns:The transformed point

The "trans" method transforms the given point. q = t(p)