cwScoreFollower.cpp : Added pedal state info to write_sync_perf_csv().
This commit is contained in:
parent
960f028a9a
commit
dce0049b76
@ -121,6 +121,21 @@ namespace cw
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool _processPedal(const char* pedalLabel, unsigned barNumb, bool curPedalDownStateFl, uint8_t d1)
|
||||||
|
{
|
||||||
|
bool newStateFl = midi::isPedalDown(d1);
|
||||||
|
/*
|
||||||
|
if( newStateFl == curPedalDownStateFl )
|
||||||
|
{
|
||||||
|
const char* upDownLabel = newStateFl ? "down" : "up";
|
||||||
|
cwLogWarning("Double %s pedal %s in bar number:%i.",pedalLabel,upDownLabel,barNumb);
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
return newStateFl;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
rc_t _destroy( score_follower_t* p)
|
rc_t _destroy( score_follower_t* p)
|
||||||
{
|
{
|
||||||
destroy(p->dynRefH);
|
destroy(p->dynRefH);
|
||||||
@ -576,10 +591,14 @@ cw::rc_t cw::score_follower::midi_state_rt_report( handle_t h, const char* out_f
|
|||||||
|
|
||||||
cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fname, const midi::file::trackMsg_t** msgA, unsigned msgN )
|
cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fname, const midi::file::trackMsg_t** msgA, unsigned msgN )
|
||||||
{
|
{
|
||||||
score_follower_t* p = _handleToPtr(h);
|
score_follower_t* p = _handleToPtr(h);
|
||||||
rc_t rc = kOkRC;
|
rc_t rc = kOkRC;
|
||||||
unsigned resultN = result_count(p->trackH);
|
unsigned resultN = result_count(p->trackH);
|
||||||
auto resultA = result_base(p->trackH);
|
auto resultA = result_base(p->trackH);
|
||||||
|
bool dampPedalDownFl = false;
|
||||||
|
bool sostPedalDownFl = false;
|
||||||
|
bool softPedalDownFl = false;
|
||||||
|
unsigned curBarNumb = 1;
|
||||||
file::handle_t fH;
|
file::handle_t fH;
|
||||||
|
|
||||||
if( msgN == 0 )
|
if( msgN == 0 )
|
||||||
@ -602,7 +621,7 @@ cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fn
|
|||||||
}
|
}
|
||||||
|
|
||||||
// write the header line
|
// write the header line
|
||||||
file::printf(fH,"meas,index,voice,loc,tick,sec,dur,rval,dots,sci_pitch,dmark,dlevel,status,d0,d1,bar,section,bpm,grace,pedal\n");
|
file::printf(fH,"meas,index,voice,loc,tick,sec,dur,rval,dots,sci_pitch,dmark,dlevel,status,d0,d1,bar,section,bpm,grace,damp_down_fl,soft_down_fl,sost_down_fl\n");
|
||||||
|
|
||||||
for(unsigned i=0; i<msgN; ++i)
|
for(unsigned i=0; i<msgN; ++i)
|
||||||
{
|
{
|
||||||
@ -615,36 +634,72 @@ cw::rc_t cw::score_follower::write_sync_perf_csv( handle_t h, const char* out_fn
|
|||||||
{
|
{
|
||||||
uint8_t d0 = m->u.chMsgPtr->d0;
|
uint8_t d0 = m->u.chMsgPtr->d0;
|
||||||
uint8_t d1 = m->u.chMsgPtr->d1;
|
uint8_t d1 = m->u.chMsgPtr->d1;
|
||||||
|
|
||||||
|
|
||||||
if( midi::isNoteOn(m->status,d1) )
|
if( midi::isNoteOn(m->status,d1) )
|
||||||
{
|
{
|
||||||
const unsigned INVALID_LOC = 0;
|
|
||||||
|
|
||||||
char sciPitch[ midi::kMidiSciPitchCharCnt + 1 ];
|
|
||||||
unsigned bar = 0;
|
unsigned bar = 0;
|
||||||
midi::midiToSciPitch( d0, sciPitch, midi::kMidiSciPitchCharCnt );
|
unsigned loc = score_parse::kInvalidLocId;
|
||||||
unsigned loc = INVALID_LOC;
|
unsigned dlevel = -1;
|
||||||
|
char sciPitch[ midi::kMidiSciPitchCharCnt + 1 ];
|
||||||
|
|
||||||
|
midi::midiToSciPitch( d0, sciPitch, midi::kMidiSciPitchCharCnt );
|
||||||
|
|
||||||
|
// locate score matching record for this performed note
|
||||||
for(unsigned i=0; i<resultN; ++i)
|
for(unsigned i=0; i<resultN; ++i)
|
||||||
{
|
{
|
||||||
|
const sfscore::event_t* e;
|
||||||
// FIX THIS:
|
// FIX THIS:
|
||||||
// THE perfA[] INDEX IS STORED IN resultA[i].muid
|
// THE perfA[] INDEX IS STORED IN resultA[i].muid
|
||||||
|
// this isn't right.
|
||||||
assert( resultA[i].muid != kInvalidIdx && resultA[i].muid < p->perfN );
|
assert( resultA[i].muid != kInvalidIdx && resultA[i].muid < p->perfN );
|
||||||
|
|
||||||
if( p->perfA[resultA[i].muid].muid == m->uid )
|
if( p->perfA[resultA[i].muid].muid == m->uid && resultA[i].scEvtIdx != kInvalidIdx)
|
||||||
{
|
{
|
||||||
assert( resultA[i].pitch == d0 );
|
assert( resultA[i].pitch == d0 );
|
||||||
loc = resultA[i].oLocId == kInvalidId ? INVALID_LOC : resultA[i].oLocId;
|
|
||||||
|
if((e = event( p->scoreH, resultA[i].scEvtIdx )) == nullptr )
|
||||||
|
{
|
||||||
|
cwLogError(kInvalidStateRC,"The performed, and matched, note with muid %i does not have a valid score event index.",m->uid);
|
||||||
|
goto errLabel;
|
||||||
|
}
|
||||||
|
|
||||||
|
bar = e->barNumb;
|
||||||
|
curBarNumb = std::max(bar,curBarNumb);
|
||||||
|
dlevel = e->dynLevel;
|
||||||
|
loc = resultA[i].oLocId == kInvalidId ? score_parse::kInvalidLocId : resultA[i].oLocId;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
rc = file::printf(fH, "%i,%i,%i,%i,0,%f,0.0,0.0,0,%s,,,%i,%i,%i,,,,,\n",
|
rc = file::printf(fH, "%i,%i,%i,%i,0,%f,0.0,0.0,0,%s,,%i,%i,%i,%i,,,,,%i,%i,%i\n",
|
||||||
bar,i,1,loc,secs,sciPitch,m->status,d0,d1);
|
bar,i,1,loc,secs,sciPitch,dlevel,m->status,d0,d1,dampPedalDownFl,softPedalDownFl,sostPedalDownFl);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
rc = file::printf(fH, ",%i,,,%i,%f,,,,,,,%i,%i,%i,,,,,\n",i,0,secs,m->status,d0,d1);
|
|
||||||
|
if( midi::isPedal(m->status,d0) )
|
||||||
|
{
|
||||||
|
switch( d0 )
|
||||||
|
{
|
||||||
|
case midi::kSustainCtlMdId:
|
||||||
|
dampPedalDownFl = _processPedal("damper",curBarNumb,dampPedalDownFl,d1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case midi::kSostenutoCtlMdId:
|
||||||
|
sostPedalDownFl = _processPedal("sostenuto",curBarNumb,sostPedalDownFl,d1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case midi::kSoftPedalCtlMdId:
|
||||||
|
softPedalDownFl = _processPedal("soft",curBarNumb,softPedalDownFl,d1);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
rc = file::printf(fH, ",%i,,,%i,%f,,,,,,,%i,%i,%i,,,,,%i,%i,%i\n",i,0,secs,m->status,d0,d1,dampPedalDownFl,softPedalDownFl,sostPedalDownFl);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user