mirror of
https://github.com/tesseract-ocr/tesseract.git
synced 2024-11-29 14:31:11 +08:00
425d593ebe
git-svn-id: https://tesseract-ocr.googlecode.com/svn/trunk/trunk@2 d0cd1f9f-072b-0410-8dd7-cf729c803f20
70 lines
2.8 KiB
C
70 lines
2.8 KiB
C
/******************************************************************************
|
|
** 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
|