/
ManagedCefBrowserAdapter.cpp
149 lines (126 loc) · 5.05 KB
/
ManagedCefBrowserAdapter.cpp
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
// Copyright © 2010-2016 The CefSharp Project. All rights reserved.
//
// Use of this source code is governed by a BSD-style license that can be found in the LICENSE file.
#include "Stdafx.h"
#include "ManagedCefBrowserAdapter.h"
#include "Internals/Messaging/Messages.h"
#include "Internals/CefFrameWrapper.h"
#include "Internals/CefSharpBrowserWrapper.h"
using namespace CefSharp::Internals::Messaging;
bool ManagedCefBrowserAdapter::IsDisposed::get()
{
return _isDisposed;
}
void ManagedCefBrowserAdapter::CreateOffscreenBrowser(IntPtr windowHandle, BrowserSettings^ browserSettings, RequestContext^ requestContext, String^ address)
{
//Create the required BitmapInfo classes before the offscreen browser is initialized
auto renderClientAdapter = dynamic_cast<RenderClientAdapter*>(_clientAdapter.get());
renderClientAdapter->CreateBitmapInfo();
auto hwnd = static_cast<HWND>(windowHandle.ToPointer());
CefWindowInfo window;
auto transparent = browserSettings->OffScreenTransparentBackground.GetValueOrDefault(true);
window.SetAsWindowless(hwnd, transparent);
CefString addressNative = StringUtils::ToNative(address);
if (!CefBrowserHost::CreateBrowser(window, _clientAdapter.get(), addressNative,
*browserSettings->_browserSettings, requestContext))
{
throw gcnew InvalidOperationException("Failed to create offscreen browser. Call Cef.Initialize() first.");
}
}
void ManagedCefBrowserAdapter::OnAfterBrowserCreated(IBrowser^ browser)
{
if (!_isDisposed)
{
_browserWrapper = browser;
_javascriptCallbackFactory->BrowserAdapter = gcnew WeakReference(this);
if (CefSharpSettings::WcfEnabled)
{
_browserProcessServiceHost = gcnew BrowserProcessServiceHost(_javaScriptObjectRepository, Process::GetCurrentProcess()->Id, browser->Identifier, _javascriptCallbackFactory);
//NOTE: Attempt to solve timing issue where browser is opened and rapidly disposed. In some cases a call to Open throws
// an exception about the process already being closed. Two relevant issues are #862 and #804.
if (_browserProcessServiceHost->State == CommunicationState::Created)
{
try
{
_browserProcessServiceHost->Open();
}
catch (Exception^)
{
//Ignore exception as it's likely cause when the browser is closing
}
}
}
if (_webBrowserInternal != nullptr)
{
_webBrowserInternal->OnAfterBrowserCreated(browser);
}
}
}
void ManagedCefBrowserAdapter::CreateBrowser(BrowserSettings^ browserSettings, RequestContext^ requestContext, IntPtr sourceHandle, String^ address)
{
HWND hwnd = static_cast<HWND>(sourceHandle.ToPointer());
RECT rect;
GetClientRect(hwnd, &rect);
CefWindowInfo window;
window.SetAsChild(hwnd, rect);
CefString addressNative = StringUtils::ToNative(address);
CefBrowserHost::CreateBrowser(window, _clientAdapter.get(), addressNative,
*browserSettings->_browserSettings, requestContext);
}
void ManagedCefBrowserAdapter::Resize(int width, int height)
{
HWND browserHwnd = _clientAdapter->GetBrowserHwnd();
if (browserHwnd)
{
if (width == 0 && height == 0)
{
// For windowed browsers when the frame window is minimized set the
// browser window size to 0x0 to reduce resource usage.
SetWindowPos(browserHwnd, NULL, 0, 0, 0, 0, SWP_NOZORDER | SWP_NOMOVE | SWP_NOACTIVATE);
}
else
{
SetWindowPos(browserHwnd, NULL, 0, 0, width, height, SWP_NOZORDER);
}
}
}
void ManagedCefBrowserAdapter::RegisterJsObject(String^ name, Object^ object, BindingOptions^ options)
{
if (!CefSharpSettings::WcfEnabled)
{
throw gcnew InvalidOperationException("To enable synchronous JS bindings set WcfEnabled true in CefSettings during initialization.");
}
_javaScriptObjectRepository->Register(name, object, options);
}
void ManagedCefBrowserAdapter::RegisterAsyncJsObject(String^ name, Object^ object, BindingOptions^ options)
{
_javaScriptObjectRepository->RegisterAsync(name, object, options);
}
IBrowser^ ManagedCefBrowserAdapter::GetBrowser(int browserId)
{
return _clientAdapter->GetBrowserWrapper(browserId);
}
IJavascriptCallbackFactory^ ManagedCefBrowserAdapter::JavascriptCallbackFactory::get()
{
return _javascriptCallbackFactory;
}
JavascriptObjectRepository^ ManagedCefBrowserAdapter::JavascriptObjectRepository::get()
{
return _javaScriptObjectRepository;
}
MethodRunnerQueue^ ManagedCefBrowserAdapter::MethodRunnerQueue::get()
{
return _methodRunnerQueue;
}
void ManagedCefBrowserAdapter::MethodInvocationComplete(Object^ sender, MethodInvocationCompleteArgs^ e)
{
auto result = e->Result;
if (result->CallbackId.HasValue)
{
_clientAdapter->MethodInvocationComplete(result);
}
}
MCefRefPtr<ClientAdapter> ManagedCefBrowserAdapter::GetClientAdapter()
{
return _clientAdapter;
}