OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef DEVICE_BLUETOOTH_BLUETOOTH_AUDIO_SINK_CHROMEOS_H_ | |
6 #define DEVICE_BLUETOOTH_BLUETOOTH_AUDIO_SINK_CHROMEOS_H_ | |
7 | |
8 #include <stdint.h> | |
9 #include <string> | |
10 #include <vector> | |
11 | |
12 #include "base/memory/scoped_ptr.h" | |
13 #include "base/memory/weak_ptr.h" | |
14 #include "base/observer_list.h" | |
15 #include "chromeos/dbus/bluetooth_media_client.h" | |
16 #include "chromeos/dbus/bluetooth_media_endpoint_service_provider.h" | |
17 #include "chromeos/dbus/bluetooth_media_transport_client.h" | |
18 #include "dbus/file_descriptor.h" | |
19 #include "dbus/object_path.h" | |
20 #include "device/bluetooth/bluetooth_adapter.h" | |
21 #include "device/bluetooth/bluetooth_adapter_chromeos.h" | |
22 #include "device/bluetooth/bluetooth_audio_sink.h" | |
23 #include "device/bluetooth/bluetooth_export.h" | |
24 | |
25 namespace chromeos { | |
26 | |
27 class DEVICE_BLUETOOTH_EXPORT BluetoothAudioSinkChromeOS | |
28 : public device::BluetoothAudioSink, | |
29 public device::BluetoothAdapter::Observer, | |
30 public BluetoothMediaClient::Observer, | |
31 public BluetoothMediaTransportClient::Observer, | |
32 public BluetoothMediaEndpointServiceProvider::Delegate { | |
33 public: | |
34 // A global sequence number used to generate unique path for Media Endpoint | |
35 // object. | |
36 static uint16_t sequence_number; | |
armansito
2015/01/20 22:47:49
Why 16-bit? I'd just make this unsigned int, which
Miao
2015/01/21 00:10:54
Done.
| |
37 | |
38 explicit BluetoothAudioSinkChromeOS(BluetoothAdapterChromeOS* adapter); | |
39 | |
40 // device::BluetoothAudioSink overrides. | |
41 void AddObserver(BluetoothAudioSink::Observer* observer) override; | |
42 void RemoveObserver(BluetoothAudioSink::Observer* observer) override; | |
43 device::BluetoothAudioSink::State GetState() const override; | |
44 uint16_t GetVolume() const override; | |
45 | |
46 // device::BluetoothAdapter::Observer overrides. | |
47 void AdapterPresentChanged(device::BluetoothAdapter* adapter, | |
48 bool present) override; | |
49 void AdapterPoweredChanged(device::BluetoothAdapter* adapter, | |
50 bool powered) override; | |
51 | |
52 // BluetoothMediaClient::Observer overrides. | |
53 void MediaAdded(const dbus::ObjectPath& object_path) override; | |
54 void MediaRemoved(const dbus::ObjectPath& object_path) override; | |
55 | |
56 // BluetoothMediaTransportClient::Observer overrides. | |
57 void MediaTransportAdded(const dbus::ObjectPath& object_path) override; | |
58 void MediaTransportRemoved(const dbus::ObjectPath& object_path) override; | |
59 void MediaTransportPropertyChanged(const dbus::ObjectPath& object_path, | |
60 const std::string& property_name) override; | |
61 | |
62 // BluetoothMediaEndpointServiceProvider::Delegate overrides. | |
63 void SetConfiguration(const dbus::ObjectPath& transport_path, | |
64 const dbus::MessageReader& properties) override; | |
65 void SelectConfiguration( | |
66 const std::vector<uint8_t>& capabilities, | |
67 const SelectConfigurationCallback& callback) override; | |
68 void ClearConfiguration(const dbus::ObjectPath& transport_path) override; | |
69 void Release() override; | |
70 | |
71 // Registers a BluetoothAudioSink. User applications can use |options| to | |
72 // configure the audio sink. |callback| will be executed if the audio sink is | |
73 // successfully registered, otherwise |error_callback| will be called. Called | |
74 // from BluetoothAdapterChromeOS. | |
75 void Register( | |
76 const device::BluetoothAudioSink::Options& options, | |
77 const base::Closure& callback, | |
78 const device::BluetoothAudioSink::ErrorCallback& error_callback); | |
79 | |
80 // Unregisters a BluetoothAudioSink. |callback| should handle | |
81 // the clean-up after the audio sink is deleted successfully, otherwise | |
82 // |error_callback| will be called. | |
83 void Unregister( | |
84 const base::Closure& callback, | |
85 const device::BluetoothAudioSink::ErrorCallback& error_callback) override; | |
86 | |
87 private: | |
88 ~BluetoothAudioSinkChromeOS() override; | |
89 | |
90 // Called when the state property of BluetoothMediaTransport has been updated. | |
91 void StateChanged(device::BluetoothAudioSink::State state); | |
92 | |
93 // Called when the volume property of BluetoothMediaTransport has been | |
94 // updated. | |
95 void VolumeChanged(uint16_t volume); | |
96 | |
97 // Generates an unique path for initiating a Media Endpoint. | |
98 dbus::ObjectPath GenerateEndpointPath(); | |
armansito
2015/01/20 22:47:49
this looks like this should be a static method.
Miao
2015/01/21 00:10:54
Done.
| |
99 | |
100 // Reads from the file descriptor acquired via Media Transport object and | |
101 // notify |observer_| while the audio data is available. | |
102 void ReadFromFD(); | |
103 | |
104 // The connection state between the BluetoothAudioSinkChromeOS and the remote | |
105 // device. | |
106 device::BluetoothAudioSink::State state_; | |
107 | |
108 // Indicates whether the adapter is present. | |
109 bool present_; | |
110 | |
111 // Indicates whether the adapter is powered. | |
112 bool powered_; | |
113 | |
114 // The volume control by the remote device during the streaming. | |
115 uint16_t volume_; | |
116 | |
117 // Read MTU of the file descriptor acquired via Media Transport object. | |
118 uint16_t read_mtu_; | |
119 | |
120 // Write MTU of the file descriptor acquired via Media Transport object. | |
121 uint16_t write_mtu_; | |
122 | |
123 // File descriptor acquired via Media Transport object. | |
124 dbus::FileDescriptor fd_; | |
125 | |
126 // Object path of the media object being used. | |
127 dbus::ObjectPath media_path_; | |
128 | |
129 // Object path of the transport object being used. | |
130 dbus::ObjectPath transport_path_; | |
131 | |
132 // Object path of the media endpoint object being used. | |
133 dbus::ObjectPath endpoint_path_; | |
134 | |
135 // BT adapter which the audio sink binds to. |adapter_| should outlive | |
136 // a BluetoothAudioSinkChromeOS object. | |
137 BluetoothAdapterChromeOS* adapter_; | |
138 | |
139 // Options used to initiate Media Endpoint and select configuration for the | |
140 // transport. | |
141 device::BluetoothAudioSink::Options options_; | |
142 | |
143 // Media Endpoint object owned by the audio sink object. | |
144 scoped_ptr<BluetoothMediaEndpointServiceProvider> media_endpoint_; | |
145 | |
146 // List of observers interested in event notifications from us. |observers_| | |
Ben Chan
2015/01/20 22:46:51
objects in |observers_|
Miao
2015/01/21 00:10:54
Done.
| |
147 // are expected to outlive a BluetoothAudioSinkChromeOS object. | |
148 ObserverList<BluetoothAudioSink::Observer> observers_; | |
149 | |
150 // Note: This should remain the last member so it'll be destroyed and | |
151 // invalidate its weak pointers before any other members are destroyed. | |
152 base::WeakPtrFactory<BluetoothAudioSinkChromeOS> weak_ptr_factory_; | |
153 | |
154 DISALLOW_COPY_AND_ASSIGN(BluetoothAudioSinkChromeOS); | |
155 }; | |
156 | |
157 } // namespace chromeos | |
158 | |
159 #endif // DEVICE_BLUETOOTH_BLUETOOTH_AUDIO_SINK_CHROMEOS_H_ | |
OLD | NEW |