From adacb33bf4eadcd49a744177bf3f059e7b2f2f52 Mon Sep 17 00:00:00 2001 From: David Robillard Date: Mon, 22 Feb 2010 21:24:34 +0000 Subject: Merge with upstream r2. git-svn-id: http://svn.drobilla.net/lad/trunk/mda-lv2@2471 a436a847-0d15-0410-975c-d299462d15a1 --- src/mdaPiano.cpp | 68 ++++++++++++++++++++++++++++---------------------------- 1 file changed, 34 insertions(+), 34 deletions(-) (limited to 'src/mdaPiano.cpp') diff --git a/src/mdaPiano.cpp b/src/mdaPiano.cpp index 2fafaf5..ccaa9f5 100644 --- a/src/mdaPiano.cpp +++ b/src/mdaPiano.cpp @@ -9,7 +9,7 @@ #include #include - + //#include "AEffEditor.hpp" ////for GUI @@ -48,7 +48,7 @@ mdaPiano::mdaPiano(audioMasterCallback audioMaster) : AudioEffectX(audioMaster, if(programs) { //fill patches... - long i=0; + LvzInt32 i=0; fillpatch(i++, "MDA Piano", 0.500f, 0.500f, 0.500f, 0.5f, 0.803f, 0.251f, 0.376f, 0.500f, 0.330f, 0.500f, 0.246f, 0.500f); fillpatch(i++, "Plain Piano", 0.500f, 0.500f, 0.500f, 0.5f, 0.751f, 0.000f, 0.452f, 0.000f, 0.000f, 0.500f, 0.000f, 0.500f); fillpatch(i++, "Compressed Piano", 0.902f, 0.399f, 0.623f, 0.5f, 1.000f, 0.331f, 0.299f, 0.499f, 0.330f, 0.500f, 0.000f, 0.500f); @@ -92,7 +92,7 @@ mdaPiano::mdaPiano(audioMasterCallback audioMaster) : AudioEffectX(audioMaster, kgrp[14].root = 93; kgrp[14].high = 999; kgrp[14].pos = 574123; kgrp[14].end = 586343; kgrp[14].loop = 2399; //initialise... - for(long v=0; v 0.03f) width = 0.03f; - poly = 8 + (long)(24.9f * param[8]); + poly = 8 + (LvzInt32)(24.9f * param[8]); } @@ -145,25 +146,22 @@ void mdaPiano::resume() mdaPiano::~mdaPiano () //destroy any buffers... { if(programs) delete [] programs; - if(comb) delete[] comb; + if(comb) delete[] comb; } void mdaPiano::setProgram(LvzInt32 program) { - long i; - - mdaPianoProgram *p = &programs[program]; curProgram = program; - for(i=0; iparam[i]; - update(); + update(); + + // TODO: guiUpdate ??? } void mdaPiano::setParameter(LvzInt32 index, float value) { - mdaPianoProgram *p = &programs[curProgram]; - param[index] = p->param[index] = value; + programs[curProgram].param[index] = value; update(); // if(editor) editor->postUpdate(); //For GUI @@ -172,7 +170,7 @@ void mdaPiano::setParameter(LvzInt32 index, float value) } -void mdaPiano::fillpatch(long p, const char *name, float p0, float p1, float p2, float p3, float p4, +void mdaPiano::fillpatch(LvzInt32 p, char *name, float p0, float p1, float p2, float p3, float p4, float p5, float p6, float p7, float p8, float p9, float p10,float p11) { strcpy(programs[p].name, name); @@ -185,7 +183,7 @@ void mdaPiano::fillpatch(long p, const char *name, float p0, float p1, float p2, } -float mdaPiano::getParameter(LvzInt32 index) { return param[index]; } +float mdaPiano::getParameter(LvzInt32 index) { return programs[curProgram].param[index]; } void mdaPiano::setProgramName(char *name) { strcpy(programs[curProgram].name, name); } void mdaPiano::getProgramName(char *name) { strcpy(name, programs[curProgram].name); } void mdaPiano::setBlockSize(LvzInt32 blockSize) { AudioEffectX::setBlockSize(blockSize); } @@ -210,7 +208,7 @@ bool mdaPiano::getOutputProperties(LvzInt32 index, LvzPinProperties* properties) bool mdaPiano::getProgramNameIndexed(LvzInt32 category, LvzInt32 index, char* text) { - if(index -2.0f) || !(l < 2.0f)) { - printf("what is this shit? %ld, %f, %f\n", i, x, V->f0); + printf("what is this shit? %d, %f, %f\n", i, x, V->f0); l = 0.0f; } if(!(r > -2.0f) || !(r < 2.0f)) @@ -423,8 +422,8 @@ if(!(r > -2.0f) || !(r < 2.0f)) if(frame -2.0f) || !(r < 2.0f)) } -void mdaPiano::noteOn(long note, long velocity) +void mdaPiano::noteOn(LvzInt32 note, LvzInt32 velocity) { + float * param = programs[curProgram].param; float l=99.0f; - long v, vl=0, k, s; + LvzInt32 v, vl=0, k, s; if(velocity>0) { @@ -458,14 +458,14 @@ void mdaPiano::noteOn(long note, long velocity) if(note > 60) l += stretch * (float)k; //stretch s = size; - if(velocity > 40) s += (long)(sizevel * (float)(velocity - 40)); + if(velocity > 40) s += (LvzInt32)(sizevel * (float)(velocity - 40)); k = 0; while(note > (kgrp[k].high + s)) k++; //find keygroup l += (float)(note - kgrp[k].root); //pitch l = 22050.0f * iFs * (float)exp(0.05776226505 * l); - voice[vl].delta = (long)(65536.0f * l); + voice[vl].delta = (LvzInt32)(65536.0f * l); voice[vl].frac = 0; voice[vl].pos = kgrp[k].pos; voice[vl].end = kgrp[k].end; @@ -508,9 +508,9 @@ void mdaPiano::noteOn(long note, long velocity) LvzInt32 mdaPiano::processEvents(LvzEvents* ev) { - long npos=0; + LvzInt32 npos=0; - for (long i=0; inumEvents; i++) + for (LvzInt32 i=0; inumEvents; i++) { if((ev->events[i])->type != kLvzMidiType) continue; LvzMidiEvent* event = (LvzMidiEvent*)ev->events[i]; @@ -556,7 +556,7 @@ LvzInt32 mdaPiano::processEvents(LvzEvents* ev) default: //all notes off if(midiData[1]>0x7A) { - for(long v=0; v