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

Side by Side Diff: chrome/browser/automation/ui_controls.h

Issue 9390038: Move automation/ui_controls to ui/ui_controls (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: win_aura fix, sync Created 8 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 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 CHROME_BROWSER_AUTOMATION_UI_CONTROLS_H_
6 #define CHROME_BROWSER_AUTOMATION_UI_CONTROLS_H_
7 #pragma once
8
9 #include "build/build_config.h"
10
11 #if defined(OS_WIN)
12 #include <wtypes.h>
13 #endif
14
15 #include "base/callback_forward.h"
16 #include "ui/base/keycodes/keyboard_codes.h"
17 #include "ui/gfx/native_widget_types.h"
18 #include "ui/gfx/point.h"
19
20 #if defined(TOOLKIT_VIEWS)
21 namespace views {
22 class View;
23 }
24 #endif
25
26 namespace ui_controls {
27
28 // Many of the functions in this class include a variant that takes a Closure.
29 // The version that takes a Closure waits until the generated event is
30 // processed. Once the generated event is processed the Closure is Run (and
31 // deleted). Note that this is a somewhat fragile process in that any event of
32 // the correct type (key down, mouse click, etc.) will trigger the Closure to be
33 // run. Hence a usage such as
34 //
35 // SendKeyPress(...);
36 // SendKeyPressNotifyWhenDone(..., task);
37 //
38 // might trigger |task| early.
39 //
40 // Note: Windows does not currently do anything with the |window| argument for
41 // these functions, so passing NULL is ok.
42
43 // Send a key press with/without modifier keys.
44 //
45 // If you're writing a test chances are you want the variant in ui_test_utils.
46 // See it for details.
47 bool SendKeyPress(gfx::NativeWindow window,
48 ui::KeyboardCode key,
49 bool control,
50 bool shift,
51 bool alt,
52 bool command);
53 bool SendKeyPressNotifyWhenDone(gfx::NativeWindow window,
54 ui::KeyboardCode key,
55 bool control,
56 bool shift,
57 bool alt,
58 bool command,
59 const base::Closure& task);
60
61 // Simulate a mouse move. (x,y) are absolute screen coordinates.
62 bool SendMouseMove(long x, long y);
63 bool SendMouseMoveNotifyWhenDone(long x, long y, const base::Closure& task);
64
65 enum MouseButton {
66 LEFT = 0,
67 MIDDLE,
68 RIGHT,
69 };
70
71 // Used to indicate the state of the button when generating events.
72 enum MouseButtonState {
73 UP = 1,
74 DOWN = 2
75 };
76
77 // Sends a mouse down and/or up message. The click will be sent to wherever
78 // the cursor currently is, so be sure to move the cursor before calling this
79 // (and be sure the cursor has arrived!).
80 bool SendMouseEvents(MouseButton type, int state);
81 bool SendMouseEventsNotifyWhenDone(MouseButton type, int state,
82 const base::Closure& task);
83 // Same as SendMouseEvents with UP | DOWN.
84 bool SendMouseClick(MouseButton type);
85
86 // A combination of SendMouseMove to the middle of the view followed by
87 // SendMouseEvents.
88 void MoveMouseToCenterAndPress(
89 #if defined(TOOLKIT_VIEWS)
90 views::View* view,
91 #elif defined(TOOLKIT_GTK)
92 GtkWidget* widget,
93 #elif defined(OS_MACOSX)
94 NSView* view,
95 #endif
96 MouseButton button,
97 int state,
98 const base::Closure& task);
99
100 #if defined(TOOLKIT_VIEWS)
101 // Runs |closure| after processing all pending ui events.
102 void RunClosureAfterAllPendingUIEvents(const base::Closure& closure);
103 #endif
104
105 } // ui_controls
106
107 #endif // CHROME_BROWSER_AUTOMATION_UI_CONTROLS_H_
OLDNEW
« no previous file with comments | « chrome/browser/automation/testing_automation_provider_gtk.cc ('k') | chrome/browser/automation/ui_controls_aurawin.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698