Dzisiaj Łukasz wrzucił nową wersję biblioteki do APRS. Pojawiło się pare nowych metod użycia dzięki czemu zzabawa jest bardziej elastyczna:
Kod:
#include <Arduino.h>
#include <ArduinoQAPRS.h>
char * packet_buffer = " \n ";
void setup(){
// inicjalizacja
// pin 3 to sensePin [wejscie] - 1 oznacza brak mozliwosci nadawania
// pin 2 to txPin [wyjscie] - stan wyski w momencie rozpoczecia nadawania
QAPRS.init(3,2,"SQ5RWU", '0', "APZQAP", '0', "WIDE1-1");
}
void loop() {
// nadanie paketu typu komentarz
packet_buffer = ":TEST TEST TEST de SQ5RWU";
// zmiana adresu źródłowego i ssida
QAPRS.setFromAddress("SQ5R", '1');
QAPRS.sendData(packet_buffer);
// nadanie pakietu z pozycja i symbolem wahadlowca
packet_buffer = "!5215.68N/02057.48ES#";
// zmiana adresu źródłowego, ssida i ścieżki
QAPRS.setFromAddress("SQ5RWU", '2');
QAPRS.setRelays("WIDE2-2");
QAPRS.sendData(packet_buffer);
// nadanie danych pogodowych bez pozycji
packet_buffer = "_07071805c025s009g008t030r000p000P000h00b10218";
// zmiana ścieżki
QAPRS.setRelays("WIDE1-1");
QAPRS.sendData(packet_buffer);
delay(5000);
}
Ja nieco poprawiłem swoją płytkę do testowania tej biblioteki i napisałem w arduino prosty program by się tym bawić.
Kod:
/*
Copyright Rysiek Labus SQ9MDD
APRS Platform na bazie arduino i QAPRS.
APRS Platform is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
APRS Platform is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with ArduinoQAPRS; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
APRS Platform jest wolnym oprogramowaniem; możesz go rozprowadzać dalej
i/lub modyfikować na warunkach Powszechnej Licencji Publicznej GNU,
wydanej przez Fundację Wolnego Oprogramowania - według wersji 2 tej
Licencji lub (według twojego wyboru) którejś z późniejszych wersji.
Niniejszy program rozpowszechniany jest z nadzieją, iż będzie on
użyteczny - jednak BEZ JAKIEJKOLWIEK GWARANCJI, nawet domyślnej
gwarancji PRZYDATNOŚCI HANDLOWEJ albo PRZYDATNOŚCI DO OKREŚLONYCH
ZASTOSOWAŃ. W celu uzyskania bliższych informacji sięgnij do
Powszechnej Licencji Publicznej GNU.
Z pewnością wraz z niniejszym programem otrzymałeś też egzemplarz
Powszechnej Licencji Publicznej GNU (GNU General Public License);
jeśli nie - napisz do Free Software Foundation, Inc., 59 Temple
Place, Fifth Floor, Boston, MA 02110-1301 USA
Changelog
2013.07.16 Stabilna wersja 1.0 obsługa wysyłania bikonu, zapis konfiguracji
do eepromu.
*/
#include <EEPROM.h>
#include <Arduino.h>
#include "ArduinoQAPRS.h"
#define version 1.0;
//zmienne, nie dotykac
char from_addr[] = "NOLIC "; //znak
char * relays = " "; //20 znaków
char * comment_arr = " ";//bufor na ramkę 60 znaków 19 na koordynaty symboj i tablice.
char * packet_buffer = " \n ";
int volt_indic = 0; //czy pokazac napięcie?
int ssid = 0; //domyślne SSID
int beacon_interwal = 1; //domyślny czas wysyłania beaconu w minutach
int napiecie_zasilania_pin = A3;
String content = "";
unsigned long time_to_beacon = millis() + (beacon_interwal*60000); //domyślnie co minute i co minute blokujemy na dole
//zapis zmiennych do eepromu
void save_to_eeprom(){
EEPROM.write(0,1); //zaznaczamy ze zapisana jest pamiec
EEPROM.write(1,volt_indic); //zaznaczamy wyswietlanie napiecia
EEPROM.write(2,ssid); //zapisujemy ssid
EEPROM.write(3,beacon_interwal); //zapisujemy co ile wysylamy beacon
//zapis callsign do eeprom 6 znaków
for(int a = 4; a <= 9; a++){
EEPROM.write((a),from_addr[a-4]);
}
//zapis path 20 znaków
for(int b = 10; b <= 29; b++){
EEPROM.write((b),relays[b-10]);
}
//zapis komentarz 60 znaków
for(int c = 30; c <= 90; c++){
EEPROM.write((c),comment_arr[c-30]);
}
}
//odczytanie zmiennych z eepromu i wczytanie do zmiennch lokalnych albo ustawienie domyślne
void read_from_eeprom_or_make_default(){
int skonfigurowany = EEPROM.read(0);
if(skonfigurowany == 1){
volt_indic = EEPROM.read(1);
ssid = EEPROM.read(2);
beacon_interwal = EEPROM.read(3);
//odczyt callsign z eeprom
for(int a = 4; a <= 9; a++){
from_addr[a-4] = EEPROM.read(a);
}
//odczyt sciezki
for(int b = 10; b <= 29; b++){
relays[b-10] = EEPROM.read(b);
}
//odczyt kometarz koordynaty symbol i tabela z eeprom'u
for(int c = 30; c <= 90; c++){
comment_arr[c-30] = EEPROM.read(c);
}
}
else{
relays = "WIDE1 0";
comment_arr = ">EMPTY EEPROM";
}
}
void clear_eeprom_memory(){
for(int a = 0; a < 512; a++){
EEPROM.write(a,0xFF);
delay(10);
}
}
//reset jakby trzeba było sprawdzić konfigurację, no i po czyszczeniu eeproma sie przydaje
void softReset(){
asm volatile (" jmp 0");
}
//przygotowujemy dane i wysyłamy ramkę
void prepare_and_send_beacon_f(){
int napiecie_zasilania = map(analogRead(napiecie_zasilania_pin),0,1023,0,159);
int v_prefix = napiecie_zasilania/10;
int v_sufix = napiecie_zasilania%10;
if(volt_indic==1){
sprintf(packet_buffer,"%s %02u.%01uV",comment_arr,v_prefix,v_sufix);
}
if(volt_indic==0){
sprintf(packet_buffer,"%s",comment_arr);
}
QAPRS.send(from_addr, ssid, "APZMDD", '0', relays, packet_buffer);
}
//mala pomoc jesli ktoś nie ma aplikacji
void print_help(){
Serial.println("APRS Platform based on Arduino and QAPRS library.\ncommands:");
Serial.println("mca= callsign");
Serial.println("mti= beacon timing (m)");
Serial.println("mpa= path");
Serial.println("mra= beacon text including symbol, table and coordinates");
Serial.println("mpv= voltage in beacon");
Serial.println("send sending beacon");
Serial.println("cls clearing eeprom memory");
Serial.println("mem writing current config to memory");
Serial.println("reset reload device");
Serial.println("help,? printing this manual");
}
//obowiązkowo setupik na starcie
void setup(){
pinMode(napiecie_zasilania_pin,INPUT);
QAPRS.init(0,0);
Serial.begin(9600);
read_from_eeprom_or_make_default();
}
//petla główna
void loop() {
unsigned long time = millis();
//słuchamy eresa
while(Serial.available()) {
char character = Serial.read();
content.concat(character);
delay (10);
}
if (content != "") {
content.trim();//wywalamy CR i LF z wchodzących stringów
time_to_beacon = time + (beacon_interwal*60000);
//zmiana znaku
if(content.substring(0,4) == "mca="){
content.substring(4).toCharArray(from_addr,7);
int by_position = content.indexOf('-')+1;
ssid = content.substring(by_position).toInt();
}
if(content.substring(0,4) == "mti="){
beacon_interwal = content.substring(4).toInt();
//Serial.print(a);
}
if(content.substring(0,4) == "mpa="){
content = content.substring(4);
int dlugosc = content.length()+1;
content.toCharArray(relays,dlugosc);
}
if(content.substring(0,4) == "mpv="){
if(content.substring(4) == "1"){
volt_indic = 1;
}
if(content.substring(4) == "0"){
volt_indic = 0;
}
}
if(content.substring(0,4) == "mra="){
content = content.substring(4);
int dlugosc = content.length()+1;
content.toCharArray(comment_arr,dlugosc);
}
if(content.substring(0,4) == "send"){
prepare_and_send_beacon_f();
}
if(content.substring(0,3) == "cls"){
clear_eeprom_memory();
}
if(content.substring(0,3) == "mem"){
save_to_eeprom();
}
if(content.substring(0,5) == "reset"){
softReset();
}
if(content.substring(0,4) == "help"){
print_help();
}
if(content.substring(0,1) == "?"){
print_help();
}
content = "";
}
//jesli ramka co minute to nie wysylamy nic takie zabezpieczenie jesli konfig nie wgrany
if (time >= time_to_beacon && beacon_interwal!= 1){
prepare_and_send_beacon_f();
time_to_beacon = time + (beacon_interwal*60000);
}
}
Kod jest do uporządkowania, piszę w arduino dopiero trzeci tydzień.
Do tego napisałem aplikację na pc w lazarusie do konfiguracji płytki...
Ogólnie trzeba jeszcze sporo nad tym popracować,
jak ktoś ma ochotę to zapraszam do zabawy.