cwIoFlow.h/cpp : Now interfaces to the flow DSP system through cwFlowCross.
This commit is contained in:
parent
b158516a6a
commit
6578f69369
50
cwIoFlow.cpp
50
cwIoFlow.cpp
@ -12,7 +12,7 @@
|
|||||||
#include "cwDspTypes.h"
|
#include "cwDspTypes.h"
|
||||||
#include "cwFlow.h"
|
#include "cwFlow.h"
|
||||||
#include "cwFlowTypes.h"
|
#include "cwFlowTypes.h"
|
||||||
|
#include "cwFlowCross.h"
|
||||||
|
|
||||||
#include "cwIo.h"
|
#include "cwIo.h"
|
||||||
|
|
||||||
@ -34,9 +34,9 @@ namespace cw
|
|||||||
|
|
||||||
typedef struct audio_group_str
|
typedef struct audio_group_str
|
||||||
{
|
{
|
||||||
double srate;
|
double srate;
|
||||||
unsigned dspFrameCnt;
|
unsigned dspFrameCnt;
|
||||||
unsigned ioGroupIdx;
|
unsigned ioGroupIdx;
|
||||||
|
|
||||||
audio_dev_t* iDeviceA;
|
audio_dev_t* iDeviceA;
|
||||||
unsigned iDeviceN;
|
unsigned iDeviceN;
|
||||||
@ -48,15 +48,15 @@ namespace cw
|
|||||||
|
|
||||||
typedef struct io_flow_str
|
typedef struct io_flow_str
|
||||||
{
|
{
|
||||||
io::handle_t ioH;
|
io::handle_t ioH; //
|
||||||
|
|
||||||
flow::external_device_t* deviceA; // Array of generic device descriptions used by the ioFlow controller
|
flow::external_device_t* deviceA; // Array of generic device descriptions used by the ioFlow controller
|
||||||
unsigned deviceN; // (This array must exist for the life of ioFlow controller)
|
unsigned deviceN; // (This array must exist for the life of ioFlow controller)
|
||||||
|
|
||||||
audio_group_t* audioGroupA; // Array of real time audio device control records.
|
audio_group_t* audioGroupA; // Array of real time audio device control records.
|
||||||
unsigned audioGroupN; //
|
unsigned audioGroupN; //
|
||||||
|
|
||||||
flow::handle_t flowH;
|
flow_cross::handle_t crossFlowH; //
|
||||||
|
|
||||||
} io_flow_t;
|
} io_flow_t;
|
||||||
|
|
||||||
@ -65,6 +65,9 @@ namespace cw
|
|||||||
|
|
||||||
rc_t _destroy( io_flow_t* p )
|
rc_t _destroy( io_flow_t* p )
|
||||||
{
|
{
|
||||||
|
|
||||||
|
flow_cross::destroy( p->crossFlowH );
|
||||||
|
|
||||||
mem::release(p->deviceA);
|
mem::release(p->deviceA);
|
||||||
p->deviceN = 0;
|
p->deviceN = 0;
|
||||||
|
|
||||||
@ -138,7 +141,6 @@ namespace cw
|
|||||||
for(unsigned gdi=0; gdi<ag->oDeviceN; ++gdi)
|
for(unsigned gdi=0; gdi<ag->oDeviceN; ++gdi)
|
||||||
_setup_audio_device( p, ag->oDeviceA + gdi, io::kOutFl, audioGroupDeviceIndex( p->ioH, gi, io::kOutFl, gdi), ag->dspFrameCnt );
|
_setup_audio_device( p, ag->oDeviceA + gdi, io::kOutFl, audioGroupDeviceIndex( p->ioH, gi, io::kOutFl, gdi), ag->dspFrameCnt );
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -247,7 +249,6 @@ namespace cw
|
|||||||
|
|
||||||
rc_t _audio_callback( io_flow_t* p, io::audio_msg_t& m )
|
rc_t _audio_callback( io_flow_t* p, io::audio_msg_t& m )
|
||||||
{
|
{
|
||||||
|
|
||||||
rc_t rc = kOkRC;
|
rc_t rc = kOkRC;
|
||||||
flow::abuf_t* abuf;
|
flow::abuf_t* abuf;
|
||||||
|
|
||||||
@ -289,7 +290,7 @@ namespace cw
|
|||||||
|
|
||||||
|
|
||||||
// update the flow network - this will generate audio into the output audio buffers
|
// update the flow network - this will generate audio into the output audio buffers
|
||||||
flow::exec_cycle(p->flowH);
|
flow_cross::exec_cycle(p->crossFlowH);
|
||||||
|
|
||||||
|
|
||||||
// if there are empty output (playback) buffers
|
// if there are empty output (playback) buffers
|
||||||
@ -323,7 +324,12 @@ namespace cw
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
cw::rc_t cw::io_flow::create( handle_t& hRef, io::handle_t ioH, const object_t& flow_class_dict, const object_t& network_cfg )
|
cw::rc_t cw::io_flow::create( handle_t& hRef,
|
||||||
|
io::handle_t ioH,
|
||||||
|
double srate,
|
||||||
|
unsigned crossFadeCnt,
|
||||||
|
const object_t& flow_class_dict,
|
||||||
|
const object_t& network_cfg )
|
||||||
{
|
{
|
||||||
rc_t rc;
|
rc_t rc;
|
||||||
|
|
||||||
@ -341,12 +347,14 @@ cw::rc_t cw::io_flow::create( handle_t& hRef, io::handle_t ioH, const object_t&
|
|||||||
_setup_generic_device_array(p);
|
_setup_generic_device_array(p);
|
||||||
|
|
||||||
// create the flow object
|
// create the flow object
|
||||||
if((rc = create( p->flowH, flow_class_dict, network_cfg, p->deviceA, p->deviceN )) != kOkRC )
|
if((rc = flow_cross::create( p->crossFlowH, flow_class_dict, network_cfg, srate, crossFadeCnt, p->deviceA, p->deviceN )) != kOkRC )
|
||||||
{
|
{
|
||||||
cwLogError(rc,"The 'flow' object create failed.");
|
cwLogError(rc,"The 'flow' object create failed.");
|
||||||
goto errLabel;
|
goto errLabel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//flow_cross::print(p->crossFlowH);
|
||||||
|
|
||||||
|
|
||||||
hRef.set(p);
|
hRef.set(p);
|
||||||
|
|
||||||
@ -396,3 +404,15 @@ cw::rc_t cw::io_flow::exec( handle_t h, const io::msg_t& msg )
|
|||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
cw::rc_t cw::io_flow::apply_preset( handle_t h, double crossFadeMs, const char* presetLabel )
|
||||||
|
{
|
||||||
|
cw::rc_t rc = kOkRC;
|
||||||
|
|
||||||
|
io_flow_t* p = _handleToPtr(h);
|
||||||
|
|
||||||
|
rc = apply_preset( p->crossFlowH, crossFadeMs, presetLabel );
|
||||||
|
|
||||||
|
return rc;
|
||||||
|
}
|
||||||
|
@ -7,11 +7,13 @@ namespace cw
|
|||||||
{
|
{
|
||||||
typedef handle< struct io_flow_str > handle_t;
|
typedef handle< struct io_flow_str > handle_t;
|
||||||
|
|
||||||
rc_t create( handle_t& hRef, io::handle_t ioH, const object_t& flow_class_dict, const object_t& cfg );
|
rc_t create( handle_t& hRef, io::handle_t ioH, double srate, unsigned crossFadeCnt, const object_t& flow_class_dict, const object_t& cfg );
|
||||||
rc_t destroy( handle_t& hRef );
|
rc_t destroy( handle_t& hRef );
|
||||||
|
|
||||||
rc_t exec( handle_t h, const io::msg_t& msg );
|
rc_t exec( handle_t h, const io::msg_t& msg );
|
||||||
|
|
||||||
|
rc_t apply_preset( handle_t h, double crossFadeMs, const char* presetLabel );
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user