blob: 5fbc209e3f973380aad988d41f0d8a0133a41bf1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
|
/***************************************************************************
ocrword.h - ocr-result word and wordlist
-------------------
begin : Fri 10 Jan 2003
copyright : (C) 2003 by Klaas Freitag
email : freitag@suse.de
***************************************************************************/
/***************************************************************************
* *
* This file may be distributed and/or modified under the terms of the *
* GNU General Public License version 2 as published by the Free Software *
* Foundation and appearing in the file COPYING included in the *
* packaging of this file. *
*
* As a special exception, permission is given to link this program *
* with any version of the KADMOS ocr/icr engine of reRecognition GmbH, *
* Kreuzlingen and distribute the resulting executable without *
* including the source code for KADMOS in the source distribution. *
*
* As a special exception, permission is given to link this program *
* with any edition of TQt, and distribute the resulting executable, *
* without including the source code for TQt in the source distribution. *
* *
***************************************************************************/
#ifndef _OCR_WORD_
#define _OCR_WORD_
#include <tqstringlist.h>
#include <tqvaluevector.h>
#include <tqvaluelist.h>
#include <tqrect.h>
class TQString;
class TQRect;
/* ==== ocrWord ====================================== */
class ocrWord : public TQString
{
public:
ocrWord(const TQString& s);
ocrWord();
TQStringList getAlternatives()
{ return m_alternatives; }
void setAlternatives( const TQString& s )
{ m_alternatives.append(s); }
// TQRect boundingRect();
void setKnode( int k )
{ m_startKnode = k; }
void setLine( int l )
{ m_line = l; }
int getLine() const { return m_line; }
int getKnode() const { return m_startKnode; }
void setRect( const TQRect& r )
{ m_position = r; }
TQRect rect()
{ return m_position; }
private:
TQStringList m_alternatives;
int m_startKnode;
int m_line;
TQRect m_position;
};
/* ==== ocrWordList ====================================== */
/**
* This represents a line of words in an ocr'ed document
*/
class ocrWordList : public TQValueList<ocrWord>
{
public:
ocrWordList();
TQStringList stringList();
bool updateOCRWord( const TQString& from, const TQString& to );
bool findFuzzyIndex( const TQString& word, ocrWord& resWord );
TQRect wordListRect( );
void setBlock( int b );
int block() const { return m_block; }
private:
int m_block;
};
/**
* All lines of a block: A value vector containing as much as entries
* as lines are available in a block. Needs to be resized acordingly.
*/
typedef TQValueVector<ocrWordList> ocrBlock;
/**
* Blocks taken together form the page.
* Attention: Needs to be resized to the amount of blocks !!
*/
typedef TQValueVector<ocrBlock> ocrBlockPage;
typedef TQValueVector<TQRect> rectList;
#endif
|