File: WebLayerTreeViewClient.h

package info (click to toggle)
qtwebkit 2.3.4.dfsg-9.1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 290,564 kB
  • ctags: 273,642
  • sloc: cpp: 1,417,509; python: 85,048; ansic: 39,357; perl: 38,862; ruby: 10,313; objc: 9,505; xml: 8,679; asm: 3,864; yacc: 2,458; sh: 1,237; lex: 813; makefile: 592; java: 228; php: 79
file content (107 lines) | stat: -rw-r--r-- 4,702 bytes parent folder | download | duplicates (3)
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
/*
 * Copyright (C) 2011 Google Inc. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1.  Redistributions of source code must retain the above copyright
 *     notice, this list of conditions and the following disclaimer.
 * 2.  Redistributions in binary form must reproduce the above copyright
 *     notice, this list of conditions and the following disclaimer in the
 *     documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#ifndef WebLayerTreeViewClient_h
#define WebLayerTreeViewClient_h

class SkBitmap;

namespace WebKit {
class WebCompositorOutputSurface;
class WebInputHandler;
class WebThread;
struct WebRect;
struct WebSize;

class WebLayerTreeViewClient {
public:
    // Indicates to the embedder that the compositor is about to begin a
    // frame. This is is a signal to flow control mechanisms that a frame is
    // beginning. This call will be followed by updateAnimations and then
    // layout, which should be used for actual animation or tree manipulation
    // tasks.  FIXME: make pure virtual once upstream deps are satisfied.
    virtual void willBeginFrame() { }

    // Indicates that main thread tasks associated with frame rendering have completed.
    // Issued unconditionally, even if the context was lost in the process.
    virtual void didBeginFrame() { }

    // Updates animation and layout. These are called before the compositing
    // pass so that layers can be updated at the given frame time.
    virtual void updateAnimations(double monotonicFrameBeginTime) = 0;
    virtual void layout() = 0;

    // Applies a scroll delta to the root layer, which is bundled with a page
    // scale factor that may apply a CSS transform on the whole document (used
    // for mobile-device pinch zooming). This is triggered by events sent to the
    // compositor thread through the WebCompositor interface.
    virtual void applyScrollAndScale(const WebSize& scrollDelta, float scaleFactor) = 0;

    // Creates the output surface. This may be called more than once
    // if the context gets lost.
    virtual WebCompositorOutputSurface* createOutputSurface() { return 0; }

    // Signals a successful recreation of the output surface (e.g. after a lost
    // 3D context event).
    virtual void didRecreateOutputSurface(bool success) { }

    virtual WebInputHandler* createInputHandler() { return 0; }

    // Indicates that a frame will be committed to the impl side of the compositor
    // for rendering.
    virtual void willCommit() { }

    // Indicates that a frame was committed to the impl side of the compositor
    // for rendering.
    //
    // FIXME: make this non-virtual when ui/compositor DEP is resolved.
    virtual void didCommit() { }

    // Indicates that a frame was committed to the impl side and drawing
    // commands for it were issued to the GPU.
    virtual void didCommitAndDrawFrame() = 0;

    // Indicates that a frame previously issued to the GPU has completed
    // rendering.
    virtual void didCompleteSwapBuffers() = 0;

    // Schedules a compositing pass, meaning the client should call
    // WebLayerTreeView::composite at a later time. This is only called if the
    // compositor thread is disabled; when enabled, the compositor will
    // internally schedule a compositing pass when needed.
    virtual void scheduleComposite() = 0;

    // Creates a font atlas to use for debug visualizations. The atlas is a bitmap
    // containing glyph data, a table of ASCII character values to a subrectangle
    // of the atlas representing the corresponding glyph, and the glyph height.
    virtual void createFontAtlas(SkBitmap&, WebRect asciiToRectTable[128], int& fontHeight) { }

protected:
    virtual ~WebLayerTreeViewClient() { }
};

} // namespace WebKit

#endif // WebLayerTreeViewClient_h