/******************************************************************************
 **	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