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 |