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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
|
/*
* This file is part of the HTML widget for KDE.
*
* Copyright (C) 1999-2003 Lars Knoll (knoll@kde.org)
* (C) 2005 Allan Sandfeld Jensen (kde@carewolf.com)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Library General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Library General Public License for more details.
*
* You should have received a copy of the GNU Library General Public License
* along with this library; see the file COPYING.LIB. If not, write to
* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
*/
#ifndef render_canvas_h
#define render_canvas_h
#include "render_block.h"
class KHTMLView;
class QScrollView;
namespace khtml {
class RenderPage;
class RenderStyle;
enum CanvasMode {
CanvasViewPort, // Paints inside a viewport
CanvasPage, // Paints one page
CanvasDocument // Paints the whole document
};
class RenderCanvas : public RenderBlock
{
public:
RenderCanvas(DOM::NodeImpl* node, KHTMLView *view);
~RenderCanvas();
virtual const char *renderName() const { return "RenderCanvas"; }
virtual bool isCanvas() const { return true; }
virtual void setStyle(RenderStyle *style);
virtual void layout();
virtual void calcWidth();
virtual void calcHeight();
virtual void calcMinMaxWidth();
virtual bool absolutePosition(int &xPos, int&yPos, bool f = false) const;
int docHeight() const;
int docWidth() const;
KHTMLView *view() const { return m_view; }
virtual void repaint(Priority p=NormalPriority);
virtual void repaintRectangle(int x, int y, int w, int h, Priority p=NormalPriority, bool f=false);
void repaintViewRectangle(int x, int y, int w, int h, bool asap=false);
bool needsFullRepaint() const;
void deferredRepaint( RenderObject* o );
void scheduleDeferredRepaints();
virtual void paint(PaintInfo&, int tx, int ty);
virtual void paintBoxDecorations(PaintInfo& paintInfo, int _tx, int _ty);
virtual void setSelection(RenderObject *s, int sp, RenderObject *e, int ep);
virtual void clearSelection(bool doRepaint=true);
virtual RenderObject *selectionStart() const { return m_selectionStart; }
virtual RenderObject *selectionEnd() const { return m_selectionEnd; }
void setPrintImages(bool enable) { m_printImages = enable; }
bool printImages() const { return m_printImages; }
void setCanvasMode(CanvasMode mode) { m_canvasMode = mode; }
CanvasMode canvasMode() const { return m_canvasMode; }
void setPagedMode(bool b) { m_pagedMode = b; }
void setStaticMode(bool b) { m_staticMode = b; }
bool pagedMode() const { return m_pagedMode; }
bool staticMode() const { return m_staticMode; }
void setPageTop(int top) {
m_pageTop = top;
// m_y = top;
}
void setPageBottom(int bottom) { m_pageBottom = bottom; }
int pageTop() const { return m_pageTop; }
int pageBottom() const { return m_pageBottom; }
int pageTopAfter(int y) const {
if (pageHeight() == 0) return 0;
return (y / pageHeight() + 1) * pageHeight() ;
}
int crossesPageBreak(int top, int bottom) const {
if (pageHeight() == 0) return false;
int pT = top / pageHeight();
// bottom is actually the first line not in the box
int pB = (bottom-1) / pageHeight();
return (pT == pB) ? 0 : (pB + 1);
}
void setPageNumber(int number) { m_pageNr = number; }
int pageNumber() const { return m_pageNr; }
public:
virtual void setWidth( int width ) { m_rootWidth = m_width = width; }
virtual void setHeight( int height ) { m_rootHeight = m_height = height; }
// void setPageHeight( int height ) { m_viewportHeight = m_pageHeight = height; }
int pageHeight() const { return m_pageBottom - m_pageTop; }
int viewportWidth() const { return m_viewportWidth; }
int viewportHeight() const { return m_viewportHeight; }
RenderPage* page();
QRect selectionRect() const;
void setMaximalOutlineSize(int o) { m_maximalOutlineSize = o; }
int maximalOutlineSize() const { return m_maximalOutlineSize; }
void setNeedsWidgetMasks( bool b=true) { m_needsWidgetMasks = b; }
bool needsWidgetMasks() const { return m_needsWidgetMasks; }
void updateDocSizeAfterLayerTranslation( RenderObject* o, bool posXOffset, bool posYOffset );
protected:
// makes sure document, scrollbars and viewport size are accurate
void updateDocumentSize();
// internal setters for cached values of document width/height
// Setting to -1/-1 invalidates the cache.
void setCachedDocWidth(int w ) { m_cachedDocWidth = w; }
void setCachedDocHeight(int h) { m_cachedDocHeight = h; }
virtual void selectionStartEnd(int& spos, int& epos);
virtual QRect viewRect() const;
KHTMLView *m_view;
RenderObject* m_selectionStart;
RenderObject* m_selectionEnd;
int m_selectionStartPos;
int m_selectionEndPos;
CanvasMode m_canvasMode;
int m_rootWidth;
int m_rootHeight;
int m_viewportWidth;
int m_viewportHeight;
int m_cachedDocWidth;
int m_cachedDocHeight;
bool m_printImages;
bool m_needsFullRepaint;
// Canvas is not interactive
bool m_staticMode;
// Canvas is paged
bool m_pagedMode;
// Canvas contains overlaid widgets
bool m_needsWidgetMasks;
short m_pageNr;
int m_pageTop;
int m_pageBottom;
RenderPage* m_page;
int m_maximalOutlineSize; // Used to apply a fudge factor to dirty-rect checks on blocks/tables.
QValueList<RenderObject*> m_dirtyChildren;
};
inline RenderCanvas* RenderObject::canvas() const
{
return static_cast<RenderCanvas*>(document()->renderer());
}
// Represents the page-context of CSS
class RenderPage
{
public:
RenderPage(RenderCanvas* canvas) : m_canvas(canvas),
m_marginTop(0), m_marginBottom(0),
m_marginLeft(0), m_marginRight(0),
m_pageWidth(0), m_pageHeight(0),
m_fixedSize(false)
{
m_style = new RenderPageStyle();
}
virtual ~RenderPage()
{
delete m_style;
}
int marginTop() const { return m_marginTop; }
int marginBottom() const { return m_marginBottom; }
int marginLeft() const { return m_marginLeft; }
int marginRight() const { return m_marginRight; }
void setMarginTop(int margin) { m_marginTop = margin; }
void setMarginBottom(int margin) { m_marginBottom = margin; }
void setMarginLeft(int margin) { m_marginLeft = margin; }
void setMarginRight(int margin) { m_marginRight = margin; }
int pageWidth() const { return m_pageWidth; }
int pageHeight() const { return m_pageHeight; }
void setPageSize(int width, int height) {
m_pageWidth = width;
m_pageHeight = height;
}
// Returns true if size was set by document, false if set by user-agent
bool fixedSize() const { return m_fixedSize; }
void setFixedSize(bool b) { m_fixedSize = b; }
RenderPageStyle* style() { return m_style; }
const RenderPageStyle* style() const { return m_style; }
protected:
RenderCanvas* m_canvas;
RenderPageStyle* m_style;
int m_marginTop;
int m_marginBottom;
int m_marginLeft;
int m_marginRight;
int m_pageWidth;
int m_pageHeight;
bool m_fixedSize;
};
}
#endif
|