Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5795)

Unified Diff: chrome/renderer/audio_device.h

Issue 6002005: Implement renderer AudioDevice API for low-latency audio output... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 12 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/renderer/audio_device.h
===================================================================
--- chrome/renderer/audio_device.h (revision 0)
+++ chrome/renderer/audio_device.h (revision 0)
@@ -0,0 +1,81 @@
+// Copyright (c) 2010 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CHROME_RENDERER_AUDIO_DEVICE_H_
+#define CHROME_RENDERER_AUDIO_DEVICE_H_
+#pragma once
+
+#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.
+#include "base/basictypes.h"
+#include "base/scoped_ptr.h"
+#include "base/shared_memory.h"
+#include "base/threading/simple_thread.h"
+#include "chrome/common/render_messages.h"
+#include "chrome/renderer/audio_message_filter.h"
+
+// 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
+class AudioDevice : public AudioMessageFilter::Delegate,
+ public base::DelegateSimpleThread::Delegate {
+ public:
+ 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
+ public:
+ 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.
+ size_t number_of_frames) = 0;
+ protected:
+ 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
+ };
+
+ AudioDevice(size_t buffer_size,
+ int channels,
+ double sample_rate,
+ RenderCallback* callback);
+ virtual ~AudioDevice();
+
+ // Returns |true| on success.
+ bool Start();
+ bool Stop();
+
+ private:
+ // 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.
+ virtual void OnRequestPacket(AudioBuffersState buffers_state);
+ virtual void OnStateChanged(const ViewMsg_AudioStreamState_Params& state);
+ virtual void OnCreated(base::SharedMemoryHandle handle, uint32 length);
+ virtual void OnLowLatencyCreated(base::SharedMemoryHandle handle,
+ base::SyncSocket::Handle socket_handle,
+ uint32 length);
+ virtual void OnVolume(double volume);
+ virtual void OnDestroy();
+ // 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.
+
+ // 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.
+ virtual void Run();
+ // End of DelegateSimpleThread::Delegate implementation
scherkus (not reviewing) 2011/01/10 23:42:32 ditto
Chris Rogers 2011/01/11 23:01:02 Done.
+
+ // Format
+ size_t buffer_size_;
+ int channels_;
+ double sample_rate_;
+
+ // Calls the client's callback for rendering audio.
+ void FireRenderCallback();
+ RenderCallback* callback_;
+
+ // The client callback renders audio into here.
+ std::vector<float*> audio_data_;
+
+ // Callbacks for rendering audio occur on this thread.
+ scoped_ptr<base::DelegateSimpleThread> audio_thread_;
+
+ // IPC message stuff.
+ static scoped_refptr<AudioMessageFilter> filter_;
+ int32 stream_id_;
+ scoped_ptr<base::SharedMemory> shared_memory_;
+ scoped_ptr<base::SyncSocket> socket_;
+
+ 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.
+ base::SyncSocket* socket() { return socket_.get(); }
+ void* shared_memory_data() { return shared_memory()->memory(); }
+};
scherkus (not reviewing) 2011/01/10 23:42:32 DISALLOW_COPY_AND_ASSIGN
Chris Rogers 2011/01/11 23:01:02 Done.
+
+#endif // CHROME_RENDERER_AUDIO_DEVICE_H_
Property changes on: chrome/renderer/audio_device.h
___________________________________________________________________
Added: svn:eol-style
+ LF

Powered by Google App Engine
This is Rietveld 408576698