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

Side by Side Diff: third_party/WebKit/Source/modules/webaudio/BaseAudioContext.cpp

Issue 2501863003: Support for AudioContextOptions latencyHint. (Closed)
Patch Set: Fixes to WebAudioDeviceImpl unit test. Created 3 years, 10 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2010, Google Inc. All rights reserved. 2 * Copyright (C) 2010, Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions 5 * modification, are permitted provided that the following conditions
6 * are met: 6 * are met:
7 * 1. Redistributions of source code must retain the above copyright 7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer. 8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright 9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the 10 * notice, this list of conditions and the following disclaimer in the
(...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after
46 #include "modules/webaudio/AudioBufferSourceNode.h" 46 #include "modules/webaudio/AudioBufferSourceNode.h"
47 #include "modules/webaudio/AudioContext.h" 47 #include "modules/webaudio/AudioContext.h"
48 #include "modules/webaudio/AudioListener.h" 48 #include "modules/webaudio/AudioListener.h"
49 #include "modules/webaudio/AudioNodeInput.h" 49 #include "modules/webaudio/AudioNodeInput.h"
50 #include "modules/webaudio/AudioNodeOutput.h" 50 #include "modules/webaudio/AudioNodeOutput.h"
51 #include "modules/webaudio/BiquadFilterNode.h" 51 #include "modules/webaudio/BiquadFilterNode.h"
52 #include "modules/webaudio/ChannelMergerNode.h" 52 #include "modules/webaudio/ChannelMergerNode.h"
53 #include "modules/webaudio/ChannelSplitterNode.h" 53 #include "modules/webaudio/ChannelSplitterNode.h"
54 #include "modules/webaudio/ConstantSourceNode.h" 54 #include "modules/webaudio/ConstantSourceNode.h"
55 #include "modules/webaudio/ConvolverNode.h" 55 #include "modules/webaudio/ConvolverNode.h"
56 #include "modules/webaudio/DefaultAudioDestinationNode.h"
57 #include "modules/webaudio/DelayNode.h" 56 #include "modules/webaudio/DelayNode.h"
58 #include "modules/webaudio/DynamicsCompressorNode.h" 57 #include "modules/webaudio/DynamicsCompressorNode.h"
59 #include "modules/webaudio/GainNode.h" 58 #include "modules/webaudio/GainNode.h"
60 #include "modules/webaudio/IIRFilterNode.h" 59 #include "modules/webaudio/IIRFilterNode.h"
61 #include "modules/webaudio/MediaElementAudioSourceNode.h" 60 #include "modules/webaudio/MediaElementAudioSourceNode.h"
62 #include "modules/webaudio/MediaStreamAudioDestinationNode.h" 61 #include "modules/webaudio/MediaStreamAudioDestinationNode.h"
63 #include "modules/webaudio/MediaStreamAudioSourceNode.h" 62 #include "modules/webaudio/MediaStreamAudioSourceNode.h"
64 #include "modules/webaudio/OfflineAudioCompletionEvent.h" 63 #include "modules/webaudio/OfflineAudioCompletionEvent.h"
65 #include "modules/webaudio/OfflineAudioContext.h" 64 #include "modules/webaudio/OfflineAudioContext.h"
66 #include "modules/webaudio/OfflineAudioDestinationNode.h" 65 #include "modules/webaudio/OfflineAudioDestinationNode.h"
67 #include "modules/webaudio/OscillatorNode.h" 66 #include "modules/webaudio/OscillatorNode.h"
68 #include "modules/webaudio/PannerNode.h" 67 #include "modules/webaudio/PannerNode.h"
69 #include "modules/webaudio/PeriodicWave.h" 68 #include "modules/webaudio/PeriodicWave.h"
70 #include "modules/webaudio/PeriodicWaveConstraints.h" 69 #include "modules/webaudio/PeriodicWaveConstraints.h"
71 #include "modules/webaudio/ScriptProcessorNode.h" 70 #include "modules/webaudio/ScriptProcessorNode.h"
72 #include "modules/webaudio/StereoPannerNode.h" 71 #include "modules/webaudio/StereoPannerNode.h"
73 #include "modules/webaudio/WaveShaperNode.h" 72 #include "modules/webaudio/WaveShaperNode.h"
74 #include "platform/CrossThreadFunctional.h" 73 #include "platform/CrossThreadFunctional.h"
75 #include "platform/Histogram.h" 74 #include "platform/Histogram.h"
76 #include "platform/UserGestureIndicator.h" 75 #include "platform/UserGestureIndicator.h"
77 #include "platform/audio/IIRFilter.h" 76 #include "platform/audio/IIRFilter.h"
78 #include "public/platform/Platform.h" 77 #include "public/platform/Platform.h"
79 #include "wtf/text/WTFString.h" 78 #include "wtf/text/WTFString.h"
80 79
81 namespace blink { 80 namespace blink {
82 81
83 BaseAudioContext* BaseAudioContext::create(Document& document, 82 BaseAudioContext* BaseAudioContext::create(
84 ExceptionState& exceptionState) { 83 Document& document,
85 return AudioContext::create(document, exceptionState); 84 const AudioContextOptions& contextOptions,
85 ExceptionState& exceptionState) {
86 return AudioContext::create(document, contextOptions, exceptionState);
86 } 87 }
87 88
88 // FIXME(dominicc): Devolve these constructors to AudioContext 89 // FIXME(dominicc): Devolve these constructors to AudioContext
89 // and OfflineAudioContext respectively. 90 // and OfflineAudioContext respectively.
90 91
91 // Constructor for rendering to the audio hardware. 92 // Constructor for rendering to the audio hardware.
92 BaseAudioContext::BaseAudioContext(Document* document) 93 BaseAudioContext::BaseAudioContext(Document* document)
93 : SuspendableObject(document), 94 : SuspendableObject(document),
94 m_destinationNode(nullptr), 95 m_destinationNode(nullptr),
95 m_isCleared(false), 96 m_isCleared(false),
96 m_isResolvingResumePromises(false), 97 m_isResolvingResumePromises(false),
97 m_userGestureRequired(false), 98 m_userGestureRequired(false),
98 m_connectionCount(0), 99 m_connectionCount(0),
99 m_deferredTaskHandler(DeferredTaskHandler::create()), 100 m_deferredTaskHandler(DeferredTaskHandler::create()),
100 m_contextState(Suspended), 101 m_contextState(Suspended),
101 m_closedContextSampleRate(-1), 102 m_closedContextSampleRate(-1),
102 m_periodicWaveSine(nullptr), 103 m_periodicWaveSine(nullptr),
103 m_periodicWaveSquare(nullptr), 104 m_periodicWaveSquare(nullptr),
104 m_periodicWaveSawtooth(nullptr), 105 m_periodicWaveSawtooth(nullptr),
105 m_periodicWaveTriangle(nullptr), 106 m_periodicWaveTriangle(nullptr),
106 m_outputPosition() { 107 m_outputPosition() {
107 // If mediaPlaybackRequiresUserGesture is enabled, cross origin iframes will 108 // If mediaPlaybackRequiresUserGesture is enabled, cross origin iframes will
108 // require user gesture for the AudioContext to produce sound. 109 // require user gesture for the AudioContext to produce sound.
109 if (document->settings() && 110 if (document->settings() &&
110 document->settings()->getMediaPlaybackRequiresUserGesture() && 111 document->settings()->getMediaPlaybackRequiresUserGesture() &&
111 document->frame() && document->frame()->isCrossOriginSubframe()) { 112 document->frame() && document->frame()->isCrossOriginSubframe()) {
112 m_autoplayStatus = AutoplayStatus::AutoplayStatusFailed; 113 m_autoplayStatus = AutoplayStatus::AutoplayStatusFailed;
113 m_userGestureRequired = true; 114 m_userGestureRequired = true;
114 } 115 }
115
116 m_destinationNode = DefaultAudioDestinationNode::create(this);
117
118 initialize();
119 } 116 }
120 117
121 // Constructor for offline (non-realtime) rendering. 118 // Constructor for offline (non-realtime) rendering.
122 BaseAudioContext::BaseAudioContext(Document* document, 119 BaseAudioContext::BaseAudioContext(Document* document,
123 unsigned numberOfChannels, 120 unsigned numberOfChannels,
124 size_t numberOfFrames, 121 size_t numberOfFrames,
125 float sampleRate) 122 float sampleRate)
126 : SuspendableObject(document), 123 : SuspendableObject(document),
127 m_destinationNode(nullptr), 124 m_destinationNode(nullptr),
128 m_isCleared(false), 125 m_isCleared(false),
(...skipping 773 matching lines...) Expand 10 before | Expand all | Expand 10 after
902 } 899 }
903 900
904 SecurityOrigin* BaseAudioContext::getSecurityOrigin() const { 901 SecurityOrigin* BaseAudioContext::getSecurityOrigin() const {
905 if (getExecutionContext()) 902 if (getExecutionContext())
906 return getExecutionContext()->getSecurityOrigin(); 903 return getExecutionContext()->getSecurityOrigin();
907 904
908 return nullptr; 905 return nullptr;
909 } 906 }
910 907
911 } // namespace blink 908 } // namespace blink
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698