Skip to content
Snippets Groups Projects
Commit f3fe5ba2 authored by jsiegle's avatar jsiegle
Browse files

Merge branch 'master' of https://github.com/open-ephys/GUI

parents f563c03d 48b51608
No related branches found
No related tags found
No related merge requests found
...@@ -149,9 +149,13 @@ void PhaseDetector::process(AudioSampleBuffer& buffer, ...@@ -149,9 +149,13 @@ void PhaseDetector::process(AudioSampleBuffer& buffer,
numPeakIntervals++; numPeakIntervals++;
//std::cout << "GOT EVENT." << std::endl;
// entering falling phase (just reached peak or trough) // entering falling phase (just reached peak or trough)
if (true) //if (true)
addEvent(events, TTL, i, 1, 3); addEvent(events, TTL, i, 1, 3);
peakIntervals[numPeakIntervals % NUM_INTERVALS] = nSamplesSinceLastPeak; peakIntervals[numPeakIntervals % NUM_INTERVALS] = nSamplesSinceLastPeak;
...@@ -168,10 +172,10 @@ void PhaseDetector::process(AudioSampleBuffer& buffer, ...@@ -168,10 +172,10 @@ void PhaseDetector::process(AudioSampleBuffer& buffer,
// either rising or falling // either rising or falling
nSamplesSinceLastPeak++; nSamplesSinceLastPeak++;
// if (nSamplesSinceLastPeak == 100) if (nSamplesSinceLastPeak == 500)
// { {
// addEvent(events, TTL, i, 0, 3); addEvent(events, TTL, i, 0, 3);
// } }
} }
......
...@@ -107,6 +107,21 @@ LfpDisplayCanvas::LfpDisplayCanvas(LfpDisplayNode* processor_) : ...@@ -107,6 +107,21 @@ LfpDisplayCanvas::LfpDisplayCanvas(LfpDisplayNode* processor_) :
lfpDisplay->setNumChannels(nChans); lfpDisplay->setNumChannels(nChans);
lfpDisplay->setRange(1000.0f); lfpDisplay->setRange(1000.0f);
// add event display-specific controls (currently just an enable/disable button)
for (int i = 0; i < 8; i++)
{
eventDisplayInterface* eventOptions = new eventDisplayInterface(lfpDisplay, this, i);
eventDisplayInterfaces.add(eventOptions);
addAndMakeVisible(eventOptions);
eventOptions->setBounds(500+(floor(i/2)*20), getHeight()-20-(i%2)*20, 40, 20);
lfpDisplay->setEventDisplayState(i,true);
}
} }
LfpDisplayCanvas::~LfpDisplayCanvas() LfpDisplayCanvas::~LfpDisplayCanvas()
...@@ -127,6 +142,13 @@ void LfpDisplayCanvas::resized() ...@@ -127,6 +142,13 @@ void LfpDisplayCanvas::resized()
timebaseSelection->setBounds(175,getHeight()-30,100,25); timebaseSelection->setBounds(175,getHeight()-30,100,25);
spreadSelection->setBounds(345,getHeight()-30,100,25); spreadSelection->setBounds(345,getHeight()-30,100,25);
for (int i = 0; i < 8; i++)
{
eventDisplayInterfaces[i]->setBounds(500+(floor(i/2)*20), getHeight()-20-(i%2)*20, 40, 20); // arrange event channel buttons in two rows
eventDisplayInterfaces[i]->repaint();
}
// std::cout << "Canvas thinks LfpDisplay should be this high: " // std::cout << "Canvas thinks LfpDisplay should be this high: "
// << lfpDisplay->getTotalHeight() << std::endl; // << lfpDisplay->getTotalHeight() << std::endl;
...@@ -305,7 +327,7 @@ void LfpDisplayCanvas::updateScreenBuffer() ...@@ -305,7 +327,7 @@ void LfpDisplayCanvas::updateScreenBuffer()
screenBuffer->clear(screenBufferIndex, 1); screenBuffer->clear(screenBufferIndex, 1);
for (int channel = 0; channel < nChans; channel++) for (int channel = 0; channel <= nChans; channel++) // pull one extra channel for event display
{ {
screenBuffer->addFrom(channel, // destChannel screenBuffer->addFrom(channel, // destChannel
...@@ -351,6 +373,11 @@ float LfpDisplayCanvas::getXCoord(int chan, int samp) ...@@ -351,6 +373,11 @@ float LfpDisplayCanvas::getXCoord(int chan, int samp)
return samp; return samp;
} }
int LfpDisplayCanvas::getNumChannels()
{
return nChans;
}
float LfpDisplayCanvas::getYCoord(int chan, int samp) float LfpDisplayCanvas::getYCoord(int chan, int samp)
{ {
return *screenBuffer->getSampleData(chan, samp); return *screenBuffer->getSampleData(chan, samp);
...@@ -395,6 +422,10 @@ void LfpDisplayCanvas::paint(Graphics& g) ...@@ -395,6 +422,10 @@ void LfpDisplayCanvas::paint(Graphics& g)
g.drawText("Timebase (s)",175,getHeight()-55,300,20,Justification::left, false); g.drawText("Timebase (s)",175,getHeight()-55,300,20,Justification::left, false);
g.drawText("Spread (px)",345,getHeight()-55,300,20,Justification::left, false); g.drawText("Spread (px)",345,getHeight()-55,300,20,Justification::left, false);
g.drawText("Event display",500,getHeight()-55,300,20,Justification::left, false);
} }
void LfpDisplayCanvas::refresh() void LfpDisplayCanvas::refresh()
...@@ -535,6 +566,12 @@ LfpDisplay::~LfpDisplay() ...@@ -535,6 +566,12 @@ LfpDisplay::~LfpDisplay()
deleteAllChildren(); deleteAllChildren();
} }
int LfpDisplay::getNumChannels()
{
return numChans;
}
void LfpDisplay::setNumChannels(int numChannels) void LfpDisplay::setNumChannels(int numChannels)
{ {
numChans = numChannels; numChans = numChannels;
...@@ -551,7 +588,7 @@ void LfpDisplay::setNumChannels(int numChannels) ...@@ -551,7 +588,7 @@ void LfpDisplay::setNumChannels(int numChannels)
//std::cout << "Adding new channel display." << std::endl; //std::cout << "Adding new channel display." << std::endl;
LfpChannelDisplay* lfpChan = new LfpChannelDisplay(canvas, i); LfpChannelDisplay* lfpChan = new LfpChannelDisplay(canvas, this, i);
lfpChan->setColour(channelColours[i % channelColours.size()]); lfpChan->setColour(channelColours[i % channelColours.size()]);
lfpChan->setRange(range); lfpChan->setRange(range);
...@@ -561,7 +598,7 @@ void LfpDisplay::setNumChannels(int numChannels) ...@@ -561,7 +598,7 @@ void LfpDisplay::setNumChannels(int numChannels)
channels.add(lfpChan); channels.add(lfpChan);
LfpChannelDisplayInfo* lfpInfo = new LfpChannelDisplayInfo(canvas, i); LfpChannelDisplayInfo* lfpInfo = new LfpChannelDisplayInfo(canvas, this, i);
lfpInfo->setColour(channelColours[i % channelColours.size()]); lfpInfo->setColour(channelColours[i % channelColours.size()]);
lfpInfo->setRange(range); lfpInfo->setRange(range);
...@@ -762,10 +799,24 @@ void LfpDisplay::mouseDown(const MouseEvent& event) ...@@ -762,10 +799,24 @@ void LfpDisplay::mouseDown(const MouseEvent& event)
} }
bool LfpDisplay::setEventDisplayState(int ch, bool state)
{
eventDisplayEnabled[ch] = state;
return eventDisplayEnabled[ch];
}
bool LfpDisplay::getEventDisplayState(int ch)
{
return eventDisplayEnabled[ch];
}
// ------------------------------------------------------------------ // ------------------------------------------------------------------
LfpChannelDisplay::LfpChannelDisplay(LfpDisplayCanvas* c, int channelNumber) : LfpChannelDisplay::LfpChannelDisplay(LfpDisplayCanvas* c, LfpDisplay* d, int channelNumber) :
canvas(c), isSelected(false), chan(channelNumber), channelHeight(40), channelOverlap(300), range(1000.0f) canvas(c), display(d), isSelected(false), chan(channelNumber), channelHeight(40), channelOverlap(300), range(1000.0f)
{ {
...@@ -793,6 +844,9 @@ void LfpChannelDisplay::paint(Graphics& g) ...@@ -793,6 +844,9 @@ void LfpChannelDisplay::paint(Graphics& g)
g.setColour(Colours::yellow); // draw most recent drawn sample position g.setColour(Colours::yellow); // draw most recent drawn sample position
g.drawLine(canvas->screenBufferIndex+1, 0, canvas->screenBufferIndex+1, getHeight()); g.drawLine(canvas->screenBufferIndex+1, 0, canvas->screenBufferIndex+1, getHeight());
//g.setColour(Colours::red); // draw oldest drawn sample position //g.setColour(Colours::red); // draw oldest drawn sample position
//g.drawLine(canvas->lastScreenBufferIndex, 0, canvas->lastScreenBufferIndex, getHeight()-channelOverlap); //g.drawLine(canvas->lastScreenBufferIndex, 0, canvas->lastScreenBufferIndex, getHeight()-channelOverlap);
...@@ -819,7 +873,6 @@ void LfpChannelDisplay::paint(Graphics& g) ...@@ -819,7 +873,6 @@ void LfpChannelDisplay::paint(Graphics& g)
int stepSize = 1; int stepSize = 1;
int from = 0; // for vertical line drawing in the LFP data int from = 0; // for vertical line drawing in the LFP data
int to = 0; int to = 0;
g.setColour(lineColour);
//for (int i = 0; i < getWidth()-stepSize; i += stepSize) // redraw entire display //for (int i = 0; i < getWidth()-stepSize; i += stepSize) // redraw entire display
int ifrom = canvas->lastScreenBufferIndex - 3; // need to start drawing a bit before the actual redraw windowfor the interpolated line to join correctly int ifrom = canvas->lastScreenBufferIndex - 3; // need to start drawing a bit before the actual redraw windowfor the interpolated line to join correctly
...@@ -839,6 +892,24 @@ void LfpChannelDisplay::paint(Graphics& g) ...@@ -839,6 +892,24 @@ void LfpChannelDisplay::paint(Graphics& g)
for (int i = ifrom; i < ito ; i += stepSize) // redraw only changed portion for (int i = ifrom; i < ito ; i += stepSize) // redraw only changed portion
{ {
// draw event markers
int rawEventState = canvas->getYCoord(canvas->getNumChannels(), i);// get last channel+1 in buffer (represents events)
for (int ev_ch = 0; ev_ch < 8 ; ev_ch++) // for all event channels
{
if (display->getEventDisplayState(ev_ch)){ // check if plotting for this channel is enabled
if ( rawEventState & (1 << ev_ch)){ // events are representet by a bit code, so we have to extract the individual bits with a mask
g.setColour(display->channelColours[ev_ch*2]); // get color from lfp color scheme
g.setOpacity(0.25f);
g.drawLine(i, center-channelHeight/2 , i, center+channelHeight/2);
}
}
}
//std::cout << "e " << canvas->getYCoord(canvas->getNumChannels()-1, i) << std::endl;
g.setColour(lineColour);
g.setOpacity(1);
// drawLine makes for ok anti-aliased plots, but is pretty slow // drawLine makes for ok anti-aliased plots, but is pretty slow
g.drawLine(i, g.drawLine(i,
(canvas->getYCoord(chan, i)/range*channelHeightFloat)+getHeight()/2, (canvas->getYCoord(chan, i)/range*channelHeightFloat)+getHeight()/2,
...@@ -889,6 +960,10 @@ void LfpChannelDisplay::paint(Graphics& g) ...@@ -889,6 +960,10 @@ void LfpChannelDisplay::paint(Graphics& g)
} }
void LfpChannelDisplay::setRange(float r) void LfpChannelDisplay::setRange(float r)
{ {
range = r; range = r;
...@@ -950,8 +1025,8 @@ void LfpChannelDisplay::setName(String name_) ...@@ -950,8 +1025,8 @@ void LfpChannelDisplay::setName(String name_)
// ------------------------------- // -------------------------------
LfpChannelDisplayInfo::LfpChannelDisplayInfo(LfpDisplayCanvas* canvas_, int ch) LfpChannelDisplayInfo::LfpChannelDisplayInfo(LfpDisplayCanvas* canvas_, LfpDisplay* display_, int ch)
: LfpChannelDisplay(canvas_, ch) : LfpChannelDisplay(canvas_, display_, ch)
{ {
} }
...@@ -972,4 +1047,67 @@ void LfpChannelDisplayInfo::paint(Graphics& g) ...@@ -972,4 +1047,67 @@ void LfpChannelDisplayInfo::paint(Graphics& g)
} }
\ No newline at end of file
// Event display Options --------------------------------------------------------------------
eventDisplayInterface::eventDisplayInterface(LfpDisplay* display_, LfpDisplayCanvas* canvas_, int chNum):
isEnabled(true), display(display_), canvas(canvas_)
{
channelNumber=chNum;
chButton = new UtilityButton(String(channelNumber+1), Font("Small Text", 13, Font::plain));
chButton->setRadius(5.0f);
chButton->setBounds(4,4,14,14);
chButton->setEnabledState(true);
chButton->setCorners(true, false, true, false);
//chButton.color = display->channelColours[channelNumber*2];
chButton->addListener(this);
addAndMakeVisible(chButton);
checkEnabledState();
}
eventDisplayInterface::~eventDisplayInterface()
{
}
void eventDisplayInterface::checkEnabledState()
{
isEnabled = display->getEventDisplayState(channelNumber);
//repaint();
}
void eventDisplayInterface::buttonClicked(Button* button)
{
checkEnabledState();
if (isEnabled){
display->setEventDisplayState(channelNumber, false);
} else {
display->setEventDisplayState(channelNumber, true);
}
repaint();
}
void eventDisplayInterface::paint(Graphics& g)
{
checkEnabledState();
if (isEnabled){
g.setColour(display->channelColours[channelNumber*2]);
g.fillRoundedRectangle(2,2,18,18,5.0f);
}
//g.drawText(String(channelNumber), 8, 2, 200, 15, Justification::left, false);
}
...@@ -33,6 +33,7 @@ class LfpTimescale; ...@@ -33,6 +33,7 @@ class LfpTimescale;
class LfpDisplay; class LfpDisplay;
class LfpChannelDisplay; class LfpChannelDisplay;
class LfpChannelDisplayInfo; class LfpChannelDisplayInfo;
class eventDisplayInterface;
/** /**
...@@ -68,6 +69,8 @@ public: ...@@ -68,6 +69,8 @@ public:
int getChannelHeight(); int getChannelHeight();
int getNumChannels();
float getXCoord(int chan, int samp); float getXCoord(int chan, int samp);
float getYCoord(int chan, int samp); float getYCoord(int chan, int samp);
...@@ -117,6 +120,9 @@ private: ...@@ -117,6 +120,9 @@ private:
StringArray timebases; StringArray timebases;
StringArray spreads; // option for vertical spacing between channels StringArray spreads; // option for vertical spacing between channels
OwnedArray<eventDisplayInterface> eventDisplayInterfaces;
void refreshScreenBuffer(); void refreshScreenBuffer();
void updateScreenBuffer(); void updateScreenBuffer();
...@@ -161,6 +167,7 @@ public: ...@@ -161,6 +167,7 @@ public:
~LfpDisplay(); ~LfpDisplay();
void setNumChannels(int numChannels); void setNumChannels(int numChannels);
int getNumChannels();
int getTotalHeight(); int getTotalHeight();
...@@ -180,9 +187,17 @@ public: ...@@ -180,9 +187,17 @@ public:
void setChannelHeight(int r); void setChannelHeight(int r);
int getChannelHeight(); int getChannelHeight();
bool setEventDisplayState(int ch, bool state);
bool getEventDisplayState(int ch);
Array<Colour> channelColours;
Array<LfpChannelDisplay*> channels; Array<LfpChannelDisplay*> channels;
Array<LfpChannelDisplayInfo*> channelInfo; Array<LfpChannelDisplayInfo*> channelInfo;
private: private:
int numChans; int numChans;
...@@ -191,7 +206,9 @@ private: ...@@ -191,7 +206,9 @@ private:
LfpDisplayCanvas* canvas; LfpDisplayCanvas* canvas;
Viewport* viewport; Viewport* viewport;
Array<Colour> channelColours; bool eventDisplayEnabled[8];
float range; float range;
...@@ -200,7 +217,7 @@ private: ...@@ -200,7 +217,7 @@ private:
class LfpChannelDisplay : public Component class LfpChannelDisplay : public Component
{ {
public: public:
LfpChannelDisplay(LfpDisplayCanvas*, int channelNumber); LfpChannelDisplay(LfpDisplayCanvas*, LfpDisplay*, int channelNumber);
~LfpChannelDisplay(); ~LfpChannelDisplay();
void paint(Graphics& g); void paint(Graphics& g);
...@@ -226,6 +243,7 @@ public: ...@@ -226,6 +243,7 @@ public:
protected: protected:
LfpDisplayCanvas* canvas; LfpDisplayCanvas* canvas;
LfpDisplay* display;
bool isSelected; bool isSelected;
...@@ -248,10 +266,37 @@ protected: ...@@ -248,10 +266,37 @@ protected:
class LfpChannelDisplayInfo : public LfpChannelDisplay class LfpChannelDisplayInfo : public LfpChannelDisplay
{ {
public: public:
LfpChannelDisplayInfo(LfpDisplayCanvas*, int channelNumber); LfpChannelDisplayInfo(LfpDisplayCanvas*, LfpDisplay*, int channelNumber);
void paint(Graphics& g); void paint(Graphics& g);
}; };
class eventDisplayInterface : public Component,
public Button::Listener
{
public:
eventDisplayInterface(LfpDisplay*, LfpDisplayCanvas*, int chNum);
~eventDisplayInterface();
void paint(Graphics& g);
void buttonClicked(Button* button);
void checkEnabledState();
private:
int channelNumber;
bool isEnabled;
LfpDisplay* display;
LfpDisplayCanvas* canvas;
ScopedPointer<UtilityButton> chButton;
};
#endif // __LFPDISPLAYCANVAS_H_B711873A__ #endif // __LFPDISPLAYCANVAS_H_B711873A__
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment