OLD | NEW |
---|---|
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 #include "content/browser/renderer_host/render_widget_host_view_base.h" | 5 #include "content/browser/renderer_host/render_widget_host_view_base.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "build/build_config.h" | 8 #include "build/build_config.h" |
9 #include "content/browser/accessibility/browser_accessibility_manager.h" | 9 #include "content/browser/accessibility/browser_accessibility_manager.h" |
10 #include "content/browser/gpu/gpu_data_manager_impl.h" | 10 #include "content/browser/gpu/gpu_data_manager_impl.h" |
11 #include "content/browser/renderer_host/input/synthetic_gesture_target_base.h" | 11 #include "content/browser/renderer_host/input/synthetic_gesture_target_base.h" |
12 #include "content/browser/renderer_host/render_process_host_impl.h" | 12 #include "content/browser/renderer_host/render_process_host_impl.h" |
13 #include "content/browser/renderer_host/render_widget_host_delegate.h" | 13 #include "content/browser/renderer_host/render_widget_host_delegate.h" |
14 #include "content/browser/renderer_host/render_widget_host_impl.h" | 14 #include "content/browser/renderer_host/render_widget_host_impl.h" |
15 #include "content/browser/renderer_host/render_widget_host_view_base_observer.h" | 15 #include "content/browser/renderer_host/render_widget_host_view_base_observer.h" |
16 #include "content/browser/renderer_host/text_input_manager.h" | |
16 #include "content/common/content_switches_internal.h" | 17 #include "content/common/content_switches_internal.h" |
17 #include "content/public/browser/render_widget_host_view_frame_subscriber.h" | 18 #include "content/public/browser/render_widget_host_view_frame_subscriber.h" |
18 #include "ui/display/display.h" | 19 #include "ui/display/display.h" |
19 #include "ui/display/screen.h" | 20 #include "ui/display/screen.h" |
20 #include "ui/gfx/geometry/point_conversions.h" | 21 #include "ui/gfx/geometry/point_conversions.h" |
21 #include "ui/gfx/geometry/size_conversions.h" | 22 #include "ui/gfx/geometry/size_conversions.h" |
22 #include "ui/gfx/geometry/size_f.h" | 23 #include "ui/gfx/geometry/size_f.h" |
23 | 24 |
24 namespace content { | 25 namespace content { |
25 | 26 |
26 namespace { | 27 namespace { |
27 | 28 |
28 // How many microseconds apart input events should be flushed. | 29 // How many microseconds apart input events should be flushed. |
29 const int kFlushInputRateInUs = 16666; | 30 const int kFlushInputRateInUs = 16666; |
30 | 31 |
31 } | 32 } |
32 | 33 |
33 RenderWidgetHostViewBase::RenderWidgetHostViewBase() | 34 RenderWidgetHostViewBase::RenderWidgetHostViewBase() |
34 : popup_type_(blink::WebPopupTypeNone), | 35 : popup_type_(blink::WebPopupTypeNone), |
35 background_color_(SK_ColorWHITE), | 36 background_color_(SK_ColorWHITE), |
36 mouse_locked_(false), | 37 mouse_locked_(false), |
37 showing_context_menu_(false), | 38 showing_context_menu_(false), |
38 selection_text_offset_(0), | 39 selection_text_offset_(0), |
39 selection_range_(gfx::Range::InvalidRange()), | 40 selection_range_(gfx::Range::InvalidRange()), |
40 current_device_scale_factor_(0), | 41 current_device_scale_factor_(0), |
41 current_display_rotation_(display::Display::ROTATE_0), | 42 current_display_rotation_(display::Display::ROTATE_0), |
42 pinch_zoom_enabled_(content::IsPinchToZoomEnabled()), | 43 pinch_zoom_enabled_(content::IsPinchToZoomEnabled()), |
44 text_input_manager_(nullptr), | |
43 renderer_frame_number_(0), | 45 renderer_frame_number_(0), |
44 weak_factory_(this) {} | 46 weak_factory_(this) {} |
45 | 47 |
46 RenderWidgetHostViewBase::~RenderWidgetHostViewBase() { | 48 RenderWidgetHostViewBase::~RenderWidgetHostViewBase() { |
47 DCHECK(!mouse_locked_); | 49 DCHECK(!mouse_locked_); |
48 // We call this here to guarantee that observers are notified before we go | 50 // We call this here to guarantee that observers are notified before we go |
49 // away. However, some subclasses may wish to call this earlier in their | 51 // away. However, some subclasses may wish to call this earlier in their |
50 // shutdown process, e.g. to force removal from | 52 // shutdown process, e.g. to force removal from |
51 // RenderWidgetHostInputEventRouter's surface map before relinquishing a | 53 // RenderWidgetHostInputEventRouter's surface map before relinquishing a |
52 // host pointer, as in RenderWidgetHostViewGuest. There is no harm in calling | 54 // host pointer, as in RenderWidgetHostViewGuest. There is no harm in calling |
(...skipping 322 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
375 gfx::ToRoundedPoint(point))); | 377 gfx::ToRoundedPoint(point))); |
376 } | 378 } |
377 | 379 |
378 void RenderWidgetHostViewBase::TransformPointToLocalCoordSpace( | 380 void RenderWidgetHostViewBase::TransformPointToLocalCoordSpace( |
379 const gfx::Point& point, | 381 const gfx::Point& point, |
380 cc::SurfaceId original_surface, | 382 cc::SurfaceId original_surface, |
381 gfx::Point* transformed_point) { | 383 gfx::Point* transformed_point) { |
382 *transformed_point = point; | 384 *transformed_point = point; |
383 } | 385 } |
384 | 386 |
387 void RenderWidgetHostViewBase::TextInputStateChanged( | |
388 const TextInputState& text_input_state) { | |
389 if (GetTextInputManager()) | |
390 GetTextInputManager()->UpdateTextInputState(this, text_input_state); | |
391 } | |
392 | |
393 TextInputManager* RenderWidgetHostViewBase::GetTextInputManager() { | |
394 if (text_input_manager_) | |
395 return text_input_manager_; | |
396 | |
397 RenderWidgetHostImpl* host = | |
398 RenderWidgetHostImpl::From(GetRenderWidgetHost()); | |
399 if (!host || !host->delegate()) | |
400 return nullptr; | |
401 | |
402 // This RWHV needs to be registered with the TextInputManager so that the | |
403 // TextInputManager starts observing its lifetime. | |
404 text_input_manager_ = host->delegate()->GetTextInputManager(); | |
405 if (text_input_manager_) { | |
406 text_input_manager_->Register(this); | |
407 text_input_manager_->AddObserver(this); | |
Charlie Reis
2016/05/18 20:46:03
Would it make sense to call TextInputManager::AddO
EhsanK
2016/05/24 20:42:44
For testing purposes, we just want to observe and
Charlie Reis
2016/05/26 06:22:03
Acknowledged.
| |
408 } | |
409 | |
410 return text_input_manager_; | |
411 } | |
412 | |
385 void RenderWidgetHostViewBase::AddObserver( | 413 void RenderWidgetHostViewBase::AddObserver( |
386 RenderWidgetHostViewBaseObserver* observer) { | 414 RenderWidgetHostViewBaseObserver* observer) { |
387 observers_.AddObserver(observer); | 415 observers_.AddObserver(observer); |
388 } | 416 } |
389 | 417 |
390 void RenderWidgetHostViewBase::RemoveObserver( | 418 void RenderWidgetHostViewBase::RemoveObserver( |
391 RenderWidgetHostViewBaseObserver* observer) { | 419 RenderWidgetHostViewBaseObserver* observer) { |
392 observers_.RemoveObserver(observer); | 420 observers_.RemoveObserver(observer); |
393 } | 421 } |
394 | 422 |
395 bool RenderWidgetHostViewBase::IsChildFrameForTesting() const { | 423 bool RenderWidgetHostViewBase::IsChildFrameForTesting() const { |
396 return false; | 424 return false; |
397 } | 425 } |
398 | 426 |
399 cc::SurfaceId RenderWidgetHostViewBase::SurfaceIdForTesting() const { | 427 cc::SurfaceId RenderWidgetHostViewBase::SurfaceIdForTesting() const { |
400 return cc::SurfaceId(); | 428 return cc::SurfaceId(); |
401 } | 429 } |
402 | 430 |
431 void RenderWidgetHostViewBase::OnDestroyingTextInputManager( | |
432 TextInputManager* text_input_manager) { | |
433 DCHECK(text_input_manager && text_input_manager_ == text_input_manager); | |
434 | |
435 if (text_input_manager_->IsRegisteredView(this)) | |
436 text_input_manager_->Unregister(this); | |
437 text_input_manager_->RemoveObserver(this); | |
Charlie Reis
2016/05/18 20:46:03
Seems a bit unusual to have the observer reach bac
EhsanK
2016/05/24 20:42:44
Acknowledged. However, I removed this method and a
Charlie Reis
2016/05/26 06:22:03
Acknowledged.
| |
438 text_input_manager_ = nullptr; | |
439 } | |
440 | |
403 } // namespace content | 441 } // namespace content |
OLD | NEW |