Compare commits
19 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
337320b433 | ||
|
7c8088f753 | ||
|
b172527d00 | ||
|
67cdd14945 | ||
|
b375b7e9e4 | ||
|
27092d23e0 | ||
|
8a6e01e289 | ||
|
83dc1de18e | ||
|
2de1c873a1 | ||
|
4d97ac2283 | ||
|
65d21aba77 | ||
|
6a2369bc27 | ||
|
76d5c362d0 | ||
|
70fc6aeba8 | ||
|
75d952718b | ||
|
1d28f3e7e9 | ||
|
51f690ef85 | ||
|
12984486a6 | ||
|
e961cd8ac9 |
30
VersionInfo.txt
Normal file
30
VersionInfo.txt
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
This file will guide you to change the source code file.
|
||||||
|
For Windows-based Arduino IDE users, the directory name and the Main source file name must be the same.
|
||||||
|
You do not need to learn github to download .hex files or source code that I release.
|
||||||
|
However, if you want to see what I'm doing right now, you should use the github homepage.
|
||||||
|
|
||||||
|
You do not need to learn git to suggest source code. If you give me an e-mail, I will correct it at any time.
|
||||||
|
If you have not joined the BITX Group, join group. There will be discussions on various topics every day.
|
||||||
|
I am getting a lot of hints from the group.
|
||||||
|
|
||||||
|
Ian KD8CEC
|
||||||
|
kd8cec@gmail.com
|
||||||
|
==================================================================
|
||||||
|
Files modified in Version1.08 Beta
|
||||||
|
|
||||||
|
1.Delted Files.
|
||||||
|
|
||||||
|
2.Added Files
|
||||||
|
|
||||||
|
3.Modified Files
|
||||||
|
- ubitx_20.ino
|
||||||
|
- ubitx_ui.ino
|
||||||
|
- cat_libs.ino
|
||||||
|
- ubitx.h
|
||||||
|
- ubitx_eemap.h
|
||||||
|
- ubitx_lcd_1602.ino
|
||||||
|
- ubitx_lcd_1602Dual.ino
|
||||||
|
- ubitx_lcd_2004.ino
|
||||||
|
- ubitx_wspr.ino
|
||||||
|
|
||||||
|
|
@@ -31,8 +31,8 @@
|
|||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
#define printLineF1(x) (printLineF(1, x))
|
|
||||||
#define printLineF2(x) (printLineF(0, x))
|
#include "ubitx.h"
|
||||||
|
|
||||||
//for broken protocol
|
//for broken protocol
|
||||||
#define CAT_RECEIVE_TIMEOUT 500
|
#define CAT_RECEIVE_TIMEOUT 500
|
||||||
@@ -654,7 +654,7 @@ void SetIFSValue(void)
|
|||||||
//void CatRxStatus(byte fromType)
|
//void CatRxStatus(byte fromType)
|
||||||
void CatRxStatus(void) //for remove warning
|
void CatRxStatus(void) //for remove warning
|
||||||
{
|
{
|
||||||
byte sMeterValue = 1;
|
byte sMeterValue = 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
http://www.ka7oei.com/ft817_meow.html
|
http://www.ka7oei.com/ft817_meow.html
|
||||||
@@ -667,6 +667,33 @@ void CatRxStatus(void) //for remove warning
|
|||||||
Bit 7 is 0 if there is a signal present, or 1 if the receiver is squelched.
|
Bit 7 is 0 if there is a signal present, or 1 if the receiver is squelched.
|
||||||
*/
|
*/
|
||||||
// The lower 4 bits (0-3) of this byte indicate the current S-meter reading. 00 refers to an S-Zero reading, 04 = S4, 09 = S9, 0A = "10 over," 0B = "20 over" and so on up to 0F.
|
// The lower 4 bits (0-3) of this byte indicate the current S-meter reading. 00 refers to an S-Zero reading, 04 = S4, 09 = S9, 0A = "10 over," 0B = "20 over" and so on up to 0F.
|
||||||
|
//0~8
|
||||||
|
switch (scaledSMeter)
|
||||||
|
{
|
||||||
|
case 8 : sMeterValue = 0x0B;
|
||||||
|
break;
|
||||||
|
case 7 : sMeterValue = 0x0A;
|
||||||
|
break;
|
||||||
|
case 6 : sMeterValue = 0x09;
|
||||||
|
break;
|
||||||
|
case 5 : sMeterValue = 0x07;
|
||||||
|
break;
|
||||||
|
case 4 : sMeterValue = 0x05;
|
||||||
|
break;
|
||||||
|
case 3 : sMeterValue = 0x04;
|
||||||
|
break;
|
||||||
|
case 2 : sMeterValue = 0x02;
|
||||||
|
break;
|
||||||
|
case 1 : sMeterValue = 0x01;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
sMeterValue = (scaledSMeter * 2) -1;
|
||||||
|
if (sMeterValue > 0)
|
||||||
|
sMeterValue--;
|
||||||
|
*/
|
||||||
|
|
||||||
CAT_BUFF[0] = sMeterValue & 0b00001111;
|
CAT_BUFF[0] = sMeterValue & 0b00001111;
|
||||||
SendCatData(1);
|
SendCatData(1);
|
||||||
}
|
}
|
||||||
|
@@ -14,6 +14,9 @@
|
|||||||
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License
|
||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
#ifndef _UBITX_HEADER__
|
||||||
|
#define _UBITX_HEADER__
|
||||||
|
|
||||||
#include <Arduino.h> //for Linux, On Linux it is case sensitive.
|
#include <Arduino.h> //for Linux, On Linux it is case sensitive.
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
@@ -21,9 +24,9 @@
|
|||||||
//==============================================================================
|
//==============================================================================
|
||||||
//Depending on the type of LCD mounted on the uBITX, uncomment one of the options below.
|
//Depending on the type of LCD mounted on the uBITX, uncomment one of the options below.
|
||||||
//You must select only one.
|
//You must select only one.
|
||||||
#define UBITX_DISPLAY_LCD1602P //LCD mounted on unmodified uBITX
|
#define UBITX_DISPLAY_LCD1602P //LCD mounted on unmodified uBITX (Parallel)
|
||||||
//#define UBITX_DISPLAY_LCD1602I //I2C type 16 x 02 LCD
|
//#define UBITX_DISPLAY_LCD1602I //I2C type 16 x 02 LCD
|
||||||
//#define UBITX_DISPLAY_LCD1602I_DUAL
|
//#define UBITX_DISPLAY_LCD1602I_DUAL //I2C type 16 x02 LCD Dual
|
||||||
//#define UBITX_DISPLAY_LCD2004P //24 x 04 LCD (Parallel)
|
//#define UBITX_DISPLAY_LCD2004P //24 x 04 LCD (Parallel)
|
||||||
//#define UBITX_DISPLAY_LCD2004I //I2C type 24 x 04 LCD
|
//#define UBITX_DISPLAY_LCD2004I //I2C type 24 x 04 LCD
|
||||||
|
|
||||||
@@ -33,8 +36,9 @@
|
|||||||
#define EXTEND_KEY_GROUP1 //MODE, BAND(-), BAND(+), STEP
|
#define EXTEND_KEY_GROUP1 //MODE, BAND(-), BAND(+), STEP
|
||||||
//#define EXTEND_KEY_GROUP2 //Numeric (0~9), Point(.), Enter //Not supported in Version 1.0x
|
//#define EXTEND_KEY_GROUP2 //Numeric (0~9), Point(.), Enter //Not supported in Version 1.0x
|
||||||
|
|
||||||
#define ENABLE_FACTORYALIGN
|
//#define ENABLE_FACTORYALIGN
|
||||||
//#define ENABLE_ADCMONITOR //Starting with Version 1.07, you can read ADC values directly from uBITX Manager. So this function is not necessary.
|
#define FACTORY_RECOVERY_BOOTUP //Whether to enter Factory Recovery mode by pressing FKey and turning on power
|
||||||
|
#define ENABLE_ADCMONITOR //Starting with Version 1.07, you can read ADC values directly from uBITX Manager. So this function is not necessary.
|
||||||
|
|
||||||
extern byte I2C_LCD_MASTER_ADDRESS; //0x27 //if Set I2C Address by uBITX Manager, read from EEProm
|
extern byte I2C_LCD_MASTER_ADDRESS; //0x27 //if Set I2C Address by uBITX Manager, read from EEProm
|
||||||
extern byte I2C_LCD_SECOND_ADDRESS; //only using Dual LCD Mode
|
extern byte I2C_LCD_SECOND_ADDRESS; //only using Dual LCD Mode
|
||||||
@@ -86,7 +90,6 @@ extern byte I2C_LCD_SECOND_ADDRESS; //only using Dual LCD Mode
|
|||||||
#define ANALOG_SPARE (A7)
|
#define ANALOG_SPARE (A7)
|
||||||
#define ANALOG_SMETER (A7) //by KD8CEC
|
#define ANALOG_SMETER (A7) //by KD8CEC
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The second set of 16 pins on the Raduino's bottom connector are have the three clock outputs and the digital lines to control the rig.
|
* The second set of 16 pins on the Raduino's bottom connector are have the three clock outputs and the digital lines to control the rig.
|
||||||
* This assignment is as follows :
|
* This assignment is as follows :
|
||||||
@@ -146,6 +149,9 @@ extern byte I2C_LCD_SECOND_ADDRESS; //only using Dual LCD Mode
|
|||||||
extern unsigned long frequency;
|
extern unsigned long frequency;
|
||||||
extern byte WsprMSGCount;
|
extern byte WsprMSGCount;
|
||||||
extern byte sMeterLevels[9];
|
extern byte sMeterLevels[9];
|
||||||
|
extern int currentSMeter; //ADC Value for S.Meter
|
||||||
|
extern byte scaledSMeter; //Calculated S.Meter Level
|
||||||
|
|
||||||
extern byte KeyValues[16][3]; //Set : Start Value, End Value, Key Type, 16 Set (3 * 16 = 48)
|
extern byte KeyValues[16][3]; //Set : Start Value, End Value, Key Type, 16 Set (3 * 16 = 48)
|
||||||
|
|
||||||
extern void printLine1(const char *c);
|
extern void printLine1(const char *c);
|
||||||
@@ -172,3 +178,7 @@ extern void SendWSPRManage(void);
|
|||||||
extern char byteToChar(byte srcByte);
|
extern char byteToChar(byte srcByte);
|
||||||
extern void DisplayCallsign(byte callSignLength);
|
extern void DisplayCallsign(byte callSignLength);
|
||||||
extern void DisplayVersionInfo(const char* fwVersionInfo);
|
extern void DisplayVersionInfo(const char* fwVersionInfo);
|
||||||
|
|
||||||
|
#endif //end of if header define
|
||||||
|
|
||||||
|
|
||||||
|
@@ -6,8 +6,8 @@
|
|||||||
// So I put + in the sense that it was improved one by one based on Original Firmware.
|
// So I put + in the sense that it was improved one by one based on Original Firmware.
|
||||||
// This firmware has been gradually changed based on the original firmware created by Farhan, Jack, Jerry and others.
|
// This firmware has been gradually changed based on the original firmware created by Farhan, Jack, Jerry and others.
|
||||||
|
|
||||||
#define FIRMWARE_VERSION_INFO F("+v1.073")
|
#define FIRMWARE_VERSION_INFO F("+v1.080")
|
||||||
#define FIRMWARE_VERSION_NUM 0x02 //1st Complete Project : 1 (Version 1.061), 2st Project : 2
|
#define FIRMWARE_VERSION_NUM 0x03 //1st Complete Project : 1 (Version 1.061), 2st Project : 2
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Cat Suppoort uBITX CEC Version
|
Cat Suppoort uBITX CEC Version
|
||||||
@@ -182,6 +182,10 @@ byte line2DisplayStatus = 0; //0:Clear, 1 : menu, 1: DisplayFrom Idle,
|
|||||||
char lcdMeter[17];
|
char lcdMeter[17];
|
||||||
byte sMeterLevels[9];
|
byte sMeterLevels[9];
|
||||||
|
|
||||||
|
//Current ADC Value for S.Meter, and S Meter Level
|
||||||
|
int currentSMeter = 0;
|
||||||
|
byte scaledSMeter = 0;
|
||||||
|
|
||||||
byte I2C_LCD_MASTER_ADDRESS; //0x27 //if Set I2C Address by uBITX Manager, read from EEProm
|
byte I2C_LCD_MASTER_ADDRESS; //0x27 //if Set I2C Address by uBITX Manager, read from EEProm
|
||||||
byte I2C_LCD_SECOND_ADDRESS; //only using Dual LCD Mode
|
byte I2C_LCD_SECOND_ADDRESS; //only using Dual LCD Mode
|
||||||
|
|
||||||
@@ -250,8 +254,8 @@ void setNextHamBandFreq(unsigned long f, char moveDirection)
|
|||||||
if ((resultFreq / 1000) < hamBandRange[(unsigned char)findedIndex][0] || (resultFreq / 1000) > hamBandRange[(unsigned char)findedIndex][1])
|
if ((resultFreq / 1000) < hamBandRange[(unsigned char)findedIndex][0] || (resultFreq / 1000) > hamBandRange[(unsigned char)findedIndex][1])
|
||||||
resultFreq = (unsigned long)(hamBandRange[(unsigned char)findedIndex][0]) * 1000;
|
resultFreq = (unsigned long)(hamBandRange[(unsigned char)findedIndex][0]) * 1000;
|
||||||
|
|
||||||
setFrequency(resultFreq);
|
|
||||||
byteToMode(loadMode, 1);
|
byteToMode(loadMode, 1);
|
||||||
|
setFrequency(resultFreq);
|
||||||
}
|
}
|
||||||
|
|
||||||
void saveBandFreqByIndex(unsigned long f, unsigned long mode, char bandIndex) {
|
void saveBandFreqByIndex(unsigned long f, unsigned long mode, char bandIndex) {
|
||||||
@@ -937,6 +941,15 @@ void initSettings(){
|
|||||||
if (EEPROM.read(VERSION_ADDRESS) != FIRMWARE_VERSION_NUM)
|
if (EEPROM.read(VERSION_ADDRESS) != FIRMWARE_VERSION_NUM)
|
||||||
EEPROM.write(VERSION_ADDRESS, FIRMWARE_VERSION_NUM);
|
EEPROM.write(VERSION_ADDRESS, FIRMWARE_VERSION_NUM);
|
||||||
|
|
||||||
|
//Backup Calibration Setting from Factory Setup
|
||||||
|
//Check Factory Setting Backup Y/N
|
||||||
|
if (EEPROM.read(FACTORY_BACKUP_YN) != 0x13) {
|
||||||
|
EEPROM.write(FACTORY_BACKUP_YN, 0x13); //Set Backup Y/N
|
||||||
|
|
||||||
|
for (unsigned int i = 0; i < 32; i++) //factory setting range
|
||||||
|
EEPROM.write(FACTORY_VALUES + i, EEPROM.read(i)); //0~31 => 65~96
|
||||||
|
}
|
||||||
|
|
||||||
EEPROM.get(CW_CAL, cwmCarrier);
|
EEPROM.get(CW_CAL, cwmCarrier);
|
||||||
|
|
||||||
//for Save VFO_A_MODE to eeprom
|
//for Save VFO_A_MODE to eeprom
|
||||||
@@ -1212,6 +1225,40 @@ void initPorts(){
|
|||||||
digitalWrite(CW_KEY, 0);
|
digitalWrite(CW_KEY, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Recovery Factory Setting Values
|
||||||
|
void factory_Recovery()
|
||||||
|
{
|
||||||
|
if (EEPROM.read(FACTORY_BACKUP_YN) != 0x13)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (digitalRead(PTT) == 0) //Do not proceed if PTT is pressed to prevent malfunction.
|
||||||
|
return;
|
||||||
|
|
||||||
|
printLineF2(F("Factory Recovery"));
|
||||||
|
delay(2000);
|
||||||
|
if (!btnDown())
|
||||||
|
return;
|
||||||
|
|
||||||
|
printLineF2(F("IF you continue"));
|
||||||
|
printLineF1(F("release the key"));
|
||||||
|
delay(2000);
|
||||||
|
if (btnDown())
|
||||||
|
return;
|
||||||
|
|
||||||
|
printLineF1(F("Press Key PTT"));
|
||||||
|
delay(2000);
|
||||||
|
if (digitalRead(PTT) == 0)
|
||||||
|
{
|
||||||
|
for (unsigned int i = 0; i < 32; i++) //factory setting range
|
||||||
|
EEPROM.write(i, EEPROM.read(FACTORY_VALUES + i)); //65~96 => 0~31
|
||||||
|
|
||||||
|
//printLineF2(F("CompleteRecovery"));
|
||||||
|
printLineF1(F("Power Reset!"));
|
||||||
|
while(1); //Hold
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void setup()
|
void setup()
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
@@ -1262,6 +1309,11 @@ void setup()
|
|||||||
|
|
||||||
initPorts();
|
initPorts();
|
||||||
|
|
||||||
|
#ifdef FACTORY_RECOVERY_BOOTUP
|
||||||
|
if (btnDown())
|
||||||
|
factory_Recovery();
|
||||||
|
#endif
|
||||||
|
|
||||||
byteToMode(vfoA_mode, 0);
|
byteToMode(vfoA_mode, 0);
|
||||||
initOscillators();
|
initOscillators();
|
||||||
|
|
||||||
@@ -1274,6 +1326,7 @@ void setup()
|
|||||||
if (btnDown())
|
if (btnDown())
|
||||||
factory_alignment();
|
factory_alignment();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Auto save Frequency and Mode with Protected eeprom life by KD8CEC
|
//Auto save Frequency and Mode with Protected eeprom life by KD8CEC
|
||||||
|
@@ -15,6 +15,9 @@
|
|||||||
You should have received a copy of the GNU General Public License
|
You should have received a copy of the GNU General Public License
|
||||||
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
|
#ifndef _UBITX_EEPOM_HEADER__
|
||||||
|
#define _UBITX_EEPOM_HEADER__
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
// Factory-shipped EEProm address
|
// Factory-shipped EEProm address
|
||||||
// (factory Firmware)
|
// (factory Firmware)
|
||||||
@@ -41,7 +44,9 @@
|
|||||||
// (Enabled if the EEProm address is insufficient)
|
// (Enabled if the EEProm address is insufficient)
|
||||||
// Address : 64 ~ 100
|
// Address : 64 ~ 100
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
#define RESERVE_FOR_FACTORY2 64
|
#define RESERVE_FOR_FACTORY2 64 //use Factory backup from Version 1.075
|
||||||
|
#define FACTORY_BACKUP_YN 64 //Check Backup //Magic : 0x13
|
||||||
|
#define FACTORY_VALUES 65 //65 ~ 65 + 32
|
||||||
|
|
||||||
//==============================================================================
|
//==============================================================================
|
||||||
// KD8CEC EEPROM MAP
|
// KD8CEC EEPROM MAP
|
||||||
@@ -125,3 +130,5 @@
|
|||||||
#define CW_DATA_OFSTADJ CW_AUTO_DATA - USER_CALLSIGN_DAT //offset adjust for ditect eeprom to lcd (basic offset is USER_CALLSIGN_DAT
|
#define CW_DATA_OFSTADJ CW_AUTO_DATA - USER_CALLSIGN_DAT //offset adjust for ditect eeprom to lcd (basic offset is USER_CALLSIGN_DAT
|
||||||
#define CW_STATION_LEN 1023 //value range : 4 ~ 30
|
#define CW_STATION_LEN 1023 //value range : 4 ~ 30
|
||||||
|
|
||||||
|
#endif //end of if header define
|
||||||
|
|
||||||
|
64
ubitx_20/ubitx_lcd.h
Normal file
64
ubitx_20/ubitx_lcd.h
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
/*************************************************************************
|
||||||
|
header file for LCD by KD8CEC
|
||||||
|
-----------------------------------------------------------------------------
|
||||||
|
This program 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 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
**************************************************************************/
|
||||||
|
#ifndef _UBITX_LCD_HEADER__
|
||||||
|
#define _UBITX_LCD_HEADER__
|
||||||
|
|
||||||
|
//Common Defines *********************************************************
|
||||||
|
#define LCD_CLEARDISPLAY 0x01
|
||||||
|
#define LCD_RETURNHOME 0x02
|
||||||
|
#define LCD_ENTRYMODESET 0x04
|
||||||
|
#define LCD_DISPLAYCONTROL 0x08
|
||||||
|
#define LCD_CURSORSHIFT 0x10
|
||||||
|
#define LCD_FUNCTIONSET 0x20
|
||||||
|
#define LCD_SETCGRAMADDR 0x40
|
||||||
|
#define LCD_SETDDRAMADDR 0x80
|
||||||
|
|
||||||
|
// flags for display entry mode
|
||||||
|
#define LCD_ENTRYRIGHT 0x00
|
||||||
|
#define LCD_ENTRYLEFT 0x02
|
||||||
|
#define LCD_ENTRYSHIFTINCREMENT 0x01
|
||||||
|
#define LCD_ENTRYSHIFTDECREMENT 0x00
|
||||||
|
|
||||||
|
// flags for display on/off control
|
||||||
|
#define LCD_DISPLAYON 0x04
|
||||||
|
#define LCD_DISPLAYOFF 0x00
|
||||||
|
#define LCD_CURSORON 0x02
|
||||||
|
#define LCD_CURSOROFF 0x00
|
||||||
|
#define LCD_BLINKON 0x01
|
||||||
|
#define LCD_BLINKOFF 0x00
|
||||||
|
|
||||||
|
// flags for display/cursor shift
|
||||||
|
#define LCD_DISPLAYMOVE 0x08
|
||||||
|
#define LCD_CURSORMOVE 0x00
|
||||||
|
#define LCD_MOVERIGHT 0x04
|
||||||
|
#define LCD_MOVELEFT 0x00
|
||||||
|
|
||||||
|
// flags for function set
|
||||||
|
#define LCD_8BITMODE 0x10
|
||||||
|
#define LCD_4BITMODE 0x00
|
||||||
|
#define LCD_2LINE 0x08
|
||||||
|
#define LCD_1LINE 0x00
|
||||||
|
#define LCD_5x10DOTS 0x04
|
||||||
|
#define LCD_5x8DOTS 0x00
|
||||||
|
|
||||||
|
// flags for backlight control
|
||||||
|
#define LCD_BACKLIGHT 0x08
|
||||||
|
#define LCD_NOBACKLIGHT 0x00
|
||||||
|
|
||||||
|
#endif //end of if header define
|
||||||
|
|
||||||
|
|
@@ -1,10 +1,7 @@
|
|||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
KD8CEC's uBITX Display Routine for LCD1602 Parrel
|
KD8CEC's uBITX Display Routine for LCD1602 Parrel
|
||||||
1.This is the display code for the default LCD mounted in uBITX.
|
1.This is the display code for the default LCD mounted in uBITX.
|
||||||
2.Display related functions of uBITX. Some functions moved from uBITX_Ui.
|
2.Some functions moved from uBITX_Ui.
|
||||||
3.uBITX Idle time Processing
|
|
||||||
Functions that run at times that do not affect TX, CW, and CAT
|
|
||||||
It is called in 1/10 time unit.
|
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
This program is free software: you can redistribute it and/or modify
|
This program is free software: you can redistribute it and/or modify
|
||||||
it under the terms of the GNU General Public License as published by
|
it under the terms of the GNU General Public License as published by
|
||||||
@@ -21,48 +18,7 @@
|
|||||||
|
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
#include "ubitx.h"
|
#include "ubitx.h"
|
||||||
|
#include "ubitx_lcd.h"
|
||||||
//Common Defines *********************************************************
|
|
||||||
#define LCD_CLEARDISPLAY 0x01
|
|
||||||
#define LCD_RETURNHOME 0x02
|
|
||||||
#define LCD_ENTRYMODESET 0x04
|
|
||||||
#define LCD_DISPLAYCONTROL 0x08
|
|
||||||
#define LCD_CURSORSHIFT 0x10
|
|
||||||
#define LCD_FUNCTIONSET 0x20
|
|
||||||
#define LCD_SETCGRAMADDR 0x40
|
|
||||||
#define LCD_SETDDRAMADDR 0x80
|
|
||||||
|
|
||||||
// flags for display entry mode
|
|
||||||
#define LCD_ENTRYRIGHT 0x00
|
|
||||||
#define LCD_ENTRYLEFT 0x02
|
|
||||||
#define LCD_ENTRYSHIFTINCREMENT 0x01
|
|
||||||
#define LCD_ENTRYSHIFTDECREMENT 0x00
|
|
||||||
|
|
||||||
// flags for display on/off control
|
|
||||||
#define LCD_DISPLAYON 0x04
|
|
||||||
#define LCD_DISPLAYOFF 0x00
|
|
||||||
#define LCD_CURSORON 0x02
|
|
||||||
#define LCD_CURSOROFF 0x00
|
|
||||||
#define LCD_BLINKON 0x01
|
|
||||||
#define LCD_BLINKOFF 0x00
|
|
||||||
|
|
||||||
// flags for display/cursor shift
|
|
||||||
#define LCD_DISPLAYMOVE 0x08
|
|
||||||
#define LCD_CURSORMOVE 0x00
|
|
||||||
#define LCD_MOVERIGHT 0x04
|
|
||||||
#define LCD_MOVELEFT 0x00
|
|
||||||
|
|
||||||
// flags for function set
|
|
||||||
#define LCD_8BITMODE 0x10
|
|
||||||
#define LCD_4BITMODE 0x00
|
|
||||||
#define LCD_2LINE 0x08
|
|
||||||
#define LCD_1LINE 0x00
|
|
||||||
#define LCD_5x10DOTS 0x04
|
|
||||||
#define LCD_5x8DOTS 0x00
|
|
||||||
|
|
||||||
// flags for backlight control
|
|
||||||
#define LCD_BACKLIGHT 0x08
|
|
||||||
#define LCD_NOBACKLIGHT 0x00
|
|
||||||
|
|
||||||
//========================================================================
|
//========================================================================
|
||||||
//Begin of TinyLCD Library by KD8CEC
|
//Begin of TinyLCD Library by KD8CEC
|
||||||
@@ -749,19 +705,15 @@ void DisplayMeter(byte meterType, byte meterValue, char drawPosition)
|
|||||||
|
|
||||||
LCD_SetCursor(drawPosition, lineNumber);
|
LCD_SetCursor(drawPosition, lineNumber);
|
||||||
|
|
||||||
//for (int i = 0; i <26; i++) //meter 5 + +db 1 = 6
|
|
||||||
LCD_Write(lcdMeter[0]);
|
LCD_Write(lcdMeter[0]);
|
||||||
LCD_Write(lcdMeter[1]);
|
LCD_Write(lcdMeter[1]);
|
||||||
|
LCD_Write(lcdMeter[2]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
byte testValue = 0;
|
|
||||||
char checkCount = 0;
|
char checkCount = 0;
|
||||||
char checkCountSMeter = 0;
|
char checkCountSMeter = 0;
|
||||||
|
|
||||||
int currentSMeter = 0;
|
|
||||||
byte scaledSMeter = 0;
|
|
||||||
|
|
||||||
void idle_process()
|
void idle_process()
|
||||||
{
|
{
|
||||||
//space for user graphic display
|
//space for user graphic display
|
||||||
@@ -781,23 +733,17 @@ void idle_process()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//EX for Meters
|
|
||||||
/*
|
|
||||||
DisplayMeter(0, testValue++, 7);
|
|
||||||
if (testValue > 30)
|
|
||||||
testValue = 0;
|
|
||||||
*/
|
|
||||||
|
|
||||||
//S-Meter Display
|
//S-Meter Display
|
||||||
if (((displayOption1 & 0x08) == 0x08 && (sdrModeOn == 0)) && (++checkCountSMeter > SMeterLatency))
|
if (((displayOption1 & 0x08) == 0x08 && (sdrModeOn == 0)) && (++checkCountSMeter > SMeterLatency))
|
||||||
{
|
{
|
||||||
int newSMeter;
|
int newSMeter;
|
||||||
|
|
||||||
//VK2ETA S-Meter from MAX9814 TC pin / divide 4 by KD8CEC for reduce EEPromSize
|
//VK2ETA S-Meter from MAX9814 TC pin / divide 4 by KD8CEC for reduce EEPromSize
|
||||||
newSMeter = analogRead(ANALOG_SMETER);
|
newSMeter = analogRead(ANALOG_SMETER) / 4;
|
||||||
|
|
||||||
//Faster attack, Slower release
|
//Faster attack, Slower release
|
||||||
currentSMeter = (newSMeter > currentSMeter ? ((currentSMeter * 3 + newSMeter * 7) + 5) / 10 : ((currentSMeter * 7 + newSMeter * 3) + 5) / 10) / 4;
|
//currentSMeter = (newSMeter > currentSMeter ? ((currentSMeter * 3 + newSMeter * 7) + 5) / 10 : ((currentSMeter * 7 + newSMeter * 3) + 5) / 10) / 4;
|
||||||
|
currentSMeter = newSMeter;
|
||||||
|
|
||||||
scaledSMeter = 0;
|
scaledSMeter = 0;
|
||||||
for (byte s = 8; s >= 1; s--) {
|
for (byte s = 8; s >= 1; s--) {
|
||||||
@@ -807,7 +753,7 @@ void idle_process()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
DisplayMeter(0, scaledSMeter, 14);
|
DisplayMeter(0, scaledSMeter, 13);
|
||||||
checkCountSMeter = 0; //Reset Latency time
|
checkCountSMeter = 0; //Reset Latency time
|
||||||
} //end of S-Meter
|
} //end of S-Meter
|
||||||
|
|
||||||
|
@@ -1,10 +1,7 @@
|
|||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
KD8CEC's uBITX Display Routine for LCD1602 Dual LCD by KD8CEC
|
KD8CEC's uBITX Display Routine for LCD1602 Dual LCD
|
||||||
1.This is the display code for the default LCD mounted in uBITX.
|
1.This is the display code for the 16x02 Dual LCD
|
||||||
2.Display related functions of uBITX. Some functions moved from uBITX_Ui.
|
2.Some functions moved from uBITX_Ui.
|
||||||
3.uBITX Idle time Processing
|
|
||||||
Functions that run at times that do not affect TX, CW, and CAT
|
|
||||||
It is called in 1/10 time unit.
|
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
This program is free software: you can redistribute it and/or modify
|
This program is free software: you can redistribute it and/or modify
|
||||||
it under the terms of the GNU General Public License as published by
|
it under the terms of the GNU General Public License as published by
|
||||||
@@ -21,48 +18,7 @@
|
|||||||
|
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
#include "ubitx.h"
|
#include "ubitx.h"
|
||||||
|
#include "ubitx_lcd.h"
|
||||||
//Common Defines *********************************************************
|
|
||||||
#define LCD_CLEARDISPLAY 0x01
|
|
||||||
#define LCD_RETURNHOME 0x02
|
|
||||||
#define LCD_ENTRYMODESET 0x04
|
|
||||||
#define LCD_DISPLAYCONTROL 0x08
|
|
||||||
#define LCD_CURSORSHIFT 0x10
|
|
||||||
#define LCD_FUNCTIONSET 0x20
|
|
||||||
#define LCD_SETCGRAMADDR 0x40
|
|
||||||
#define LCD_SETDDRAMADDR 0x80
|
|
||||||
|
|
||||||
// flags for display entry mode
|
|
||||||
#define LCD_ENTRYRIGHT 0x00
|
|
||||||
#define LCD_ENTRYLEFT 0x02
|
|
||||||
#define LCD_ENTRYSHIFTINCREMENT 0x01
|
|
||||||
#define LCD_ENTRYSHIFTDECREMENT 0x00
|
|
||||||
|
|
||||||
// flags for display on/off control
|
|
||||||
#define LCD_DISPLAYON 0x04
|
|
||||||
#define LCD_DISPLAYOFF 0x00
|
|
||||||
#define LCD_CURSORON 0x02
|
|
||||||
#define LCD_CURSOROFF 0x00
|
|
||||||
#define LCD_BLINKON 0x01
|
|
||||||
#define LCD_BLINKOFF 0x00
|
|
||||||
|
|
||||||
// flags for display/cursor shift
|
|
||||||
#define LCD_DISPLAYMOVE 0x08
|
|
||||||
#define LCD_CURSORMOVE 0x00
|
|
||||||
#define LCD_MOVERIGHT 0x04
|
|
||||||
#define LCD_MOVELEFT 0x00
|
|
||||||
|
|
||||||
// flags for function set
|
|
||||||
#define LCD_8BITMODE 0x10
|
|
||||||
#define LCD_4BITMODE 0x00
|
|
||||||
#define LCD_2LINE 0x08
|
|
||||||
#define LCD_1LINE 0x00
|
|
||||||
#define LCD_5x10DOTS 0x04
|
|
||||||
#define LCD_5x8DOTS 0x00
|
|
||||||
|
|
||||||
// flags for backlight control
|
|
||||||
#define LCD_BACKLIGHT 0x08
|
|
||||||
#define LCD_NOBACKLIGHT 0x00
|
|
||||||
|
|
||||||
//========================================================================
|
//========================================================================
|
||||||
//Begin of I2CTinyLCD Library for Dual LCD by KD8CEC
|
//Begin of I2CTinyLCD Library for Dual LCD by KD8CEC
|
||||||
@@ -624,17 +580,13 @@ void DisplayMeter(byte meterType, byte meterValue, char drawPosition)
|
|||||||
LCD_Write('S');
|
LCD_Write('S');
|
||||||
|
|
||||||
LCD_Write(':');
|
LCD_Write(':');
|
||||||
for (int i = 0; i < 6; i++) //meter 5 + +db 1 = 6
|
for (int i = 0; i < 7; i++)
|
||||||
LCD_Write(lcdMeter[i]);
|
LCD_Write(lcdMeter[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
byte testValue = 0;
|
|
||||||
char checkCount = 0;
|
char checkCount = 0;
|
||||||
|
|
||||||
int currentSMeter = 0;
|
|
||||||
byte scaledSMeter = 0;
|
|
||||||
char checkCountSMeter = 0;
|
char checkCountSMeter = 0;
|
||||||
|
|
||||||
char beforeKeyType = -1;
|
char beforeKeyType = -1;
|
||||||
@@ -717,12 +669,13 @@ void idle_process()
|
|||||||
int newSMeter;
|
int newSMeter;
|
||||||
displaySDRON = 0;
|
displaySDRON = 0;
|
||||||
|
|
||||||
//VK2ETA S-Meter from MAX9814 TC pin
|
//VK2ETA S-Meter from MAX9814 TC pin / divide 4 by KD8CEC for reduce EEPromSize
|
||||||
newSMeter = analogRead(ANALOG_SMETER);
|
newSMeter = analogRead(ANALOG_SMETER) / 4;
|
||||||
|
|
||||||
//Faster attack, Slower release
|
//Faster attack, Slower release
|
||||||
//currentSMeter = (newSMeter > currentSMeter ? ((currentSMeter * 3 + newSMeter * 7) + 5) / 10 : ((currentSMeter * 7 + newSMeter * 3) + 5) / 10);
|
//currentSMeter = (newSMeter > currentSMeter ? ((currentSMeter * 3 + newSMeter * 7) + 5) / 10 : ((currentSMeter * 7 + newSMeter * 3) + 5) / 10);
|
||||||
currentSMeter = (currentSMeter * 3 + newSMeter * 7) / 10; //remarked becaused of have already Latency time
|
//currentSMeter = (currentSMeter * 3 + newSMeter * 7) / 10; //remarked becaused of have already Latency time
|
||||||
|
currentSMeter = newSMeter;
|
||||||
|
|
||||||
scaledSMeter = 0;
|
scaledSMeter = 0;
|
||||||
for (byte s = 8; s >= 1; s--) {
|
for (byte s = 8; s >= 1; s--) {
|
||||||
|
@@ -1,10 +1,7 @@
|
|||||||
/*************************************************************************
|
/*************************************************************************
|
||||||
KD8CEC's uBITX Display Routine for LCD2004 Parrel
|
KD8CEC's uBITX Display Routine for LCD2004 Parrel & I2C
|
||||||
1.This is the display code for the default LCD mounted in uBITX.
|
1.This is the display code for the 20x04 LCD
|
||||||
2.Display related functions of uBITX. Some functions moved from uBITX_Ui.
|
2.Some functions moved from uBITX_Ui.
|
||||||
3.uBITX Idle time Processing
|
|
||||||
Functions that run at times that do not affect TX, CW, and CAT
|
|
||||||
It is called in 1/10 time unit.
|
|
||||||
-----------------------------------------------------------------------------
|
-----------------------------------------------------------------------------
|
||||||
This program is free software: you can redistribute it and/or modify
|
This program is free software: you can redistribute it and/or modify
|
||||||
it under the terms of the GNU General Public License as published by
|
it under the terms of the GNU General Public License as published by
|
||||||
@@ -21,48 +18,7 @@
|
|||||||
|
|
||||||
**************************************************************************/
|
**************************************************************************/
|
||||||
#include "ubitx.h"
|
#include "ubitx.h"
|
||||||
|
#include "ubitx_lcd.h"
|
||||||
//Common Defines *********************************************************
|
|
||||||
#define LCD_CLEARDISPLAY 0x01
|
|
||||||
#define LCD_RETURNHOME 0x02
|
|
||||||
#define LCD_ENTRYMODESET 0x04
|
|
||||||
#define LCD_DISPLAYCONTROL 0x08
|
|
||||||
#define LCD_CURSORSHIFT 0x10
|
|
||||||
#define LCD_FUNCTIONSET 0x20
|
|
||||||
#define LCD_SETCGRAMADDR 0x40
|
|
||||||
#define LCD_SETDDRAMADDR 0x80
|
|
||||||
|
|
||||||
// flags for display entry mode
|
|
||||||
#define LCD_ENTRYRIGHT 0x00
|
|
||||||
#define LCD_ENTRYLEFT 0x02
|
|
||||||
#define LCD_ENTRYSHIFTINCREMENT 0x01
|
|
||||||
#define LCD_ENTRYSHIFTDECREMENT 0x00
|
|
||||||
|
|
||||||
// flags for display on/off control
|
|
||||||
#define LCD_DISPLAYON 0x04
|
|
||||||
#define LCD_DISPLAYOFF 0x00
|
|
||||||
#define LCD_CURSORON 0x02
|
|
||||||
#define LCD_CURSOROFF 0x00
|
|
||||||
#define LCD_BLINKON 0x01
|
|
||||||
#define LCD_BLINKOFF 0x00
|
|
||||||
|
|
||||||
// flags for display/cursor shift
|
|
||||||
#define LCD_DISPLAYMOVE 0x08
|
|
||||||
#define LCD_CURSORMOVE 0x00
|
|
||||||
#define LCD_MOVERIGHT 0x04
|
|
||||||
#define LCD_MOVELEFT 0x00
|
|
||||||
|
|
||||||
// flags for function set
|
|
||||||
#define LCD_8BITMODE 0x10
|
|
||||||
#define LCD_4BITMODE 0x00
|
|
||||||
#define LCD_2LINE 0x08
|
|
||||||
#define LCD_1LINE 0x00
|
|
||||||
#define LCD_5x10DOTS 0x04
|
|
||||||
#define LCD_5x8DOTS 0x00
|
|
||||||
|
|
||||||
// flags for backlight control
|
|
||||||
#define LCD_BACKLIGHT 0x08
|
|
||||||
#define LCD_NOBACKLIGHT 0x00
|
|
||||||
|
|
||||||
//========================================================================
|
//========================================================================
|
||||||
//Begin of TinyLCD Library by KD8CEC
|
//Begin of TinyLCD Library by KD8CEC
|
||||||
@@ -683,90 +639,16 @@ void DisplayMeter(byte meterType, byte meterValue, char drawPosition)
|
|||||||
if (meterType == 0 || meterType == 1 || meterType == 2)
|
if (meterType == 0 || meterType == 1 || meterType == 2)
|
||||||
{
|
{
|
||||||
drawMeter(meterValue);
|
drawMeter(meterValue);
|
||||||
//int lineNumber = 0;
|
|
||||||
//if ((displayOption1 & 0x01) == 0x01)
|
|
||||||
//lineNumber = 1;
|
|
||||||
|
|
||||||
LCD_SetCursor(drawPosition, 2);
|
LCD_SetCursor(drawPosition, 2);
|
||||||
LCD_Write('S');
|
LCD_Write('S');
|
||||||
LCD_Write(':');
|
LCD_Write(':');
|
||||||
for (int i = 0; i < 6; i++) //meter 5 + +db 1 = 6
|
for (int i = 0; i < 7; i++) //meter 5 + +db 1 = 6
|
||||||
LCD_Write(lcdMeter[i]);
|
LCD_Write(lcdMeter[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//meterType : 0 = S.Meter, 1 = Forward Power Meter, 2 = SWR Meter
|
|
||||||
void DisplayMeter(byte meterType, int meterValue, char drawPosition)
|
|
||||||
{
|
|
||||||
|
|
||||||
#ifdef OPTION_SKINNYBARS //We want skinny meter bars with more text/numbers
|
|
||||||
memcpy(&(line2Buffer[drawPosition]), " ", 8); //Blank that section of 8 characters first
|
|
||||||
if (meterType == 0) { //SWR meter
|
|
||||||
drawMeter(meterValue); //Only 2 characters
|
|
||||||
line2Buffer[drawPosition] = 'S';
|
|
||||||
byte sValue = round((float)meterValue * 1.5); //6 bars available only to show 9 S values
|
|
||||||
sValue = sValue > 9 ? 9 : sValue; //Max S9
|
|
||||||
line2Buffer[drawPosition + 1] = '0' + sValue; //0 to 9
|
|
||||||
memcpy(&(line2Buffer[drawPosition + 2]), lcdMeter, 2); //Copy the S-Meter bars
|
|
||||||
//Add the +10, +20, etc...
|
|
||||||
if (meterValue > 6) {
|
|
||||||
//We are over S9
|
|
||||||
line2Buffer[drawPosition + 4] = '+';
|
|
||||||
line2Buffer[drawPosition + 5] = '0' + meterValue - 6; //1,2,3 etc...
|
|
||||||
line2Buffer[drawPosition + 6] = '0';
|
|
||||||
}
|
|
||||||
} else if (meterType == 1) { //Forward Power
|
|
||||||
drawMeter(round((float)meterValue / 40)); //4 watts per bar
|
|
||||||
//meterValue contains power value x 10 (one decimal point)
|
|
||||||
line2Buffer[drawPosition] = 'P';
|
|
||||||
meterValue = meterValue > 999 ? 999 : meterValue; //Limit to 99.9 watts!!!!
|
|
||||||
//Remove decimal value and divide by 10
|
|
||||||
meterValue = round((float)meterValue / 10);
|
|
||||||
if (meterValue < 10) {
|
|
||||||
line2Buffer[drawPosition + 1] = ' ';
|
|
||||||
line2Buffer[drawPosition + 2] = '0' + meterValue; //0 to 9
|
|
||||||
} else {
|
|
||||||
line2Buffer[drawPosition + 1] = '0' + meterValue / 10;
|
|
||||||
line2Buffer[drawPosition + 2] = '0' + (meterValue - ((meterValue / 10) * 10));
|
|
||||||
}
|
|
||||||
line2Buffer[drawPosition + 3] = 'W';
|
|
||||||
memcpy(&(line2Buffer[drawPosition + 4]), lcdMeter, 2); //Copy the S-Meter bars
|
|
||||||
} else { //SWR
|
|
||||||
drawMeter((int)(((float)meterValue - 21) / 100)); //no bar = < 1.2, then 1 bar = 1.2 to 2.2, 2 bars = 2.2 to 3.2, etc...
|
|
||||||
//meterValue contains SWR x 100 (two decimal point)
|
|
||||||
memcpy(&(line2Buffer[drawPosition]), "SWR", 3);
|
|
||||||
meterValue = round((float)meterValue / 10); //We now have swr x 10 (1 decimal point)
|
|
||||||
if (meterValue < 100) { //10 to 99, no decimal point
|
|
||||||
//Draw the decimal value
|
|
||||||
line2Buffer[drawPosition + 3] = '0' + meterValue / 10;
|
|
||||||
line2Buffer[drawPosition + 4] = '.';
|
|
||||||
line2Buffer[drawPosition + 5] = '0' + (meterValue - ((meterValue / 10) * 10));
|
|
||||||
} else {
|
|
||||||
memcpy(&(line2Buffer[drawPosition + 3]), "10+", 3); //over 10
|
|
||||||
}
|
|
||||||
memcpy(&(line2Buffer[drawPosition + 6]), lcdMeter, 2); //Copy the S-Meter bars
|
|
||||||
}
|
|
||||||
#else //We want fat bars, easy to read, with less text/numbers
|
|
||||||
//Serial.print("In displaymeter, meterValue: "); Serial.println(meterValue);
|
|
||||||
drawMeter(meterValue);
|
|
||||||
//Always line 2
|
|
||||||
char sym = 'S';
|
|
||||||
if (meterType == 1) sym = 'P';
|
|
||||||
else if (meterType == 2) sym = 'R'; //For SWR
|
|
||||||
line2Buffer[drawPosition] = sym;
|
|
||||||
memcpy(&(line2Buffer[drawPosition + 1]), lcdMeter, 7);
|
|
||||||
#endif //OPTION_SKINNYBARS
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
byte testValue = 0;
|
|
||||||
char checkCount = 0;
|
char checkCount = 0;
|
||||||
|
|
||||||
int currentSMeter = 0;
|
|
||||||
//int sMeterLevels[] = {0, 5, 17, 41, 74, 140, 255, 365, 470};
|
|
||||||
byte scaledSMeter = 0;
|
|
||||||
char checkCountSMeter = 0;
|
char checkCountSMeter = 0;
|
||||||
|
|
||||||
//execute interval : 0.25sec
|
//execute interval : 0.25sec
|
||||||
@@ -810,10 +692,12 @@ void idle_process()
|
|||||||
int newSMeter;
|
int newSMeter;
|
||||||
|
|
||||||
//VK2ETA S-Meter from MAX9814 TC pin
|
//VK2ETA S-Meter from MAX9814 TC pin
|
||||||
newSMeter = analogRead(ANALOG_SMETER);
|
newSMeter = analogRead(ANALOG_SMETER) / 4;
|
||||||
|
|
||||||
//Faster attack, Slower release
|
//Faster attack, Slower release
|
||||||
currentSMeter = (newSMeter > currentSMeter ? ((currentSMeter * 3 + newSMeter * 7) + 5) / 10 : ((currentSMeter * 7 + newSMeter * 3) + 5) / 10);
|
//currentSMeter = (newSMeter > currentSMeter ? ((currentSMeter * 3 + newSMeter * 7) + 5) / 10 : ((currentSMeter * 7 + newSMeter * 3) + 5) / 10);
|
||||||
|
//currentSMeter = ((currentSMeter * 7 + newSMeter * 3) + 5) / 10;
|
||||||
|
currentSMeter = newSMeter;
|
||||||
|
|
||||||
scaledSMeter = 0;
|
scaledSMeter = 0;
|
||||||
for (byte s = 8; s >= 1; s--) {
|
for (byte s = 8; s >= 1; s--) {
|
||||||
|
@@ -271,8 +271,10 @@ void menuCHMemory(int btn, byte isMemoryToVfo){
|
|||||||
if (isMemoryToVfo == 1)
|
if (isMemoryToVfo == 1)
|
||||||
{
|
{
|
||||||
if (resultFreq > 3000 && resultFreq < 60000000)
|
if (resultFreq > 3000 && resultFreq < 60000000)
|
||||||
setFrequency(resultFreq);
|
{
|
||||||
byteToMode(loadMode, 1);
|
byteToMode(loadMode, 1);
|
||||||
|
setFrequency(resultFreq);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -1106,7 +1108,6 @@ void menuSetupKeyType(int btn){
|
|||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
printLineF2(F("CW Key Type set!"));
|
printLineF2(F("CW Key Type set!"));
|
||||||
cwKeyType = selectedKeyType;
|
cwKeyType = selectedKeyType;
|
||||||
EEPROM.put(CW_KEY_TYPE, cwKeyType);
|
EEPROM.put(CW_KEY_TYPE, cwKeyType);
|
||||||
@@ -1127,7 +1128,7 @@ void menuSetupKeyType(int btn){
|
|||||||
}
|
}
|
||||||
|
|
||||||
//=====================================================
|
//=====================================================
|
||||||
//END OF STANDARD Tune Setup for reduce Program Memory
|
//END OF STANDARD Set by Knob for reduce Program Memory
|
||||||
//=====================================================
|
//=====================================================
|
||||||
|
|
||||||
|
|
||||||
|
@@ -95,7 +95,7 @@ void initMeter(){
|
|||||||
|
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
tmpbytes[i] = pgm_read_byte(p_metes_bitmap + i + 48);
|
tmpbytes[i] = pgm_read_byte(p_metes_bitmap + i + 48);
|
||||||
LCD_CreateChar(6, tmpbytes);
|
LCD_CreateChar(7, tmpbytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -128,13 +128,23 @@ void drawMeter(int needle)
|
|||||||
{
|
{
|
||||||
#ifdef OPTION_SKINNYBARS
|
#ifdef OPTION_SKINNYBARS
|
||||||
//Fill buffer with growing set of bars, up to needle value
|
//Fill buffer with growing set of bars, up to needle value
|
||||||
|
lcdMeter[0] = 0x20;
|
||||||
|
lcdMeter[1] = 0x20;
|
||||||
for (int i = 0; i < 6; i++) {
|
for (int i = 0; i < 6; i++) {
|
||||||
if (needle > i)
|
if (needle > i)
|
||||||
lcdMeter[i / 3] = byte(i + 1); //Custom characters above
|
lcdMeter[i / 3] = byte(i + 1); //Custom characters above
|
||||||
else if (i == 1 || i == 4) {
|
//else if (i == 1 || i == 4) {
|
||||||
lcdMeter[i / 3] = 0x20; //blank
|
// lcdMeter[i / 3] = 0x20; //blank
|
||||||
}
|
//}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (needle > 7) {
|
||||||
|
lcdMeter[2] = byte(7); //Custom character "++"
|
||||||
|
} else if (needle > 6) {
|
||||||
|
lcdMeter[2] = '+'; //"+"
|
||||||
|
} else lcdMeter[2] = 0x20;
|
||||||
|
|
||||||
|
|
||||||
#else //Must be "fat" bars
|
#else //Must be "fat" bars
|
||||||
//Fill buffer with growing set of bars, up to needle value
|
//Fill buffer with growing set of bars, up to needle value
|
||||||
for (int i = 0; i < 6; i++) {
|
for (int i = 0; i < 6; i++) {
|
||||||
@@ -143,11 +153,13 @@ void drawMeter(int needle)
|
|||||||
else
|
else
|
||||||
lcdMeter[i] = 0x20; //blank
|
lcdMeter[i] = 0x20; //blank
|
||||||
}
|
}
|
||||||
|
|
||||||
if (needle > 7) {
|
if (needle > 7) {
|
||||||
lcdMeter[6] = byte(7); //Custom character "++"
|
lcdMeter[6] = byte(7); //Custom character "++"
|
||||||
} else if (needle > 6) {
|
} else if (needle > 6) {
|
||||||
lcdMeter[6] = 0x2B; //"+"
|
lcdMeter[6] = '+'; //"+"
|
||||||
} else lcdMeter[6] = 0x20;
|
} else lcdMeter[6] = 0x20;
|
||||||
|
|
||||||
#endif //OPTION_FATBARS
|
#endif //OPTION_FATBARS
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -187,7 +199,7 @@ int getBtnStatus(void){
|
|||||||
readButtonValue = readButtonValue / 4;
|
readButtonValue = readButtonValue / 4;
|
||||||
//return FKEY_VFOCHANGE;
|
//return FKEY_VFOCHANGE;
|
||||||
for (int i = 0; i < 16; i++)
|
for (int i = 0; i < 16; i++)
|
||||||
if (KeyValues[i][0] <= readButtonValue && KeyValues[i][1] >= readButtonValue)
|
if (KeyValues[i][2] != 0 && KeyValues[i][0] <= readButtonValue && KeyValues[i][1] >= readButtonValue)
|
||||||
return KeyValues[i][2];
|
return KeyValues[i][2];
|
||||||
//return i;
|
//return i;
|
||||||
}
|
}
|
||||||
|
@@ -113,22 +113,9 @@ void SendWSPRManage()
|
|||||||
EEPROM.get(bandBuffIndex, WsprTXFreq);
|
EEPROM.get(bandBuffIndex, WsprTXFreq);
|
||||||
EEPROM.get(bandBuffIndex + 4, WsprMultiChan);
|
EEPROM.get(bandBuffIndex + 4, WsprMultiChan);
|
||||||
|
|
||||||
/*
|
|
||||||
//3, 4, 5, 6, 7
|
|
||||||
Wspr_Reg1[3] = EEPROM.read(bandBuffIndex + 6);
|
|
||||||
Wspr_Reg1[4] = EEPROM.read(bandBuffIndex + 7);
|
|
||||||
Wspr_Reg1[5] = EEPROM.read(bandBuffIndex + 8);
|
|
||||||
Wspr_Reg1[6] = EEPROM.read(bandBuffIndex + 9);
|
|
||||||
Wspr_Reg1[7] = EEPROM.read(bandBuffIndex + 10);
|
|
||||||
*/
|
|
||||||
for (loopIndex = 3; loopIndex < 8; loopIndex++)
|
for (loopIndex = 3; loopIndex < 8; loopIndex++)
|
||||||
Wspr_Reg1[loopIndex] = EEPROM.read(bandBuffIndex + loopIndex + 3);
|
Wspr_Reg1[loopIndex] = EEPROM.read(bandBuffIndex + loopIndex + 3);
|
||||||
|
|
||||||
/*
|
|
||||||
Wspr_Reg2[2] = EEPROM.read(bandBuffIndex + 11);
|
|
||||||
Wspr_Reg2[3] = EEPROM.read(bandBuffIndex + 12);
|
|
||||||
Wspr_Reg2[4] = EEPROM.read(bandBuffIndex + 13);
|
|
||||||
*/
|
|
||||||
//2, 3, 4
|
//2, 3, 4
|
||||||
for (loopIndex = 2; loopIndex < 5; loopIndex++)
|
for (loopIndex = 2; loopIndex < 5; loopIndex++)
|
||||||
Wspr_Reg2[loopIndex] = EEPROM.read(bandBuffIndex + loopIndex + 9);
|
Wspr_Reg2[loopIndex] = EEPROM.read(bandBuffIndex + loopIndex + 9);
|
||||||
@@ -136,18 +123,32 @@ void SendWSPRManage()
|
|||||||
TX_MSNB_P2 = ((unsigned long)Wspr_Reg1[5] & 0x0F) << 16 | ((unsigned long)Wspr_Reg1[6]) << 8 | Wspr_Reg1[7];
|
TX_MSNB_P2 = ((unsigned long)Wspr_Reg1[5] & 0x0F) << 16 | ((unsigned long)Wspr_Reg1[6]) << 8 | Wspr_Reg1[7];
|
||||||
}
|
}
|
||||||
|
|
||||||
ltoa(WsprTXFreq, b, DEC);
|
|
||||||
if (digitalRead(PTT) == 0)
|
if (digitalRead(PTT) == 0)
|
||||||
strcpy(c, "SEND: ");
|
strcpy(c, "SEND: ");
|
||||||
else
|
else
|
||||||
strcpy(c, "PTT-> ");
|
strcpy(c, "PTT-> ");
|
||||||
|
|
||||||
strcat(c, b);
|
//ltoa(WsprTXFreq, b, DEC);
|
||||||
|
//strcat(c, b);
|
||||||
|
|
||||||
|
//display frequency, Frequency to String for KD8CEC
|
||||||
|
unsigned long tmpFreq = WsprTXFreq;
|
||||||
|
for (int i = 15; i >= 6; i--) {
|
||||||
|
if (tmpFreq > 0) {
|
||||||
|
if (i == 12 || i == 8) c[i] = '.';
|
||||||
|
else {
|
||||||
|
c[i] = tmpFreq % 10 + 0x30;
|
||||||
|
tmpFreq /= 10;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
c[i] = ' ';
|
||||||
|
}
|
||||||
|
|
||||||
printLine1(c);
|
printLine1(c);
|
||||||
|
|
||||||
if (digitalRead(PTT) == 0)
|
if (digitalRead(PTT) == 0)
|
||||||
{
|
{
|
||||||
//printLineF1(F("Transmitting"));
|
|
||||||
//SEND WSPR
|
//SEND WSPR
|
||||||
//If you need to consider the Rit and Sprite modes, uncomment them below.
|
//If you need to consider the Rit and Sprite modes, uncomment them below.
|
||||||
//remark = To reduce the size of the program
|
//remark = To reduce the size of the program
|
||||||
|
Reference in New Issue
Block a user