Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(114)

Side by Side Diff: content/browser/renderer_host/render_widget_host_view_base.h

Issue 1652483002: Browser Side Text Input State Tracking for OOPIF. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed a Compile Error Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_BASE_H_ 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_BASE_H_
6 #define CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_BASE_H_ 6 #define CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_BASE_H_
7 7
8 #include <stddef.h> 8 #include <stddef.h>
9 #include <stdint.h> 9 #include <stdint.h>
10 10
(...skipping 23 matching lines...) Expand all
34 #include "ui/gfx/display.h" 34 #include "ui/gfx/display.h"
35 #include "ui/gfx/geometry/rect.h" 35 #include "ui/gfx/geometry/rect.h"
36 #include "ui/gfx/native_widget_types.h" 36 #include "ui/gfx/native_widget_types.h"
37 #include "ui/gfx/range/range.h" 37 #include "ui/gfx/range/range.h"
38 #include "ui/surface/transport_dib.h" 38 #include "ui/surface/transport_dib.h"
39 39
40 class SkBitmap; 40 class SkBitmap;
41 41
42 struct AccessibilityHostMsg_EventParams; 42 struct AccessibilityHostMsg_EventParams;
43 struct ViewHostMsg_SelectionBounds_Params; 43 struct ViewHostMsg_SelectionBounds_Params;
44 struct ViewHostMsg_TextInputState_Params; 44 struct TextInputState;
45 45
46 namespace media { 46 namespace media {
47 class VideoFrame; 47 class VideoFrame;
48 } 48 }
49 49
50 namespace blink { 50 namespace blink {
51 struct WebScreenInfo; 51 struct WebScreenInfo;
52 class WebMouseEvent; 52 class WebMouseEvent;
53 class WebMouseWheelEvent; 53 class WebMouseWheelEvent;
54 } 54 }
55 55
56 namespace cc { 56 namespace cc {
57 class SurfaceHittestDelegate; 57 class SurfaceHittestDelegate;
58 } 58 }
59 59
60 namespace ui { 60 namespace ui {
61 class LatencyInfo; 61 class LatencyInfo;
62 } 62 }
63 63
64 namespace content { 64 namespace content {
65 class BrowserAccessibilityDelegate; 65 class BrowserAccessibilityDelegate;
66 class BrowserAccessibilityManager; 66 class BrowserAccessibilityManager;
67 class RenderWidgetHostViewBaseObserver; 67 class RenderWidgetHostViewBaseObserver;
68 class SyntheticGesture; 68 class SyntheticGesture;
69 class SyntheticGestureTarget; 69 class SyntheticGestureTarget;
70 class WebCursor; 70 class WebCursor;
71 struct DidOverscrollParams; 71 struct DidOverscrollParams;
72 struct NativeWebKeyboardEvent; 72 struct NativeWebKeyboardEvent;
73 struct TextInputState;
73 struct WebPluginGeometry; 74 struct WebPluginGeometry;
74 75
75 // Basic implementation shared by concrete RenderWidgetHostView subclasses. 76 // Basic implementation shared by concrete RenderWidgetHostView subclasses.
76 class CONTENT_EXPORT RenderWidgetHostViewBase : public RenderWidgetHostView, 77 class CONTENT_EXPORT RenderWidgetHostViewBase : public RenderWidgetHostView,
77 public IPC::Listener { 78 public IPC::Listener {
78 public: 79 public:
79 ~RenderWidgetHostViewBase() override; 80 ~RenderWidgetHostViewBase() override;
80 81
81 float current_device_scale_factor() const { 82 float current_device_scale_factor() const {
82 return current_device_scale_factor_; 83 return current_device_scale_factor_;
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
120 // the renderer. 121 // the renderer.
121 void DidReceiveRendererFrame(); 122 void DidReceiveRendererFrame();
122 123
123 // Notification that a resize or move session ended on the native widget. 124 // Notification that a resize or move session ended on the native widget.
124 void UpdateScreenInfo(gfx::NativeView view); 125 void UpdateScreenInfo(gfx::NativeView view);
125 126
126 // Tells if the display property (work area/scale factor) has 127 // Tells if the display property (work area/scale factor) has
127 // changed since the last time. 128 // changed since the last time.
128 bool HasDisplayPropertyChanged(gfx::NativeView view); 129 bool HasDisplayPropertyChanged(gfx::NativeView view);
129 130
131 const TextInputState* text_input_state() const {
Charlie Reis 2016/03/15 18:32:00 Let's include a comment to give context about when
EhsanK 2016/03/15 23:51:18 Done.
132 return text_input_state_.get();
133 }
134
130 base::WeakPtr<RenderWidgetHostViewBase> GetWeakPtr(); 135 base::WeakPtr<RenderWidgetHostViewBase> GetWeakPtr();
131 136
132 //---------------------------------------------------------------------------- 137 //----------------------------------------------------------------------------
133 // The following methods can be overridden by derived classes. 138 // The following methods can be overridden by derived classes.
134 139
135 // Notifies the View that the renderer text selection has changed. 140 // Notifies the View that the renderer text selection has changed.
136 virtual void SelectionChanged(const base::string16& text, 141 virtual void SelectionChanged(const base::string16& text,
137 size_t offset, 142 size_t offset,
138 const gfx::Range& range); 143 const gfx::Range& range);
139 144
(...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after
229 // embedded within the RenderWidgetHostViewBase's Surface to the 234 // embedded within the RenderWidgetHostViewBase's Surface to the
230 // coordinate space of the embedding Surface. Typically this means that a 235 // coordinate space of the embedding Surface. Typically this means that a
231 // point was received from an out-of-process iframe's RenderWidget and needs 236 // point was received from an out-of-process iframe's RenderWidget and needs
232 // to be translated to viewport coordinates for the root RWHV, in which case 237 // to be translated to viewport coordinates for the root RWHV, in which case
233 // this method is called on the root RWHV with the out-of-process iframe's 238 // this method is called on the root RWHV with the out-of-process iframe's
234 // SurfaceId. 239 // SurfaceId.
235 virtual void TransformPointToLocalCoordSpace(const gfx::Point& point, 240 virtual void TransformPointToLocalCoordSpace(const gfx::Point& point,
236 cc::SurfaceId original_surface, 241 cc::SurfaceId original_surface,
237 gfx::Point* transformed_point); 242 gfx::Point* transformed_point);
238 243
244 // This method is excusively called by the owner RenderWidgetHost to inform
245 // the view about a change in the input state which originated in the
246 // corresponding RenderWidget. This state is stored at the RWHV.
247 // Also, this change does not necessarily reflect the current state of the
248 // input since the text input could be due to a change in the focused
Charlie Reis 2016/03/15 18:32:00 nit: Remove extra space.
EhsanK 2016/03/15 23:51:18 Done. Thanks!
249 // child-frame's (in OOPIF) or the out of process content managed by
250 // BrowserPlugin.
251 // TODO(ekaramad): Make this non-virtual if possible.
252 virtual void TextInputStateChanged(const TextInputState& params);
253
254 // This method is used by the WebContents owning this view to notify the view
255 // of a text input change in the tab. This method should not be called on
256 // RenderWidgetHostViewChildFrame.
Charlie Reis 2016/03/15 18:32:00 I'm unclear on the last sentence. Would it be cle
EhsanK 2016/03/15 23:51:17 Yes. Revised. Thanks!
257 virtual void UpdateInputMethodIfNecessary(bool text_input_state_changed);
258
239 //---------------------------------------------------------------------------- 259 //----------------------------------------------------------------------------
240 // The following static methods are implemented by each platform. 260 // The following static methods are implemented by each platform.
241 261
242 static void GetDefaultScreenInfo(blink::WebScreenInfo* results); 262 static void GetDefaultScreenInfo(blink::WebScreenInfo* results);
243 263
244 //---------------------------------------------------------------------------- 264 //----------------------------------------------------------------------------
245 // The following pure virtual methods are implemented by derived classes. 265 // The following pure virtual methods are implemented by derived classes.
246 266
247 // Perform all the initialization steps necessary for this object to represent 267 // Perform all the initialization steps necessary for this object to represent
248 // a popup (such as a <select> dropdown), then shows the popup at |pos|. 268 // a popup (such as a <select> dropdown), then shows the popup at |pos|.
(...skipping 10 matching lines...) Expand all
259 // |scroll_offset| is the scroll offset of the render view. 279 // |scroll_offset| is the scroll offset of the render view.
260 virtual void MovePluginWindows( 280 virtual void MovePluginWindows(
261 const std::vector<WebPluginGeometry>& moves) = 0; 281 const std::vector<WebPluginGeometry>& moves) = 0;
262 282
263 // Sets the cursor to the one associated with the specified cursor_type 283 // Sets the cursor to the one associated with the specified cursor_type
264 virtual void UpdateCursor(const WebCursor& cursor) = 0; 284 virtual void UpdateCursor(const WebCursor& cursor) = 0;
265 285
266 // Indicates whether the page has finished loading. 286 // Indicates whether the page has finished loading.
267 virtual void SetIsLoading(bool is_loading) = 0; 287 virtual void SetIsLoading(bool is_loading) = 0;
268 288
269 // Updates the state of the input method attached to the view.
270 virtual void TextInputStateChanged(
271 const ViewHostMsg_TextInputState_Params& params) = 0;
272
273 // Cancel the ongoing composition of the input method attached to the view. 289 // Cancel the ongoing composition of the input method attached to the view.
274 virtual void ImeCancelComposition() = 0; 290 virtual void ImeCancelComposition() = 0;
275 291
276 // Notifies the View that the renderer has ceased to exist. 292 // Notifies the View that the renderer has ceased to exist.
277 virtual void RenderProcessGone(base::TerminationStatus status, 293 virtual void RenderProcessGone(base::TerminationStatus status,
278 int error_code) = 0; 294 int error_code) = 0;
279 295
280 // Tells the View to destroy itself. 296 // Tells the View to destroy itself.
281 virtual void Destroy() = 0; 297 virtual void Destroy() = 0;
282 298
(...skipping 160 matching lines...) Expand 10 before | Expand all | Expand 10 after
443 // A buffer containing the text inside and around the current selection range. 459 // A buffer containing the text inside and around the current selection range.
444 base::string16 selection_text_; 460 base::string16 selection_text_;
445 461
446 // The offset of the text stored in |selection_text_| relative to the start of 462 // The offset of the text stored in |selection_text_| relative to the start of
447 // the web page. 463 // the web page.
448 size_t selection_text_offset_; 464 size_t selection_text_offset_;
449 465
450 // The current selection range relative to the start of the web page. 466 // The current selection range relative to the start of the web page.
451 gfx::Range selection_range_; 467 gfx::Range selection_range_;
452 468
453 protected:
454 // The scale factor of the display the renderer is currently on. 469 // The scale factor of the display the renderer is currently on.
455 float current_device_scale_factor_; 470 float current_device_scale_factor_;
456 471
457 // The orientation of the display the renderer is currently on. 472 // The orientation of the display the renderer is currently on.
458 gfx::Display::Rotation current_display_rotation_; 473 gfx::Display::Rotation current_display_rotation_;
459 474
460 // Whether pinch-to-zoom should be enabled and pinch events forwarded to the 475 // Whether pinch-to-zoom should be enabled and pinch events forwarded to the
461 // renderer. 476 // renderer.
462 bool pinch_zoom_enabled_; 477 bool pinch_zoom_enabled_;
463 478
464 private: 479 private:
465 void FlushInput(); 480 void FlushInput();
466 481
467 gfx::Rect current_display_area_; 482 gfx::Rect current_display_area_;
468 483
469 uint32_t renderer_frame_number_; 484 uint32_t renderer_frame_number_;
470 485
471 base::OneShotTimer flush_input_timer_; 486 base::OneShotTimer flush_input_timer_;
472 487
473 base::ObserverList<RenderWidgetHostViewBaseObserver> observers_; 488 base::ObserverList<RenderWidgetHostViewBaseObserver> observers_;
474 489
490 // The last reported input state by the RenderWidget.
491 scoped_ptr<TextInputState> text_input_state_;
492
475 base::WeakPtrFactory<RenderWidgetHostViewBase> weak_factory_; 493 base::WeakPtrFactory<RenderWidgetHostViewBase> weak_factory_;
476 494
477 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewBase); 495 DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewBase);
478 }; 496 };
479 497
480 } // namespace content 498 } // namespace content
481 499
482 #endif // CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_BASE_H_ 500 #endif // CONTENT_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_BASE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698