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 #ifndef ASH_WM_DEFAULT_WINDOW_RESIZER_H_ | 5 #ifndef ASH_WM_DEFAULT_WINDOW_RESIZER_H_ |
6 #define ASH_WM_DEFAULT_WINDOW_RESIZER_H_ | 6 #define ASH_WM_DEFAULT_WINDOW_RESIZER_H_ |
7 | 7 |
8 #include "ash/wm/window_resizer.h" | 8 #include "ash/wm/window_resizer.h" |
9 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
10 | 10 |
11 namespace ash { | 11 namespace ash { |
12 | 12 |
13 // WindowResizer is used by ToplevelWindowEventFilter to handle dragging, moving | 13 // WindowResizer is used by ToplevelWindowEventFilter to handle dragging, moving |
14 // or resizing a window. All coordinates passed to this are in the parent | 14 // or resizing a window. All coordinates passed to this are in the parent |
15 // windows coordiantes. | 15 // windows coordiantes. |
16 class ASH_EXPORT DefaultWindowResizer : public WindowResizer { | 16 class ASH_EXPORT DefaultWindowResizer : public WindowResizer { |
17 public: | 17 public: |
18 virtual ~DefaultWindowResizer(); | 18 virtual ~DefaultWindowResizer(); |
19 | 19 |
20 // Creates a new DefaultWindowResizer. The caller takes ownership of the | 20 // Creates a new DefaultWindowResizer. The caller takes ownership of the |
21 // returned object. Returns NULL if not resizable. | 21 // returned object. |
22 static DefaultWindowResizer* Create(aura::Window* window, | 22 static DefaultWindowResizer* Create(wm::WindowState* window_state); |
23 const gfx::Point& location, | |
24 int window_component, | |
25 aura::client::WindowMoveSource source); | |
26 | 23 |
27 // Returns true if the drag will result in changing the window in anyway. | 24 // Returns true if the drag will result in changing the window in anyway. |
28 bool is_resizable() const { return details_.is_resizable; } | 25 bool is_resizable() const { return details().is_resizable; } |
29 | 26 |
30 bool changed_size() const { | 27 bool changed_size() const { |
31 return !(details_.bounds_change & kBoundsChange_Repositions); | 28 return !(details().bounds_change & kBoundsChange_Repositions); |
32 } | 29 } |
33 aura::Window* target_window() const { return details_.window; } | |
34 | 30 |
35 // WindowResizer: | 31 // WindowResizer: |
36 virtual void Drag(const gfx::Point& location, int event_flags) OVERRIDE; | 32 virtual void Drag(const gfx::Point& location, int event_flags) OVERRIDE; |
37 virtual void CompleteDrag() OVERRIDE; | 33 virtual void CompleteDrag() OVERRIDE; |
38 virtual void RevertDrag() OVERRIDE; | 34 virtual void RevertDrag() OVERRIDE; |
39 virtual aura::Window* GetTarget() OVERRIDE; | |
40 virtual const gfx::Point& GetInitialLocation() const OVERRIDE; | |
41 | 35 |
42 private: | 36 private: |
43 explicit DefaultWindowResizer(const Details& details); | 37 explicit DefaultWindowResizer(wm::WindowState* window_state); |
44 | |
45 const Details details_; | |
46 | 38 |
47 // Set to true once Drag() is invoked and the bounds of the window change. | 39 // Set to true once Drag() is invoked and the bounds of the window change. |
48 bool did_move_or_resize_; | 40 bool did_move_or_resize_; |
49 | 41 |
50 DISALLOW_COPY_AND_ASSIGN(DefaultWindowResizer); | 42 DISALLOW_COPY_AND_ASSIGN(DefaultWindowResizer); |
51 }; | 43 }; |
52 | 44 |
53 } // namespace aura | 45 } // namespace aura |
54 | 46 |
55 #endif // ASH_WM_DEFAULT_WINDOW_RESIZER_H_ | 47 #endif // ASH_WM_DEFAULT_WINDOW_RESIZER_H_ |
OLD | NEW |