|
OLD | NEW |
---|---|
(Empty) | |
1 // Copyright (c) 2010 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 CHROME_RENDERER_AUDIO_DEVICE_H_ | |
6 #define CHROME_RENDERER_AUDIO_DEVICE_H_ | |
7 #pragma once | |
8 | |
9 #include <vector> | |
scherkus (not reviewing)
2011/01/10 23:42:32
nit: blank line between system + non-system header
Chris Rogers
2011/01/11 23:01:02
Done.
| |
10 #include "base/basictypes.h" | |
11 #include "base/scoped_ptr.h" | |
12 #include "base/shared_memory.h" | |
13 #include "base/threading/simple_thread.h" | |
14 #include "chrome/common/render_messages.h" | |
15 #include "chrome/renderer/audio_message_filter.h" | |
16 | |
17 // Each instance of AudioDevice corresponds to one host stream. | |
scherkus (not reviewing)
2011/01/10 23:42:32
are there any threading restrictions as to how Aud
Chris Rogers
2011/01/11 23:01:02
I've added a comment that the class is *not* threa
| |
18 class AudioDevice : public AudioMessageFilter::Delegate, | |
19 public base::DelegateSimpleThread::Delegate { | |
20 public: | |
21 class RenderCallback { | |
scherkus (not reviewing)
2011/01/10 23:42:32
what about typedeffing a callback type instead of
Chris Rogers
2011/01/11 23:01:02
Yes, it's pretty much mirroring what we're doing i
| |
22 public: | |
23 virtual void render(const std::vector<float*>& audio_data, | |
scherkus (not reviewing)
2011/01/10 23:42:32
considering this isn't a non-trivial function it s
Chris Rogers
2011/01/11 23:01:02
Done.
| |
24 size_t number_of_frames) = 0; | |
25 protected: | |
26 virtual ~RenderCallback() { } | |
scherkus (not reviewing)
2011/01/10 23:42:32
no inlined ctors/dtors in header files
http://dev
Chris Rogers
2011/01/11 23:01:02
I agree with the style guideline in general, but I
| |
27 }; | |
28 | |
29 AudioDevice(size_t buffer_size, | |
30 int channels, | |
31 double sample_rate, | |
32 RenderCallback* callback); | |
33 virtual ~AudioDevice(); | |
34 | |
35 // Returns |true| on success. | |
36 bool Start(); | |
37 bool Stop(); | |
38 | |
39 private: | |
40 // AudioMessageFilter::Delegate implementation | |
scherkus (not reviewing)
2011/01/10 23:42:32
nit: period at end
Chris Rogers
2011/01/11 23:01:02
Done.
| |
41 virtual void OnRequestPacket(AudioBuffersState buffers_state); | |
42 virtual void OnStateChanged(const ViewMsg_AudioStreamState_Params& state); | |
43 virtual void OnCreated(base::SharedMemoryHandle handle, uint32 length); | |
44 virtual void OnLowLatencyCreated(base::SharedMemoryHandle handle, | |
45 base::SyncSocket::Handle socket_handle, | |
46 uint32 length); | |
47 virtual void OnVolume(double volume); | |
48 virtual void OnDestroy(); | |
49 // End of AudioMessageFilter::Delegate implementation | |
scherkus (not reviewing)
2011/01/10 23:42:32
nit: based on recent chromium-dev style conversati
Chris Rogers
2011/01/11 23:01:02
Done.
| |
50 | |
51 // DelegateSimpleThread::Delegate implementation | |
scherkus (not reviewing)
2011/01/10 23:42:32
nit: period at end
Chris Rogers
2011/01/11 23:01:02
Done.
| |
52 virtual void Run(); | |
53 // End of DelegateSimpleThread::Delegate implementation | |
scherkus (not reviewing)
2011/01/10 23:42:32
ditto
Chris Rogers
2011/01/11 23:01:02
Done.
| |
54 | |
55 // Format | |
56 size_t buffer_size_; | |
57 int channels_; | |
58 double sample_rate_; | |
59 | |
60 // Calls the client's callback for rendering audio. | |
61 void FireRenderCallback(); | |
62 RenderCallback* callback_; | |
63 | |
64 // The client callback renders audio into here. | |
65 std::vector<float*> audio_data_; | |
66 | |
67 // Callbacks for rendering audio occur on this thread. | |
68 scoped_ptr<base::DelegateSimpleThread> audio_thread_; | |
69 | |
70 // IPC message stuff. | |
71 static scoped_refptr<AudioMessageFilter> filter_; | |
72 int32 stream_id_; | |
73 scoped_ptr<base::SharedMemory> shared_memory_; | |
74 scoped_ptr<base::SyncSocket> socket_; | |
75 | |
76 base::SharedMemory* shared_memory() { return shared_memory_.get(); } | |
scherkus (not reviewing)
2011/01/10 23:42:32
nit: class order style has helper methods go befor
Chris Rogers
2011/01/11 23:01:02
Done.
| |
77 base::SyncSocket* socket() { return socket_.get(); } | |
78 void* shared_memory_data() { return shared_memory()->memory(); } | |
79 }; | |
scherkus (not reviewing)
2011/01/10 23:42:32
DISALLOW_COPY_AND_ASSIGN
Chris Rogers
2011/01/11 23:01:02
Done.
| |
80 | |
81 #endif // CHROME_RENDERER_AUDIO_DEVICE_H_ | |
OLD | NEW |