OLD | NEW |
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 20 matching lines...) Expand all Loading... |
31 #include "wtf/ThreadingPrimitives.h" | 31 #include "wtf/ThreadingPrimitives.h" |
32 | 32 |
33 namespace blink { | 33 namespace blink { |
34 | 34 |
35 class AudioBuffer; | 35 class AudioBuffer; |
36 class ExceptionState; | 36 class ExceptionState; |
37 class Reverb; | 37 class Reverb; |
38 | 38 |
39 class ConvolverNode FINAL : public AudioNode { | 39 class ConvolverNode FINAL : public AudioNode { |
40 public: | 40 public: |
41 static PassRefPtrWillBeRawPtr<ConvolverNode> create(AudioContext* context, f
loat sampleRate) | 41 static ConvolverNode* create(AudioContext* context, float sampleRate) |
42 { | 42 { |
43 return adoptRefWillBeNoop(new ConvolverNode(context, sampleRate)); | 43 return adoptRefCountedGarbageCollectedWillBeNoop(new ConvolverNode(conte
xt, sampleRate)); |
44 } | 44 } |
45 | 45 |
46 virtual ~ConvolverNode(); | 46 virtual ~ConvolverNode(); |
47 | 47 |
48 // AudioNode | 48 // AudioNode |
49 virtual void dispose() OVERRIDE; | 49 virtual void dispose() OVERRIDE; |
50 virtual void process(size_t framesToProcess) OVERRIDE; | 50 virtual void process(size_t framesToProcess) OVERRIDE; |
51 virtual void initialize() OVERRIDE; | 51 virtual void initialize() OVERRIDE; |
52 virtual void uninitialize() OVERRIDE; | 52 virtual void uninitialize() OVERRIDE; |
53 | 53 |
54 // Impulse responses | 54 // Impulse responses |
55 void setBuffer(AudioBuffer*, ExceptionState&); | 55 void setBuffer(AudioBuffer*, ExceptionState&); |
56 AudioBuffer* buffer(); | 56 AudioBuffer* buffer(); |
57 | 57 |
58 bool normalize() const { return m_normalize; } | 58 bool normalize() const { return m_normalize; } |
59 void setNormalize(bool normalize) { m_normalize = normalize; } | 59 void setNormalize(bool normalize) { m_normalize = normalize; } |
60 | 60 |
61 virtual void trace(Visitor*) OVERRIDE; | 61 virtual void trace(Visitor*) OVERRIDE; |
62 | 62 |
63 private: | 63 private: |
64 ConvolverNode(AudioContext*, float sampleRate); | 64 ConvolverNode(AudioContext*, float sampleRate); |
65 | 65 |
66 virtual double tailTime() const OVERRIDE; | 66 virtual double tailTime() const OVERRIDE; |
67 virtual double latencyTime() const OVERRIDE; | 67 virtual double latencyTime() const OVERRIDE; |
68 | 68 |
69 OwnPtr<Reverb> m_reverb; | 69 OwnPtr<Reverb> m_reverb; |
70 RefPtrWillBeMember<AudioBuffer> m_buffer; | 70 Member<AudioBuffer> m_buffer; |
71 | 71 |
72 // This synchronizes dynamic changes to the convolution impulse response wit
h process(). | 72 // This synchronizes dynamic changes to the convolution impulse response wit
h process(). |
73 mutable Mutex m_processLock; | 73 mutable Mutex m_processLock; |
74 | 74 |
75 // Normalize the impulse response or not. Must default to true. | 75 // Normalize the impulse response or not. Must default to true. |
76 bool m_normalize; | 76 bool m_normalize; |
77 }; | 77 }; |
78 | 78 |
79 } // namespace blink | 79 } // namespace blink |
80 | 80 |
81 #endif // ConvolverNode_h | 81 #endif // ConvolverNode_h |
OLD | NEW |