| Index: ash/common/frame/caption_buttons/frame_size_button.h
|
| diff --git a/ash/common/frame/caption_buttons/frame_size_button.h b/ash/common/frame/caption_buttons/frame_size_button.h
|
| deleted file mode 100644
|
| index 0ab4dcf0a2274dea815083546cf4ce9ec3c5c21a..0000000000000000000000000000000000000000
|
| --- a/ash/common/frame/caption_buttons/frame_size_button.h
|
| +++ /dev/null
|
| @@ -1,120 +0,0 @@
|
| -// Copyright 2014 The Chromium Authors. All rights reserved.
|
| -// Use of this source code is governed by a BSD-style license that can be
|
| -// found in the LICENSE file.
|
| -
|
| -#ifndef ASH_COMMON_FRAME_CAPTION_BUTTONS_FRAME_SIZE_BUTTON_H_
|
| -#define ASH_COMMON_FRAME_CAPTION_BUTTONS_FRAME_SIZE_BUTTON_H_
|
| -
|
| -#include <memory>
|
| -
|
| -#include "ash/ash_export.h"
|
| -#include "ash/common/frame/caption_buttons/frame_caption_button.h"
|
| -#include "ash/common/frame/caption_buttons/frame_size_button_delegate.h"
|
| -#include "base/macros.h"
|
| -#include "base/timer/timer.h"
|
| -
|
| -namespace views {
|
| -class Widget;
|
| -}
|
| -
|
| -namespace ash {
|
| -class FrameSizeButtonDelegate;
|
| -class PhantomWindowController;
|
| -
|
| -// The maximize/restore button.
|
| -// When the mouse is pressed over the size button or the size button is touched:
|
| -// - The minimize and close buttons are set to snap left and snap right
|
| -// respectively.
|
| -// - The size button stays pressed while the mouse is over the buttons to snap
|
| -// left and to snap right. The button underneath the mouse is hovered.
|
| -// When the drag terminates, the action for the button underneath the mouse
|
| -// is executed. For the sake of simplicity, the size button is the event
|
| -// handler for a click starting on the size button and the entire drag.
|
| -class ASH_EXPORT FrameSizeButton : public FrameCaptionButton {
|
| - public:
|
| - FrameSizeButton(views::ButtonListener* listener,
|
| - views::Widget* frame,
|
| - FrameSizeButtonDelegate* delegate);
|
| -
|
| - ~FrameSizeButton() override;
|
| -
|
| - // views::CustomButton overrides:
|
| - bool OnMousePressed(const ui::MouseEvent& event) override;
|
| - bool OnMouseDragged(const ui::MouseEvent& event) override;
|
| - void OnMouseReleased(const ui::MouseEvent& event) override;
|
| - void OnMouseCaptureLost() override;
|
| - void OnMouseMoved(const ui::MouseEvent& event) override;
|
| - void OnGestureEvent(ui::GestureEvent* event) override;
|
| -
|
| - void set_delay_to_set_buttons_to_snap_mode(int delay_ms) {
|
| - set_buttons_to_snap_mode_delay_ms_ = delay_ms;
|
| - }
|
| -
|
| - private:
|
| - enum SnapType { SNAP_LEFT, SNAP_RIGHT, SNAP_NONE };
|
| -
|
| - // Starts |set_buttons_to_snap_mode_timer_|.
|
| - void StartSetButtonsToSnapModeTimer(const ui::LocatedEvent& event);
|
| -
|
| - // Animates the buttons adjacent to the size button to snap left and right.
|
| - void AnimateButtonsToSnapMode();
|
| -
|
| - // Sets the buttons adjacent to the size button to snap left and right.
|
| - // Passing in ANIMATE_NO progresses the animation (if any) to the end.
|
| - void SetButtonsToSnapMode(FrameSizeButtonDelegate::Animate animate);
|
| -
|
| - // Updates |snap_type_|, whether the size button is pressed and whether any
|
| - // other buttons are hovered.
|
| - void UpdateSnapType(const ui::LocatedEvent& event);
|
| -
|
| - // Returns the button which should be hovered (if any) while in "snap mode"
|
| - // for |event_location_in_screen|.
|
| - const FrameCaptionButton* GetButtonToHover(
|
| - const gfx::Point& event_location_in_screen) const;
|
| -
|
| - // Snaps |frame_| according to |snap_type_|. Returns true if |frame_| was
|
| - // snapped.
|
| - bool CommitSnap(const ui::LocatedEvent& event);
|
| -
|
| - // Sets the buttons adjacent to the size button to minimize and close again.
|
| - // Clears any state set while snapping was enabled. |animate| indicates
|
| - // whether the buttons should animate back to their original icons.
|
| - void SetButtonsToNormalMode(FrameSizeButtonDelegate::Animate animate);
|
| -
|
| - // Widget that the size button acts on.
|
| - views::Widget* frame_;
|
| -
|
| - // Not owned.
|
| - FrameSizeButtonDelegate* delegate_;
|
| -
|
| - // Location of the event which started |set_buttons_to_snap_mode_timer_| in
|
| - // view coordinates.
|
| - gfx::Point set_buttons_to_snap_mode_timer_event_location_;
|
| -
|
| - // The delay between the user pressing the size button and the buttons
|
| - // adjacent to the size button morphing into buttons for snapping left and
|
| - // right.
|
| - int set_buttons_to_snap_mode_delay_ms_;
|
| -
|
| - base::OneShotTimer set_buttons_to_snap_mode_timer_;
|
| -
|
| - // Whether the buttons adjacent to the size button snap the window left and
|
| - // right.
|
| - bool in_snap_mode_;
|
| -
|
| - // The action to execute when the drag/click is ended. If
|
| - // |snap_type_| == SNAP_NONE, the size button's default action is run when the
|
| - // drag/click is ended.
|
| - SnapType snap_type_;
|
| -
|
| - // Displays a preview of how the window's bounds will change as a result of
|
| - // snapping the window left or right. The preview is only visible if the snap
|
| - // left or snap right button is pressed.
|
| - std::unique_ptr<PhantomWindowController> phantom_window_controller_;
|
| -
|
| - DISALLOW_COPY_AND_ASSIGN(FrameSizeButton);
|
| -};
|
| -
|
| -} // namespace ash
|
| -
|
| -#endif // ASH_COMMON_FRAME_CAPTION_BUTTONS_FRAME_SIZE_BUTTON_H_
|
|
|