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

Unified Diff: content/renderer/render_audiosourceprovider.h

Issue 7631033: Very early implementation for HTMLMediaElement / Web Audio API integration (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 9 years, 4 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
« no previous file with comments | « content/renderer/media/audio_renderer_impl.cc ('k') | content/renderer/render_audiosourceprovider.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/renderer/render_audiosourceprovider.h
===================================================================
--- content/renderer/render_audiosourceprovider.h (revision 0)
+++ content/renderer/render_audiosourceprovider.h (revision 0)
@@ -0,0 +1,47 @@
+// Copyright (c) 2011 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 CONTENT_RENDERER_RENDERER_WEBAUDIOSOURCEPROVIDER_IMPL_H_
+#define CONTENT_RENDERER_RENDERER_WEBAUDIOSOURCEPROVIDER_IMPL_H_
+
+#include <vector>
+
+#include "media/filters/audio_renderer_sink.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebAudioSourceProvider.h"
+#include "third_party/WebKit/Source/WebKit/chromium/public/WebVector.h"
+
+// RenderAudioSourceProvider provides a bridge between classes:
+// WebKit::WebAudioSourceProvider <---> media::AudioRendererSink
+//
+// The idea is that some code within WebKit periodically calls provideInput()
+// to render a certain number of audio sample-frames. provideInput()
+// uses its callback to get this data, and then massages it into the form
+// required by provideInput().
+
+class RenderAudioSourceProvider
+ : public WebKit::WebAudioSourceProvider,
+ public media::AudioRendererSink {
+ public:
+ RenderAudioSourceProvider(media::AudioRendererSink::RenderCallback* callback);
+ virtual ~RenderAudioSourceProvider() { }
+
+ // WebKit::WebAudioSourceProvider implementation.
+ // WebKit calls this to get the rendered audio stream.
+ virtual void provideInput(const WebKit::WebVector<float*>& audio_data,
+ size_t number_of_frames);
+
+ // AudioSink implementation.
+ virtual bool Start();
+ virtual bool Stop();
+ virtual bool SetVolume(double volume);
+
+ private:
+ bool is_running_;
+ double volume_;
+ media::AudioRendererSink::RenderCallback* callback_;
+
+ DISALLOW_COPY_AND_ASSIGN(RenderAudioSourceProvider);
+};
+
+#endif // CONTENT_RENDERER_RENDERER_WEBAUDIOSOURCEPROVIDER_IMPL_H_
« no previous file with comments | « content/renderer/media/audio_renderer_impl.cc ('k') | content/renderer/render_audiosourceprovider.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698