/****************************************************************************** ** Filename: xform2d.h ** Purpose: Definitions for using 2D point transformation library ** Author: Dan Johnson ** History: Fri Sep 22 09:57:08 1989, DSJ, Created. ** ** (c) Copyright Hewlett-Packard Company, 1988. ** Licensed under the Apache License, Version 2.0 (the "License"); ** you may not use this file except in compliance with the License. ** You may obtain a copy of the License at ** http://www.apache.org/licenses/LICENSE-2.0 ** Unless required by applicable law or agreed to in writing, software ** distributed under the License is distributed on an "AS IS" BASIS, ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. ** See the License for the specific language governing permissions and ** limitations under the License. ******************************************************************************/ #ifndef XFORM2D_H #define XFORM2D_H /**---------------------------------------------------------------------------- Include Files and Type Defines ----------------------------------------------------------------------------**/ #include "fpoint.h" typedef struct { FLOAT32 a, b, c, d, tx, ty; } MATRIX_2D, *MATRIX_2D_PTR; /**---------------------------------------------------------------------------- Macros ----------------------------------------------------------------------------**/ /* macros for initializing transform matrices */ #define InitMatrix(M) ((M)->a = 1, (M)->b = 0, \ (M)->c = 0, (M)->d = 1, \ (M)->tx = 0, (M)->ty = 0 ) #define CopyMatrix(A,B) ((B)->a = (A)->a, (B)->b = (A)->b, \ (B)->c = (A)->c, (B)->d = (A)->d, \ (B)->tx = (A)->tx, (B)->ty = (A)->ty) /* matrix scaling, translation, rotation, mirroring, etc.*/ #define TranslateMatrix(M,X,Y) ((M)->tx += (M)->a * (X) + (M)->c * (Y), \ (M)->ty += (M)->b * (X) + (M)->d * (Y) ) #define ScaleMatrix(M,X,Y) ((M)->a *= (X), (M)->b *= (X), \ (M)->c *= (Y), (M)->d *= (Y)) #define MirrorMatrixInX(M) (ScaleMatrix((M),-1,1)) #define MirrorMatrixInY(M) (ScaleMatrix((M),1,-1)) #define MirrorMatrixInXY(M) (ScaleMatrix((M),-1,-1)) /* using a matrix to map points*/ #define MapX(M,X,Y) ((M)->a * (X) + (M)->c * (Y) + (M)->tx) #define MapY(M,X,Y) ((M)->b * (X) + (M)->d * (Y) + (M)->ty) #define MapPoint(M,A,B) (Xof(B) = MapX (M, Xof(A), Yof(A)), \ Yof(B) = MapY (M, Xof(A), Yof(A))) #define MapDx(M,DX,DY) ((M)->a * (DX) + (M)->c * (DY)) #define MapDy(M,DX,DY) ((M)->b * (DX) + (M)->d * (DY)) /**---------------------------------------------------------------------------- Public Function Prototypes ----------------------------------------------------------------------------**/ void RotateMatrix(MATRIX_2D_PTR Matrix, FLOAT32 Angle); #endif