Roll src/third_party/WebKit eac3800:0237a66 (svn 202606:202607)
[chromium-blink-merge.git] / ash / rotator / screen_rotation_animator.h
blobd57a85e7ae37db7139ae09261778dc074a2cecd8
1 // Copyright 2015 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.
5 #ifndef ASH_ROTATOR_SCREEN_ROTATION_ANIMATOR_H_
6 #define ASH_ROTATOR_SCREEN_ROTATION_ANIMATOR_H_
8 #include "ash/ash_export.h"
9 #include "base/basictypes.h"
10 #include "ui/gfx/display.h"
12 namespace ash {
14 // Utility to perform a screen rotation with an animation.
15 class ASH_EXPORT ScreenRotationAnimator {
16 public:
17 explicit ScreenRotationAnimator(int64 display_id);
18 ~ScreenRotationAnimator();
20 // Returns true if the screen rotation animation can be completed
21 // successfully. For example an animation is not possible if |display_id_|
22 // specifies a gfx::Display that is not currently active. See
23 // www.crbug.com/479503.
24 bool CanAnimate() const;
26 // Rotates the gfx::Display specified by |display_id_| to the |new_rotation|
27 // orientation, for the given |source|. The rotation will also become active.
28 // Clients should only call |Rotate()| if |CanAnimate()| returns true.
29 void Rotate(gfx::Display::Rotation new_rotation,
30 gfx::Display::RotationSource source);
32 private:
33 // The id of the display to rotate.
34 int64 display_id_;
36 DISALLOW_COPY_AND_ASSIGN(ScreenRotationAnimator);
39 } // namespace ash
41 #endif // ASH_ROTATOR_SCREEN_ROTATION_ANIMATOR_H_