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

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

Issue 2045363002: Routing IME Result Calls to the Correct RenderWidgetHost (Aura Only) (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixing a comment Created 4 years, 6 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 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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_TEXT_INPUT_MANAGER_H__ 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_TEXT_INPUT_MANAGER_H__
6 #define CONTENT_BROWSER_RENDERER_HOST_TEXT_INPUT_MANAGER_H__ 6 #define CONTENT_BROWSER_RENDERER_HOST_TEXT_INPUT_MANAGER_H__
7 7
8 #include <unordered_map> 8 #include <unordered_map>
9 9
10 #include "base/observer_list.h" 10 #include "base/observer_list.h"
11 #include "content/common/content_export.h" 11 #include "content/common/content_export.h"
12 #include "content/common/text_input_state.h" 12 #include "content/common/text_input_state.h"
13 13
14 namespace content { 14 namespace content {
15 15
16 class RenderWidgetHostImpl;
16 class RenderWidgetHostView; 17 class RenderWidgetHostView;
17 class RenderWidgetHostViewBase; 18 class RenderWidgetHostViewBase;
18 class WebContents; 19 class WebContents;
19 20
20 // A class which receives updates of TextInputState from multiple sources and 21 // A class which receives updates of TextInputState from multiple sources and
21 // decides what the new TextInputState is. It also notifies the observers when 22 // decides what the new TextInputState is. It also notifies the observers when
22 // text input state is updated. 23 // text input state is updated.
23 class CONTENT_EXPORT TextInputManager { 24 class CONTENT_EXPORT TextInputManager {
24 public: 25 public:
25 // The tab's top-level RWHV should be an observer of TextInputManager to get 26 // The tab's top-level RWHV should be an observer of TextInputManager to get
26 // notifications about changes in TextInputState or other IME related state 27 // notifications about changes in TextInputState or other IME related state
27 // for child frames. 28 // for child frames.
28 class CONTENT_EXPORT Observer { 29 class CONTENT_EXPORT Observer {
29 public: 30 public:
30 // Called when a view has called UpdateTextInputState on TextInputManager. 31 // Called when a view has called UpdateTextInputState on TextInputManager.
31 // If the call has led to a change in TextInputState, |did_update_state| is 32 // If the call has led to a change in TextInputState, |did_update_state| is
32 // true. In some plaforms, we need this update even when the state has not 33 // true. In some plaforms, we need this update even when the state has not
33 // changed (e.g., Aura for updating IME). 34 // changed (e.g., Aura for updating IME).
34 virtual void OnUpdateTextInputStateCalled( 35 virtual void OnUpdateTextInputStateCalled(
35 TextInputManager* text_input_manager, 36 TextInputManager* text_input_manager,
36 RenderWidgetHostViewBase* updated_view, 37 RenderWidgetHostViewBase* updated_view,
37 bool did_update_state) {} 38 bool did_update_state) {}
38 }; 39 };
39 40
40 TextInputManager(); 41 TextInputManager();
41 ~TextInputManager(); 42 ~TextInputManager();
42 43
43 // Returns the currently active view (i.e., the RWHV with a focused <input> 44 // ---------------------------------------------------------------------------
44 // element), or nullptr if none exist. The |active_view_| cannot have a 45 // The following methods can be used to obtain information about IME-related
45 // |TextInputState.type| of ui::TEXT_INPUT_TYPE_NONE. 46 // state for the active RenderWidget.
Charlie Reis 2016/06/21 21:13:56 We've lost the last sentence of the comment. Shou
EhsanK 2016/06/22 18:26:33 Yes and thanks for noticing this.
46 RenderWidgetHostViewBase* GetActiveView() const; 47
48 // Returns the currently active widget, i.e., the RWH which is associated with
49 // |active_view_|.
50 RenderWidgetHostImpl* GetActiveWidget() const;
47 51
48 // Returns the TextInputState corresponding to |active_view_|. 52 // Returns the TextInputState corresponding to |active_view_|.
49 // Users of this method should not hold on to the pointer as it might become 53 // Users of this method should not hold on to the pointer as it might become
50 // dangling if the TextInputManager or |active_view_| might go away. 54 // dangling if the TextInputManager or |active_view_| might go away.
51 const TextInputState* GetTextInputState(); 55 const TextInputState* GetTextInputState();
52 56
57 // ---------------------------------------------------------------------------
58 // The following methods are called by RWHVs on the tab to update their IME-
59 // related state.
60
53 // Updates the TextInputState for |view|. 61 // Updates the TextInputState for |view|.
54 void UpdateTextInputState(RenderWidgetHostViewBase* view, 62 void UpdateTextInputState(RenderWidgetHostViewBase* view,
55 const TextInputState& state); 63 const TextInputState& state);
56 64
57 // Registers the given |view| for tracking its TextInputState. This is called 65 // Registers the given |view| for tracking its TextInputState. This is called
58 // by any view which has updates in its TextInputState (whether tab's RWHV or 66 // by any view which has updates in its TextInputState (whether tab's RWHV or
59 // that of a child frame). The |view| must unregister itself before being 67 // that of a child frame). The |view| must unregister itself before being
60 // destroyed (i.e., call TextInputManager::Unregister). 68 // destroyed (i.e., call TextInputManager::Unregister).
61 void Register(RenderWidgetHostViewBase* view); 69 void Register(RenderWidgetHostViewBase* view);
62 70
(...skipping 15 matching lines...) Expand all
78 void RemoveObserver(Observer* observer); 86 void RemoveObserver(Observer* observer);
79 87
80 private: 88 private:
81 friend bool GetTextInputTypeForView(WebContents* web_contents, 89 friend bool GetTextInputTypeForView(WebContents* web_contents,
82 RenderWidgetHostView* view, 90 RenderWidgetHostView* view,
83 ui::TextInputType* type); 91 ui::TextInputType* type);
84 92
85 void NotifyObserversAboutInputStateUpdate(RenderWidgetHostViewBase* view, 93 void NotifyObserversAboutInputStateUpdate(RenderWidgetHostViewBase* view,
86 bool did_update_state); 94 bool did_update_state);
87 95
88 // The view with active text input state. 96 // The view with active text input state, i.e., a focused <input> element.
89 RenderWidgetHostViewBase* active_view_; 97 RenderWidgetHostViewBase* active_view_;
90 98
91 std::unordered_map<RenderWidgetHostViewBase*, TextInputState> 99 std::unordered_map<RenderWidgetHostViewBase*, TextInputState>
92 text_input_state_map_; 100 text_input_state_map_;
93 101
94 base::ObserverList<Observer> observer_list_; 102 base::ObserverList<Observer> observer_list_;
95 103
96 DISALLOW_COPY_AND_ASSIGN(TextInputManager); 104 DISALLOW_COPY_AND_ASSIGN(TextInputManager);
97 }; 105 };
98 } 106 }
99 107
100 #endif // CONTENT_BROWSER_RENDERER_HOST_TEXT_INPUT_MANAGER_H__ 108 #endif // CONTENT_BROWSER_RENDERER_HOST_TEXT_INPUT_MANAGER_H__
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698