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
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
|
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef WIN8_METRO_DRIVER_CHROME_APP_VIEW_ASH_H_
#define WIN8_METRO_DRIVER_CHROME_APP_VIEW_ASH_H_
#include <windows.applicationmodel.core.h>
#include <windows.ui.core.h>
#include <windows.ui.input.h>
#include <windows.ui.viewmanagement.h>
#include "base/memory/scoped_ptr.h"
#include "base/message_loop/message_loop.h"
#include "base/strings/string16.h"
#include "base/threading/thread.h"
#include "ipc/ipc_listener.h"
#include "ui/events/event_constants.h"
#include "win8/metro_driver/direct3d_helper.h"
#include "win8/metro_driver/ime/ime_popup_observer.h"
#include "win8/metro_driver/ime/input_source_observer.h"
#include "win8/metro_driver/ime/text_service_delegate.h"
namespace base {
class FilePath;
}
namespace IPC {
class Listener;
class ChannelProxy;
}
namespace metro_driver {
class InputSource;
class TextService;
}
namespace metro_viewer {
struct CharacterBounds;
struct UnderlineInfo;
}
class OpenFilePickerSession;
class SaveFilePickerSession;
class FolderPickerSession;
class FilePickerSessionBase;
struct MetroViewerHostMsg_SaveAsDialogParams;
enum MetroTerminateMethod {
TERMINATE_USING_KEY_SEQUENCE = 1,
TERMINATE_USING_PROCESS_EXIT = 2,
};
class ChromeAppViewAsh
: public mswr::RuntimeClass<winapp::Core::IFrameworkView>,
public metro_driver::ImePopupObserver,
public metro_driver::InputSourceObserver,
public metro_driver::TextServiceDelegate {
public:
ChromeAppViewAsh();
~ChromeAppViewAsh();
// IViewProvider overrides.
IFACEMETHOD(Initialize)(winapp::Core::ICoreApplicationView* view);
IFACEMETHOD(SetWindow)(winui::Core::ICoreWindow* window);
IFACEMETHOD(Load)(HSTRING entryPoint);
IFACEMETHOD(Run)();
IFACEMETHOD(Uninitialize)();
// Helper function to unsnap the chrome metro app if it is snapped.
// Returns S_OK on success.
static HRESULT Unsnap();
void OnActivateDesktop(const base::FilePath& file_path, bool ash_exit);
void OnOpenURLOnDesktop(const base::FilePath& shortcut,
const base::string16& url);
void OnSetCursor(HCURSOR cursor);
void OnDisplayFileOpenDialog(const base::string16& title,
const base::string16& filter,
const base::FilePath& default_path,
bool allow_multiple_files);
void OnDisplayFileSaveAsDialog(
const MetroViewerHostMsg_SaveAsDialogParams& params);
void OnDisplayFolderPicker(const base::string16& title);
void OnSetCursorPos(int x, int y);
// This function is invoked when the open file operation completes. The
// result of the operation is passed in along with the OpenFilePickerSession
// instance which is deleted after we read the required information from
// the OpenFilePickerSession class.
void OnOpenFileCompleted(OpenFilePickerSession* open_file_picker,
bool success);
// This function is invoked when the save file operation completes. The
// result of the operation is passed in along with the SaveFilePickerSession
// instance which is deleted after we read the required information from
// the SaveFilePickerSession class.
void OnSaveFileCompleted(SaveFilePickerSession* save_file_picker,
bool success);
// This function is invoked when the folder picker operation completes. The
// result of the operation is passed in along with the FolderPickerSession
// instance which is deleted after we read the required information from
// the FolderPickerSession class.
void OnFolderPickerCompleted(FolderPickerSession* folder_picker,
bool success);
void OnImeCancelComposition();
void OnImeUpdateTextInputClient(
const std::vector<int32>& input_scopes,
const std::vector<metro_viewer::CharacterBounds>& character_bounds);
void OnMetroExit(MetroTerminateMethod method);
HWND core_window_hwnd() const { return core_window_hwnd_; }
private:
class PointerInfoHandler;
// ImePopupObserver overrides.
virtual void OnImePopupChanged(ImePopupObserver::EventType event) OVERRIDE;
// InputSourceObserver overrides.
virtual void OnInputSourceChanged() OVERRIDE;
// TextServiceDelegate overrides.
virtual void OnCompositionChanged(
const base::string16& text,
int32 selection_start,
int32 selection_end,
const std::vector<metro_viewer::UnderlineInfo>& underlines) OVERRIDE;
virtual void OnTextCommitted(const base::string16& text) OVERRIDE;
// Convenience for sending a MetroViewerHostMsg_MouseButton with the specified
// parameters.
void SendMouseButton(int x,
int y,
int extra,
ui::EventType event_type,
uint32 flags,
ui::EventFlags changed_button,
bool is_horizontal_wheel);
// Win8 only generates a mouse press for the initial button that goes down and
// a release when the last button is released. Any intermediary presses (or
// releases) do not result in a new press/release event. Instead a move is
// generated with the winui::Input::PointerUpdateKind identifying what
// changed. This function generates the necessary intermediary events (as
// necessary).
void GenerateMouseEventFromMoveIfNecessary(const PointerInfoHandler& pointer);
HRESULT OnActivate(winapp::Core::ICoreApplicationView* view,
winapp::Activation::IActivatedEventArgs* args);
HRESULT OnPointerMoved(winui::Core::ICoreWindow* sender,
winui::Core::IPointerEventArgs* args);
HRESULT OnPointerPressed(winui::Core::ICoreWindow* sender,
winui::Core::IPointerEventArgs* args);
HRESULT OnPointerReleased(winui::Core::ICoreWindow* sender,
winui::Core::IPointerEventArgs* args);
HRESULT OnWheel(winui::Core::ICoreWindow* sender,
winui::Core::IPointerEventArgs* args);
HRESULT OnKeyDown(winui::Core::ICoreWindow* sender,
winui::Core::IKeyEventArgs* args);
HRESULT OnKeyUp(winui::Core::ICoreWindow* sender,
winui::Core::IKeyEventArgs* args);
// Invoked for system keys like Alt, etc.
HRESULT OnAcceleratorKeyDown(winui::Core::ICoreDispatcher* sender,
winui::Core::IAcceleratorKeyEventArgs* args);
HRESULT OnCharacterReceived(winui::Core::ICoreWindow* sender,
winui::Core::ICharacterReceivedEventArgs* args);
HRESULT OnWindowActivated(winui::Core::ICoreWindow* sender,
winui::Core::IWindowActivatedEventArgs* args);
// Helper to handle search requests received via the search charm in ASH.
HRESULT HandleSearchRequest(winapp::Activation::IActivatedEventArgs* args);
// Helper to handle http/https url requests in ASH.
HRESULT HandleProtocolRequest(winapp::Activation::IActivatedEventArgs* args);
HRESULT OnEdgeGestureCompleted(winui::Input::IEdgeGesture* gesture,
winui::Input::IEdgeGestureEventArgs* args);
// Tasks posted to the UI thread to initiate the search/url navigation
// requests.
void OnSearchRequest(const base::string16& search_string);
void OnNavigateToUrl(const base::string16& url);
HRESULT OnSizeChanged(winui::Core::ICoreWindow* sender,
winui::Core::IWindowSizeChangedEventArgs* args);
// This function checks if the Chrome browser channel is initialized. If yes
// then it goes ahead and starts up the viewer in Chrome OS mode. If not it
// posts a delayed task and checks again. It does this for a duration of 10
// seconds and then bails.
void StartChromeOSMode();
mswr::ComPtr<winui::Core::ICoreWindow> window_;
mswr::ComPtr<winapp::Core::ICoreApplicationView> view_;
EventRegistrationToken activated_token_;
EventRegistrationToken pointermoved_token_;
EventRegistrationToken pointerpressed_token_;
EventRegistrationToken pointerreleased_token_;
EventRegistrationToken wheel_token_;
EventRegistrationToken keydown_token_;
EventRegistrationToken keyup_token_;
EventRegistrationToken character_received_token_;
EventRegistrationToken accel_keydown_token_;
EventRegistrationToken accel_keyup_token_;
EventRegistrationToken window_activated_token_;
EventRegistrationToken sizechange_token_;
EventRegistrationToken edgeevent_token_;
// Keep state about which button is currently down, if any, as PointerMoved
// events do not contain that state, but Ash's MouseEvents need it. Value is
// as a bitmask of ui::EventFlags.
uint32 mouse_down_flags_;
// Set the D3D swap chain and nothing else.
metro_driver::Direct3DHelper direct3d_helper_;
// The IPC channel IO thread.
scoped_ptr<base::Thread> io_thread_;
// The channel to Chrome, in particular to the MetroViewerProcessHost.
scoped_ptr<IPC::ChannelProxy> ui_channel_;
// The actual window behind the view surface.
HWND core_window_hwnd_;
// UI message loop to allow message passing into this thread.
base::MessageLoopForUI ui_loop_;
// For IME support.
scoped_ptr<metro_driver::InputSource> input_source_;
scoped_ptr<metro_driver::TextService> text_service_;
// The metro device scale factor as reported by the winrt interfaces.
float metro_dpi_scale_;
// The win32 dpi scale which is queried via GetDeviceCaps. Please refer to
// ui/gfx/win/dpi.cc for more information.
float win32_dpi_scale_;
// The cursor set by the chroem browser process.
HCURSOR last_cursor_;
// Pointer to the channel listener for the channel between the viewer and
// the browser.
IPC::Listener* channel_listener_;
};
#endif // WIN8_METRO_DRIVER_CHROME_APP_VIEW_ASH_H_
|