123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- #ifndef _STRING_CONTAINER_H
- #define _STRING_CONTAINER_H
- #include <QVector>
- #include "vibrating_string.h"
- #include "MemoryManager.h"
- class stringContainer
- {
- MM_OPERATORS
- public:
- stringContainer(const float _pitch,
- const sample_rate_t _sample_rate,
- const int _buffer_length,
- const int _strings = 9 );
-
- void addString( int _harm,
- const float _pick,
- const float _pickup,
- const float * _impluse,
- const float _randomize,
- const float _string_loss,
- const float _detune,
- const int _oversample,
- const bool _state,
- const int _id );
-
- bool exists( int _id ) const
- {
- return m_exists[_id];
- }
-
- ~stringContainer()
- {
- int strings = m_strings.count();
- for( int i = 0; i < strings; i++ )
- {
- delete m_strings[i];
- }
- }
-
- float getStringSample( int _string )
- {
- return m_strings[_string]->nextSample();
- }
-
- private:
- QVector<vibratingString *> m_strings;
- const float m_pitch;
- const sample_rate_t m_sampleRate;
- const int m_bufferLength;
- QVector<bool> m_exists;
- } ;
- #endif
|