You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdegraphics/kooka/ocrword.h

112 lines
3.3 KiB

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