Index: athena/wm/split_view_controller.h |
diff --git a/athena/wm/split_view_controller.h b/athena/wm/split_view_controller.h |
index c6c5e8e23c01f35624982a1a85fe7c0ca24bc7ef..b32fbfc611e20497beba73b2f79939e08a9f2942 100644 |
--- a/athena/wm/split_view_controller.h |
+++ b/athena/wm/split_view_controller.h |
@@ -6,7 +6,9 @@ |
#define ATHENA_WM_SPLIT_VIEW_CONTROLLER_H_ |
#include "athena/athena_export.h" |
+#include "athena/util/drag_handle.h" |
#include "athena/wm/bezel_controller.h" |
+#include "athena/wm/public/window_manager_observer.h" |
#include "base/memory/scoped_ptr.h" |
#include "base/memory/weak_ptr.h" |
@@ -15,6 +17,17 @@ class Rect; |
class Transform; |
} |
+namespace aura { |
+class ScopedWindowTargeter; |
+class Window; |
+class WindowTargeter; |
+} |
+ |
+namespace views { |
+class ViewTargeterDelegate; |
+class Widget; |
+} |
+ |
namespace athena { |
class WindowListProvider; |
class SplitViewControllerTest; |
@@ -22,7 +35,9 @@ class SplitViewControllerTest; |
// Responsible for entering split view mode, exiting from split view mode, and |
// laying out the windows in split view mode. |
class ATHENA_EXPORT SplitViewController |
- : public BezelController::ScrollDelegate { |
+ : public BezelController::ScrollDelegate, |
+ public DragHandle::ScrollDelegate, |
+ public WindowManagerObserver { |
public: |
SplitViewController(aura::Window* container, |
WindowListProvider* window_list_provider); |
@@ -45,12 +60,10 @@ class ATHENA_EXPORT SplitViewController |
void ReplaceWindow(aura::Window* window, |
aura::Window* replace_with); |
- // Returns the bounds that the left and right windows will have once split |
- // view is active and they are done animating. If |left_window_| and |
- // |right_window_| are still animating this may be different than their |
- // current bounds. |
- gfx::Rect GetLeftTargetBounds(); |
- gfx::Rect GetRightTargetBounds(); |
+ // Returns the bounds of the left and right parts of the |container_| based |
+ // on the current value of |divider_position_|. |
+ gfx::Rect GetLeftAreaBounds(); |
+ gfx::Rect GetRightAreaBounds(); |
aura::Window* left_window() { return left_window_; } |
aura::Window* right_window() { return right_window_; } |
@@ -72,10 +85,16 @@ class ATHENA_EXPORT SplitViewController |
}; |
void SetState(State state); |
+ |
+ void InitializeDivider(); |
+ void HideDivider(); |
+ void ShowDivider(); |
+ |
void UpdateLayout(bool animate); |
void SetWindowTransforms(const gfx::Transform& left_transform, |
const gfx::Transform& right_transform, |
+ const gfx::Transform& divider_transform, |
bool animate); |
// Called when the animation initiated by SetWindowTransforms() completes. |
@@ -89,6 +108,18 @@ class ATHENA_EXPORT SplitViewController |
virtual void ScrollUpdate(float delta) OVERRIDE; |
virtual bool CanScroll() OVERRIDE; |
+ // DragHandle::ScrollDelegate: |
+ virtual void HandleScrollBegin(float delta) OVERRIDE; |
+ virtual void HandleScrollEnd() OVERRIDE; |
+ virtual void HandleScrollUpdate(float delta) OVERRIDE; |
+ virtual bool HandleCanScroll() OVERRIDE; |
+ |
+ // WindowManagerObserver: |
+ virtual void OnOverviewModeEnter() OVERRIDE; |
+ virtual void OnOverviewModeExit() OVERRIDE; |
+ virtual void OnSplitViewModeEnter() OVERRIDE; |
+ virtual void OnSplitViewModeExit() OVERRIDE; |
+ |
State state_; |
aura::Window* container_; |
@@ -101,9 +132,19 @@ class ATHENA_EXPORT SplitViewController |
aura::Window* left_window_; |
aura::Window* right_window_; |
- // Position of the separator between left_window_ and right_window_ in |
- // container_ coordinates (along the x axis). |
- int separator_position_; |
+ // X-Coordinate of the (center of the) divider between left_window_ and |
+ // right_window_ in |container_| coordinates. |
+ int divider_position_; |
+ |
+ // Visually separates the windows and contains the drag handle. |
+ views::Widget* divider_widget_; |
+ |
+ // The drag handle which can be used when split view is active to exit the |
+ // split view mode. |
+ views::View* drag_handle_; |
+ |
+ scoped_ptr<aura::ScopedWindowTargeter> window_targeter_; |
+ scoped_ptr<views::ViewTargeterDelegate> view_targeter_delegate_; |
base::WeakPtrFactory<SplitViewController> weak_factory_; |