1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef COMPONENTS_PLUGINS_RENDERER_WEBVIEW_PLUGIN_H_
6 #define COMPONENTS_PLUGINS_RENDERER_WEBVIEW_PLUGIN_H_
10 #include "base/memory/scoped_ptr.h"
11 #include "base/sequenced_task_runner_helpers.h"
12 #include "third_party/WebKit/public/platform/WebCursorInfo.h"
13 #include "third_party/WebKit/public/platform/WebString.h"
14 #include "third_party/WebKit/public/platform/WebURLResponse.h"
15 #include "third_party/WebKit/public/web/WebFrameClient.h"
16 #include "third_party/WebKit/public/web/WebPlugin.h"
17 #include "third_party/WebKit/public/web/WebViewClient.h"
25 struct WebPreferences
;
28 // This class implements the WebPlugin interface by forwarding drawing and
29 // handling input events to a WebView.
30 // It can be used as a placeholder for an actual plugin, using HTML for the UI.
31 // To show HTML data inside the WebViewPlugin,
32 // call web_view->mainFrame()->loadHTMLString() with the HTML data and a fake
33 // chrome:// URL as origin.
35 class WebViewPlugin
: public blink::WebPlugin
,
36 public blink::WebViewClient
,
37 public blink::WebFrameClient
{
41 // Bind |frame| to a Javascript object, enabling the delegate to receive
42 // callback methods from Javascript inside the WebFrame.
43 // This method is called from WebFrameClient::didClearWindowObject.
44 virtual void BindWebFrame(blink::WebFrame
* frame
) = 0;
46 // Called upon a context menu event.
47 virtual void ShowContextMenu(const blink::WebMouseEvent
&) = 0;
49 // Called when the WebViewPlugin is destroyed.
50 virtual void PluginDestroyed() = 0;
53 // Convenience method to set up a new WebViewPlugin using |preferences|
54 // and displaying |html_data|. |url| should be a (fake) data:text/html URL;
55 // it is only used for navigation and never actually resolved.
56 static WebViewPlugin
* Create(Delegate
* delegate
,
57 const content::WebPreferences
& preferences
,
58 const std::string
& html_data
,
61 blink::WebView
* web_view() { return web_view_
; }
63 // When loading a plugin document (i.e. a full page plugin not embedded in
64 // another page), we save all data that has been received, and replay it with
65 // this method on the actual plugin.
66 void ReplayReceivedData(blink::WebPlugin
* plugin
);
68 void RestoreTitleText();
71 virtual blink::WebPluginContainer
* container() const;
72 virtual bool initialize(blink::WebPluginContainer
*);
73 virtual void destroy();
75 virtual NPObject
* scriptableObject();
76 virtual struct _NPP
* pluginNPP();
78 virtual bool getFormValue(blink::WebString
& value
);
80 virtual void paint(blink::WebCanvas
* canvas
, const blink::WebRect
& rect
);
82 // Coordinates are relative to the containing window.
83 virtual void updateGeometry(
84 const blink::WebRect
& frame_rect
,
85 const blink::WebRect
& clip_rect
,
86 const blink::WebVector
<blink::WebRect
>& cut_out_rects
,
89 virtual void updateFocus(bool foucsed
, blink::WebFocusType focus_type
);
90 virtual void updateVisibility(bool) {}
92 virtual bool acceptsInputEvents();
93 virtual bool handleInputEvent(const blink::WebInputEvent
& event
,
94 blink::WebCursorInfo
& cursor_info
);
96 virtual void didReceiveResponse(const blink::WebURLResponse
& response
);
97 virtual void didReceiveData(const char* data
, int data_length
);
98 virtual void didFinishLoading();
99 virtual void didFailLoading(const blink::WebURLError
& error
);
101 // Called in response to WebPluginContainer::loadFrameRequest
102 virtual void didFinishLoadingFrameRequest(const blink::WebURL
& url
,
104 virtual void didFailLoadingFrameRequest(const blink::WebURL
& url
,
106 const blink::WebURLError
& error
) {}
108 // WebViewClient methods:
109 virtual bool acceptsLoadDrops();
111 virtual void setToolTipText(const blink::WebString
&,
112 blink::WebTextDirection
);
114 virtual void startDragging(blink::WebLocalFrame
* frame
,
115 const blink::WebDragData
& drag_data
,
116 blink::WebDragOperationsMask mask
,
117 const blink::WebImage
& image
,
118 const blink::WebPoint
& point
);
120 // TODO(ojan): Remove this override and have this class use a non-null
122 virtual bool allowsBrokenNullLayerTreeView() const;
124 // WebWidgetClient methods:
125 virtual void didInvalidateRect(const blink::WebRect
&);
126 virtual void didChangeCursor(const blink::WebCursorInfo
& cursor
);
127 virtual void scheduleAnimation();
129 // WebFrameClient methods:
130 virtual void didClearWindowObject(blink::WebLocalFrame
* frame
);
132 // This method is defined in WebPlugin as well as in WebFrameClient, but with
133 // different parameters. We only care about implementing the WebPlugin
134 // version, so we implement this method and call the default in WebFrameClient
135 // (which does nothing) to correctly overload it.
136 virtual void didReceiveResponse(blink::WebLocalFrame
* frame
,
138 const blink::WebURLResponse
& response
);
141 friend class base::DeleteHelper
<WebViewPlugin
>;
142 WebViewPlugin(Delegate
* delegate
, const content::WebPreferences
& preferences
);
143 virtual ~WebViewPlugin();
145 // Manages its own lifetime.
148 blink::WebCursorInfo current_cursor_
;
151 blink::WebPluginContainer
* container_
;
153 // Owned by us, deleted via |close()|.
154 blink::WebView
* web_view_
;
156 // Owned by us, deleted via |close()|.
157 blink::WebFrame
* web_frame_
;
160 blink::WebURLResponse response_
;
161 std::list
<std::string
> data_
;
162 bool finished_loading_
;
163 scoped_ptr
<blink::WebURLError
> error_
;
164 blink::WebString old_title_
;
168 #endif // COMPONENTS_PLUGINS_RENDERER_WEBVIEW_PLUGIN_H_