Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Fork of slider_diatonic_v1 by
slider_diatonic_v1.cpp
- Committer:
- scohennm
- Date:
- 2015-02-18
- Revision:
- 3:f68e9cdfaf2d
- Parent:
- slider_tone_v1.cpp@ 2:7f347d6a6422
- Child:
- 4:761f247c603e
File content as of revision 3:f68e9cdfaf2d:
#include "mbed.h"
#include "SLCD.h"
#include "TSISensor.h"
#define CHANNELON 0
#define CHANNELOFF 1
#define LCDLEN 10
#define DATATIME 100 //milli seccnds
//LCD messages
// Operating parameters
#define SIDETONE 700.0
#define TONEMIN 200.0
#define TONEINT 800.00 // So tone max is 1000
#define TONEON 0.50
#define TONEOFF 0.0
#define SPEEDAST 0
#define TONEAST 1
#define NUMTONES 10
#define LEDPERIOD 0.001
//#define PRINTDEBUG
Serial pc(USBTX, USBRX);
float diatonicScale[NUMTONES] = {246.94, 261.63,293.66,329.63,349.23,392.00,440.00,493.88,523.25,587.33};
SLCD slcd; //define LCD display
TSISensor tsiScaling; // Capacitive sensor/slider
PwmOut led(LED_RED);
DigitalOut outPin(PTC9); //J1-16
PwmOut soundOut(PTA13);
Timer dataTimer;
// Global scalars
char lcdData[LCDLEN];
float tonePeriod;
float toneFreq = SIDETONE;
void LCDMessNoDwell(char *lMess){
slcd.Home();
slcd.clear();
slcd.printf(lMess);
}
void diatonicAdjust( float scaling) {
int tempInt;
int scaleIndex;
static int oldScaleIndex = 0;
/* There appears to be a set up time for setting the PWM time period
only do a nes set up if the indext changes.
*/
scaleIndex = (int)(NUMTONES * scaling);
if (scaleIndex != oldScaleIndex) {
toneFreq = diatonicScale[scaleIndex];
tonePeriod = 1.0/toneFreq;
soundOut.period(tonePeriod); // adjusting period
soundOut.write(TONEON); // there is a setup time for both period and DF
oldScaleIndex = scaleIndex;
} else {
return;
}
#ifdef PRINTDEBUG
pc.printf(" %f,%d\n\r",scaling, scaleIndex );
#endif
tempInt = (int)toneFreq;
sprintf (lcdData,"%4d",tempInt);
LCDMessNoDwell(lcdData);
return;
}
void lightAdjust( float scaling) { // Control brightness of LED
float tempDutyFactor;
tempDutyFactor = 1.0 - scaling; //LED is a sinking connection // anode is held at 5V
led.write(tempDutyFactor); //adjusting duty factor
return;
}
int main(){
int tempInt;
float tempValue;
tonePeriod = 1.0/toneFreq;
soundOut.period(tonePeriod);
led.period(tonePeriod);
led.write(CHANNELOFF);
outPin.write(CHANNELOFF);
tempInt = (int)toneFreq;
sprintf (lcdData,"%4d",tempInt);
LCDMessNoDwell(lcdData);
// Start data timer
dataTimer.start();
dataTimer.reset();
while (true) {
if (dataTimer.read_ms() > DATATIME){ // check to see if enough time has passed
// to read the touch pad
tempValue = tsiScaling.readPercentage();
if(tempValue > 0) {
// soundOut.write(TONEON); // set duty factor to 50%
diatonicAdjust(tempValue);
lightAdjust(tempValue);
} else {
soundOut.write(TONEOFF); // set dutyfactor to 0%
LCDMessNoDwell("SOFF");
}
dataTimer.reset();
}
} // while forever
}// end main
