| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/ui/webui/options2/chromeos/display_options_handler.h" | 5 #include "chrome/browser/ui/webui/options2/chromeos/display_options_handler.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "ash/display/display_controller.h" | 9 #include "ash/display/display_controller.h" |
| 10 #include "ash/display/output_configurator_animation.h" | 10 #include "ash/display/output_configurator_animation.h" |
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 113 js_display->SetDouble("x", bounds.x()); | 113 js_display->SetDouble("x", bounds.x()); |
| 114 js_display->SetDouble("y", bounds.y()); | 114 js_display->SetDouble("y", bounds.y()); |
| 115 js_display->SetDouble("width", bounds.width()); | 115 js_display->SetDouble("width", bounds.width()); |
| 116 js_display->SetDouble("height", bounds.height()); | 116 js_display->SetDouble("height", bounds.height()); |
| 117 displays.Set(i, js_display); | 117 displays.Set(i, js_display); |
| 118 } | 118 } |
| 119 | 119 |
| 120 PrefService* pref_service = Profile::FromWebUI(web_ui())->GetPrefs(); | 120 PrefService* pref_service = Profile::FromWebUI(web_ui())->GetPrefs(); |
| 121 base::FundamentalValue layout( | 121 base::FundamentalValue layout( |
| 122 pref_service->GetInteger(prefs::kSecondaryDisplayLayout)); | 122 pref_service->GetInteger(prefs::kSecondaryDisplayLayout)); |
| 123 base::FundamentalValue offset( |
| 124 pref_service->GetInteger(prefs::kSecondaryDisplayOffset)); |
| 123 | 125 |
| 124 web_ui()->CallJavascriptFunction( | 126 web_ui()->CallJavascriptFunction( |
| 125 "options.DisplayOptions.setDisplayInfo", | 127 "options.DisplayOptions.setDisplayInfo", |
| 126 mirroring, displays, layout); | 128 mirroring, displays, layout, offset); |
| 127 } | 129 } |
| 128 | 130 |
| 129 void DisplayOptionsHandler::FadeOutForMirroringFinished(bool is_mirroring) { | 131 void DisplayOptionsHandler::FadeOutForMirroringFinished(bool is_mirroring) { |
| 130 // We use 'PRIMARY_ONLY' for non-mirroring state for now. | 132 // We use 'PRIMARY_ONLY' for non-mirroring state for now. |
| 131 // TODO(mukai): fix this and support multiple display modes. | 133 // TODO(mukai): fix this and support multiple display modes. |
| 132 chromeos::OutputState new_state = | 134 chromeos::OutputState new_state = |
| 133 is_mirroring ? STATE_DUAL_MIRROR : STATE_DUAL_PRIMARY_ONLY; | 135 is_mirroring ? STATE_DUAL_MIRROR : STATE_DUAL_PRIMARY_ONLY; |
| 134 ash::Shell::GetInstance()->output_configurator()->SetDisplayMode(new_state); | 136 ash::Shell::GetInstance()->output_configurator()->SetDisplayMode(new_state); |
| 135 SendDisplayInfo(); | 137 SendDisplayInfo(); |
| 136 // Not necessary to start fade-in animation. OutputConfigurator will do that. | 138 // Not necessary to start fade-in animation. OutputConfigurator will do that. |
| 137 } | 139 } |
| 138 | 140 |
| 139 void DisplayOptionsHandler::FadeOutForDisplayLayoutFinished(int layout) { | 141 void DisplayOptionsHandler::FadeOutForDisplayLayoutFinished( |
| 142 int layout, int offset) { |
| 140 PrefService* pref_service = Profile::FromWebUI(web_ui())->GetPrefs(); | 143 PrefService* pref_service = Profile::FromWebUI(web_ui())->GetPrefs(); |
| 141 pref_service->SetInteger(prefs::kSecondaryDisplayLayout, layout); | 144 pref_service->SetInteger(prefs::kSecondaryDisplayLayout, layout); |
| 145 pref_service->SetInteger(prefs::kSecondaryDisplayOffset, offset); |
| 142 SendDisplayInfo(); | 146 SendDisplayInfo(); |
| 143 ash::Shell::GetInstance()->output_configurator_animation()-> | 147 ash::Shell::GetInstance()->output_configurator_animation()-> |
| 144 StartFadeInAnimation(); | 148 StartFadeInAnimation(); |
| 145 } | 149 } |
| 146 | 150 |
| 147 void DisplayOptionsHandler::HandleDisplayInfo( | 151 void DisplayOptionsHandler::HandleDisplayInfo( |
| 148 const base::ListValue* unused_args) { | 152 const base::ListValue* unused_args) { |
| 149 SendDisplayInfo(); | 153 SendDisplayInfo(); |
| 150 } | 154 } |
| 151 | 155 |
| 152 void DisplayOptionsHandler::HandleMirroring(const base::ListValue* args) { | 156 void DisplayOptionsHandler::HandleMirroring(const base::ListValue* args) { |
| 153 DCHECK(!args->empty()); | 157 DCHECK(!args->empty()); |
| 154 bool is_mirroring = false; | 158 bool is_mirroring = false; |
| 155 args->GetBoolean(0, &is_mirroring); | 159 args->GetBoolean(0, &is_mirroring); |
| 156 ash::Shell::GetInstance()->output_configurator_animation()-> | 160 ash::Shell::GetInstance()->output_configurator_animation()-> |
| 157 StartFadeOutAnimation(base::Bind( | 161 StartFadeOutAnimation(base::Bind( |
| 158 &DisplayOptionsHandler::FadeOutForMirroringFinished, | 162 &DisplayOptionsHandler::FadeOutForMirroringFinished, |
| 159 base::Unretained(this), | 163 base::Unretained(this), |
| 160 is_mirroring)); | 164 is_mirroring)); |
| 161 } | 165 } |
| 162 | 166 |
| 163 void DisplayOptionsHandler::HandleDisplayLayout(const base::ListValue* args) { | 167 void DisplayOptionsHandler::HandleDisplayLayout(const base::ListValue* args) { |
| 164 double layout = -1; | 168 double layout = -1; |
| 165 if (!args->GetDouble(0, &layout)) { | 169 double offset = -1; |
| 170 if (!args->GetDouble(0, &layout) || !args->GetDouble(1, &offset)) { |
| 166 LOG(ERROR) << "Invalid parameter"; | 171 LOG(ERROR) << "Invalid parameter"; |
| 167 return; | 172 return; |
| 168 } | 173 } |
| 169 DCHECK_LE(DisplayController::TOP, layout); | 174 DCHECK_LE(DisplayController::TOP, layout); |
| 170 DCHECK_GE(DisplayController::LEFT, layout); | 175 DCHECK_GE(DisplayController::LEFT, layout); |
| 171 ash::Shell::GetInstance()->output_configurator_animation()-> | 176 ash::Shell::GetInstance()->output_configurator_animation()-> |
| 172 StartFadeOutAnimation(base::Bind( | 177 StartFadeOutAnimation(base::Bind( |
| 173 &DisplayOptionsHandler::FadeOutForDisplayLayoutFinished, | 178 &DisplayOptionsHandler::FadeOutForDisplayLayoutFinished, |
| 174 base::Unretained(this), | 179 base::Unretained(this), |
| 175 static_cast<int>(layout))); | 180 static_cast<int>(layout), |
| 181 static_cast<int>(offset))); |
| 176 } | 182 } |
| 177 | 183 |
| 178 } // namespace options2 | 184 } // namespace options2 |
| 179 } // namespace chromeos | 185 } // namespace chromeos |
| OLD | NEW |