mirror of
https://github.com/cjcliffe/CubicSDR.git
synced 2025-09-07 23:57:50 -04:00
tuner hover states and visual test
This commit is contained in:
parent
2893a1ab17
commit
36f1bd6b01
@ -1,6 +1,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#define CUBICSDR_TITLE "CubicSDR " CUBICSDR_VERSION " by Charles J. Cliffe (@ccliffe)"
|
#define CUBICSDR_TITLE "CubicSDR " CUBICSDR_VERSION " by Charles J. Cliffe (@ccliffe) :: www.cubicsdr.com"
|
||||||
|
|
||||||
#ifndef __BYTE_ORDER
|
#ifndef __BYTE_ORDER
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
|
@ -49,6 +49,8 @@ DefaultColorTheme::DefaultColorTheme() {
|
|||||||
fftHighlight = RGBColor(1, 1, 1);
|
fftHighlight = RGBColor(1, 1, 1);
|
||||||
scopeLine = RGBColor(0.9, 0.9, 0.9);
|
scopeLine = RGBColor(0.9, 0.9, 0.9);
|
||||||
tuningBar = RGBColor(0.2, 0.2, 0.9);
|
tuningBar = RGBColor(0.2, 0.2, 0.9);
|
||||||
|
tuningBarUp = RGBColor(1.0, 139.0/255.0, 96.0/255.0);
|
||||||
|
tuningBarDown = RGBColor(148.0/255.0, 148.0/255.0, 1.0);
|
||||||
meterLevel = RGBColor(0.1, 0.75, 0.1);
|
meterLevel = RGBColor(0.1, 0.75, 0.1);
|
||||||
meterValue = RGBColor(0.75, 0.1, 0.1);
|
meterValue = RGBColor(0.75, 0.1, 0.1);
|
||||||
text = RGBColor(1, 1, 1);
|
text = RGBColor(1, 1, 1);
|
||||||
|
@ -48,6 +48,8 @@ public:
|
|||||||
RGBColor fftHighlight;
|
RGBColor fftHighlight;
|
||||||
RGBColor scopeLine;
|
RGBColor scopeLine;
|
||||||
RGBColor tuningBar;
|
RGBColor tuningBar;
|
||||||
|
RGBColor tuningBarUp;
|
||||||
|
RGBColor tuningBarDown;
|
||||||
RGBColor meterLevel;
|
RGBColor meterLevel;
|
||||||
RGBColor meterValue;
|
RGBColor meterValue;
|
||||||
RGBColor text;
|
RGBColor text;
|
||||||
|
@ -28,6 +28,18 @@ TuningCanvas::TuningCanvas(wxWindow *parent, int *attribList) :
|
|||||||
InteractiveCanvas(parent, attribList), dragAccum(0) {
|
InteractiveCanvas(parent, attribList), dragAccum(0) {
|
||||||
|
|
||||||
glContext = new TuningContext(this, &wxGetApp().GetContext(this));
|
glContext = new TuningContext(this, &wxGetApp().GetContext(this));
|
||||||
|
|
||||||
|
hoverIndex = 0;
|
||||||
|
hoverState = TUNING_HOVER_NONE;
|
||||||
|
|
||||||
|
freqDP = -1.0;
|
||||||
|
freqW = (1.0 / 3.0) * 2.0;
|
||||||
|
|
||||||
|
bwDP = -1.0 + (2.25 / 3.0);
|
||||||
|
bwW = (1.0 / 4.0) * 2.0;
|
||||||
|
|
||||||
|
centerDP = -1.0 + (2.0 / 3.0) * 2.0;
|
||||||
|
centerW = (1.0 / 3.0) * 2.0;
|
||||||
}
|
}
|
||||||
|
|
||||||
TuningCanvas::~TuningCanvas() {
|
TuningCanvas::~TuningCanvas() {
|
||||||
@ -56,41 +68,57 @@ void TuningCanvas::OnPaint(wxPaintEvent& WXUNUSED(event)) {
|
|||||||
long long bw = wxGetApp().getDemodMgr().getLastBandwidth();
|
long long bw = wxGetApp().getDemodMgr().getLastBandwidth();
|
||||||
long long center = wxGetApp().getFrequency();
|
long long center = wxGetApp().getFrequency();
|
||||||
|
|
||||||
float freqDP = -1.0;
|
|
||||||
float freqW = (1.0 / 3.0) * 2.0;
|
|
||||||
|
|
||||||
float bwDP = -1.0 + (2.25 / 3.0);
|
|
||||||
float bwW = (1.0 / 4.0) * 2.0;
|
|
||||||
|
|
||||||
float centerDP = -1.0 + (2.0 / 3.0) * 2.0;
|
|
||||||
float centerW = (1.0 / 3.0) * 2.0;
|
|
||||||
|
|
||||||
glContext->DrawTuner(freq, 11, freqDP, freqW);
|
|
||||||
glContext->DrawTuner(bw, 7, bwDP, bwW);
|
|
||||||
glContext->DrawTuner(center, 11, centerDP, centerW);
|
|
||||||
|
|
||||||
if (mouseTracker.mouseDown()) {
|
if (mouseTracker.mouseDown()) {
|
||||||
glContext->Draw(ThemeMgr::mgr.currentTheme->tuningBar.r, ThemeMgr::mgr.currentTheme->tuningBar.g, ThemeMgr::mgr.currentTheme->tuningBar.b,
|
glContext->Draw(ThemeMgr::mgr.currentTheme->tuningBar.r, ThemeMgr::mgr.currentTheme->tuningBar.g, ThemeMgr::mgr.currentTheme->tuningBar.b,
|
||||||
0.6, mouseTracker.getOriginMouseX(), mouseTracker.getMouseX());
|
0.6, mouseTracker.getOriginMouseX(), mouseTracker.getMouseX());
|
||||||
}
|
}
|
||||||
|
|
||||||
int index;
|
bool top = mouseTracker.getMouseY() >= 0.5;
|
||||||
bool top = mouseTracker.getMouseY()>=0.5;
|
bool bottom = mouseTracker.getMouseY() <= 0.5;
|
||||||
bool bottom = mouseTracker.getMouseY()<=0.5;
|
|
||||||
index = glContext->GetTunerDigitIndex(mouseTracker.getMouseX(), 11, freqDP, freqW); // freq
|
RGBColor clr = top ? ThemeMgr::mgr.currentTheme->tuningBarUp : ThemeMgr::mgr.currentTheme->tuningBarDown;
|
||||||
if (index > 0) {
|
|
||||||
glContext->DrawTunerBarIndexed(1, index, 11, freqDP, freqW, ThemeMgr::mgr.currentTheme->tuningBar, 0.6, top, bottom); // freq
|
RGBColor clrDark = ThemeMgr::mgr.currentTheme->tuningBar;
|
||||||
|
RGBColor clrMid = ThemeMgr::mgr.currentTheme->tuningBar;
|
||||||
|
RGBColor clrLight = ThemeMgr::mgr.currentTheme->tuningBar;
|
||||||
|
|
||||||
|
clrDark.r*=0.5;clrDark.g*=0.5;clrDark.b*=0.5;
|
||||||
|
clrLight.r*=2.0;clrLight.g*=2.0;clrLight.b*=2.0;
|
||||||
|
|
||||||
|
glContext->DrawTunerBarIndexed(1, 3, 11, freqDP, freqW, clrDark, 0.25, true, true); // freq
|
||||||
|
glContext->DrawTunerBarIndexed(4, 6, 11, freqDP, freqW, clrMid, 0.25, true, true);
|
||||||
|
glContext->DrawTunerBarIndexed(7, 9, 11, freqDP, freqW, clrDark, 0.25, true, true);
|
||||||
|
glContext->DrawTunerBarIndexed(10, 11, 11, freqDP, freqW, clrMid, 0.25, true, true);
|
||||||
|
|
||||||
|
glContext->DrawTunerBarIndexed(1, 3, 7, bwDP, bwW, clrDark, 0.25, true, true); // bw
|
||||||
|
glContext->DrawTunerBarIndexed(4, 6, 7, bwDP, bwW, clrMid, 0.25, true, true);
|
||||||
|
glContext->DrawTunerBarIndexed(7, 7, 7, bwDP, bwW, clrDark, 0.25, true, true);
|
||||||
|
|
||||||
|
glContext->DrawTunerBarIndexed(1, 3, 11, centerDP, centerW, clrDark, 0.25, true, true); // freq
|
||||||
|
glContext->DrawTunerBarIndexed(4, 6, 11, centerDP, centerW, clrMid, 0.25, true, true);
|
||||||
|
glContext->DrawTunerBarIndexed(7, 9, 11, centerDP, centerW, clrDark, 0.25, true, true);
|
||||||
|
glContext->DrawTunerBarIndexed(10, 11, 11, centerDP, centerW, clrMid, 0.25, true, true);
|
||||||
|
|
||||||
|
if (hoverIndex > 0) {
|
||||||
|
switch (hoverState) {
|
||||||
|
|
||||||
|
case TUNING_HOVER_FREQ:
|
||||||
|
glContext->DrawTunerBarIndexed(hoverIndex, hoverIndex, 11, freqDP, freqW, clr, 0.25, top, bottom); // freq
|
||||||
|
break;
|
||||||
|
case TUNING_HOVER_BW:
|
||||||
|
glContext->DrawTunerBarIndexed(hoverIndex, hoverIndex, 7, bwDP, bwW, clr, 0.25, top, bottom); // bw
|
||||||
|
break;
|
||||||
|
case TUNING_HOVER_CENTER:
|
||||||
|
glContext->DrawTunerBarIndexed(hoverIndex, hoverIndex, 11, centerDP, centerW, clr, 0.25, top, bottom); // center
|
||||||
|
break;
|
||||||
|
case TUNING_HOVER_NONE:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
index = glContext->GetTunerDigitIndex(mouseTracker.getMouseX(), 7, bwDP, bwW); // bw
|
glContext->DrawTuner(freq, 11, freqDP, freqW);
|
||||||
if (index > 0) {
|
glContext->DrawTuner(bw, 7, bwDP, bwW);
|
||||||
glContext->DrawTunerBarIndexed(1, index, 7, bwDP, bwW, ThemeMgr::mgr.currentTheme->tuningBar, 0.6, top, bottom); // bw
|
glContext->DrawTuner(center, 11, centerDP, centerW);
|
||||||
}
|
|
||||||
|
|
||||||
index = glContext->GetTunerDigitIndex(mouseTracker.getMouseX(), 11, centerDP, centerW); // center
|
|
||||||
if (index > 0) {
|
|
||||||
glContext->DrawTunerBarIndexed(1, index, 11, centerDP, centerW, ThemeMgr::mgr.currentTheme->tuningBar, 0.6, top, bottom); // center
|
|
||||||
}
|
|
||||||
|
|
||||||
glContext->DrawEnd();
|
glContext->DrawEnd();
|
||||||
|
|
||||||
@ -142,6 +170,32 @@ void TuningCanvas::OnIdle(wxIdleEvent &event) {
|
|||||||
|
|
||||||
void TuningCanvas::OnMouseMoved(wxMouseEvent& event) {
|
void TuningCanvas::OnMouseMoved(wxMouseEvent& event) {
|
||||||
InteractiveCanvas::OnMouseMoved(event);
|
InteractiveCanvas::OnMouseMoved(event);
|
||||||
|
|
||||||
|
int index = 0;
|
||||||
|
|
||||||
|
index = glContext->GetTunerDigitIndex(mouseTracker.getMouseX(), 11, freqDP, freqW); // freq
|
||||||
|
if (index > 0) {
|
||||||
|
hoverIndex = index;
|
||||||
|
hoverState = TUNING_HOVER_FREQ;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
index = glContext->GetTunerDigitIndex(mouseTracker.getMouseX(), 7, bwDP, bwW); // bw
|
||||||
|
if (index > 0) {
|
||||||
|
hoverIndex = index;
|
||||||
|
hoverState = TUNING_HOVER_BW;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
index = glContext->GetTunerDigitIndex(mouseTracker.getMouseX(), 11, centerDP, centerW); // center
|
||||||
|
if (index > 0) {
|
||||||
|
hoverIndex = index;
|
||||||
|
hoverState = TUNING_HOVER_CENTER;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
hoverIndex = 0;
|
||||||
|
hoverState = TUNING_HOVER_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TuningCanvas::OnMouseDown(wxMouseEvent& event) {
|
void TuningCanvas::OnMouseDown(wxMouseEvent& event) {
|
||||||
@ -161,17 +215,21 @@ void TuningCanvas::OnMouseWheelMoved(wxMouseEvent& event) {
|
|||||||
void TuningCanvas::OnMouseReleased(wxMouseEvent& event) {
|
void TuningCanvas::OnMouseReleased(wxMouseEvent& event) {
|
||||||
InteractiveCanvas::OnMouseReleased(event);
|
InteractiveCanvas::OnMouseReleased(event);
|
||||||
mouseTracker.setVertDragLock(false);
|
mouseTracker.setVertDragLock(false);
|
||||||
SetCursor(wxCURSOR_SIZEWE);
|
SetCursor(wxCURSOR_ARROW);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TuningCanvas::OnMouseLeftWindow(wxMouseEvent& event) {
|
void TuningCanvas::OnMouseLeftWindow(wxMouseEvent& event) {
|
||||||
InteractiveCanvas::OnMouseLeftWindow(event);
|
InteractiveCanvas::OnMouseLeftWindow(event);
|
||||||
SetCursor(wxCURSOR_CROSS);
|
SetCursor(wxCURSOR_CROSS);
|
||||||
|
hoverIndex = 0;
|
||||||
|
hoverState = TUNING_HOVER_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TuningCanvas::OnMouseEnterWindow(wxMouseEvent& event) {
|
void TuningCanvas::OnMouseEnterWindow(wxMouseEvent& event) {
|
||||||
InteractiveCanvas::mouseTracker.OnMouseEnterWindow(event);
|
InteractiveCanvas::mouseTracker.OnMouseEnterWindow(event);
|
||||||
SetCursor(wxCURSOR_SIZEWE);
|
SetCursor(wxCURSOR_ARROW);
|
||||||
|
hoverIndex = 0;
|
||||||
|
hoverState = TUNING_HOVER_NONE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TuningCanvas::setHelpTip(std::string tip) {
|
void TuningCanvas::setHelpTip(std::string tip) {
|
||||||
|
@ -15,6 +15,9 @@
|
|||||||
|
|
||||||
class TuningCanvas: public InteractiveCanvas {
|
class TuningCanvas: public InteractiveCanvas {
|
||||||
public:
|
public:
|
||||||
|
enum HoverState {
|
||||||
|
TUNING_HOVER_NONE, TUNING_HOVER_FREQ, TUNING_HOVER_BW, TUNING_HOVER_CENTER
|
||||||
|
};
|
||||||
TuningCanvas(wxWindow *parent, int *attribList = NULL);
|
TuningCanvas(wxWindow *parent, int *attribList = NULL);
|
||||||
~TuningCanvas();
|
~TuningCanvas();
|
||||||
|
|
||||||
@ -36,6 +39,17 @@ private:
|
|||||||
std::string helpTip;
|
std::string helpTip;
|
||||||
float dragAccum;
|
float dragAccum;
|
||||||
float uxDown;
|
float uxDown;
|
||||||
|
HoverState hoverState;
|
||||||
|
int hoverIndex;
|
||||||
|
|
||||||
|
float freqDP;
|
||||||
|
float freqW;
|
||||||
|
|
||||||
|
float bwDP;
|
||||||
|
float bwW;
|
||||||
|
|
||||||
|
float centerDP;
|
||||||
|
float centerW;
|
||||||
//
|
//
|
||||||
wxDECLARE_EVENT_TABLE();
|
wxDECLARE_EVENT_TABLE();
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user