• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2012 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 PPAPI_CPP_AUDIO_H_
6 #define PPAPI_CPP_AUDIO_H_
7 
8 #include "ppapi/c/pp_stdint.h"
9 #include "ppapi/c/ppb_audio.h"
10 #include "ppapi/cpp/audio_config.h"
11 #include "ppapi/cpp/resource.h"
12 
13 /// @file
14 /// This file defines the API to create realtime stereo audio streaming
15 /// capabilities.
16 
17 namespace pp {
18 
19 class InstanceHandle;
20 
21 /// An audio resource. Refer to the
22 /// <a href="/native-client/devguide/coding/audio.html">Audio</a>
23 /// chapter in the Developer's Guide for information on using this interface.
24 class Audio : public Resource {
25  public:
26 
27   /// An empty constructor for an Audio resource.
Audio()28   Audio() {}
29 
30   /// A constructor that creates an Audio resource. No sound will be heard
31   /// until StartPlayback() is called. The callback is called with the buffer
32   /// address and given user data whenever the buffer needs to be filled.
33   /// From within the callback, you should not call <code>PPB_Audio</code>
34   /// functions. The callback will be called on a different thread than the one
35   /// which created the interface. For performance-critical applications (such
36   /// as low-latency audio), the callback should avoid blocking or calling
37   /// functions that can obtain locks, such as malloc. The layout and the size
38   /// of the buffer passed to the audio callback will be determined by
39   /// the device configuration and is specified in the <code>AudioConfig</code>
40   /// documentation.
41   ///
42   /// @param[in] instance The instance with which this resource will be
43   /// associated.
44   /// @param[in] config An <code>AudioConfig</code> containing the audio config
45   /// resource.
46   /// @param[in] callback A <code>PPB_Audio_Callback</code> callback function
47   /// that the browser calls when it needs more samples to play.
48   /// @param[in] user_data A pointer to user data used in the callback function.
49   Audio(const InstanceHandle& instance,
50         const AudioConfig& config,
51         PPB_Audio_Callback callback,
52         void* user_data);
53 
54   /// A constructor that creates an Audio resource.
55   ///
56   /// @param[in] instance The instance with which this resource will be
57   /// associated.
58   /// @param[in] config An <code>AudioConfig</code> containing the audio config
59   /// resource.
60   /// @param[in] callback A <code>PPB_Audio_Callback_1_0</code> callback
61   /// function that the browser calls when it needs more samples to play.
62   /// @param[in] user_data A pointer to user data used in the callback function.
63   Audio(const InstanceHandle& instance,
64         const AudioConfig& config,
65         PPB_Audio_Callback_1_0 callback,
66         void* user_data);
67 
68   /// Getter function for returning the internal <code>PPB_AudioConfig</code>
69   /// struct.
70   ///
71   /// @return A mutable reference to the PPB_AudioConfig struct.
config()72   AudioConfig& config() { return config_; }
73 
74   /// Getter function for returning the internal <code>PPB_AudioConfig</code>
75   /// struct.
76   ///
77   /// @return A const reference to the internal <code>PPB_AudioConfig</code>
78   /// struct.
config()79   const AudioConfig& config() const { return config_; }
80 
81   /// StartPlayback() starts playback of audio.
82   ///
83   /// @return true if successful, otherwise false.
84   bool StartPlayback();
85 
86   /// StopPlayback stops playback of audio.
87   ///
88   /// @return true if successful, otherwise false.
89   bool StopPlayback();
90 
91  private:
92   AudioConfig config_;
93   bool use_1_0_interface_;
94 };
95 
96 }  // namespace pp
97 
98 #endif  // PPAPI_CPP_AUDIO_H_
99 
100