• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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
3 // found in the LICENSE file.
4 
5 #ifndef UI_BASE_IME_INPUT_METHOD_BASE_H_
6 #define UI_BASE_IME_INPUT_METHOD_BASE_H_
7 
8 #include "base/basictypes.h"
9 #include "base/compiler_specific.h"
10 #include "base/memory/weak_ptr.h"
11 #include "base/observer_list.h"
12 #include "ui/base/ime/input_method.h"
13 #include "ui/base/ui_base_export.h"
14 
15 namespace gfx {
16 class Rect;
17 }  // namespace gfx
18 
19 namespace ui {
20 
21 class InputMethodObserver;
22 class KeyEvent;
23 class TextInputClient;
24 
25 // A helper class providing functionalities shared among ui::InputMethod
26 // implementations.
27 class UI_BASE_EXPORT InputMethodBase
NON_EXPORTED_BASE(public InputMethod)28    : NON_EXPORTED_BASE(public InputMethod),
29      public base::SupportsWeakPtr<InputMethodBase> {
30  public:
31   InputMethodBase();
32   virtual ~InputMethodBase();
33 
34   // Overriden from InputMethod.
35   virtual void SetDelegate(internal::InputMethodDelegate* delegate) OVERRIDE;
36   virtual void Init(bool focused) OVERRIDE;
37   // If a derived class overrides OnFocus()/OnBlur(), it should call parent's
38   // implementation first, to make sure |system_toplevel_window_focused_| flag
39   // can be updated correctly.
40   virtual void OnFocus() OVERRIDE;
41   virtual void OnBlur() OVERRIDE;
42   virtual void SetFocusedTextInputClient(TextInputClient* client) OVERRIDE;
43   virtual void DetachTextInputClient(TextInputClient* client) OVERRIDE;
44   virtual TextInputClient* GetTextInputClient() const OVERRIDE;
45 
46   // If a derived class overrides this method, it should call parent's
47   // implementation.
48   virtual void OnTextInputTypeChanged(const TextInputClient* client) OVERRIDE;
49 
50   virtual TextInputType GetTextInputType() const OVERRIDE;
51   virtual TextInputMode GetTextInputMode() const OVERRIDE;
52   virtual bool CanComposeInline() const OVERRIDE;
53   virtual void ShowImeIfNeeded() OVERRIDE;
54 
55   virtual void AddObserver(InputMethodObserver* observer) OVERRIDE;
56   virtual void RemoveObserver(InputMethodObserver* observer) OVERRIDE;
57 
58  protected:
59   virtual void OnWillChangeFocusedClient(TextInputClient* focused_before,
60                                          TextInputClient* focused) {}
61   virtual void OnDidChangeFocusedClient(TextInputClient* focused_before,
62                                         TextInputClient* focused) {}
63 
64   // Returns true if |client| is currently focused.
65   bool IsTextInputClientFocused(const TextInputClient* client);
66 
67   // Checks if the focused text input client's text input type is
68   // TEXT_INPUT_TYPE_NONE. Also returns true if there is no focused text
69   // input client.
70   bool IsTextInputTypeNone() const;
71 
72   // Convenience method to call the focused text input client's
73   // OnInputMethodChanged() method. It'll only take effect if the current text
74   // input type is not TEXT_INPUT_TYPE_NONE.
75   void OnInputMethodChanged() const;
76 
77   // Convenience method to call delegate_->DispatchKeyEventPostIME().
78   // Returns true if the event was processed
79   bool DispatchKeyEventPostIME(const ui::KeyEvent& event) const;
80 
81   // Convenience method to notify all observers of TextInputClient changes.
82   void NotifyTextInputStateChanged(const TextInputClient* client);
83 
84   // Interface for for signalling candidate window events.
85   // See also *Callback functions below. To avoid reentrancy issue that
86   // TextInputClient manipulates IME state during even handling, these methods
87   // defer sending actual signals to renderer.
88   void OnCandidateWindowShown();
89   void OnCandidateWindowUpdated();
90   void OnCandidateWindowHidden();
91 
92   bool system_toplevel_window_focused() const {
93     return system_toplevel_window_focused_;
94   }
95 
96  private:
97   void SetFocusedTextInputClientInternal(TextInputClient* client);
98 
99   // Deferred callbacks for signalling TextInputClient about candidate window
100   // appearance changes.
101   void CandidateWindowShownCallback();
102   void CandidateWindowUpdatedCallback();
103   void CandidateWindowHiddenCallback();
104 
105   internal::InputMethodDelegate* delegate_;
106   TextInputClient* text_input_client_;
107 
108   ObserverList<InputMethodObserver> observer_list_;
109 
110   bool system_toplevel_window_focused_;
111 
112   DISALLOW_COPY_AND_ASSIGN(InputMethodBase);
113 };
114 
115 }  // namespace ui
116 
117 #endif  // UI_BASE_IME_INPUT_METHOD_BASE_H_
118