/**********************************************************************
* File: normalis.h (Formerly denorm.h)
* Description: Code for the DENORM class.
* Author: Ray Smith
* Created: Thu Apr 23 09:22:43 BST 1992
*
* (C) Copyright 1992, Hewlett-Packard Ltd.
** 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 NORMALIS_H
#define NORMALIS_H
#include <stdio.h>
class ROW; //forward decl
class BLOCK;
class DENORM_SEG
{
public:
DENORM_SEG() {
} //empty
inT32 xstart; //start of segment
inT32 ycoord; //y at segment
float scale_factor; //for this segment
};
class DENORM
{
public:
DENORM() { //constructor
source_row = NULL;
x_centre = 0.0f;
scale_factor = 1.0f;
segments = 0;
segs = NULL;
base_is_row = TRUE;
m = c = 0;
block_ = NULL;
}
DENORM( //constructor
float x, //from same pieces
float scaling,
ROW *src) {
x_centre = x; //just copy
scale_factor = scaling;
source_row = src;
segments = 0;
segs = NULL;
base_is_row = TRUE;
m = c = 0;
block_ = NULL;
}
DENORM( //constructor
float x, //from same pieces
float scaling,
double line_m, //default line //no of segments
double line_c,
inT16 seg_count,
DENORM_SEG *seg_pts, //actual segments
BOOL8 using_row, //as baseline
ROW *src);
DENORM(const DENORM &);
DENORM & operator= (const DENORM &);
~DENORM () {
if (segments > 0)
delete[]segs;
}
float origin() const { //get x centre
return x_centre;
}
float scale() const { //get scale
return scale_factor;
}
ROW *row() const { //get row
return source_row;
}
const BLOCK* block() const {
return block_;
}
void set_block(const BLOCK* block) {
block_ = block;
}
float x( //convert an xcoord
float src_x) const;
float y( //convert a ycoord
float src_y, //coord to convert
float src_centre) const; //normed x centre
float scale_at_x( // Return scaling at this coord.
float src_x) const;
float yshift_at_x( // Return yshift at this coord.
float src_x) const;
private:
const DENORM_SEG *binary_search_segment(float src_x) const;
BOOL8 base_is_row; //using row baseline?
inT16 segments; //no of segments
double c, m; //baseline
float x_centre; //middle of word
float scale_factor; //scaling
ROW *source_row; //row it came from
DENORM_SEG *segs; //array of segments
const BLOCK* block_; // Block the word came from.
};
#endif