parent
2a1ce062d5
commit
7783794527
@ -1,3 +1,5 @@
|
|||||||
# witty
|
# Witty support Libraries
|
||||||
|
|
||||||
|
Arduino support libraries and demo code for Didels Witty 2WD balancing robot.
|
||||||
|
|
||||||
|
|
||||||
Arduino support libraries and demo code for Didels Witty 2WD balancing robot.
|
|
Binary file not shown.
@ -0,0 +1,32 @@
|
|||||||
|
//DemoWittyPfm.h #include "DemoWittyPfm.h"
|
||||||
|
// erreur d'avoir fusionner
|
||||||
|
#include "Pfm.h"
|
||||||
|
#include "Inter2.h"
|
||||||
|
|
||||||
|
SetupInter2(); // set interrupts
|
||||||
|
#define D2 DelMs(1000)
|
||||||
|
#define D5 DelMs(50)
|
||||||
|
pfmL=2; pfmR=2; D2;
|
||||||
|
pfmL=-2; pfmR=-2; D2;
|
||||||
|
pfmL=0; pfmR=0; D2;
|
||||||
|
pfmL=80; pfmR=80; D5;
|
||||||
|
pfmL=0; pfmR=0; D2;
|
||||||
|
pfmL=-80; pfmR=-80; D5;
|
||||||
|
pfmL=0; pfmR=0; D2;
|
||||||
|
|
||||||
|
#define MaxVit 40
|
||||||
|
#define MaxVit2 10
|
||||||
|
#define Dac DelMs(20)
|
||||||
|
for (pfmR=0; pfmR<MaxVit; pfmR++) {pfmL=pfmR; Dac;}
|
||||||
|
for (pfmR=MaxVit; pfmR>0; pfmR--) {pfmL=pfmR; Dac;}
|
||||||
|
for (pfmR=0; pfmR>-MaxVit; pfmR--) {pfmL=pfmR; Dac;}
|
||||||
|
for (pfmR=-MaxVit; pfmR<0; pfmR++) {pfmL=pfmR; Dac;}
|
||||||
|
D2;
|
||||||
|
#define Dacf DelMs(10)
|
||||||
|
for (pfmR=0; pfmR<MaxVit2; pfmR++) {pfmL=pfmR; Dacf;}
|
||||||
|
for (pfmR=MaxVit2; pfmR>0; pfmR--) {pfmL=pfmR; Dacf;}
|
||||||
|
for (pfmR=0; pfmR>-MaxVit2; pfmR--) {pfmL=pfmR; Dacf;}
|
||||||
|
for (pfmR=-MaxVit2; pfmR<0; pfmR++) {pfmL=pfmR; Dacf;}
|
||||||
|
D2;
|
||||||
|
|
||||||
|
//break, fin while
|
@ -0,0 +1,174 @@
|
|||||||
|
// WittyDemo2.ino 190419 4434b 112v !! 2 copies ajouté effet lum
|
||||||
|
// welcome with Rainbow and fast blink push n times
|
||||||
|
// 1 push red several move on-off and back to menu
|
||||||
|
// 2 pushes green same with pfm speed changes
|
||||||
|
// 3 control blue with most TV IR 1pulse stop, 2,3,4,5 move
|
||||||
|
// 4 demonstrate log dim
|
||||||
|
// 5 compte
|
||||||
|
// 6 test accelero Gy521 reset to restart demo
|
||||||
|
|
||||||
|
#include "Witty.h"
|
||||||
|
#include "GetPush.h"
|
||||||
|
#define Npix 8 // nombre de LEDs
|
||||||
|
#define Brt 2 // max 31 brigtness
|
||||||
|
#include "Apa102.h"
|
||||||
|
#include "Telec.h"
|
||||||
|
#include "Pfm.h"
|
||||||
|
#include "Inter2.h"
|
||||||
|
#include "TerSer.h"
|
||||||
|
#define aadd 0x68*2 // a revoir
|
||||||
|
#include "I2Ctwi.h"
|
||||||
|
#include "Gy521.h"
|
||||||
|
void setup() {
|
||||||
|
SetupWitty();
|
||||||
|
SetupApa102();
|
||||||
|
// ApaClear (); // not required?
|
||||||
|
SetupInter2();
|
||||||
|
SetupTerSer();
|
||||||
|
SetupI2Ctwi();
|
||||||
|
SetupGy521();
|
||||||
|
Cli(2); DelMs(500);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Une fonction démo à mettre dans un .h sépare avec par exemple un générateur de caractères
|
||||||
|
// On veut tester un compteur binaire 1 allumé 0 sombre
|
||||||
|
void ShowByte (uint8_t nn,uint8_t rr,uint8_t gg,uint8_t bb) {
|
||||||
|
ApaHead();
|
||||||
|
for (byte i=0; i<Npix; i++) {
|
||||||
|
if (nn&0x80) {ApaLed(rr,gg,bb);}
|
||||||
|
else {ApaLed(rr&3,gg&3,bb&3);} // int modulo 1,2,3
|
||||||
|
nn<<=1;
|
||||||
|
}
|
||||||
|
ApaTail();
|
||||||
|
}
|
||||||
|
|
||||||
|
byte cPush;
|
||||||
|
byte cnt5=0; // test 5
|
||||||
|
#define D DelMs(1000)
|
||||||
|
#define D2 DelMs(2000)
|
||||||
|
void loop() {
|
||||||
|
cli(); // if Demo3 before
|
||||||
|
ApaRainbow();
|
||||||
|
cPush= GetPush();
|
||||||
|
switch (cPush) {
|
||||||
|
case 1: // Demo1 Move
|
||||||
|
byte cmo;
|
||||||
|
cmo=2;
|
||||||
|
while(cmo--){ // on répète 2 fois
|
||||||
|
ApaLogRed(1);
|
||||||
|
AvD; AvG; D; // Avance
|
||||||
|
StopG; StopD; D;
|
||||||
|
ApaLogGreen(4);
|
||||||
|
AvD; D; //TourneG
|
||||||
|
StopG; StopD; D;
|
||||||
|
ApaLogBlue(4);
|
||||||
|
AvG; D; // TourneD
|
||||||
|
StopG; StopD; D;
|
||||||
|
ApaLogWhite(4);
|
||||||
|
RecD; RecG; D; // Recule
|
||||||
|
StopG; StopD; D;
|
||||||
|
ApaLogRed(15);
|
||||||
|
AvD; AvG; D; RecD; RecG; D;
|
||||||
|
BlockG; BlockD; D;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 2: // Demo2 Pfm Move
|
||||||
|
ApaLogBlue(10);
|
||||||
|
SetupInter2();
|
||||||
|
ApaLogGreen(1);
|
||||||
|
pfmL=1; pfmR=1; D2;
|
||||||
|
ApaLogGreen(2);
|
||||||
|
pfmL=2; pfmR=2; D2;
|
||||||
|
ApaLogGreen(4);
|
||||||
|
pfmL=4; pfmR=4; D2;
|
||||||
|
ApaLogGreen(8);
|
||||||
|
pfmL=8; pfmR=8; D;
|
||||||
|
ApaLogGreen(10);
|
||||||
|
pfmL=20; pfmR=20; DelMs(500);
|
||||||
|
ApaClear();
|
||||||
|
pfmL=0; pfmR=0; D;
|
||||||
|
ApaLogRed(10);
|
||||||
|
pfmL=-20; pfmR=-20; DelMs(500);
|
||||||
|
pfmL=0; pfmR=0; D;
|
||||||
|
ApaLogRed(15);
|
||||||
|
pfmL=70; pfmR=70; DelMs(300);
|
||||||
|
pfmL=0; pfmR=0; D;
|
||||||
|
ApaLogYellow(15);
|
||||||
|
pfmL=-70; pfmR=-70; DelMs(300);
|
||||||
|
pfmL=0; pfmR=0; D;
|
||||||
|
ApaLogBlue(2);
|
||||||
|
#define Dac DelMs(20)
|
||||||
|
#define MaxVit 75 // 15x5 a cause int logique leds
|
||||||
|
for (pfmR=0; pfmR<MaxVit; pfmR++) {pfmL=pfmR; ApaLogGreen(pfmR/5);Dac;}
|
||||||
|
for (pfmR=MaxVit; pfmR>=0; pfmR--) {pfmL=pfmR; ApaLogBlue(pfmR/5);Dac;}
|
||||||
|
pfmL=0; pfmR=0; ApaLogWhite(5); D;
|
||||||
|
for (pfmR=0; pfmR>-MaxVit; pfmR--) {pfmL=pfmR; ApaLogBlue(-pfmR/5);Dac;}
|
||||||
|
for (pfmR=-MaxVit; pfmR<0; pfmR++) {pfmL=pfmR; ApaLogGreen(-pfmR/5);Dac;}
|
||||||
|
pfmL=0; pfmR=0; ApaLogWhite(5); D;
|
||||||
|
DelMs(1000);
|
||||||
|
cli();
|
||||||
|
break;
|
||||||
|
case 3: // Demo IRM control
|
||||||
|
ApaLogWhite(10);
|
||||||
|
byte nPress;
|
||||||
|
while(1) {
|
||||||
|
nPress= Compte();
|
||||||
|
switch (nPress) {
|
||||||
|
case 1: // stop
|
||||||
|
ApaLogGreen(5);
|
||||||
|
FreeG; FreeD; break;
|
||||||
|
case 2: // avance
|
||||||
|
ApaLogRed(5);
|
||||||
|
AvG; AvD; break;
|
||||||
|
case 3: // tourneG
|
||||||
|
ApaLogBlue(5);
|
||||||
|
FreeG; AvD; break;
|
||||||
|
case 4: // tourneG
|
||||||
|
ApaLogPink(5);
|
||||||
|
AvG; FreeD; break;
|
||||||
|
case 5: // recule
|
||||||
|
ApaLogYellow(10);
|
||||||
|
RecG; RecD; break;
|
||||||
|
default: // plus de 5
|
||||||
|
ShowByte (0x55,5,5,5);
|
||||||
|
FreeG; FreeD; break;
|
||||||
|
} // end switch
|
||||||
|
} // end while
|
||||||
|
case 5: // RGB // new numbering
|
||||||
|
sei();
|
||||||
|
for (byte i=0;i<16;i++) {ApaLogRed(i); DelMs(100);}
|
||||||
|
for (byte i=16;i>0;i--) {ApaLogRed(i-1); DelMs(100);}
|
||||||
|
ApaLogGreen(1);DelMs(1000);ApaLogBlue(1);DelMs(1000);ApaLogRed(1);DelMs(1000);
|
||||||
|
ApaLogGreen(15);DelMs(1000);ApaLogBlue(15);DelMs(1000);ApaLogRed(15);DelMs(1000); // max intensity
|
||||||
|
// add your own tricks
|
||||||
|
cli();
|
||||||
|
break;
|
||||||
|
case 6:
|
||||||
|
while(1) {
|
||||||
|
ShowByte (cnt5++,41,41,0);
|
||||||
|
DelMs(200);
|
||||||
|
}
|
||||||
|
// reset to quit
|
||||||
|
|
||||||
|
case 4: // Demo6 Gy521 color effect click on terminal before to sse data
|
||||||
|
ApaLogYellow(10);
|
||||||
|
Text("EnvoiSer Gy521"); CR();
|
||||||
|
while(1){
|
||||||
|
ReadGy521();
|
||||||
|
Text("AcX"); Dec16s(AcX); Text("GyX"); Dec16s(GyX);
|
||||||
|
Text("AcY"); Dec16s(AcY); Text("GyY"); Dec16s(GyY);
|
||||||
|
Text("AcZ"); Dec16s(AcZ); Text("GyZ"); Dec16s(GyZ);
|
||||||
|
CR();
|
||||||
|
if (AcY> 10000) {ApaLogCyan(10);}
|
||||||
|
else if (AcY<-10000) {ApaLogBlue(10);}
|
||||||
|
if (AcZ>10000) {ApaLogRed(10);}
|
||||||
|
else if (AcZ<-10000) {ApaLogGreen(10);}
|
||||||
|
DelMs (200);
|
||||||
|
}
|
||||||
|
// reset to quit
|
||||||
|
default: // blink wait return ;
|
||||||
|
break;
|
||||||
|
} // end switch
|
||||||
|
|
||||||
|
} // end loop
|
||||||
|
|
@ -0,0 +1,110 @@
|
|||||||
|
#######################################
|
||||||
|
# Syntax Coloring Map
|
||||||
|
#######################################
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# Datatypes (KEYWORD1)
|
||||||
|
#######################################
|
||||||
|
TerSer KEYWORD1
|
||||||
|
moz KEYWORD1
|
||||||
|
uni KEYWORD1
|
||||||
|
diz KEYWORD1
|
||||||
|
cen KEYWORD1
|
||||||
|
mil KEYWORD1
|
||||||
|
dim KEYWORD1
|
||||||
|
Normal KEYWORD1
|
||||||
|
Spaces KEYWORD1
|
||||||
|
Zeros KEYWORD1
|
||||||
|
Compact KEYWORD1
|
||||||
|
zr KEYWORD1
|
||||||
|
zg KEYWORD1
|
||||||
|
zb KEYWORD1
|
||||||
|
status KEYWORD1
|
||||||
|
|
||||||
|
#######################################
|
||||||
|
# Methods and Functions (KEYWORD2)
|
||||||
|
#######################################
|
||||||
|
Af3Dig KEYWORD2
|
||||||
|
Af5Dig KEYWORD2
|
||||||
|
ApaClear KEYWORD2
|
||||||
|
ApaHead KEYWORD2
|
||||||
|
ApaHtoRGB KEYWORD2
|
||||||
|
ApaHue KEYWORD2
|
||||||
|
ApaLed KEYWORD2
|
||||||
|
ApaLogBlue KEYWORD2
|
||||||
|
ApaLogCyan KEYWORD2
|
||||||
|
ApaLogGreen KEYWORD2
|
||||||
|
ApaLogPink KEYWORD2
|
||||||
|
ApaLogRed KEYWORD2
|
||||||
|
ApaLogRGB KEYWORD2
|
||||||
|
ApaLogWhite KEYWORD2
|
||||||
|
ApaLogYellow KEYWORD2
|
||||||
|
ApaRainbow KEYWORD2
|
||||||
|
ApaRGB KEYWORD2
|
||||||
|
ApaS8 KEYWORD2
|
||||||
|
ApaTail KEYWORD2
|
||||||
|
Bin16 KEYWORD2
|
||||||
|
Bin8 KEYWORD2
|
||||||
|
BinDec16 KEYWORD2
|
||||||
|
BinDec8 KEYWORD2
|
||||||
|
BinDec9999 KEYWORD2
|
||||||
|
Car KEYWORD2
|
||||||
|
Clibyte KEYWORD2
|
||||||
|
CliErr KEYWORD2
|
||||||
|
Clignobyte KEYWORD2
|
||||||
|
Compte KEYWORD2
|
||||||
|
cntPush KEYWORD2
|
||||||
|
CR KEYWORD2
|
||||||
|
Dec16s KEYWORD2
|
||||||
|
Dec16u KEYWORD2
|
||||||
|
Dec8s KEYWORD2
|
||||||
|
Dec8u KEYWORD2
|
||||||
|
delMs KEYWORD2
|
||||||
|
DelMs KEYWORD2
|
||||||
|
Delus KEYWORD2
|
||||||
|
DoPfm KEYWORD2
|
||||||
|
Get KEYWORD2
|
||||||
|
GetPush KEYWORD2
|
||||||
|
Hex16 KEYWORD2
|
||||||
|
Hex32 KEYWORD2
|
||||||
|
Hex8 KEYWORD2
|
||||||
|
ReadByte KEYWORD2
|
||||||
|
ReadByteAt KEYWORD2
|
||||||
|
ReadGy521 KEYWORD2
|
||||||
|
ReadWord KEYWORD2
|
||||||
|
ReadWordAt KEYWORD2
|
||||||
|
SetupApa102 KEYWORD2
|
||||||
|
SetupGy521 KEYWORD2
|
||||||
|
SetupI2Ctwi KEYWORD2
|
||||||
|
SetupInter2 KEYWORD2
|
||||||
|
SetupSerNum KEYWORD2
|
||||||
|
SetupTerSer KEYWORD2
|
||||||
|
SetupWitty KEYWORD2
|
||||||
|
TerBin8 KEYWORD2
|
||||||
|
TerBinDec8 KEYWORD2
|
||||||
|
TerCar KEYWORD2
|
||||||
|
TerConvNibble KEYWORD2
|
||||||
|
TerCR KEYWORD2
|
||||||
|
TerDec16 KEYWORD2
|
||||||
|
TerDec16S KEYWORD2
|
||||||
|
TerDec8 KEYWORD2
|
||||||
|
TerDec8S KEYWORD2
|
||||||
|
TerDec9999 KEYWORD2
|
||||||
|
TerHex12 KEYWORD2
|
||||||
|
TerHex16 KEYWORD2
|
||||||
|
TerHex20 KEYWORD2
|
||||||
|
TerHex32 KEYWORD2
|
||||||
|
TerHex8 KEYWORD2
|
||||||
|
TerTextconst KEYWORD2
|
||||||
|
Textconst KEYWORD2
|
||||||
|
Textlnconst KEYWORD2
|
||||||
|
TtBin8 KEYWORD2
|
||||||
|
TwReadAck KEYWORD2
|
||||||
|
TwReadNack KEYWORD2
|
||||||
|
TwReStart KEYWORD2
|
||||||
|
TwStart KEYWORD2
|
||||||
|
TwStop KEYWORD2
|
||||||
|
TwWrite KEYWORD2
|
||||||
|
WriteByteAtbyte KEYWORD2
|
||||||
|
WriteBytebyte KEYWORD2
|
||||||
|
WriteWordAtbyte KEYWORD2
|
@ -0,0 +1,9 @@
|
|||||||
|
name=Witty Library
|
||||||
|
version=1.0.0
|
||||||
|
author=Didel <info@didel.com>
|
||||||
|
maintainer=Boxtec <info@boxtec.ch>
|
||||||
|
sentence=Witty
|
||||||
|
paragraph=Several support libraries for the Witty self-balancing 2WD bot from Didel.com. See the WittyQuickStartGuide.pdf in the docs folder.
|
||||||
|
category=Other
|
||||||
|
url=https://git.boxtec.ch/didel/Witty
|
||||||
|
architectures=*
|
@ -0,0 +1,130 @@
|
|||||||
|
// Apa102.h ref 190303ino Doc Apa.pdf
|
||||||
|
// #include "Apa102.h" SetupApa102(); dans PP
|
||||||
|
#define nop asm ("nop")
|
||||||
|
#define bApaCk 1
|
||||||
|
#define bApaDa 0
|
||||||
|
#define ApaCkOn bitSet (PORTB,bApaCk)
|
||||||
|
#define ApaCkOff bitClear (PORTB,bApaCk)
|
||||||
|
#define ApaDaOn bitSet (PORTB,bApaDa)
|
||||||
|
#define ApaDaOff bitClear (PORTB,bApaDa)
|
||||||
|
#define ApaCkPulse bitSet(PORTB,bApaCk); bitClear(PORTB,bApaCk)
|
||||||
|
|
||||||
|
void SetupApa102() {
|
||||||
|
DDRB |= (1<<bApaCk)+(1<<bApaDa) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
// ne pas utiliser delay()
|
||||||
|
#define Calib1ms 900 // 1ms 16 MHz
|
||||||
|
void delMs (int dm) {
|
||||||
|
for (volatile int i=0; i<dm; i++) {
|
||||||
|
for (volatile int j=0; j<Calib1ms; j++) {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ApaS8 (uint8_t dd) {
|
||||||
|
for (uint8_t i=0;i<8;i++) {
|
||||||
|
if (dd&0x80) ApaDaOn; else ApaDaOff;
|
||||||
|
ApaCkOn; dd<<=1; ApaCkOff; // durée 0.25 us
|
||||||
|
}
|
||||||
|
ApaDaOff;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ApaHead () {
|
||||||
|
ApaS8(0); ApaS8(0); ApaS8(0); ApaS8(0);
|
||||||
|
}
|
||||||
|
void ApaLed (uint8_t rr,uint8_t gg,uint8_t bb) {
|
||||||
|
ApaS8(224+Brt); ApaS8(bb); ApaS8(gg); ApaS8(rr);
|
||||||
|
}
|
||||||
|
void ApaTail () {
|
||||||
|
for (byte i=0; i<Npix/2; i++) {ApaCkOn; asm("nop"); ApaCkOff; }
|
||||||
|
}
|
||||||
|
|
||||||
|
void ApaClear () {
|
||||||
|
ApaHead ();
|
||||||
|
for (byte i=0; i<Npix; i++) { ApaLed (0,0,0); }
|
||||||
|
for (byte i=0; i<Npix/2; i++) {ApaCkOn; asm("nop"); ApaCkOff; }
|
||||||
|
}
|
||||||
|
void ApaRGB (uint8_t rr,uint8_t gg,uint8_t bb) {
|
||||||
|
ApaHead ();
|
||||||
|
for (byte i=0; i<Npix; i++) { ApaLed (rr,gg,bb); }
|
||||||
|
for (byte i=0; i<Npix/2; i++) {ApaCkOn; asm("nop"); ApaCkOff; }
|
||||||
|
}
|
||||||
|
|
||||||
|
byte taApaConv [16]={0,1,2,4, 6,9,12,17, 27,37,53,78, 100,144,198,255};
|
||||||
|
|
||||||
|
byte ApaConv (byte vv) {
|
||||||
|
return taApaConv [vv/8];
|
||||||
|
}
|
||||||
|
|
||||||
|
void ApaLogRGB( byte bb, byte gg, byte rr ) {
|
||||||
|
ApaS8(224+Brt); ApaS8(taApaConv [bb/8]);
|
||||||
|
ApaS8(taApaConv [gg/8]); ApaS8(taApaConv [rr/8]);
|
||||||
|
}
|
||||||
|
volatile byte lu;
|
||||||
|
void ApaLogRed (uint8_t log) {
|
||||||
|
lu= taApaConv[log]; ApaRGB (lu,0,0);
|
||||||
|
}
|
||||||
|
void ApaLogGreen (uint8_t log) {
|
||||||
|
lu= taApaConv[log]; ApaRGB (0,lu,0);
|
||||||
|
}
|
||||||
|
void ApaLogBlue (uint8_t log) {
|
||||||
|
lu=taApaConv[log]; ApaRGB (0,0,lu);
|
||||||
|
}
|
||||||
|
void ApaLogYellow (uint8_t log) {
|
||||||
|
lu=taApaConv[log]; ApaRGB (lu,lu,0);
|
||||||
|
}
|
||||||
|
void ApaLogPink (uint8_t log) {
|
||||||
|
lu=taApaConv[log]; ApaRGB (lu,0,lu);
|
||||||
|
}
|
||||||
|
void ApaLogCyan (uint8_t log) {
|
||||||
|
lu=taApaConv[log]; ApaRGB (0,lu,lu);
|
||||||
|
}
|
||||||
|
void ApaLogWhite (uint8_t log) {
|
||||||
|
lu=taApaConv[log]; ApaRGB (lu,lu,lu);
|
||||||
|
}
|
||||||
|
|
||||||
|
// HtoRGB.h ancien définitivement ici voir doc
|
||||||
|
|
||||||
|
uint16_t zr,zg,zb; // globales
|
||||||
|
uint16_t xr,xg,xb;
|
||||||
|
byte e;
|
||||||
|
void ApaHtoRGB (uint8_t h) {
|
||||||
|
e = h/32 ; // 8 zones
|
||||||
|
switch (e) {
|
||||||
|
case 0: xr=(96-h)*8 ; xg=h*8 ; xb=0 ; break;
|
||||||
|
case 1: xr=160*3 ; xg=h*8 ; xb=0 ; break;
|
||||||
|
case 2: xr=(96-h)*16 ; xg=h*8 ; xb=0 ; break;
|
||||||
|
case 3: xr=0 ; xg=(192-h)*8 ; xb=(h-96)*8 ; break;
|
||||||
|
case 4: xr=0 ; xg=(160-h)*16 ; xb=(h-112)*16 ; break;
|
||||||
|
case 5: xr=(h-160)*8 ; xg= 0 ; xb=(256-h)*8 ; break;
|
||||||
|
case 6: xr=(h-160)*8 ; xg= 0 ; xb=(256-h)*8 ; break;
|
||||||
|
case 7: xr=(h-160)*8 ; xg= 0 ; xb=(256-h)*8 ; break;
|
||||||
|
}
|
||||||
|
zr=(xr*85)/256; zg=(xg*85)/256; zb=(xb*85)/256;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ApaHue (byte hh) {
|
||||||
|
e = hh/32 ; // 8 zones
|
||||||
|
switch (e) {
|
||||||
|
case 0: xr=(96-hh)*8 ; xg=hh*8 ; xb=0 ; break;
|
||||||
|
case 1: xr=160*3 ; xg=hh*8 ; xb=0 ; break;
|
||||||
|
case 2: xr=(96-hh)*16 ; xg=hh*8 ; xb=0 ; break;
|
||||||
|
case 3: xr=0 ; xg=(192-hh)*8 ; xb=(hh-96)*8 ; break;
|
||||||
|
case 4: xr=0 ; xg=(160-hh)*16 ; xb=(hh-112)*16 ; break;
|
||||||
|
case 5: xr=(hh-160)*8 ; xg= 0 ; xb=(256-hh)*8 ; break;
|
||||||
|
case 6: xr=(hh-160)*8 ; xg= 0 ; xb=(256-hh)*8 ;break;
|
||||||
|
case 7: xr=(hh-160)*8 ; xg= 0 ; xb=(256-hh)*8 ; break;
|
||||||
|
}
|
||||||
|
ApaRGB (xr,xg,xb);
|
||||||
|
}
|
||||||
|
void ApaRainbow() { // exemple joli, manque d'orange
|
||||||
|
ApaHead();
|
||||||
|
for (byte i=1; i<Npix+1; i++) {
|
||||||
|
ApaHtoRGB(i*32); // 10x25
|
||||||
|
ApaLed (zr,zg,zb);
|
||||||
|
}
|
||||||
|
ApaTail();
|
||||||
|
}
|
||||||
|
// fin de Apa102.h
|
||||||
|
|
||||||
|
|
@ -0,0 +1,43 @@
|
|||||||
|
// GetPush.h bloquant repris pour Libx19 corr 190303
|
||||||
|
// main PP #include "GetPush.h"
|
||||||
|
// utilise PushOn et LedOn comme défini dans Witty.h
|
||||||
|
// si pin partagée, voir Dixi
|
||||||
|
|
||||||
|
byte cntPush, cntOff = 0, cli=0;
|
||||||
|
//<-- Fonction GetPous --> rend nbre d'actions 1 2 3..
|
||||||
|
enum { WaitFirst, Pushing, NotPushing } npl= WaitFirst;
|
||||||
|
byte GetPush() {
|
||||||
|
cntPush=0; cntOff = 0;
|
||||||
|
while (cntOff < (500/5)) { // attend dernier push 0.5s
|
||||||
|
switch (npl) {
|
||||||
|
case WaitFirst: // on clignote en attendant un push
|
||||||
|
if (!PushOn) {
|
||||||
|
LedOff; DelMs (2);
|
||||||
|
if (cli++ == 40) { cli = 0; LedOn; DelMs (5);}
|
||||||
|
LedOff; break;
|
||||||
|
}
|
||||||
|
npl= Pushing; break;
|
||||||
|
case Pushing: // on attend le relâchemnent
|
||||||
|
LedOn;
|
||||||
|
if (PushOn) { break; } //attend relaché
|
||||||
|
LedOff;
|
||||||
|
cntPush++ ; cntOff= 0 ;
|
||||||
|
npl = NotPushing ; break ;
|
||||||
|
case NotPushing: // on attend un peu s'il y a une pression suivant
|
||||||
|
DelMs (5);
|
||||||
|
cntOff++; //200x5 = 1 sec
|
||||||
|
if (!PushOn) break ; //on relâche
|
||||||
|
npl = Pushing ;
|
||||||
|
break;
|
||||||
|
} // end switch
|
||||||
|
} // end while
|
||||||
|
npl = WaitFirst; // prépare appel suivant
|
||||||
|
// clignote cntPous fois
|
||||||
|
for (cli=0; cli<cntPush; cli++) {
|
||||||
|
LedOn ; DelMs(100); LedOff ; DelMs(200);
|
||||||
|
} // end for
|
||||||
|
cntOff = 0;
|
||||||
|
return cntPush ;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,17 @@
|
|||||||
|
// Gy521 190419
|
||||||
|
//dans le pp #include "Gy521" SetupGy521();
|
||||||
|
// Adresse 7 bits 0x68 a déclarer en 8 bits pour TWI
|
||||||
|
#define aadd 0x68*2 // adresse 8bits
|
||||||
|
void SetupGy521() { WriteByteAt(0x6B,0); } //wakes up the MPU-6050)
|
||||||
|
|
||||||
|
volatile int16_t AcX,AcY,AcZ;
|
||||||
|
volatile int16_t GyX,GyY,GyZ;
|
||||||
|
void ReadGy521 () { // update global variables
|
||||||
|
AcX=ReadWordAt(0x3B); //Acceleration X
|
||||||
|
AcY=ReadWordAt(0x3D);
|
||||||
|
AcZ=ReadWordAt(0x3F);
|
||||||
|
GyX=ReadWordAt(0x43); //Gyro X
|
||||||
|
GyY=ReadWordAt(0x45);
|
||||||
|
GyZ=ReadWordAt(0x47);
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,75 @@
|
|||||||
|
//#include "I2Ctwi.h" TWI et fonctions composées
|
||||||
|
// inside PP #include "I2Ctwi.h" SetupI2Ctwi();
|
||||||
|
//#include <Arduino.h> // pas nécessaire?
|
||||||
|
// aadd defini dans pp avec #define aadd valeur adresse 8 bits sélect
|
||||||
|
// ? changera avec paramètre explicite? ou nom G521Twi
|
||||||
|
byte status;
|
||||||
|
void SetupI2Ctwi() {
|
||||||
|
TWSR = 1; //0 400kHz 1-160k 2 40k
|
||||||
|
TWBR = 0x0C; // bitrate
|
||||||
|
TWCR = (1 << TWEN); // autres bits à 0
|
||||||
|
}
|
||||||
|
|
||||||
|
void TwStart () {
|
||||||
|
TWCR = (1 << TWINT) | (1 << TWSTA) | (1 << TWEN); // start
|
||||||
|
while (!(TWCR & (1 << TWINT))) {}
|
||||||
|
}
|
||||||
|
void TwReStart () {
|
||||||
|
TWCR = (1 << TWINT) | (1 << TWSTA) | (1 << TWEN); // start
|
||||||
|
while (!(TWCR & (1 << TWINT))) {}
|
||||||
|
}
|
||||||
|
void TwStop () {
|
||||||
|
TWCR = (1 << TWINT) | (1 << TWSTO) | (1 << TWEN); // stop
|
||||||
|
for (volatile int i = 0; i < 20; i++) ;
|
||||||
|
}
|
||||||
|
void TwWrite (byte ab) { // addr8 ou data8
|
||||||
|
TWDR = ab;
|
||||||
|
TWCR = (1 << TWINT) | (1 << TWEN);
|
||||||
|
while (!(TWCR & (1 << TWINT))) {}
|
||||||
|
; status = TWSR & 0xF8;
|
||||||
|
}
|
||||||
|
byte TwReadAck () {
|
||||||
|
TWCR = (1 << TWINT) | (1 << TWEN) |(1<<TWEA);
|
||||||
|
while (!(TWCR & (1 << TWINT))) {}
|
||||||
|
return (TWDR);
|
||||||
|
}
|
||||||
|
byte TwReadNack () {
|
||||||
|
TWCR = (1 << TWINT) | (1 << TWEN);
|
||||||
|
while (!(TWCR & (1 << TWINT))) {}
|
||||||
|
return (TWDR);
|
||||||
|
}
|
||||||
|
// Fonctions composées pour aadd -------------------------------
|
||||||
|
void WriteByte(byte dd) {
|
||||||
|
TwStart(); TwWrite(aadd); TwWrite(dd); TwStop();
|
||||||
|
}
|
||||||
|
void WriteByteAt(byte rr,byte dd) {
|
||||||
|
TwStart(); TwWrite(aadd); TwWrite(rr); TwWrite(dd); TwStop();
|
||||||
|
}
|
||||||
|
void WriteWordAt(byte rr,uint16_t dd) { //Little Endian
|
||||||
|
TwStart(); TwWrite(aadd); TwWrite(rr); TwWrite(dd>>8); TwWrite(dd&0xFF); TwStop();
|
||||||
|
}
|
||||||
|
byte ReadByte() {
|
||||||
|
byte dd;
|
||||||
|
TwStart(); TwWrite(aadd+1); dd=TwReadNack(); TwStop();
|
||||||
|
return (dd);
|
||||||
|
}
|
||||||
|
byte ReadWord() {
|
||||||
|
byte dd;
|
||||||
|
TwStart(); TwWrite(aadd+1); dd=(TwReadAck()<<8); dd|= TwReadNack(); TwStop();
|
||||||
|
return (dd);
|
||||||
|
}
|
||||||
|
uint8_t ReadByteAt(byte rr) {
|
||||||
|
byte dd;
|
||||||
|
TwStart(); TwWrite(aadd); TwWrite(rr);
|
||||||
|
TwReStart(); TwWrite(aadd+1); dd=TwReadNack(); TwStop();
|
||||||
|
return(dd);
|
||||||
|
}
|
||||||
|
uint16_t ReadWordAt(byte rr) {
|
||||||
|
uint16_t dd;
|
||||||
|
TwStart(); TwWrite(aadd); TwWrite(rr);
|
||||||
|
TwReStart(); TwWrite(aadd+1); dd=(TwReadAck()<<8); dd |=(TwReadNack()); TwStop();
|
||||||
|
return(dd);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -0,0 +1,20 @@
|
|||||||
|
//Inter2.h
|
||||||
|
//Dans PP #include "Inter2.h" SetupInter2();
|
||||||
|
volatile byte cpf,cup,cdo;
|
||||||
|
ISR (TIMER2_OVF_vect) {
|
||||||
|
// TCNT2 = 256-20; // 2M 20 11us 100 35us 200 85us
|
||||||
|
TCNT2 = 141; // 58 us calibre pour Tell
|
||||||
|
cup++;cdo++;
|
||||||
|
if (cpf++ > 35) { cpf=0; // toutes les 35x58= 2ms
|
||||||
|
DoPfm (); //durée 2us
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetupInter2() { // initialisation
|
||||||
|
TCCR2A = 0; //default
|
||||||
|
TCCR2B = 0b00000010; // 2MHz
|
||||||
|
TIMSK2 = 0b00000001; // TOIE2
|
||||||
|
//TIFR2 flag TOV2
|
||||||
|
sei();
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,39 @@
|
|||||||
|
//Pfm.h avec table vit
|
||||||
|
//#include "Pfm.h" SetupPfm(); dans le pp
|
||||||
|
volatile int8_t pfmL, pfmR; // -80 .. +80
|
||||||
|
#define MaxPfm 80
|
||||||
|
volatile byte pfmCntL;
|
||||||
|
volatile byte pfmCntR;
|
||||||
|
void DoPfm () {
|
||||||
|
char tempL,tempR;
|
||||||
|
if (pfmR > MaxPfm) pfmR=MaxPfm; // saturer
|
||||||
|
if (pfmR < -MaxPfm) pfmR= -MaxPfm;
|
||||||
|
|
||||||
|
if (pfmR >=0) {
|
||||||
|
if ((pfmCntR += pfmR) > MaxPfm) {
|
||||||
|
pfmCntR -= MaxPfm; AvD; }
|
||||||
|
else { FreeD; }
|
||||||
|
}
|
||||||
|
if (pfmR <0) {
|
||||||
|
tempR= -pfmR; // ou pfR= ABS(pfR)
|
||||||
|
if ((pfmCntR += tempR) > MaxPfm) {
|
||||||
|
pfmCntR -= MaxPfm; RecD; }
|
||||||
|
else { FreeD; }
|
||||||
|
}
|
||||||
|
if (pfmL > MaxPfm) pfmL=MaxPfm; // saturer
|
||||||
|
if (pfmL < -MaxPfm) pfmL= -MaxPfm;
|
||||||
|
|
||||||
|
if (pfmL >=0) {
|
||||||
|
if ((pfmCntL += pfmL) > MaxPfm) {
|
||||||
|
pfmCntL -= MaxPfm; AvG; }
|
||||||
|
else { FreeG; }
|
||||||
|
}
|
||||||
|
if (pfmL <0) {
|
||||||
|
tempL= -pfmL; // ou pfL= ABS(pfL)
|
||||||
|
if ((pfmCntL += tempL) > MaxPfm) {
|
||||||
|
pfmCntL -= MaxPfm; RecG; }
|
||||||
|
else { FreeG; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
@ -0,0 +1,158 @@
|
|||||||
|
// SerNum.h Formats avec zéros enlever
|
||||||
|
//Dans PP #include "SerNum.h" SetupSerNum();
|
||||||
|
void SetupSerNum() {
|
||||||
|
UBRR0=F_CPU/(9600*16L)-1; // set speed
|
||||||
|
UCSR0B=0x18; // -- -- -- rxe txe -- -- --
|
||||||
|
UCSR0C=0x06; // set mode: 8 data bits, no parity, 1 stop bit
|
||||||
|
}
|
||||||
|
//Rx S1 est toujours en sortie
|
||||||
|
//Tx S2 aussi, sous controle du 328 si TerOn (S2 ignoré);
|
||||||
|
#define TerOn UBRR0=F_CPU/(9600*16L)-1; UCSR0C=0x06; UCSR0B=0x08
|
||||||
|
#define TerOff DelMs(3); UCSR0C=0x06; UCSR0B=0
|
||||||
|
|
||||||
|
void TerCar( byte dd) { // write bloquant Ok initial
|
||||||
|
while(!(UCSR0A&0x20));// wait
|
||||||
|
UDR0=dd; // OK, send it now!
|
||||||
|
}
|
||||||
|
void TerCR() {
|
||||||
|
TerCar(13);TerCar(10);
|
||||||
|
}
|
||||||
|
void TerText(const char str[]) {
|
||||||
|
for (byte i=0; i< strlen(str); i++) {
|
||||||
|
TerCar(str[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void TerBin8 (byte bb) {
|
||||||
|
for (byte i=0;i<8;i++) {
|
||||||
|
if (bb&0x80) TerCar('1');
|
||||||
|
else TerCar('0');
|
||||||
|
bb <<= 1;
|
||||||
|
}
|
||||||
|
TerCar(' ');
|
||||||
|
}
|
||||||
|
char TerConvNibble (byte nn) { // converti 4 bit hexa en Ascii
|
||||||
|
byte cc;
|
||||||
|
if (nn<10) {cc = nn + '0';}
|
||||||
|
else {cc = nn-10 + 'A';}
|
||||||
|
return cc;
|
||||||
|
}
|
||||||
|
void TerHex8 (byte hh) {
|
||||||
|
byte cc;
|
||||||
|
cc = TerConvNibble (hh >> 4) ; // ne modifie pas hh
|
||||||
|
TerCar(cc);
|
||||||
|
cc = TerConvNibble (hh & 0x0F) ;
|
||||||
|
TerCar(cc);
|
||||||
|
TerCar(' '); // space
|
||||||
|
}
|
||||||
|
void TerHex16 (uint16_t hh) {
|
||||||
|
byte cc;
|
||||||
|
cc = TerConvNibble (hh >> 12) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 8)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 4)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh )&0x0F) ; TerCar(cc);
|
||||||
|
TerCar(' ');
|
||||||
|
}
|
||||||
|
void TerHex12 (uint16_t hh) {
|
||||||
|
byte cc=0;
|
||||||
|
cc = TerConvNibble ((hh >> 8)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 4)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble (hh & 0x0F) ; TerCar(cc);
|
||||||
|
TerCar(' ');
|
||||||
|
}
|
||||||
|
void TerHex20 (uint32_t hh) {
|
||||||
|
byte cc;
|
||||||
|
cc = TerConvNibble ((hh >> 16)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 12)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 8 )&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 4 )&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble (hh & 0x0F) ; TerCar(cc);
|
||||||
|
TerCar(' ');
|
||||||
|
}
|
||||||
|
void TerHex32 (uint32_t hh) {
|
||||||
|
byte cc;
|
||||||
|
|
||||||
|
cc = TerConvNibble ((hh >> 28)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 24)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 20)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 16)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 12)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 8)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh >> 4)&0x0F) ; TerCar(cc);
|
||||||
|
cc = TerConvNibble ((hh )&0x0F) ; TerCar(cc);
|
||||||
|
TerCar(' ');
|
||||||
|
}
|
||||||
|
uint16_t TerBinDec8 (uint8_t bb) {
|
||||||
|
uint16_t dd=0;
|
||||||
|
for (byte i=0; i<8; i++) {
|
||||||
|
if ((dd & 0x0F)>0x04) {dd += 0x03;}
|
||||||
|
if ((dd & 0xF0)>0x40) {dd += 0x30;}
|
||||||
|
dd=dd<<1;
|
||||||
|
if ((bb & 0x80)) {dd += 1;} //inject bit
|
||||||
|
bb=bb<<1; // prepare next bit
|
||||||
|
}
|
||||||
|
return dd;
|
||||||
|
}
|
||||||
|
/*#define TerDec8(v) \
|
||||||
|
do { const int8_t vv = (v); \
|
||||||
|
if(vv<0) { TerDec8S(vv); } \
|
||||||
|
else { TerDec8U(vv); } \
|
||||||
|
} while(0)
|
||||||
|
*/
|
||||||
|
void TerDec8 (uint8_t hh) {
|
||||||
|
TerHex12(TerBinDec8(hh));
|
||||||
|
}
|
||||||
|
|
||||||
|
void TerDec8S (int8_t hh) {
|
||||||
|
if (hh<0) { // négatif
|
||||||
|
TerCar('-'); hh = -hh;
|
||||||
|
} else {
|
||||||
|
TerCar('+');
|
||||||
|
}
|
||||||
|
TerHex12(TerBinDec8(hh));
|
||||||
|
}
|
||||||
|
uint16_t BinDec9999 (uint16_t bb) { //0x270F max
|
||||||
|
uint32_t dd=0;
|
||||||
|
for (byte i=0; i<16; i++) {
|
||||||
|
if ((dd & 0x000F)>0x0004) {dd += 0x0003;}
|
||||||
|
if ((dd & 0x00F0)>0x0040) {dd += 0x0030;}
|
||||||
|
if ((dd & 0x0F00)>0x0400) {dd += 0x0300;}
|
||||||
|
if ((dd & 0xF000)>0x4000) {dd += 0x3000;}
|
||||||
|
dd=dd<<1;
|
||||||
|
if ((bb & 0x8000)) {dd += 1; } //inject bit
|
||||||
|
bb<<=1; // prepare next bit
|
||||||
|
}
|
||||||
|
return dd;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32_t BinDec16 (uint16_t bb) {
|
||||||
|
uint32_t dd=0;
|
||||||
|
for (byte i=0; i<16 ; i++) {
|
||||||
|
if ((dd & 0x000F)>0x0004) {dd += 0x0003;}
|
||||||
|
if ((dd & 0x00F0)>0x0040) {dd += 0x0030;}
|
||||||
|
if ((dd & 0x0F00)>0x0400) {dd += 0x0300;}
|
||||||
|
if ((dd & 0xF000)>0x4000) {dd += 0x3000;}
|
||||||
|
dd=dd<<1;
|
||||||
|
if ((bb & 0x8000)) {dd += 1; } //inject bit
|
||||||
|
bb<<=1; // prepare next bit
|
||||||
|
}
|
||||||
|
return dd;
|
||||||
|
}
|
||||||
|
void TerDec9999 (uint16_t hh) { // limité à 0x2703
|
||||||
|
if (hh>9999) { TerText("over "); }
|
||||||
|
else TerHex16(BinDec9999(hh));
|
||||||
|
}
|
||||||
|
void TerDec16 (uint32_t hh) { //
|
||||||
|
TerHex20(BinDec16(hh));
|
||||||
|
}
|
||||||
|
|
||||||
|
void TerDec16S (int16_t hh) { // signé
|
||||||
|
if (hh<0) { // negatif
|
||||||
|
TerCar('-'); hh = -hh;
|
||||||
|
} else {
|
||||||
|
TerCar('+');
|
||||||
|
}
|
||||||
|
TerHex20(BinDec16(hh));
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,17 @@
|
|||||||
|
//Telec.h Telec simple
|
||||||
|
// #include "Telec.h" setup dans Witty.h
|
||||||
|
|
||||||
|
// Compte rend le nombre de pressions courtes
|
||||||
|
#define DelSil 100
|
||||||
|
#define DelCnt 500
|
||||||
|
byte Compte () {
|
||||||
|
byte cnt;
|
||||||
|
while (!IrmOn) ; // attend 1ere imp
|
||||||
|
int cDel=0; cnt=0;
|
||||||
|
while (cDel++<DelCnt) {
|
||||||
|
if (IrmOn) { LedOn; cDel=0;} else {LedOff;}
|
||||||
|
if (cDel==DelSil) { cnt++; }
|
||||||
|
DelMs (2);
|
||||||
|
}
|
||||||
|
return (cnt);
|
||||||
|
}
|
@ -0,0 +1,275 @@
|
|||||||
|
// TerSer.h 4 modes 190323
|
||||||
|
// ~280 lines ~7700 car
|
||||||
|
//add to main program #include "TerSer.h" SetupTerSer();
|
||||||
|
// or from Arduino lib #include <TerSer.h> SetupTerSer();
|
||||||
|
void SetupTerSer() {
|
||||||
|
UBRR0= 103; // 9600
|
||||||
|
UCSR0B=0x18; // -- -- -- rxe txe -- -- --
|
||||||
|
UCSR0C=0x06; // set mode: 8 data bits, no parity, 1 stop bit
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t moz=0; // Default value
|
||||||
|
#define Normal moz=0
|
||||||
|
#define Spaces moz=1
|
||||||
|
#define Zeros moz=2
|
||||||
|
#define Compact moz=3
|
||||||
|
|
||||||
|
uint8_t Get() { // read blocking
|
||||||
|
while (!(UCSR0A&0x80)); // wait
|
||||||
|
return UDR0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Car( uint8_t dd) { // write blocking
|
||||||
|
while(!(UCSR0A&0x20));// wait
|
||||||
|
UDR0=dd; // OK, send it now!
|
||||||
|
}
|
||||||
|
|
||||||
|
void CR() {
|
||||||
|
Car(13);Car(10); // CR LF
|
||||||
|
}
|
||||||
|
|
||||||
|
void Text(const char str[]) {
|
||||||
|
for (uint8_t i=0; i< strlen(str); i++) { Car(str[i]); }
|
||||||
|
}
|
||||||
|
|
||||||
|
void Textln(const char str[]) {
|
||||||
|
for (uint8_t i=0; i< strlen(str); i++) { Car(str[i]); }
|
||||||
|
Car(13);Car(10);
|
||||||
|
}
|
||||||
|
|
||||||
|
void TtBin8 (uint8_t bb) { // auxiliary function
|
||||||
|
for (uint8_t i=0;i<8;i++) {
|
||||||
|
if (bb&0x80) Car('1');
|
||||||
|
else Car('0');
|
||||||
|
bb <<= 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void Bin8 (uint8_t bb) {
|
||||||
|
TtBin8 (bb); Car(' ');
|
||||||
|
}
|
||||||
|
void Bin16 (uint16_t bb) {
|
||||||
|
TtBin8 (bb>>8); Car('.');
|
||||||
|
TtBin8 (bb&0xFF);
|
||||||
|
Car(' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
char ConvNibble (uint8_t nn) { // 4 bit binary to Ascii
|
||||||
|
uint8_t cc;
|
||||||
|
if (nn<10) {cc = nn + '0';}
|
||||||
|
else {cc = nn-10 + 'A';}
|
||||||
|
return cc;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Hex8 (uint8_t hh) {
|
||||||
|
uint8_t cc;
|
||||||
|
cc = ConvNibble (hh >> 4); Car(cc);
|
||||||
|
cc = ConvNibble (hh & 0x0F) ; Car(cc);
|
||||||
|
Car(' '); // space
|
||||||
|
}
|
||||||
|
void Hex16 (uint16_t hh) {
|
||||||
|
uint8_t cc;
|
||||||
|
cc = ConvNibble (hh >> 12) ; Car(cc);
|
||||||
|
cc = ConvNibble ((hh >> 8)&0x0F) ; Car(cc);
|
||||||
|
cc=hh&0xFF; Hex8 (cc);
|
||||||
|
Car(' ');
|
||||||
|
}
|
||||||
|
void Hex32 (uint32_t hh) {
|
||||||
|
uint8_t cc;
|
||||||
|
cc = ConvNibble (hh >> 28) ; Car(cc);
|
||||||
|
cc = ConvNibble ((hh >> 24)&0x0F) ; Car(cc);
|
||||||
|
cc = ConvNibble ((hh >> 20)&0x0F) ; Car(cc);
|
||||||
|
cc = ConvNibble ((hh >> 16)&0x0F) ; Car(cc);
|
||||||
|
cc=hh&0xFFFF; Hex16 (cc);
|
||||||
|
Car(' ');
|
||||||
|
}
|
||||||
|
|
||||||
|
// -- new Decimal functions with 4 modes (see above)
|
||||||
|
|
||||||
|
uint8_t uni,diz,cen,mil,dim;
|
||||||
|
uint8_t tyn; // type number
|
||||||
|
uint8_t sig;
|
||||||
|
|
||||||
|
void BinDec8 (uint8_t bb) {
|
||||||
|
uni=0;diz=0;cen=0;
|
||||||
|
tyn=0; if (bb==0) return;
|
||||||
|
uni=bb%10; bb=bb/10; if (bb==0){tyn=1;return;}
|
||||||
|
diz=bb%10; bb=bb/10; if (bb==0){tyn=2;return;}
|
||||||
|
cen=bb; tyn=3;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Af3Dig() {
|
||||||
|
switch (moz) {
|
||||||
|
case 0: // Normal signe devant le nombre
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car(' '); Car(' ');Car(' ');Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(' ');Car(' '); Car(sig); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(' '); Car(sig); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(sig); Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break; // end case moz 0
|
||||||
|
case 1: // Spaces
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car(' '); Car(' ');Car(' ');Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(sig);Car(' '); Car(' '); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(sig); Car(' '); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(sig); Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break; // end case moz 1
|
||||||
|
case 2: // Zeros
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car(' '); Car('0');Car('0');Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(sig);Car('0'); Car('0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(sig); Car('0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(sig); Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break; // end case moz 2
|
||||||
|
case 3: // Compact
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(sig); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(sig); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(sig); Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break; // endcase moz 3
|
||||||
|
} // end switch moz
|
||||||
|
}
|
||||||
|
// this macro generate a warning depending on sign
|
||||||
|
#define Dec8(v) \
|
||||||
|
do { typeof(v) _v = -1; \
|
||||||
|
if (_v < 0) { Dec8s(v); } \
|
||||||
|
else { Dec8u(v); } \
|
||||||
|
} while(0);
|
||||||
|
|
||||||
|
void Dec8u (uint8_t hh) {
|
||||||
|
sig=' ';
|
||||||
|
BinDec8 (hh); Af3Dig();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Dec8s (int8_t hh) {
|
||||||
|
if (hh<0) { // négatif
|
||||||
|
sig='-'; hh = -hh;
|
||||||
|
} else {
|
||||||
|
sig='+';
|
||||||
|
}
|
||||||
|
BinDec8 (hh); Af3Dig();
|
||||||
|
}
|
||||||
|
|
||||||
|
//-----------------
|
||||||
|
void BinDec16 (uint32_t bb) {
|
||||||
|
uni=0;diz=0;cen=0;mil=0;dim=0;
|
||||||
|
tyn=0; if (bb==0) return;
|
||||||
|
uni=bb%10; bb=bb/10; if (bb==0){tyn=1;return;}
|
||||||
|
diz=bb%10; bb=bb/10; if (bb==0){tyn=2;return;}
|
||||||
|
cen=bb%10; bb=bb/10; if (bb==0){tyn=3;return;}
|
||||||
|
mil=bb%10; bb=bb/10; if (bb==0){tyn=4;return;}
|
||||||
|
dim=bb; tyn=5;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Af5Dig() {
|
||||||
|
switch (moz) {
|
||||||
|
case 0: // Normal mode
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car(' '); Car(' '); Car(' ');Car(' ');Car(' ');Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(' '); Car(' '); Car(' ');Car(' ');Car(sig);Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(' '); Car(' '); Car(' ');Car(sig);Car(diz+'0');Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(' '); Car(' '); Car(sig);Car(cen+'0');Car(diz+'0');Car(uni+'0'); Car(' '); break;
|
||||||
|
case 4:
|
||||||
|
Car(' '); Car(sig); Car(mil+'0');Car(cen+'0');Car(diz+'0');Car(uni+'0'); Car(' '); break;
|
||||||
|
case 5:
|
||||||
|
Car(sig); Car(dim+'0'); Car(mil+'0');Car(cen+'0');Car(diz+'0');Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break;
|
||||||
|
case 1: // Spaces
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car(' '); Car(' ');Car(' ');Car(' ');Car(' ');Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(sig);Car(' '); Car(' ');Car(' ');Car(' '); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(sig); Car(' '); Car(' ');Car(' ');Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(sig); Car(' '); Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 4:
|
||||||
|
Car(sig); Car(' ');Car(mil+'0');Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 5:
|
||||||
|
Car(sig); Car(dim+'0');Car(mil+'0');Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break; // case 1
|
||||||
|
case 2: // Zeros
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car(' '); Car('0');Car('0');Car('0');Car('0');Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(sig); Car('0');Car('0');Car('0'); Car('0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(sig); Car('0');Car('0');Car('0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(sig); Car('0');Car('0');Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 4:
|
||||||
|
Car(sig); Car('0');Car(mil+'0');Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 5:
|
||||||
|
Car(sig); Car(dim+'0');Car(mil+'0');Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break;
|
||||||
|
case 3: // Compact
|
||||||
|
switch (tyn) {
|
||||||
|
case 0:
|
||||||
|
Car('0'); Car(' '); break;
|
||||||
|
case 1:
|
||||||
|
Car(sig); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 2:
|
||||||
|
Car(sig); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 3:
|
||||||
|
Car(sig); Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 4:
|
||||||
|
Car(sig); Car(mil+'0');Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
case 5:
|
||||||
|
Car(sig); Car(dim+'0');Car(mil+'0');Car(cen+'0'); Car(diz+'0'); Car(uni+'0'); Car(' '); break;
|
||||||
|
} // end switch tyn
|
||||||
|
break;
|
||||||
|
} // end switch moz
|
||||||
|
}
|
||||||
|
|
||||||
|
// this macro generate a warning depending on sign
|
||||||
|
#define Dec16(v) \
|
||||||
|
do { typeof(v) _v = -1; \
|
||||||
|
if (_v < 0) { Dec16s(v); } \
|
||||||
|
else { Dec16u(v); } \
|
||||||
|
} while(0);
|
||||||
|
|
||||||
|
void Dec16u (uint16_t hh) {
|
||||||
|
sig=' ';
|
||||||
|
BinDec16(hh); Af5Dig();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Dec16s (int16_t hh) {
|
||||||
|
if (hh<0) { // négatif
|
||||||
|
sig='-'; hh = -hh;
|
||||||
|
} else {
|
||||||
|
sig='+';
|
||||||
|
}
|
||||||
|
BinDec16(hh); Af5Dig();
|
||||||
|
}
|
||||||
|
// end code
|
||||||
|
|
||||||
|
|
@ -0,0 +1,74 @@
|
|||||||
|
//Witty.h 190124 voir www.didel.com/Witty.pdf
|
||||||
|
//Dans PP #include "Witty.h" SetupWitty();
|
||||||
|
//Strip RGB - voir Apa102.h et www.didel.com/ApaWitty.pdf
|
||||||
|
//Gy521 - voir Gy521.h www.didel.com/Gy521Witty.pdf
|
||||||
|
//Simple teled control
|
||||||
|
//Push et Led - voir GetPush.h et https://www.didel.com/diduino/Poussoir.pdf
|
||||||
|
#define bLed 1 // PORTC
|
||||||
|
#define bPush 0 // actif à zero
|
||||||
|
#define PushOn (!(PINC&(1<<bPush))) // pull-up int
|
||||||
|
#define LedOn bitSet (PORTC,bLed)
|
||||||
|
#define LedOff bitClear (PORTC,bLed)
|
||||||
|
#define LedToggle (PORTC^=(1<<bLed))
|
||||||
|
//Module IR - voir Telec.h et www.didel.com/TelecommandeIrSimple.pdf
|
||||||
|
#define bIrm 2 // on PORTD int
|
||||||
|
#define IrmOn !(PIND&(1<<bIrm))
|
||||||
|
|
||||||
|
//Moteurs;
|
||||||
|
#define bAvD 6
|
||||||
|
#define bRecD 7
|
||||||
|
#define AvD bitSet (PORTD,bAvD); bitClear (PORTD,bRecD)
|
||||||
|
#define RecD bitClear (PORTD,bAvD); bitSet (PORTD,bRecD)
|
||||||
|
#define FreeD bitClear (PORTD,bAvD); bitClear (PORTD,bRecD)
|
||||||
|
#define BlockD bitSet (PORTD,bAvD); bitSet (PORTD,bRecD)
|
||||||
|
#define bAvG 5
|
||||||
|
#define bRecG 4
|
||||||
|
#define AvG bitSet (PORTD,bAvG); bitClear (PORTD,bRecG)
|
||||||
|
#define RecG bitClear (PORTD,bAvG); bitSet (PORTD,bRecG)
|
||||||
|
#define FreeG bitClear (PORTD,bAvG); bitClear (PORTD,bRecG) // TEST
|
||||||
|
#define BlockG bitSet (PORTD,bAvG); bitSet (PORTD,bRecG)
|
||||||
|
#define StopG BlockG
|
||||||
|
#define StopD BlockD
|
||||||
|
|
||||||
|
#define bIrm 2 // on PORTD int
|
||||||
|
#define IrmOn !(PIND&(1<<bIrm))
|
||||||
|
|
||||||
|
#define bLed 1 // PORTC
|
||||||
|
#define bPous 0 // actif à zero
|
||||||
|
#define PousOn (!(PINC&(1<<bPous))) // pull-up
|
||||||
|
#define LedOn bitSet (PORTC,bLed)
|
||||||
|
#define LedOff bitClear (PORTC,bLed)
|
||||||
|
#define LedToggle (PORTC^=(1<<bLed))
|
||||||
|
|
||||||
|
void SetupWitty() {
|
||||||
|
DDRD = 0b11111000; // rien sur pd3?
|
||||||
|
DDRC = 0 ;
|
||||||
|
PORTC = 0b000001; // pullup pous
|
||||||
|
DDRB= 0x03; // PB0 1 sur connecteur pour Apa102
|
||||||
|
}
|
||||||
|
|
||||||
|
#define nop asm ("nop")
|
||||||
|
void DelMs (uint16_t dm) { //172-152
|
||||||
|
for (uint16_t i=0; i<dm; i++) {
|
||||||
|
for (uint16_t j=0; j<3200; j++) {nop;}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void Delus (uint16_t dm) { // 182-152
|
||||||
|
for (uint16_t i=0; i<dm; i++) {nop;nop;nop;nop;}
|
||||||
|
for (uint16_t i=0; i<dm; i++) {nop;nop;nop;}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Cli(byte nn) { // do not use
|
||||||
|
for (byte i=0; i<2*nn; i++) { LedToggle; DelMs(300);}
|
||||||
|
}
|
||||||
|
void Cligno(byte nn,byte dd) {
|
||||||
|
for (byte i=0; i<2*nn; i++) { LedToggle, DelMs(dd);}
|
||||||
|
}
|
||||||
|
void CliErr (byte ct,byte dd) {
|
||||||
|
while(1) {
|
||||||
|
Cligno (ct,dd);
|
||||||
|
DelMs (1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in new issue