forked from CinemaMod/java-cef
-
Notifications
You must be signed in to change notification settings - Fork 7
Expand file tree
/
Copy pathCefRenderHandler.java
More file actions
160 lines (141 loc) · 6.24 KB
/
CefRenderHandler.java
File metadata and controls
160 lines (141 loc) · 6.24 KB
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
// Copyright (c) 2014 The Chromium Embedded Framework Authors. All rights
// reserved. Use of this source code is governed by a BSD-style license that
// can be found in the LICENSE file.
package org.cef.handler;
import org.cef.browser.CefAcceleratedPaintEvent;
import org.cef.browser.CefBrowser;
import org.cef.browser.CefPaintEvent;
import org.cef.callback.CefDragData;
import java.awt.Point;
import java.awt.Rectangle;
import java.nio.ByteBuffer;
import java.util.function.Consumer;
/**
* Implement this interface to handle events when window rendering is disabled.
* The methods of this class will be called on the UI thread.
*/
public interface CefRenderHandler {
/**
* Retrieve the view rectangle.
* @param browser The browser generating the event.
* @return The view rectangle.
*/
public Rectangle getViewRect(CefBrowser browser);
/**
* Retrieve the screen info.
* @param browser The browser generating the event.
* @param screenInfo The screenInfo
* @return True if this callback was handled. False to fallback to defaults.
*/
public boolean getScreenInfo(CefBrowser browser, CefScreenInfo screenInfo);
/**
* Retrieve the screen point for the specified view point.
* @param browser The browser generating the event.
* @param viewPoint The point in the view.
* @return The screen point.
*/
public Point getScreenPoint(CefBrowser browser, Point viewPoint);
/**
* Show or hide the popup window.
* @param browser The browser generating the event.
* @param show True if the popup window is being shown.
*/
public void onPopupShow(CefBrowser browser, boolean show);
/**
* Size the popup window.
* @param browser The browser generating the event.
* @param size Size of the popup window.
*/
public void onPopupSize(CefBrowser browser, Rectangle size);
/**
* Handle painting.
* @param browser The browser generating the event.
* @param popup True if painting a popup window.
* @param dirtyRects Array of dirty regions.
* @param buffer Pixel buffer for the whole window.
* @param width Width of the buffer.
* @param height Height of the buffer.
*/
public void onPaint(CefBrowser browser, boolean popup, Rectangle[] dirtyRects,
ByteBuffer buffer, int width, int height);
/**
* Called when an element has been rendered to the shared texture handle.
* This method is only called when CefWindowInfo::shared_texture_enabled is set to true.
* @param browser The browser generating the event.
* @param popup True if painting a popup window.
* @param dirtyRects Array of dirty regions.
* @param info Platform-specific info instance. Expect one of
* {@link CefAcceleratedPaintInfoWin},
* {@link CefAcceleratedPaintInfoMac},
* {@link CefAcceleratedPaintInfoLinux}, or a base
* {@link CefAcceleratedPaintInfo} on unsupported platforms.
*/
public void onAcceleratedPaint(CefBrowser browser, boolean popup, Rectangle[] dirtyRects,
CefAcceleratedPaintInfo info);
/**
* Add provided listener for accelerated paint events.
* @param listener Code that gets executed after a frame was rendered with accelerated painting.
*/
public void addOnAcceleratedPaintListener(Consumer<CefAcceleratedPaintEvent> listener);
/**
* Remove existing accelerated paint listeners and replace with provided listener.
* @param listener Code that gets executed after a frame was rendered with accelerated painting.
*/
public void setOnAcceleratedPaintListener(Consumer<CefAcceleratedPaintEvent> listener);
/**
* Remove provided accelerated paint listener.
* @param listener Code that gets executed after a frame was rendered with accelerated painting.
*/
public void removeOnAcceleratedPaintListener(Consumer<CefAcceleratedPaintEvent> listener);
/**
* Add provided listener.
* @param listener Code that gets executed after a frame was rendered.
*/
public void addOnPaintListener(Consumer<CefPaintEvent> listener);
/**
* Remove existing listeners and replace with provided listener.
* @param listener Code that gets executed after a frame was rendered.
*/
public void setOnPaintListener(Consumer<CefPaintEvent> listener);
/**
* Remove provided listener.
* @param listener Code that gets executed after a frame was rendered.
*/
public void removeOnPaintListener(Consumer<CefPaintEvent> listener);
/**
* Handle cursor changes.
* @param browser The browser generating the event.
* @param cursorType The new cursor type.
* @return true if the cursor change was handled.
*/
public boolean onCursorChange(CefBrowser browser, int cursorType);
/**
* Called when the user starts dragging content in the web view. Contextual
* information about the dragged content is supplied by dragData.
* OS APIs that run a system message loop may be used within the
* StartDragging call.
*
* Return false to abort the drag operation. Don't call any of
* CefBrowser-dragSource*Ended* methods after returning false.
*
* Return true to handle the drag operation. Call
* CefBrowser.dragSourceEndedAt and CefBrowser.ragSourceSystemDragEnded either
* synchronously or asynchronously to inform the web view that the drag
* operation has ended.
* @param browser The browser generating the event.
* @param dragData Contextual information about the dragged content
* @param mask Describes the allowed operation (none, move, copy, link).
* @param x Coordinate within CefBrowser
* @param y Coordinate within CefBrowser
* @return false to abort the drag operation or true to handle the drag operation.
*/
public boolean startDragging(CefBrowser browser, CefDragData dragData, int mask, int x, int y);
/**
* Called when the web view wants to update the mouse cursor during a
* drag & drop operation.
*
* @param browser The browser generating the event.
* @param operation Describes the allowed operation (none, move, copy, link).
*/
public void updateDragCursor(CefBrowser browser, int operation);
}