webview: allow setting background color
This commit is contained in:
parent
100ea975bd
commit
f8f3fba433
11 changed files with 17 additions and 69 deletions
|
@ -1100,11 +1100,6 @@ void WebContents::SetSize(const SetSizeParams& params) {
|
||||||
guest_delegate_->SetSize(params);
|
guest_delegate_->SetSize(params);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebContents::SetAllowTransparency(bool allow) {
|
|
||||||
if (guest_delegate_)
|
|
||||||
guest_delegate_->SetAllowTransparency(allow);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool WebContents::IsGuest() const {
|
bool WebContents::IsGuest() const {
|
||||||
return type_ == WEB_VIEW;
|
return type_ == WEB_VIEW;
|
||||||
}
|
}
|
||||||
|
@ -1202,7 +1197,6 @@ void WebContents::BuildPrototype(v8::Isolate* isolate,
|
||||||
&WebContents::BeginFrameSubscription)
|
&WebContents::BeginFrameSubscription)
|
||||||
.SetMethod("endFrameSubscription", &WebContents::EndFrameSubscription)
|
.SetMethod("endFrameSubscription", &WebContents::EndFrameSubscription)
|
||||||
.SetMethod("setSize", &WebContents::SetSize)
|
.SetMethod("setSize", &WebContents::SetSize)
|
||||||
.SetMethod("setAllowTransparency", &WebContents::SetAllowTransparency)
|
|
||||||
.SetMethod("isGuest", &WebContents::IsGuest)
|
.SetMethod("isGuest", &WebContents::IsGuest)
|
||||||
.SetMethod("getWebPreferences", &WebContents::GetWebPreferences)
|
.SetMethod("getWebPreferences", &WebContents::GetWebPreferences)
|
||||||
.SetMethod("getOwnerBrowserWindow", &WebContents::GetOwnerBrowserWindow)
|
.SetMethod("getOwnerBrowserWindow", &WebContents::GetOwnerBrowserWindow)
|
||||||
|
|
|
@ -131,7 +131,6 @@ class WebContents : public mate::TrackableObject<WebContents>,
|
||||||
|
|
||||||
// Methods for creating <webview>.
|
// Methods for creating <webview>.
|
||||||
void SetSize(const SetSizeParams& params);
|
void SetSize(const SetSizeParams& params);
|
||||||
void SetAllowTransparency(bool allow);
|
|
||||||
bool IsGuest() const;
|
bool IsGuest() const;
|
||||||
|
|
||||||
// Callback triggered on permission response.
|
// Callback triggered on permission response.
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
#include "atom/browser/web_view_guest_delegate.h"
|
#include "atom/browser/web_view_guest_delegate.h"
|
||||||
|
|
||||||
#include "atom/browser/api/atom_api_web_contents.h"
|
#include "atom/browser/api/atom_api_web_contents.h"
|
||||||
|
#include "atom/common/api/api_messages.h"
|
||||||
#include "atom/common/native_mate_converters/gurl_converter.h"
|
#include "atom/common/native_mate_converters/gurl_converter.h"
|
||||||
#include "content/public/browser/guest_host.h"
|
#include "content/public/browser/guest_host.h"
|
||||||
#include "content/public/browser/render_frame_host.h"
|
#include "content/public/browser/render_frame_host.h"
|
||||||
|
@ -22,8 +23,7 @@ const int kDefaultHeight = 300;
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
WebViewGuestDelegate::WebViewGuestDelegate()
|
WebViewGuestDelegate::WebViewGuestDelegate()
|
||||||
: guest_opaque_(true),
|
: guest_host_(nullptr),
|
||||||
guest_host_(nullptr),
|
|
||||||
auto_size_enabled_(false),
|
auto_size_enabled_(false),
|
||||||
is_full_page_plugin_(false),
|
is_full_page_plugin_(false),
|
||||||
api_web_contents_(nullptr) {
|
api_web_contents_(nullptr) {
|
||||||
|
@ -96,23 +96,6 @@ void WebViewGuestDelegate::SetSize(const SetSizeParams& params) {
|
||||||
auto_size_enabled_ = enable_auto_size;
|
auto_size_enabled_ = enable_auto_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewGuestDelegate::SetAllowTransparency(bool allow) {
|
|
||||||
if (guest_opaque_ != allow)
|
|
||||||
return;
|
|
||||||
|
|
||||||
auto render_view_host = web_contents()->GetRenderViewHost();
|
|
||||||
guest_opaque_ = !allow;
|
|
||||||
if (!render_view_host->GetWidget()->GetView())
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (guest_opaque_) {
|
|
||||||
render_view_host->GetWidget()->GetView()->SetBackgroundColorToDefault();
|
|
||||||
} else {
|
|
||||||
render_view_host->GetWidget()->GetView()->SetBackgroundColor(
|
|
||||||
SK_ColorTRANSPARENT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void WebViewGuestDelegate::HandleKeyboardEvent(
|
void WebViewGuestDelegate::HandleKeyboardEvent(
|
||||||
content::WebContents* source,
|
content::WebContents* source,
|
||||||
const content::NativeWebKeyboardEvent& event) {
|
const content::NativeWebKeyboardEvent& event) {
|
||||||
|
@ -121,16 +104,9 @@ void WebViewGuestDelegate::HandleKeyboardEvent(
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewGuestDelegate::RenderViewReady() {
|
void WebViewGuestDelegate::RenderViewReady() {
|
||||||
// We don't want to accidentally set the opacity of an interstitial page.
|
// Set default UA-dependent background as transparent.
|
||||||
// WebContents::GetRenderWidgetHostView will return the RWHV of an
|
api_web_contents_->Send(new AtomViewMsg_SetTransparentBackground(
|
||||||
// interstitial page if one is showing at this time. We only want opacity
|
api_web_contents_->routing_id()));
|
||||||
// to apply to web pages.
|
|
||||||
auto render_view_host_view =
|
|
||||||
web_contents()->GetRenderViewHost()->GetWidget()->GetView();
|
|
||||||
if (guest_opaque_)
|
|
||||||
render_view_host_view->SetBackgroundColorToDefault();
|
|
||||||
else
|
|
||||||
render_view_host_view->SetBackgroundColor(SK_ColorTRANSPARENT);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebViewGuestDelegate::DidCommitProvisionalLoadForFrame(
|
void WebViewGuestDelegate::DidCommitProvisionalLoadForFrame(
|
||||||
|
|
|
@ -49,9 +49,6 @@ class WebViewGuestDelegate : public content::BrowserPluginGuestDelegate,
|
||||||
// and normal sizes.
|
// and normal sizes.
|
||||||
void SetSize(const SetSizeParams& params);
|
void SetSize(const SetSizeParams& params);
|
||||||
|
|
||||||
// Sets the transparency of the guest.
|
|
||||||
void SetAllowTransparency(bool allow);
|
|
||||||
|
|
||||||
// Transfer the keyboard event to embedder.
|
// Transfer the keyboard event to embedder.
|
||||||
void HandleKeyboardEvent(content::WebContents* source,
|
void HandleKeyboardEvent(content::WebContents* source,
|
||||||
const content::NativeWebKeyboardEvent& event);
|
const content::NativeWebKeyboardEvent& event);
|
||||||
|
@ -85,9 +82,6 @@ class WebViewGuestDelegate : public content::BrowserPluginGuestDelegate,
|
||||||
// Returns the default size of the guestview.
|
// Returns the default size of the guestview.
|
||||||
gfx::Size GetDefaultSize() const;
|
gfx::Size GetDefaultSize() const;
|
||||||
|
|
||||||
// Stores whether the contents of the guest can be transparent.
|
|
||||||
bool guest_opaque_;
|
|
||||||
|
|
||||||
// The WebContents that attaches this guest view.
|
// The WebContents that attaches this guest view.
|
||||||
content::WebContents* embedder_web_contents_;
|
content::WebContents* embedder_web_contents_;
|
||||||
|
|
||||||
|
|
|
@ -37,3 +37,5 @@ IPC_MESSAGE_ROUTED2(AtomViewMsg_Message,
|
||||||
// Sent by the renderer when the draggable regions are updated.
|
// Sent by the renderer when the draggable regions are updated.
|
||||||
IPC_MESSAGE_ROUTED1(AtomViewHostMsg_UpdateDraggableRegions,
|
IPC_MESSAGE_ROUTED1(AtomViewHostMsg_UpdateDraggableRegions,
|
||||||
std::vector<atom::DraggableRegion> /* regions */)
|
std::vector<atom::DraggableRegion> /* regions */)
|
||||||
|
|
||||||
|
IPC_MESSAGE_ROUTED0(AtomViewMsg_SetTransparentBackground)
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include "ipc/ipc_message_macros.h"
|
#include "ipc/ipc_message_macros.h"
|
||||||
#include "net/base/net_module.h"
|
#include "net/base/net_module.h"
|
||||||
#include "net/grit/net_resources.h"
|
#include "net/grit/net_resources.h"
|
||||||
|
#include "third_party/skia/include/core/SkColor.h"
|
||||||
#include "third_party/WebKit/public/web/WebDraggableRegion.h"
|
#include "third_party/WebKit/public/web/WebDraggableRegion.h"
|
||||||
#include "third_party/WebKit/public/web/WebDocument.h"
|
#include "third_party/WebKit/public/web/WebDocument.h"
|
||||||
#include "third_party/WebKit/public/web/WebFrame.h"
|
#include "third_party/WebKit/public/web/WebFrame.h"
|
||||||
|
@ -113,6 +114,8 @@ bool AtomRenderViewObserver::OnMessageReceived(const IPC::Message& message) {
|
||||||
bool handled = true;
|
bool handled = true;
|
||||||
IPC_BEGIN_MESSAGE_MAP(AtomRenderViewObserver, message)
|
IPC_BEGIN_MESSAGE_MAP(AtomRenderViewObserver, message)
|
||||||
IPC_MESSAGE_HANDLER(AtomViewMsg_Message, OnBrowserMessage)
|
IPC_MESSAGE_HANDLER(AtomViewMsg_Message, OnBrowserMessage)
|
||||||
|
IPC_MESSAGE_HANDLER(AtomViewMsg_SetTransparentBackground,
|
||||||
|
OnSetTransparentBackground)
|
||||||
IPC_MESSAGE_UNHANDLED(handled = false)
|
IPC_MESSAGE_UNHANDLED(handled = false)
|
||||||
IPC_END_MESSAGE_MAP()
|
IPC_END_MESSAGE_MAP()
|
||||||
|
|
||||||
|
@ -148,4 +151,10 @@ void AtomRenderViewObserver::OnBrowserMessage(const base::string16& channel,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AtomRenderViewObserver::OnSetTransparentBackground() {
|
||||||
|
if (!render_view()->GetWebView())
|
||||||
|
return;
|
||||||
|
render_view()->GetWebView()->setBaseBackgroundColor(SK_ColorTRANSPARENT);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace atom
|
} // namespace atom
|
||||||
|
|
|
@ -32,6 +32,7 @@ class AtomRenderViewObserver : public content::RenderViewObserver {
|
||||||
|
|
||||||
void OnBrowserMessage(const base::string16& channel,
|
void OnBrowserMessage(const base::string16& channel,
|
||||||
const base::ListValue& args);
|
const base::ListValue& args);
|
||||||
|
void OnSetTransparentBackground();
|
||||||
|
|
||||||
// Weak reference to renderer client.
|
// Weak reference to renderer client.
|
||||||
AtomRendererClient* renderer_client_;
|
AtomRendererClient* renderer_client_;
|
||||||
|
|
|
@ -131,9 +131,6 @@ var createGuest = function(embedder, params) {
|
||||||
}
|
}
|
||||||
this.loadURL(params.src, opts);
|
this.loadURL(params.src, opts);
|
||||||
}
|
}
|
||||||
if (params.allowtransparency != null) {
|
|
||||||
this.setAllowTransparency(params.allowtransparency);
|
|
||||||
}
|
|
||||||
return guest.allowPopups = params.allowpopups;
|
return guest.allowPopups = params.allowpopups;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -229,11 +226,6 @@ ipcMain.on('ATOM_SHELL_GUEST_VIEW_MANAGER_SET_SIZE', function(event, id, params)
|
||||||
return (ref1 = guestInstances[id]) != null ? ref1.guest.setSize(params) : void 0;
|
return (ref1 = guestInstances[id]) != null ? ref1.guest.setSize(params) : void 0;
|
||||||
});
|
});
|
||||||
|
|
||||||
ipcMain.on('ATOM_SHELL_GUEST_VIEW_MANAGER_SET_ALLOW_TRANSPARENCY', function(event, id, allowtransparency) {
|
|
||||||
var ref1;
|
|
||||||
return (ref1 = guestInstances[id]) != null ? ref1.guest.setAllowTransparency(allowtransparency) : void 0;
|
|
||||||
});
|
|
||||||
|
|
||||||
// Returns WebContents from its guest id.
|
// Returns WebContents from its guest id.
|
||||||
exports.getGuest = function(id) {
|
exports.getGuest = function(id) {
|
||||||
var ref1;
|
var ref1;
|
||||||
|
|
|
@ -106,7 +106,4 @@ module.exports = {
|
||||||
setSize: function(guestInstanceId, params) {
|
setSize: function(guestInstanceId, params) {
|
||||||
return ipcRenderer.send('ATOM_SHELL_GUEST_VIEW_MANAGER_SET_SIZE', guestInstanceId, params);
|
return ipcRenderer.send('ATOM_SHELL_GUEST_VIEW_MANAGER_SET_SIZE', guestInstanceId, params);
|
||||||
},
|
},
|
||||||
setAllowTransparency: function(guestInstanceId, allowtransparency) {
|
|
||||||
return ipcRenderer.send('ATOM_SHELL_GUEST_VIEW_MANAGER_SET_ALLOW_TRANSPARENCY', guestInstanceId, allowtransparency);
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -81,20 +81,6 @@ class BooleanAttribute extends WebViewAttribute {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Attribute that specifies whether transparency is allowed in the webview.
|
|
||||||
class AllowTransparencyAttribute extends BooleanAttribute {
|
|
||||||
constructor(webViewImpl) {
|
|
||||||
super(webViewConstants.ATTRIBUTE_ALLOWTRANSPARENCY, webViewImpl);
|
|
||||||
}
|
|
||||||
|
|
||||||
handleMutation() {
|
|
||||||
if (!this.webViewImpl.guestInstanceId) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
return guestViewInternal.setAllowTransparency(this.webViewImpl.guestInstanceId, this.getValue());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Attribute used to define the demension limits of autosizing.
|
// Attribute used to define the demension limits of autosizing.
|
||||||
class AutosizeDimensionAttribute extends WebViewAttribute {
|
class AutosizeDimensionAttribute extends WebViewAttribute {
|
||||||
constructor(name, webViewImpl) {
|
constructor(name, webViewImpl) {
|
||||||
|
@ -298,7 +284,6 @@ class BlinkFeaturesAttribute extends WebViewAttribute {
|
||||||
// Sets up all of the webview attributes.
|
// Sets up all of the webview attributes.
|
||||||
WebViewImpl.prototype.setupWebViewAttributes = function() {
|
WebViewImpl.prototype.setupWebViewAttributes = function() {
|
||||||
this.attributes = {};
|
this.attributes = {};
|
||||||
this.attributes[webViewConstants.ATTRIBUTE_ALLOWTRANSPARENCY] = new AllowTransparencyAttribute(this);
|
|
||||||
this.attributes[webViewConstants.ATTRIBUTE_AUTOSIZE] = new AutosizeAttribute(this);
|
this.attributes[webViewConstants.ATTRIBUTE_AUTOSIZE] = new AutosizeAttribute(this);
|
||||||
this.attributes[webViewConstants.ATTRIBUTE_PARTITION] = new PartitionAttribute(this);
|
this.attributes[webViewConstants.ATTRIBUTE_PARTITION] = new PartitionAttribute(this);
|
||||||
this.attributes[webViewConstants.ATTRIBUTE_SRC] = new SrcAttribute(this);
|
this.attributes[webViewConstants.ATTRIBUTE_SRC] = new SrcAttribute(this);
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
module.exports = {
|
module.exports = {
|
||||||
// Attributes.
|
// Attributes.
|
||||||
ATTRIBUTE_ALLOWTRANSPARENCY: 'allowtransparency',
|
|
||||||
ATTRIBUTE_AUTOSIZE: 'autosize',
|
ATTRIBUTE_AUTOSIZE: 'autosize',
|
||||||
ATTRIBUTE_MAXHEIGHT: 'maxheight',
|
ATTRIBUTE_MAXHEIGHT: 'maxheight',
|
||||||
ATTRIBUTE_MAXWIDTH: 'maxwidth',
|
ATTRIBUTE_MAXWIDTH: 'maxwidth',
|
||||||
|
|
Loading…
Reference in a new issue