| Index: athena/system/power_button_controller.cc
|
| diff --git a/athena/system/power_button_controller.cc b/athena/system/power_button_controller.cc
|
| index b4195a3061a080c7ea01b60c68061beec61dfa74..521dbde6417ba65e532f2f263c284fbbb647ae64 100644
|
| --- a/athena/system/power_button_controller.cc
|
| +++ b/athena/system/power_button_controller.cc
|
| @@ -5,23 +5,31 @@
|
| #include "athena/system/power_button_controller.h"
|
|
|
| #include "athena/screen/public/screen_manager.h"
|
| +#include "base/strings/utf_string_conversions.h"
|
| #include "chromeos/dbus/dbus_thread_manager.h"
|
| -#include "ui/compositor/layer_animator.h"
|
| -#include "ui/compositor/scoped_layer_animation_settings.h"
|
| +#include "ui/gfx/font_list.h"
|
| +#include "ui/views/background.h"
|
| +#include "ui/views/border.h"
|
| +#include "ui/views/controls/label.h"
|
| +#include "ui/views/layout/box_layout.h"
|
| +#include "ui/views/widget/widget.h"
|
|
|
| namespace athena {
|
| namespace {
|
|
|
| -// Duration of the shutdown animation.
|
| -const int kShutdownDurationMs = 1000;
|
| +// The amount of time that the power button must be held to show the shutdown
|
| +// warning dialog.
|
| +const int kShowShutdownWarningTimeoutMs = 1000;
|
|
|
| -// Duration of the cancel shutdown animation.
|
| -const int kCancelShutdownDurationMs = 500;
|
| +// The amount of time that the power button must be held to shut down the
|
| +// device.
|
| +const int kShutdownTimeoutMs = 5000;
|
|
|
| } // namespace
|
|
|
| -PowerButtonController::PowerButtonController()
|
| - : brightness_is_zero_(false),
|
| +PowerButtonController::PowerButtonController(aura::Window* dialog_container)
|
| + : warning_message_container_(dialog_container),
|
| + brightness_is_zero_(false),
|
| state_(STATE_OTHER) {
|
| chromeos::DBusThreadManager::Get()->GetPowerManagerClient()->AddObserver(
|
| this);
|
| @@ -32,21 +40,48 @@ PowerButtonController::~PowerButtonController() {
|
| this);
|
| }
|
|
|
| -void PowerButtonController::StartGrayscaleAndBrightnessAnimation(
|
| - float target,
|
| - int duration_ms,
|
| - gfx::Tween::Type tween_type) {
|
| - ui::LayerAnimator* animator = ScreenManager::Get()->GetScreenAnimator();
|
| - ui::ScopedLayerAnimationSettings settings(animator);
|
| - settings.SetTransitionDuration(
|
| - base::TimeDelta::FromMilliseconds(duration_ms));
|
| - settings.SetTweenType(tween_type);
|
| - settings.SetPreemptionStrategy(
|
| - ui::LayerAnimator::IMMEDIATELY_ANIMATE_TO_NEW_TARGET);
|
| - settings.AddObserver(this);
|
| -
|
| - animator->SetBrightness(target);
|
| - animator->SetGrayscale(target);
|
| +void PowerButtonController::ShowShutdownWarningDialog() {
|
| + state_ = STATE_SHUTDOWN_WARNING_VISIBLE;
|
| +
|
| + shutdown_warning_message_.reset(new views::Widget);
|
| +
|
| + views::Widget::InitParams params(views::Widget::InitParams::TYPE_POPUP);
|
| + params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
|
| + params.parent = warning_message_container_;
|
| + shutdown_warning_message_->Init(params);
|
| +
|
| + // TODO(pkotwicz): Get text from the resource.
|
| + views::Label* label = new views::Label(
|
| + base::UTF8ToUTF16("Keep holding power button to shutdown."));
|
| + label->SetBackgroundColor(SK_ColorWHITE);
|
| + label->SetFontList(gfx::FontList().DeriveWithStyle(gfx::Font::BOLD));
|
| +
|
| + views::View* container = new views::View;
|
| + container->AddChildView(label);
|
| +
|
| + const int kBorderSpacing = 50;
|
| + container->SetLayoutManager(new views::BoxLayout(
|
| + views::BoxLayout::kHorizontal, kBorderSpacing, kBorderSpacing, 0));
|
| + container->set_background(
|
| + views::Background::CreateSolidBackground(SK_ColorWHITE));
|
| + container->SetBorder(views::Border::CreateSolidBorder(1, SK_ColorBLACK));
|
| +
|
| + shutdown_warning_message_->SetContentsView(container);
|
| + shutdown_warning_message_->CenterWindow(container->GetPreferredSize());
|
| + shutdown_warning_message_->Show();
|
| +
|
| + timer_.Start(FROM_HERE,
|
| + base::TimeDelta::FromMilliseconds(kShutdownTimeoutMs -
|
| + kShowShutdownWarningTimeoutMs),
|
| + this,
|
| + &PowerButtonController::Shutdown);
|
| +}
|
| +
|
| +void PowerButtonController::Shutdown() {
|
| + state_ = STATE_SHUTDOWN_REQUESTED;
|
| + chromeos::DBusThreadManager::Get()
|
| + ->GetPowerManagerClient()
|
| + ->RequestShutdown();
|
| }
|
|
|
| void PowerButtonController::BrightnessChanged(int level, bool user_initiated) {
|
| @@ -58,35 +93,33 @@ void PowerButtonController::BrightnessChanged(int level, bool user_initiated) {
|
| void PowerButtonController::PowerButtonEventReceived(
|
| bool down,
|
| const base::TimeTicks& timestamp) {
|
| - // Avoid requesting a shutdown if the power button is pressed while the screen
|
| - // is off (http://crbug.com/128451)
|
| + if (state_ == STATE_SHUTDOWN_REQUESTED)
|
| + return;
|
| +
|
| + // Avoid requesting suspend or shutdown if the power button is pressed while
|
| + // the screen is off (http://crbug.com/128451).
|
| base::TimeDelta time_since_zero_brightness = brightness_is_zero_ ?
|
| base::TimeDelta() : (base::TimeTicks::Now() - zero_brightness_end_time_);
|
| const int kShortTimeMs = 10;
|
| if (time_since_zero_brightness.InMilliseconds() <= kShortTimeMs)
|
| return;
|
|
|
| - if (state_ == STATE_SHUTDOWN_REQUESTED)
|
| - return;
|
| -
|
| - StopObservingImplicitAnimations();
|
| if (down) {
|
| - state_ = STATE_PRE_SHUTDOWN_ANIMATION;
|
| - StartGrayscaleAndBrightnessAnimation(
|
| - 1.0f, kShutdownDurationMs, gfx::Tween::EASE_IN);
|
| + state_ = STATE_SUSPEND_ON_RELEASE;
|
| + timer_.Start(
|
| + FROM_HERE,
|
| + base::TimeDelta::FromMilliseconds(kShowShutdownWarningTimeoutMs),
|
| + this,
|
| + &PowerButtonController::ShowShutdownWarningDialog);
|
| } else {
|
| + if (state_ == STATE_SUSPEND_ON_RELEASE) {
|
| + chromeos::DBusThreadManager::Get()
|
| + ->GetPowerManagerClient()
|
| + ->RequestSuspend();
|
| + }
|
| state_ = STATE_OTHER;
|
| - StartGrayscaleAndBrightnessAnimation(
|
| - 0.0f, kCancelShutdownDurationMs, gfx::Tween::EASE_IN_OUT);
|
| - }
|
| -}
|
| -
|
| -void PowerButtonController::OnImplicitAnimationsCompleted() {
|
| - if (state_ == STATE_PRE_SHUTDOWN_ANIMATION) {
|
| - state_ = STATE_SHUTDOWN_REQUESTED;
|
| - chromeos::DBusThreadManager::Get()
|
| - ->GetPowerManagerClient()
|
| - ->RequestShutdown();
|
| + timer_.Stop();
|
| + shutdown_warning_message_.reset();
|
| }
|
| }
|
|
|
|
|