2004-09-08 12:41:14 +00:00
|
|
|
/***************************************************************************
|
|
|
|
* Copyright (C) 2004 by Enrico Ros <eros.kde@email.it> *
|
|
|
|
* *
|
|
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU General Public License as published by *
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
|
|
* (at your option) any later version. *
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
#ifndef _KPDF_PAGE_H_
|
|
|
|
#define _KPDF_PAGE_H_
|
|
|
|
|
2004-10-02 14:30:30 +00:00
|
|
|
#include <qmap.h>
|
|
|
|
#include <qvaluelist.h>
|
|
|
|
|
2004-09-10 17:44:05 +00:00
|
|
|
class QPainter;
|
2004-09-15 20:45:00 +00:00
|
|
|
class QPixmap;
|
2004-09-16 21:04:49 +00:00
|
|
|
class TextPage;
|
2004-12-10 16:04:45 +00:00
|
|
|
class KPDFPageRect;
|
2004-09-08 12:41:14 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @short Collector for all the data belonging to a page.
|
2004-11-07 14:15:33 +00:00
|
|
|
* ### MERGE: definition and implementation must be moved to kpdfpage.h/.cpp
|
2004-12-10 16:04:45 +00:00
|
|
|
* ### RECOMMENT
|
2004-09-08 12:41:14 +00:00
|
|
|
*
|
2004-09-15 20:45:00 +00:00
|
|
|
* The KPDFPage class contains pixmaps (referenced using obsedvers id as key),
|
|
|
|
* a search page (a class used internally for searching data), link classes
|
|
|
|
* (that describe links in the current page) plus graphics overlays and more.
|
|
|
|
*
|
|
|
|
* Note: All objects passed to this class will be destoryed on class deletion.
|
2004-09-08 12:41:14 +00:00
|
|
|
*/
|
2004-09-10 17:44:05 +00:00
|
|
|
class KPDFPage
|
2004-09-08 12:41:14 +00:00
|
|
|
{
|
2004-11-06 00:56:55 +00:00
|
|
|
public:
|
|
|
|
KPDFPage( uint number, float width, float height, int rotation );
|
|
|
|
~KPDFPage();
|
|
|
|
|
|
|
|
enum KPDFPageAttributes { Highlight = 1, Bookmark = 2 };
|
|
|
|
|
|
|
|
// query properties (const read-only methods)
|
|
|
|
inline int number() const { return m_number; }
|
|
|
|
inline int rotation() const { return m_rotation; }
|
|
|
|
inline int attributes() const { return m_attributes; }
|
|
|
|
inline float width() const { return m_width; }
|
|
|
|
inline float height() const { return m_height; }
|
|
|
|
inline float ratio() const { return m_height / m_width; }
|
|
|
|
|
2004-12-21 12:38:52 +00:00
|
|
|
bool hasPixmap( int id, int width = -1, int height = -1 ) const;
|
2004-12-10 16:04:45 +00:00
|
|
|
bool hasSearchPage() const;
|
|
|
|
bool hasRect( int mouseX, int mouseY ) const;
|
|
|
|
const KPDFPageRect * getRect( int mouseX, int mouseY ) const;
|
2004-11-06 00:56:55 +00:00
|
|
|
const QString getTextInRect( const QRect & rect, double zoom = 1.0 ) const;
|
|
|
|
|
2004-11-12 10:58:33 +00:00
|
|
|
// operations (by KPDFDocument)
|
2004-11-06 00:56:55 +00:00
|
|
|
inline void setAttribute( int att ) { m_attributes |= att; }
|
|
|
|
inline void clearAttribute( int att ) { m_attributes &= ~att; }
|
|
|
|
inline void toggleAttribute( int att ) { m_attributes ^= att; }
|
|
|
|
bool hasText( const QString & text, bool strictCase, bool fromTop );
|
|
|
|
|
2004-12-21 12:38:52 +00:00
|
|
|
// set/delete contents (by KPDFDocument)
|
2004-11-06 00:56:55 +00:00
|
|
|
void setPixmap( int id, QPixmap * pixmap );
|
|
|
|
void setSearchPage( TextPage * text );
|
2004-12-10 16:04:45 +00:00
|
|
|
void setRects( const QValueList< KPDFPageRect * > rects );
|
2004-12-21 12:38:52 +00:00
|
|
|
void deletePixmap( int id );
|
2004-12-10 16:04:45 +00:00
|
|
|
void deletePixmapsAndRects();
|
2004-11-06 00:56:55 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
friend class PagePainter;
|
|
|
|
int m_number, m_rotation, m_attributes;
|
|
|
|
float m_width, m_height;
|
|
|
|
double m_sLeft, m_sTop, m_sRight, m_sBottom;
|
|
|
|
|
|
|
|
QMap< int, QPixmap * > m_pixmaps;
|
|
|
|
TextPage * m_text;
|
2004-12-10 16:04:45 +00:00
|
|
|
QValueList< KPDFPageRect * > m_rects;
|
2004-09-08 12:41:14 +00:00
|
|
|
};
|
2004-10-02 14:30:30 +00:00
|
|
|
|
2004-12-10 16:04:45 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @short A rect on the page that may contain an object.
|
|
|
|
*
|
|
|
|
* This class describes a rect (geometrical coordinates) and may hold a
|
|
|
|
* pointer to an associated object. An object is reparented to this class
|
|
|
|
* and deleted when this class is deleted.
|
|
|
|
*
|
|
|
|
* Objects are stored and read as 'void pointers' so you have to perform
|
|
|
|
* the cast on the code that handles the object using information provided
|
|
|
|
* by pointerType().
|
|
|
|
*
|
|
|
|
* Type / Class correspondency tab:
|
|
|
|
* - NoPointer : '' : no object is stored
|
|
|
|
* - Link : class KPDFLink : description of a link
|
|
|
|
* - Image : class KPDFImage : description of an image
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
class KPDFPageRect
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
KPDFPageRect( int left, int top, int right, int bottom );
|
|
|
|
~KPDFPageRect();
|
|
|
|
|
|
|
|
// query geometric properties
|
|
|
|
bool contains( int x, int y ) const;
|
|
|
|
QRect geometry() const; //TODO add intersects( qrect )
|
|
|
|
|
|
|
|
// set a pointer to data associated to this rect
|
|
|
|
enum PointerType { NoPointer, Link, Image };
|
|
|
|
void setPointer( void * object, enum PointerType pType );
|
|
|
|
|
|
|
|
// query type and get a const pointer to the stored object
|
|
|
|
PointerType pointerType() const;
|
|
|
|
const void * pointer() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
void deletePointer();
|
|
|
|
int m_xMin, m_xMax, m_yMin, m_yMax;
|
|
|
|
PointerType m_pointerType;
|
|
|
|
void * m_pointer;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
2004-11-07 14:15:33 +00:00
|
|
|
/**
|
|
|
|
* @short Paints a KPDFPage to an open painter using given flags.
|
|
|
|
* ### MERGE: since this file will be empty, we might consider renaming
|
|
|
|
* ### definition and implementation to pagepainter.*
|
|
|
|
*/
|
2004-11-06 00:56:55 +00:00
|
|
|
class PagePainter
|
|
|
|
{
|
|
|
|
public:
|
2004-11-07 14:15:33 +00:00
|
|
|
// list of flags passed to the painting function. by OR-ing those flags
|
|
|
|
// you can decide wether or not to permit drawing of a certain feature.
|
|
|
|
enum PagePainterFlags { Accessibility = 1, EnhanceLinks = 2,
|
2004-12-10 16:04:45 +00:00
|
|
|
EnhanceImages = 4, Highlight = 8 };
|
2004-11-07 14:15:33 +00:00
|
|
|
|
|
|
|
// draw (using painter 'p') the 'page' requested by 'id' using features
|
|
|
|
// in 'flags'. 'limits' is the bounding rect of the paint operation,
|
|
|
|
// 'width' and 'height' the expected size of page contents (used only
|
|
|
|
// to pick up an alternative pixmap if the pixmap of 'id' is missing.
|
|
|
|
static void paintPageOnPainter( const KPDFPage * page, int id, int flags,
|
2004-11-06 00:56:55 +00:00
|
|
|
QPainter * p, const QRect & limits, int width = -1, int height = -1 );
|
|
|
|
};
|
|
|
|
|
2004-09-08 12:41:14 +00:00
|
|
|
#endif
|