| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/chromeos/dbus/display_power_service_provider.h" | 5 #include "chromeos/dbus/services/display_power_service_provider.h" |
| 6 | 6 |
| 7 #include "ash/shell.h" | |
| 8 #include "base/bind.h" | 7 #include "base/bind.h" |
| 9 #include "dbus/bus.h" | |
| 10 #include "dbus/message.h" | 8 #include "dbus/message.h" |
| 11 #include "third_party/cros_system_api/dbus/service_constants.h" | 9 #include "third_party/cros_system_api/dbus/service_constants.h" |
| 12 #include "ui/display/chromeos/display_configurator.h" | |
| 13 #include "ui/wm/core/user_activity_detector.h" | |
| 14 | 10 |
| 15 namespace chromeos { | 11 namespace chromeos { |
| 16 | 12 |
| 17 DisplayPowerServiceProvider::DisplayPowerServiceProvider() | 13 DisplayPowerServiceProvider::DisplayPowerServiceProvider( |
| 18 : weak_ptr_factory_(this) { | 14 scoped_ptr<Delegate> delegate) |
| 15 : delegate_(delegate.Pass()), |
| 16 weak_ptr_factory_(this) { |
| 19 } | 17 } |
| 20 | 18 |
| 21 DisplayPowerServiceProvider::~DisplayPowerServiceProvider() {} | 19 DisplayPowerServiceProvider::~DisplayPowerServiceProvider() {} |
| 22 | 20 |
| 23 void DisplayPowerServiceProvider::Start( | 21 void DisplayPowerServiceProvider::Start( |
| 24 scoped_refptr<dbus::ExportedObject> exported_object) { | 22 scoped_refptr<dbus::ExportedObject> exported_object) { |
| 25 exported_object->ExportMethod( | 23 exported_object->ExportMethod( |
| 26 kLibCrosServiceInterface, | 24 kLibCrosServiceInterface, |
| 27 kSetDisplayPower, | 25 kSetDisplayPower, |
| 28 base::Bind(&DisplayPowerServiceProvider::SetDisplayPower, | 26 base::Bind(&DisplayPowerServiceProvider::SetDisplayPower, |
| (...skipping 17 matching lines...) Expand all Loading... |
| 46 << method_name; | 44 << method_name; |
| 47 } | 45 } |
| 48 } | 46 } |
| 49 | 47 |
| 50 void DisplayPowerServiceProvider::SetDisplayPower( | 48 void DisplayPowerServiceProvider::SetDisplayPower( |
| 51 dbus::MethodCall* method_call, | 49 dbus::MethodCall* method_call, |
| 52 dbus::ExportedObject::ResponseSender response_sender) { | 50 dbus::ExportedObject::ResponseSender response_sender) { |
| 53 dbus::MessageReader reader(method_call); | 51 dbus::MessageReader reader(method_call); |
| 54 int int_state = 0; | 52 int int_state = 0; |
| 55 if (reader.PopInt32(&int_state)) { | 53 if (reader.PopInt32(&int_state)) { |
| 56 // Turning displays off when the device becomes idle or on just before | |
| 57 // we suspend may trigger a mouse move, which would then be incorrectly | |
| 58 // reported as user activity. Let the UserActivityDetector | |
| 59 // know so that it can ignore such events. | |
| 60 wm::UserActivityDetector::Get()->OnDisplayPowerChanging(); | |
| 61 | |
| 62 DisplayPowerState state = static_cast<DisplayPowerState>(int_state); | 54 DisplayPowerState state = static_cast<DisplayPowerState>(int_state); |
| 63 ash::Shell::GetInstance()->display_configurator()->SetDisplayPower( | 55 delegate_->SetDisplayPower(state); |
| 64 state, ui::DisplayConfigurator::kSetDisplayPowerNoFlags); | |
| 65 } else { | 56 } else { |
| 66 LOG(ERROR) << "Unable to parse " << kSetDisplayPower << " request"; | 57 LOG(ERROR) << "Unable to parse " << kSetDisplayPower << " request"; |
| 67 } | 58 } |
| 68 | 59 |
| 69 response_sender.Run(dbus::Response::FromMethodCall(method_call)); | 60 response_sender.Run(dbus::Response::FromMethodCall(method_call)); |
| 70 } | 61 } |
| 71 | 62 |
| 72 void DisplayPowerServiceProvider::SetDisplaySoftwareDimming( | 63 void DisplayPowerServiceProvider::SetDisplaySoftwareDimming( |
| 73 dbus::MethodCall* method_call, | 64 dbus::MethodCall* method_call, |
| 74 dbus::ExportedObject::ResponseSender response_sender) { | 65 dbus::ExportedObject::ResponseSender response_sender) { |
| 75 dbus::MessageReader reader(method_call); | 66 dbus::MessageReader reader(method_call); |
| 76 bool dimmed = false; | 67 bool dimmed = false; |
| 77 if (reader.PopBool(&dimmed)) { | 68 if (reader.PopBool(&dimmed)) { |
| 78 ash::Shell::GetInstance()->SetDimming(dimmed); | 69 delegate_->SetDimming(dimmed); |
| 79 } else { | 70 } else { |
| 80 LOG(ERROR) << "Unable to parse " << kSetDisplaySoftwareDimming | 71 LOG(ERROR) << "Unable to parse " << kSetDisplaySoftwareDimming |
| 81 << " request"; | 72 << " request"; |
| 82 } | 73 } |
| 83 response_sender.Run(dbus::Response::FromMethodCall(method_call)); | 74 response_sender.Run(dbus::Response::FromMethodCall(method_call)); |
| 84 } | 75 } |
| 85 | 76 |
| 86 } // namespace chromeos | 77 } // namespace chromeos |
| OLD | NEW |