Compare commits

...

2 Commits

Author SHA1 Message Date
Andrea Santaniello
9747599c63
Update README.md
Some checks failed
Build and Release RadioGUI / build (push) Has been cancelled
Build and Release RadioGUI / release (push) Has been cancelled
2025-01-08 17:20:30 +01:00
Andrea Santaniello
f8389e0ddf
Update RadioController.cs for V4 Format 2025-01-08 16:38:43 +01:00
2 changed files with 14 additions and 13 deletions

View File

@ -1,6 +1,6 @@
# KV4P-Sharp # KV4P-Sharp
KV4P-Sharp is a C# library designed to communicate with KV4P USB VHF radios. It facilitates control over radio operations through serial communication but does not handle audio encoding or decoding. Users must manage audio processing separately by encoding/decoding audio data as PCM 44100Hz, 8-bit mono. KV4P-Sharp is a C# library designed to communicate with KV4P USB VHF radios. It facilitates control over radio operations through serial communication but does not handle audio encoding or decoding. Users must manage audio processing separately by encoding/decoding audio data as PCM ~44100~ 16000Hz, 8-bit mono.
## Features ## Features
- Control transmit (PTT) and receive (RX) modes. - Control transmit (PTT) and receive (RX) modes.

View File

@ -44,10 +44,10 @@ public class RadioController : IDisposable
} }
private RadioMode currentMode = RadioMode.STARTUP; private RadioMode currentMode = RadioMode.STARTUP;
private const int MIN_FIRMWARE_VER = 1; private const int MIN_FIRMWARE_VER = 4;
private string versionStrBuffer = ""; private string versionStrBuffer = "";
private const int AUDIO_SAMPLE_RATE = 44100; private const int AUDIO_SAMPLE_RATE = 16000;
// Synchronization locks // Synchronization locks
private readonly object _syncLock = new object(); private readonly object _syncLock = new object();
@ -146,15 +146,16 @@ public class RadioController : IDisposable
} }
SendCommand(ESP32Command.STOP); SendCommand(ESP32Command.STOP);
} }
/// <summary> /// <summary>
/// Tunes the radio to the specified frequencies with tone and squelch level. /// Tunes the radio to the specified frequencies with tone, squelch level, and bandwidth.
/// </summary> /// </summary>
/// <param name="txFrequencyStr">Transmit frequency as a string (e.g., "146.520").</param> /// <param name="txFrequencyStr">Transmit frequency as a string (e.g., "146.520").</param>
/// <param name="rxFrequencyStr">Receive frequency as a string (e.g., "146.520").</param> /// <param name="rxFrequencyStr">Receive frequency as a string (e.g., "146.520").</param>
/// <param name="tone">Tone value as an integer (00 to 99).</param> /// <param name="tone">Tone value as an integer (00 to 99).</param>
/// <param name="squelchLevel">Squelch level as an integer (0 to 9).</param> /// <param name="squelchLevel">Squelch level as an integer (0 to 9).</param>
public void TuneToFrequency(string txFrequencyStr, string rxFrequencyStr, int tone, int squelchLevel) /// <param name="wideband">True for 25kHz bandwidth, false for 12.5kHz bandwidth.</param>
public void TuneToFrequency(string txFrequencyStr, string rxFrequencyStr, int tone, int squelchLevel, bool wideband)
{ {
if (string.IsNullOrWhiteSpace(txFrequencyStr)) if (string.IsNullOrWhiteSpace(txFrequencyStr))
throw new ArgumentException("Transmit frequency cannot be null or empty.", nameof(txFrequencyStr)); throw new ArgumentException("Transmit frequency cannot be null or empty.", nameof(txFrequencyStr));
@ -172,11 +173,12 @@ public class RadioController : IDisposable
if (squelchStr.Length != 1) if (squelchStr.Length != 1)
throw new ArgumentException("Squelch level must be a single digit (0-9).", nameof(squelchLevel)); throw new ArgumentException("Squelch level must be a single digit (0-9).", nameof(squelchLevel));
// Build parameters string // Build parameters string with bandwidth setting
string paramsStr = txFrequencyStr + rxFrequencyStr + toneStr + squelchStr; string bandwidthSetting = wideband ? "W" : "N";
string paramsStr = txFrequencyStr + rxFrequencyStr + toneStr + squelchStr + bandwidthSetting;
SendCommand(ESP32Command.TUNE_TO, paramsStr); SendCommand(ESP32Command.TUNE_TO, paramsStr);
} }
public void SetFilters(bool emphasis, bool highpass, bool lowpass) public void SetFilters(bool emphasis, bool highpass, bool lowpass)
{ {
string paramsStr = (emphasis ? "1" : "0") + (highpass ? "1" : "0") + (lowpass ? "1" : "0"); string paramsStr = (emphasis ? "1" : "0") + (highpass ? "1" : "0") + (lowpass ? "1" : "0");
@ -241,7 +243,7 @@ public class RadioController : IDisposable
HandleData(receivedData); HandleData(receivedData);
} }
} }
private void HandleData(byte[] data) private void HandleData(byte[] data)
{ {
RadioMode mode; RadioMode mode;
@ -256,7 +258,7 @@ public class RadioController : IDisposable
} }
else if (mode == RadioMode.STARTUP) else if (mode == RadioMode.STARTUP)
{ {
// Handle firmware version check // Handle firmware version check with updated minimum version
string dataStr = System.Text.Encoding.UTF8.GetString(data); string dataStr = System.Text.Encoding.UTF8.GetString(data);
lock (_versionStrBufferLock) lock (_versionStrBufferLock)
{ {
@ -271,7 +273,7 @@ public class RadioController : IDisposable
{ {
if (verInt < MIN_FIRMWARE_VER) if (verInt < MIN_FIRMWARE_VER)
{ {
OnErrorOccurred(new ErrorEventArgs(new InvalidOperationException("Unsupported firmware version."))); OnErrorOccurred(new ErrorEventArgs(new InvalidOperationException($"Unsupported firmware version. Version 4 or higher is required.")));
} }
else else
{ {
@ -279,7 +281,6 @@ public class RadioController : IDisposable
{ {
currentMode = RadioMode.RX; currentMode = RadioMode.RX;
} }
// No need to initialize audio playback
} }
} }
else else