Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "components/arc/audio/arc_audio_bridge.h" | 5 #include "components/arc/audio/arc_audio_bridge.h" |
| 6 | 6 |
| 7 #include "ash/common/system/tray/system_tray_notifier.h" | 7 #include "ash/common/system/tray/system_tray_notifier.h" |
| 8 #include "ash/common/wm_shell.h" | 8 #include "ash/common/wm_shell.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "chromeos/audio/audio_device.h" | 10 #include "chromeos/audio/audio_device.h" |
| 11 | 11 |
| 12 namespace arc { | 12 namespace arc { |
| 13 | 13 |
| 14 ArcAudioBridge::ArcAudioBridge(ArcBridgeService* bridge_service) | 14 ArcAudioBridge::ArcAudioBridge(ArcBridgeService* bridge_service) |
| 15 : ArcService(bridge_service), binding_(this) { | 15 : ArcService(bridge_service), binding_(this) { |
| 16 arc_bridge_service()->AddObserver(this); | 16 arc_bridge_service()->audio()->AddObserver(this); |
| 17 if (chromeos::CrasAudioHandler::IsInitialized()) { | 17 if (chromeos::CrasAudioHandler::IsInitialized()) { |
| 18 cras_audio_handler_ = chromeos::CrasAudioHandler::Get(); | 18 cras_audio_handler_ = chromeos::CrasAudioHandler::Get(); |
| 19 cras_audio_handler_->AddAudioObserver(this); | 19 cras_audio_handler_->AddAudioObserver(this); |
| 20 } | 20 } |
| 21 } | 21 } |
| 22 | 22 |
| 23 ArcAudioBridge::~ArcAudioBridge() { | 23 ArcAudioBridge::~ArcAudioBridge() { |
| 24 arc_bridge_service()->RemoveObserver(this); | 24 arc_bridge_service()->audio()->RemoveObserver(this); |
|
hidehiko
2016/07/11 05:24:53
nit: As you're here, could you move this to after
Luis Héctor Chávez
2016/07/11 17:13:34
Done.
| |
| 25 if (cras_audio_handler_ && chromeos::CrasAudioHandler::IsInitialized()) { | 25 if (cras_audio_handler_ && chromeos::CrasAudioHandler::IsInitialized()) { |
| 26 cras_audio_handler_->RemoveAudioObserver(this); | 26 cras_audio_handler_->RemoveAudioObserver(this); |
| 27 } | 27 } |
| 28 } | 28 } |
| 29 | 29 |
| 30 void ArcAudioBridge::OnAudioInstanceReady() { | 30 void ArcAudioBridge::OnInstanceReady(mojom::AudioInstance* audio_instance, |
| 31 mojom::AudioInstance* audio_instance = | 31 uint32_t version) { |
| 32 arc_bridge_service()->audio_instance(); | 32 if (version < 1) { |
| 33 if (!audio_instance) { | |
| 34 LOG(ERROR) << "OnAudioInstanceReady called, " | |
| 35 << "but no audio instance found"; | |
| 36 return; | |
| 37 } | |
| 38 if (arc_bridge_service()->audio_version() < 1) { | |
| 39 LOG(WARNING) << "Audio instance is too old and does not support Init()"; | 33 LOG(WARNING) << "Audio instance is too old and does not support Init()"; |
| 40 return; | 34 return; |
| 41 } | 35 } |
| 42 audio_instance->Init(binding_.CreateInterfacePtrAndBind()); | 36 audio_instance->Init(binding_.CreateInterfacePtrAndBind()); |
| 43 } | 37 } |
| 44 | 38 |
| 45 void ArcAudioBridge::ShowVolumeControls() { | 39 void ArcAudioBridge::ShowVolumeControls() { |
| 46 VLOG(2) << "ArcAudioBridge::ShowVolumeControls"; | 40 VLOG(2) << "ArcAudioBridge::ShowVolumeControls"; |
| 47 ash::WmShell::Get()->system_tray_notifier()-> | 41 ash::WmShell::Get()->system_tray_notifier()->NotifyAudioOutputVolumeChanged( |
| 48 NotifyAudioOutputVolumeChanged(0, 0); | 42 0, 0); |
| 49 } | 43 } |
| 50 | 44 |
| 51 void ArcAudioBridge::OnAudioNodesChanged() { | 45 void ArcAudioBridge::OnAudioNodesChanged() { |
| 52 uint64_t output_id = cras_audio_handler_->GetPrimaryActiveOutputNode(); | 46 uint64_t output_id = cras_audio_handler_->GetPrimaryActiveOutputNode(); |
| 53 const chromeos::AudioDevice* output_device = | 47 const chromeos::AudioDevice* output_device = |
| 54 cras_audio_handler_->GetDeviceFromId(output_id); | 48 cras_audio_handler_->GetDeviceFromId(output_id); |
| 55 bool headphone_inserted = | 49 bool headphone_inserted = |
| 56 (output_device && | 50 (output_device && |
| 57 output_device->type == chromeos::AudioDeviceType::AUDIO_TYPE_HEADPHONE); | 51 output_device->type == chromeos::AudioDeviceType::AUDIO_TYPE_HEADPHONE); |
| 58 | 52 |
| 59 uint64_t input_id = cras_audio_handler_->GetPrimaryActiveInputNode(); | 53 uint64_t input_id = cras_audio_handler_->GetPrimaryActiveInputNode(); |
| 60 const chromeos::AudioDevice* input_device = | 54 const chromeos::AudioDevice* input_device = |
| 61 cras_audio_handler_->GetDeviceFromId(input_id); | 55 cras_audio_handler_->GetDeviceFromId(input_id); |
| 62 bool microphone_inserted = | 56 bool microphone_inserted = |
| 63 (input_device && | 57 (input_device && |
| 64 input_device->type == chromeos::AudioDeviceType::AUDIO_TYPE_MIC); | 58 input_device->type == chromeos::AudioDeviceType::AUDIO_TYPE_MIC); |
| 65 | 59 |
| 66 VLOG(1) << "HEADPHONE " << headphone_inserted | 60 VLOG(1) << "HEADPHONE " << headphone_inserted << " MICROPHONE " |
| 67 << " MICROPHONE " << microphone_inserted; | 61 << microphone_inserted; |
| 68 SendSwitchState(headphone_inserted, microphone_inserted); | 62 SendSwitchState(headphone_inserted, microphone_inserted); |
| 69 } | 63 } |
| 70 | 64 |
| 71 void ArcAudioBridge::SendSwitchState(bool headphone_inserted, | 65 void ArcAudioBridge::SendSwitchState(bool headphone_inserted, |
| 72 bool microphone_inserted) { | 66 bool microphone_inserted) { |
| 73 uint32_t switch_state = 0; | 67 uint32_t switch_state = 0; |
| 74 if (headphone_inserted) { | 68 if (headphone_inserted) { |
| 75 switch_state |= | 69 switch_state |= |
| 76 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_HEADPHONE_INSERT)); | 70 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_HEADPHONE_INSERT)); |
| 77 } | 71 } |
| 78 if (microphone_inserted) { | 72 if (microphone_inserted) { |
| 79 switch_state |= | 73 switch_state |= |
| 80 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_MICROPHONE_INSERT)); | 74 (1 << static_cast<uint32_t>(mojom::AudioSwitch::SW_MICROPHONE_INSERT)); |
| 81 } | 75 } |
| 82 | 76 |
| 83 VLOG(1) << "Send switch state " << switch_state; | 77 VLOG(1) << "Send switch state " << switch_state; |
| 84 mojom::AudioInstance* audio_instance = arc_bridge_service()->audio_instance(); | 78 mojom::AudioInstance* audio_instance = |
| 79 arc_bridge_service()->audio()->instance(); | |
| 85 if (audio_instance) | 80 if (audio_instance) |
| 86 audio_instance->NotifySwitchState(switch_state); | 81 audio_instance->NotifySwitchState(switch_state); |
| 87 } | 82 } |
| 88 | 83 |
| 89 } // namespace arc | 84 } // namespace arc |
| OLD | NEW |