blob: 6d26e68c9537b3789656787d11d98fe67cadaf7b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
// Copyright (c) 2012 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_WM_SCREEN_DIMMER_H_
#define ASH_WM_SCREEN_DIMMER_H_
#include "ash/ash_export.h"
#include "ash/shell_observer.h"
#include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "base/memory/scoped_ptr.h"
#include "ui/aura/window_observer.h"
namespace ui {
class Layer;
}
namespace ash {
class DimWindow;
// ScreenDimmer displays a partially-opaque layer above everything
// else in the given container window to darken the display. It shouldn't be
// used for long-term brightness adjustments due to performance
// considerations -- it's only intended for cases where we want to
// briefly dim the screen (e.g. to indicate to the user that we're
// about to suspend a machine that lacks an internal backlight that
// can be adjusted).
class ASH_EXPORT ScreenDimmer : ShellObserver {
public:
// Creates a screen dimmer for the containers given by |container_id|.
// It's owned by the container in the primary root window and will be
// destroyed when the container is destroyed.
static ScreenDimmer* GetForContainer(int container_id);
// Creates a dimmer a root window level. This is used for suspend animation.
static ScreenDimmer* GetForRoot();
~ScreenDimmer() override;
// Dim or undim the layers.
void SetDimming(bool should_dim);
bool is_dimming() const { return is_dimming_; }
// Find a ScreenDimmer in the container, or nullptr if it does not exist.
static ScreenDimmer* FindForTest(int container_id);
private:
static aura::Window* FindContainer(int container_id);
explicit ScreenDimmer(int container_id);
// ShellObserver:
void OnRootWindowAdded(aura::Window* root_window) override;
// Update the dimming state. This will also create a new DimWindow
// if necessary. (Used when a new display is connected)
void Update(bool should_dim);
int container_id_;
float target_opacity_;
// Are we currently dimming the screen?
bool is_dimming_;
DISALLOW_COPY_AND_ASSIGN(ScreenDimmer);
};
} // namespace ash
#endif // ASH_WM_SCREEN_DIMMER_H_
|