okular/core/page.h
Enrico Ros f4b94c016d SEARCH CHANGES: absolutely want to get in those fixes before freeze.
fixed multiple selections on page bugs.
next commits will come tomorrow.

svn path=/trunk/kdegraphics/kpdf/; revision=385045
2005-02-01 18:26:56 +00:00

145 lines
4.9 KiB
C++

/***************************************************************************
* 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_
#include <qmap.h>
#include <qvaluelist.h>
class QPixmap;
class QRect;
class TextPage;
class KPDFPageRect;
class KPDFPageTransition;
class HighlightRect;
/**
* @short Collector for all the data belonging to a page.
*
* The KPDFPage class contains pixmaps (referenced using observers id as key),
* a search page (a class used internally for retrieving text), rect classes
* (that describe links or other active areas in the current page) and more.
*
* Note: All objects are reparented to this class.
*/
class KPDFPage
{
public:
KPDFPage( uint number, float width, float height, int rotation );
~KPDFPage();
enum KPDFPageAttributes { Bookmark = 1, Highlights = 2 };
// query properties (const read-only methods)
inline int number() const { return m_number; }
inline int rotation() const { return m_rotation; }
inline float width() const { return m_width; }
inline float height() const { return m_height; }
inline float ratio() const { return m_height / m_width; }
inline bool hasBookmark() const { return m_bookmarked; }
inline bool hasHighlights() const { return !m_highlights.isEmpty(); }
bool hasPixmap( int id, int width = -1, int height = -1 ) const;
bool hasSearchPage() const;
bool hasRect( int mouseX, int mouseY ) const;
bool hasLink( int mouseX, int mouseY ) const;
const KPDFPageRect * getRect( int mouseX, int mouseY ) const;
// - HL? .. -
const KPDFPageTransition * getTransition() const;
const QString getTextInRect( const QRect & rect, double zoom /*= 1.0*/ ) const;
// operations (by KPDFDocument)
inline void setBookmark( bool state ) { m_bookmarked = state; }
HighlightRect * searchText( const QString & text,
bool strictCase, HighlightRect * lastPosition = 0 );
// oprations: set/delete contents (by KPDFDocument)
void setPixmap( int id, QPixmap * pixmap );
void setSearchPage( TextPage * text );
void setRects( const QValueList< KPDFPageRect * > rects );
void setHighlight( HighlightRect * hr, bool add = true );
void setTransition( const KPDFPageTransition * transition );
void deletePixmap( int id );
void deletePixmapsAndRects();
void deleteHighlights( int id = -1 );
private:
friend class PagePainter;
int m_number, m_rotation;
float m_width, m_height;
bool m_bookmarked;
QMap< int, QPixmap * > m_pixmaps;
TextPage * m_text;
QValueList< KPDFPageRect * > m_rects;
QValueList< HighlightRect * > m_highlights;
const KPDFPageTransition * m_transition;
};
/**
* @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;
// 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;
};
// TODO: comment this
struct HighlightRect
{
// publicly accessed fields
int id;
double left, top, right, bottom;
QColor color;
// initialize default values
HighlightRect();
HighlightRect( double l, double t, double r, double b );
};
#endif