From fc4939bf385401f2eef9d65bd585081ea95c2680 Mon Sep 17 00:00:00 2001 From: SnkMtn000 Date: Thu, 1 Feb 2018 17:23:05 -0500 Subject: [PATCH] Delete promini33_rfm69_FELD_HELL_Keyboard_20180116.ino --- ...ni33_rfm69_FELD_HELL_Keyboard_20180116.ino | 268 ------------------ 1 file changed, 268 deletions(-) delete mode 100644 promini33_rfm69_FELD_HELL_Keyboard_20180116.ino diff --git a/promini33_rfm69_FELD_HELL_Keyboard_20180116.ino b/promini33_rfm69_FELD_HELL_Keyboard_20180116.ino deleted file mode 100644 index d82f251..0000000 --- a/promini33_rfm69_FELD_HELL_Keyboard_20180116.ino +++ /dev/null @@ -1,268 +0,0 @@ -/* - * A simple Feld Hell sender - * for the HopeRF rfm69hcw - * on a ProMini 3.3 - * Charles Webb - * KC1ENN@arrl.net - * - * with thanks to James Coxon - * - * Feld Hell for HopeRF rfm69hcw modifed from source below - * https://github.com/jamescoxon/PicoAtlas/blob/master/Pico6MK3/sketch_apr02b/sketch_apr02b.ino - * - * - */ - -#include - -#define MY_DELAY 5000 // delay in loop, between sending the message -#define ssPin 10 // SS -#define rstPin 9 // reset pin -//#define radioPower 0x58 // 6 dBm -//#define radioPower 0x5B // 9 dBm -//#define radioPower 0x5E // 12 dBm -#define radioPower 0x7F // 17 dBm -#define radioModulation 0x48 // Modulation for OOK, Continuous w.o bit synch, OOK, no shaping - -char mytext[80]; -String inputString = ""; // a String to hold incoming data -boolean stringComplete = false; // whether the string is complete -long myFrequency = 433200000; -//long myFrequency = 915000000; -String myString = ""; -String myCall = "... CQ CQ CQ MYCALLSIGN MYCALLSIGN MYCALLSIGN PSK ... "; -int myStringLen = 0; - -void setup(){ - Serial.begin(9600); - Serial.println("Starting up"); - pinMode(ssPin, OUTPUT); - pinMode(rstPin, OUTPUT); - setupSPI(); - delay(1000); - resetRFM69(); - delay(1000); - setupRFM69(); -} - -void loop (){ - if (stringComplete) { - // clear the string: - inputString = ""; - stringComplete = false; - } -} //ends void loop - -void serialEvent() { - while (Serial.available()) { - // get the new byte: - char inChar = (char)Serial.read(); - // add it to the inputString: - inputString += inChar; - // if the incoming character is a newline, set a flag so the main loop can - // do something about it: - if (inChar == '\n') { - stringComplete = true; - if(inputString.indexOf("@freq=") == 0) { - myFrequency = inputString.substring(6,15).toInt(); - setFrequency(myFrequency); - Serial.print("Frequency now set to: "); Serial.println(inputString.substring(6,15)); - inputString = ""; - } - if(inputString.indexOf("@freq+") == 0) { - myFrequency = myFrequency + 61; - setFrequency(myFrequency); - Serial.print("Frequency now set to: "); Serial.println(myFrequency); - inputString = ""; - } - if(inputString.indexOf("@freq-") == 0) { - myFrequency = myFrequency - 61; - setFrequency(myFrequency); - Serial.print("Frequency now set to: "); Serial.println(myFrequency); - inputString = ""; - } - if (inputString.indexOf("@cq") == 0) { - myString = myCall; - myString.toUpperCase(); - myStringLen = myString.length(); - myString.toCharArray(mytext,myString.length() + 1); - Serial.print("I am sending: "); Serial.println(myString); - hellsendmsg(mytext); - } - else { - inputString.trim(); - if(inputString.length() > 0) { - myString = "..." + inputString + " ... "; - myString.toUpperCase(); - myStringLen = myString.length(); - myString.toCharArray(mytext,myString.length() + 1); - Serial.print("I am sending: "); Serial.println(myString); - hellsendmsg(mytext); - } - } - } - } -} - -void setupRFM69() { - writeReg(0x02,radioModulation); - setFrequency(myFrequency); - Serial.print("Frequency set to "); Serial.println(myFrequency); - writeReg(0x26,0x07); // CLK off to save power - writeReg(0x01,0x0C); // Set mode to Transmitter TX mode - Serial.println("Transmitter is ready...."); -} - -// set the frequency (in Hz) -void setFrequency(uint32_t freqHz){ - freqHz /= 61; // divide down by FSTEP to get FRF - writeReg(0x07, freqHz >> 16); - writeReg(0x08, freqHz >> 8); - writeReg(0x09, freqHz); -} - -void resetRFM69() { - digitalWrite(rstPin, HIGH); - delay(100); - digitalWrite(rstPin, LOW); - delay(100); -} - -void printReg(byte data) { - Serial.print("Register "); - Serial.print(data); - Serial.print(" = "); - Serial.println(readReg(data), HEX); -} - -void writeReg(uint8_t addr, uint8_t value) { - digitalWrite(ssPin,LOW); - SPI.transfer(addr | 0x80); - SPI.transfer(value); - digitalWrite(ssPin, HIGH); -} - -uint8_t readReg(uint8_t addr) { - digitalWrite(ssPin, LOW); - SPI.transfer(addr & 0x7F); - uint8_t regval = SPI.transfer(0); - digitalWrite(ssPin, HIGH); - return regval; -} - -void setupSPI() { - SPI.begin(); - SPI.setBitOrder(MSBFIRST); - SPI.setClockDivider(SPI_CLOCK_DIV4); -} - -//***************Hellschreiber****************** - -struct t_htab { char c; int hellpat[5]; } ; - -struct t_htab helltab[] = { - - {'1', { B00000100, B00000100, B01111100, B00000000, B00000000 } }, - {'2', { B01001000, B01100100, B01010100, B01001100, B01000000 } }, - {'3', { B01000100, B01000100, B01010100, B01010100, B00111100 } }, - {'4', { B00011100, B00010000, B00010000, B01111100, B00010000 } }, - {'5', { B01000000, B01011100, B01010100, B01010100, B00110100 } }, - {'6', { B00111100, B01010010, B01001010, B01001000, B00110000 } }, - {'7', { B01000100, B00100100, B00010100, B00001100, B00000100 } }, - {'8', { B00111100, B01001010, B01001010, B01001010, B00111100 } }, - {'9', { B00001100, B01001010, B01001010, B00101010, B00111100 } }, - {'0', { B00111000, B01100100, B01010100, B01001100, B00111000 } }, - {'A', { B01111000, B00101100, B00100100, B00101100, B01111000 } }, - {'B', { B01000100, B01111100, B01010100, B01010100, B00101000 } }, - {'C', { B00111000, B01101100, B01000100, B01000100, B00101000 } }, - {'D', { B01000100, B01111100, B01000100, B01000100, B00111000 } }, - {'E', { B01111100, B01010100, B01010100, B01000100, B01000100 } }, - {'F', { B01111100, B00010100, B00010100, B00000100, B00000100 } }, - {'G', { B00111000, B01101100, B01000100, B01010100, B00110100 } }, - {'H', { B01111100, B00010000, B00010000, B00010000, B01111100 } }, - {'I', { B00000000, B01000100, B01111100, B01000100, B00000000 } }, - {'J', { B01100000, B01000000, B01000000, B01000000, B01111100 } }, - {'K', { B01111100, B00010000, B00111000, B00101000, B01000100 } }, - {'L', { B01111100, B01000000, B01000000, B01000000, B01000000 } }, - {'M', { B01111100, B00001000, B00010000, B00001000, B01111100 } }, - {'N', { B01111100, B00000100, B00001000, B00010000, B01111100 } }, - {'O', { B00111000, B01000100, B01000100, B01000100, B00111000 } }, - {'P', { B01000100, B01111100, B01010100, B00010100, B00011000 } }, - {'Q', { B00111000, B01000100, B01100100, B11000100, B10111000 } }, - {'R', { B01111100, B00010100, B00010100, B00110100, B01011000 } }, - {'S', { B01011000, B01010100, B01010100, B01010100, B00100100 } }, - {'T', { B00000100, B00000100, B01111100, B00000100, B00000100 } }, - {'U', { B01111100, B01000000, B01000000, B01000000, B01111100 } }, - {'V', { B01111100, B00100000, B00010000, B00001000, B00000100 } }, - {'W', { B01111100, B01100000, B01111100, B01000000, B01111100 } }, - {'X', { B01000100, B00101000, B00010000, B00101000, B01000100 } }, - {'Y', { B00000100, B00001000, B01110000, B00001000, B00000100 } }, - {'Z', { B01000100, B01100100, B01010100, B01001100, B01100100 } }, - {'.', { B01000000, B01000000, B00000000, B00000000, B00000000 } }, - {',', { B10000000, B10100000, B01100000, B00000000, B00000000 } }, - {'/', { B01000000, B00100000, B00010000, B00001000, B00000100 } }, - {'*', { B00000000, B00000000, B00000100, B00001110, B00000100 } } - -}; - -#define N_HELL (sizeof(helltab)/sizeof(helltab[0])) - -void helldelay() { - //Slow Hell - //delay(64); - //delayMicroseconds(900); - - //Feld-Hell - delay(8); // was 8 and hands off - delayMicroseconds(100); // was 160 used to adjust slope of displayed text -} - -void on() { - writeReg(0x11,radioPower); // PA On - helldelay(); - writeReg(0x11,0x00); -} - -void hellsend(char c) { - int i ; - if (c == ' ') { - for (int d=0; d<14; d++){ - helldelay(); - } - return ; - } - for (i=0; i>= 1; - } - } - for (int d=0; d<14; d++){ - helldelay(); - } - return ; - } - } - /* if we drop off the end, then we send a space */ - //Serial.print("?") ; -} - -void hellsendmsg(char *str) { - //flag = 1; - delay(1000); - while (*str) - hellsend(*str++) ; - //Serial.println(""); - //flag = 0; -}