Isis 3 Programmer Reference
Isis::ScatterPlotWindow Class Reference

Scatter Plot Window. More...

#include <ScatterPlotWindow.h>

Inheritance diagram for Isis::ScatterPlotWindow:
Inheritance graph
Collaboration diagram for Isis::ScatterPlotWindow:
Collaboration graph

Public Types

enum  AlarmRangeUnits { CubeUnits , ScreenUnits }
 This enumeration differentiates alarming a strict cube DN box size from a screen region. More...
 
enum  MenuOptions {
  ShowHideMarkersMenuOption = 1 , ShowHideCurvesMenuOption = 2 , ShowTableMenuOption = 4 , SaveMenuOption = 8 ,
  PrintMenuOption = 16 , TrackMenuOption = 32 , BackgroundSwitchMenuOption = 64 , ShowHideGridMenuOption = 128 ,
  RenameLabelsMenuOption = 256 , SetDisplayRangeMenuOption = 512 , ResetScaleMenuOption = 1024 , ClearPlotMenuOption = 2048 ,
  DefaultHelpMenuOption = 4096 , LineFitMenuOption = 8192 , ConfigurePlotMenuOption = 16384 , AllMenuOptions
}
 There is a menu option for everything in the plot window's menu. More...
 

Public Slots

void forgetCubes ()
 This causes the window to lose it's pointers to the input cubes.
 
void clearPlot ()
 This method completely clears the plot of all plot items.
 
void configurePlotCurves ()
 This method creates a CubePlotCurveConfigureDialog object.
 
void createBestFitLine ()
 This method prompts the user to select the best fit line criterea.
 
void printPlot ()
 Provides printing support of the plot image.
 
void changePlotLabels ()
 This method creates the dialog box which allows the user to relabel the plot window.
 
void savePlot ()
 This method allows the user to save the plot as a png, jpg, or tif image file.
 
void setDefaultRange ()
 Resets the x/y min/max to the defaults.
 
void setLabels ()
 Makes the user specified changes to the plot labels.
 
void setUserValues ()
 This method sets the scale for the axis according to the user specified numbers.
 
void showHideAllMarkers ()
 Shows/Hides all the markers(symbols)
 
void showHideAllCurves ()
 This method shows or hides all of the curves in the plotWindow.
 
void resetScale ()
 Sets plot scale back to the defaults.
 
void showHideGrid ()
 This method hides/shows the grid on the plotWindow and changes the text for the action.
 
void showHelp ()
 This method creates and shows the help dialog box for the plot window.
 
void showTable ()
 This method is called from the showTable action on the tool bar There are some checks done to make sure there are data to fill the table.
 
void switchBackground ()
 This method toggles the plot background color between black and white.
 
void trackerEnabled ()
 Enables the plot mouse tracker.
 
void scheduleFillTable ()
 Fills in the table with the data from the current curves in the plotWindow once all current actions/activations are done.
 
void fillTable ()
 Fills in the table with the data from the current curves in the plotWindow immediately.
 

Signals

void closed ()
 Emitted when there is a close event on this window that will be accepted.
 
void plotChanged ()
 Emitted every time there is a change to the plot window.
 
void requestFillTable ()
 

Public Member Functions

 ScatterPlotWindow (QString title, Cube *xAxisCube, int xAxisBand, int xAxisBinCount, Cube *yAxisCube, int yAxisBand, int yAxisBinCount, QwtInterval sampleRange, QwtInterval lineRange, QWidget *parent)
 Create a scatter plot window with the given data.
 
bool alarmingPlot () const
 This indicates if we are alarming from viewport to plot.
 
bool alarmingViewport () const
 This indicates if we are alarming from plot to viewport.
 
QPair< int, int > alarmPlotBoxSize () const
 This is the sample/line box sizes for alarming from viewport to plot.
 
AlarmRangeUnits alarmViewportUnits () const
 This is the active alarming units for plot->viewport.
 
QPair< int, int > alarmViewportScreenBoxSize () const
 This is the alarming box size for plot->viewport in screen units.
 
QPair< double, double > alarmViewportDnBoxSize () const
 This is the alarming box size for plot->viewport in cube units (number of samples/lines).
 
bool eventFilter (QObject *o, QEvent *e)
 We override events done on the plot canvas for alarming purposes.
 
virtual void paint (MdiCubeViewport *vp, QPainter *painter)
 If the viewport is showing the x axis cube data or y axis cube data, and alarming is enabled, this paints alarmed values from the plot onto the viewport.
 
void setMousePosition (MdiCubeViewport *vp, QPoint mouseLoc)
 Saves the current mouse position in the viewport so that the plot can be alarmed around that position.
 
void setAlarmingPlot (bool)
 This enables or disables alarming viewport->plot.
 
void setAlarmingViewport (bool)
 This enables or disables alarming plot->viewport.
 
void setAlarmPlotBoxSize (int, int)
 This sets the box size for alarming viewport->plot in cube samples/lines.
 
void setAlarmViewportUnits (AlarmRangeUnits)
 This sets the units to be used for alarming plot->viewport.
 
void setAlarmViewportScreenBoxSize (int, int)
 This sets the screen pixel box size for alarming plot->viewport.
 
void setAlarmViewportDnBoxSize (double, double)
 This sets the cube DN box size for alarming plot->viewport.
 
virtual void add (CubePlotCurve *pc)
 This method adds the curves to the plot.
 
virtual void clearPlotCurves ()
 This method also clears the plot of all plot items, but does not call the table delete stuff This method is called from plotTool each time the changePlot() method is called.
 
bool canAdd (CubePlotCurve *curveToTest) const
 This method tests whethere or not a CubePlotCurve can be successfully added to this window.
 
QColor plotBackgroundColor () const
 Returns the plot's background color.
 
QList< CubePlotCurve * > plotCurves ()
 Get a comprehensive list of the plot curves inside of this plot window, excluding plot curves that are in the process of being removed.
 
QList< const CubePlotCurve * > plotCurves () const
 Get a comprehensive const list of the plot curves inside of this plot window, excluding plot curves that are in the process of being removed.
 
QList< QwtPlotSpectrogram * > plotSpectrograms ()
 Get a comprehensive list of the scatter plots (spectrograms) inside of this plot window.
 
QList< const QwtPlotSpectrogram * > plotSpectrograms () const
 Get a comprehensive const list of the scatter plots (spectrograms) inside of this plot window.
 
QString plotTitle () const
 Returns the plot title.
 
bool userCanAddCurves () const
 Ask if a user action can add this curve to this window in general.
 
PlotCurve::Units xAxisUnits () const
 This is the data-type of the curves' x data in this plot window.
 
PlotCurve::Units yAxisUnits () const
 This is the data-type of the curves' y data in this plot window.
 
void replot ()
 Reset the scale of the plot, replot it and emit plot changed.
 
void setAxisLabel (int axisId, QString title)
 Sets the plots given axis title to the given string.
 
void setPlotBackground (QColor c)
 Sets the plot background color to the given color.
 
void setPlotTitle (QString pt)
 Sets the plot title to the given string.
 
void setUserCanAddCurves (bool)
 Allow or disallow users from manually putting curves into this plot window through either copy-and-paste or drag-and-drop.
 
void showWindow ()
 Shows the plot window, and raises it to the front of any overlapping sibling widgets.
 
virtual void update (MdiCubeViewport *activeViewport)
 This is provided to allow children to react to tool updates.
 

Static Public Member Functions

static QString defaultWindowTitle ()
 This is the typical suffix for plot windows, it's here in case we want to update all plot windows to have a different ending than just 'Plot' on them (for example, 'Plot Window').
 
static QString settingsFileName (QString objectTitle)
 

Protected Slots

void colorPlot ()
 This method switches the color mode of the scatter plot from black and white to color and visa versa.
 
void showHideContour ()
 This method hides or displays the contour lines on the spectrogram.
 

Protected Member Functions

void createWidgets (MenuOptions optionsToProvide)
 This method is called by the constructor to create the plot, legend.
 
void disableAxisAutoScale ()
 This turns off scaling the x/y axes automatically.
 
virtual void dragEnterEvent (QDragEnterEvent *event)
 When a user drags data into our plot window, we need to indicate whether or not this data is compatible with this window.
 
virtual void dropEvent (QDropEvent *event)
 This is called when a user drops data into our window.
 
void mousePressEvent (QObject *object, QMouseEvent *e)
 This is a helper method for the eventFilter() method.
 
QwtPlotplot ()
 Get the plot encapsulated by this PlotWindow.
 
void setMenus (QList< QMenu * > menus, QList< QAction * > actions)
 Sets up the menus added from a parent object.
 
QwtPlotZoomer * zoomer ()
 Get this window's plot's zoomer.
 
QString settingsFileName () const
 
virtual void closeEvent (QCloseEvent *event)
 This method is overridden so that we can be sure to write the current settings of the Main window.
 
virtual void readSettings (QSize defaultSize=QSize())
 This method ensure that the settings get written even if the Main window was only hidden, not closed.
 

Private Slots

void configureAlarming ()
 Give the users an alarm config dialog to change the alarming settings.
 
void autoScaleCheckboxToggled ()
 This is a helper method for the set scale configuration dialog.
 
void onClipboardChanged ()
 This slot will be called when the system clipboard is changed.
 
void pasteCurve ()
 When the user pastes a curve try to put it into this plot window.
 

Private Member Functions

bool isXCube (MdiCubeViewport *vp) const
 Returns true if the viewport's cube is the cube currently being used on the x-axis.
 
bool isYCube (MdiCubeViewport *vp) const
 Returns true if the viewport's cube is the cube currently being used on the y-axis.
 
void mouseMoveEvent (QMouseEvent *e)
 When the mosue moves, this updates the alarming information and causes repaints on the cube viewports in order to show the alarming appropriately.
 
void mouseLeaveEvent (QMouseEvent *e)
 When the mouse leaves the plot canvas we disable all alarming from plot->viewport.
 
void updateContourPen ()
 This sets the contour pen to an appropriate color based on the color of the plot (B/W v.
 
QPair< double, double > findDataRange (int axisId) const
 This calculates the data range of the specified axis (works with xBottom and yLeft only).
 
bool userCanAddCurve (const QMimeData *curve)
 Ask if a user action can add this curve to this window.
 
void updateVisibility (PlotCurve *curve)
 This method sets the visibility states in the curve (and it's symbols) to match with this window's current visibility settings.
 
void setupDefaultMenu (MenuOptions optionsToProvide)
 The user can add menu items from parent classes, but there are some menu items that are common between many types of plot windows.
 
virtual void writeSettings () const
 This method is called when the Main window is closed or hidden to write the size and location settings to a config file in the user's home directory.
 

Static Private Member Functions

static bool numericStringLessThan (QString left, QString right)
 

Private Attributes

QwtPlotSpectrogram * m_spectrogram
 This is the scatter plot's Qwt plot item.
 
QPointer< QActionm_colorize
 The action for switching the scatter plot from B/W to color.
 
QPointer< QActionm_contour
 The action for switching on and off contour lines.
 
Cubem_xAxisCube
 The cube associated with the X-Axis DN values.
 
Cubem_yAxisCube
 The cube associated with the Y-Axis DN values.
 
QPair< double, double > m_xCubeDnAlarmRange
 The DN range of the X-Axis Cube to be alarmed when painting.
 
QPair< double, double > m_yCubeDnAlarmRange
 The DN range of the Y-Axis Cube to be alarmed when painting.
 
int m_xAxisCubeBand
 The band on the X-Axis cube used for the scatter plot.
 
int m_yAxisCubeBand
 The band on the Y-Axis cube used for the scatter plot.
 
QwtInterval m_sampleRange
 The sample range (1-based inclusive) of data used for the scatter plot.
 
QwtInterval m_lineRange
 The line range (1-based inclusive) of data used for the scatter plot.
 
bool m_alarmPlot
 Alarm onto plot... aka alarm viewport->plot.
 
bool m_alarmViewport
 Alarm onto viewport... aka alarm plot->viewport.
 
int m_alarmPlotSamples
 Alarm viewport->plot viewport sample box size.
 
int m_alarmPlotLines
 Alarm viewport->plot viewport line box size.
 
AlarmRangeUnits m_alarmViewportUnits
 Alarm plot->viewport current units.
 
int m_alarmViewportScreenWidth
 Alarm plot->viewport X (screen pixels) box size.
 
int m_alarmViewportScreenHeight
 Alarm plot->viewport Y (screen pixels) box size.
 
double m_alarmViewportXDnBoxSize
 Alarm plot->viewport X (Cube DN) box size.
 
double m_alarmViewportYDnBoxSize
 Alarm plot->viewport Y (Cube DN) box size.
 
QWidgetm_parent
 Parent widget.
 
QwtPlotZoomer * m_zoomer
 Plot Zoomer.
 
QwtPlotGrid * m_grid
 Plot grid lines.
 
QCheckBox * m_autoScaleCheckBox
 Set Scale Dialog's checkbox for enabling automatic scaling on x & y.
 
QCheckBox * m_xLogCheckBox
 Set Scale Dialog's checkbox for using logarithmic scale for the x axis.
 
QCheckBox * m_yLogCheckBox
 Set Scale Dialog's checkbox for using logarithmic scale for the y axis.
 
QLineEdit * m_xMinEdit
 Set Scale Dialog's edit for the min X-axis value.
 
QLineEdit * m_xMaxEdit
 Set Scale Dialog's edit for the max X-axis value.
 
QLineEdit * m_yMinEdit
 Set Scale Dialog's edit for the min Y-axis value.
 
QLineEdit * m_yMaxEdit
 Set Scale Dialog's edit for the max Y-axis value.
 
QLineEdit * m_xAxisText
 Set Labels Dialog's edit for the x-axis label.
 
QLineEdit * m_yAxisText
 Set Labels Dialog's edit for the y-axis label.
 
QLineEdit * m_plotTitleText
 Set Labels Dialog's edit for the plot title.
 
QMenuBar * m_menubar
 Plot window's menu bar.
 
QActionm_pasteAct
 This is the paste action in the edit menu to paste a curve into the plot window.
 
QPointer< QActionm_action
 Plot window's action.
 
QPointer< QActionm_showHideAllCurves
 Hide all curves action.
 
QPointer< QActionm_showHideAllMarkers
 Hide all markers action.
 
QPointer< QActionm_showHideGrid
 Show plot grid lines action.
 
PlotCurve::Units m_xAxisUnits
 The units of the data on the x-bottom axis.
 
PlotCurve::Units m_yAxisUnits
 The units of the data on the y-left axis.
 
bool m_allowUserToAddCurves
 Is the window showing the curve markers?
 
bool m_autoscaleAxes
 True if we are autoscaling the x-bottom and y-left axes.
 
QwtPlotm_plot
 The plot in this window.
 
QwtLegend * m_legend
 The legend inserted in this plot.
 
bool m_plotXLogScale
 Tracks if the plot X axis is using a log (true) or linear (false) scale.
 
bool m_plotYLogScale
 Tracks if the plot Y axis is using a log (true) or linear (false) scale.
 
TableMainWindowm_tableWindow
 Table window.
 
QToolBarm_toolBar
 Tool bar on the plot window.
 
bool m_scheduledFillTable
 

Detailed Description

Scatter Plot Window.

Author
????-??-?? Stacy Alley
History

2014-06-23 Ian Humphrey - Modified hard coded /usgs/cpkgs/ paths to relative pathnames. Fixes #2054.

2014-07-31 Ian Humphrey - Removed ConfigurePlotMenuOption for scatter plot window. References #2089.

Definition at line 28 of file ScatterPlotWindow.h.

Member Enumeration Documentation

◆ AlarmRangeUnits

This enumeration differentiates alarming a strict cube DN box size from a screen region.

Enumerator
CubeUnits 

Alarming is a DN range around the mouse.

ScreenUnits 

Alarming is a visible area around the mouse.

Definition at line 36 of file ScatterPlotWindow.h.

◆ MenuOptions

There is a menu option for everything in the plot window's menu.

This is provided so that you can enable/disable any given option.

Enumerator
ShowHideMarkersMenuOption 

This option is titled 'Hide All Symbols' which hides all markers.

ShowHideCurvesMenuOption 

This option is titled 'Hide All Curves' which makes all curves invisible.

ShowTableMenuOption 

This option brings up the table.

No table will be available without this option.

SaveMenuOption 

This option exports the plot into a standard image format.

No conversion to a standard image format file will be available without this option, but printing will still be available.

PrintMenuOption 

This option sends the plot to a printer.

TrackMenuOption 

This option enables mouse tracking on the plot area (displays next to the mouse which x/y point you are hovering over).

This option is by default disabled.

BackgroundSwitchMenuOption 

This option enables the ability for a user to change the background color of the plot from black to white.

ShowHideGridMenuOption 

This option enables the ability for a user to enable a grid over the plot area.

RenameLabelsMenuOption 

This option enables the ability for a user to change the x/y axis labels and plot title.

SetDisplayRangeMenuOption 

This option allows the user to set the x/y axis display value ranges.

ResetScaleMenuOption 

This option provides the user with an alternative zoom out button.

ClearPlotMenuOption 

This option allows the user to delete all of the data inside the plot.

If you don't want the user deleting a custom plot item, you should disable this option.

DefaultHelpMenuOption 

Not implemented.

LineFitMenuOption 

This option allows the user to create a best fit line for any of the scatter plot data or cube plot curve data in the window.

This allows the user to create new plot curves.

ConfigurePlotMenuOption 

This option allows the user to change the curve name, color, style size, and symbol of the curve.

AllMenuOptions 

This is all of the available menu options.

Definition at line 96 of file PlotWindow.h.

Constructor & Destructor Documentation

◆ ScatterPlotWindow()

Isis::ScatterPlotWindow::ScatterPlotWindow ( QString title,
Cube * xAxisCube,
int xAxisBand,
int xAxisBinCount,
Cube * yAxisCube,
int yAxisBand,
int yAxisBinCount,
QwtInterval sampleRange,
QwtInterval lineRange,
QWidget * parent )

Create a scatter plot window with the given data.

This will fully populate the window with scatter plot data automatically.

Parameters
titleThe window title and plot title
xAxisCubeThe cube to use for reading X values
xAxisBandThe band of the x axis cube to read
xAxisBinCountThe resolution of the x axis data
yAxisCubeThe cube to use for reading X values
yAxisBandThe band of the y axis cube to read
yAxisBinCountThe resolution of the y axis data
sampleRangeThe sample range, inclusive 1-based, to read data from
lineRangeThe line range, inclusive 1-based, to read data from
parentThe Qt-parent relationship parent widget

Definition at line 45 of file ScatterPlotWindow.cpp.

References colorPlot(), configureAlarming(), Isis::PlotWindow::disableAxisAutoScale(), Isis::Cube::fileName(), m_alarmPlot, m_alarmPlotLines, m_alarmPlotSamples, m_alarmViewport, m_alarmViewportScreenHeight, m_alarmViewportScreenWidth, m_alarmViewportUnits, m_alarmViewportXDnBoxSize, m_alarmViewportYDnBoxSize, m_colorize, m_contour, m_lineRange, m_sampleRange, m_spectrogram, m_xAxisCube, m_xAxisCubeBand, m_xCubeDnAlarmRange, m_yAxisCube, m_yAxisCubeBand, m_yCubeDnAlarmRange, Isis::Null, Isis::PlotWindow::plot(), Isis::PlotWindow::replot(), ScreenUnits, showHideContour(), Isis::ScatterPlotData::xCubeMax(), Isis::ScatterPlotData::xCubeMin(), Isis::ScatterPlotData::yCubeMax(), Isis::ScatterPlotData::yCubeMin(), and Isis::PlotWindow::zoomer().

◆ ~ScatterPlotWindow()

Isis::ScatterPlotWindow::~ScatterPlotWindow ( )
virtual

Definition at line 183 of file ScatterPlotWindow.cpp.

Member Function Documentation

◆ add()

◆ alarmingPlot()

bool Isis::ScatterPlotWindow::alarmingPlot ( ) const

This indicates if we are alarming from viewport to plot.

Returns
True if alarming viewport->plot, false otherwise

Definition at line 209 of file ScatterPlotWindow.cpp.

References m_alarmPlot.

Referenced by setMousePosition().

◆ alarmingViewport()

bool Isis::ScatterPlotWindow::alarmingViewport ( ) const

This indicates if we are alarming from plot to viewport.

Returns
True if alarming plot->viewport, false otherwise

Definition at line 219 of file ScatterPlotWindow.cpp.

References m_alarmViewport.

Referenced by mouseMoveEvent(), and paint().

◆ alarmPlotBoxSize()

QPair< int, int > Isis::ScatterPlotWindow::alarmPlotBoxSize ( ) const

This is the sample/line box sizes for alarming from viewport to plot.

Returns
Sample Box Size, Line Box Size

Definition at line 229 of file ScatterPlotWindow.cpp.

References m_alarmPlotLines, and m_alarmPlotSamples.

◆ alarmViewportDnBoxSize()

QPair< double, double > Isis::ScatterPlotWindow::alarmViewportDnBoxSize ( ) const

This is the alarming box size for plot->viewport in cube units (number of samples/lines).

If the current units are not cube units then this is not actively alarming the given box. These values are valid even when alarming is a screen pixel box, just not use, and they are never translated/re-calculated based on the conversion from screen pixels to cube pixels.

Returns
The sample/line alarming box size

Definition at line 271 of file ScatterPlotWindow.cpp.

References m_alarmViewportXDnBoxSize, and m_alarmViewportYDnBoxSize.

◆ alarmViewportScreenBoxSize()

QPair< int, int > Isis::ScatterPlotWindow::alarmViewportScreenBoxSize ( ) const

This is the alarming box size for plot->viewport in screen units.

If the current units are not screen units, this is not actively alarming the given box. These values are valid even when alarming is a Cube DN box, just not use, and they are never translated/re-calculated based on the conversion from screen pixels to cube pixels.

Returns
The screen pixel alarming box size

Definition at line 255 of file ScatterPlotWindow.cpp.

References m_alarmViewportScreenHeight, and m_alarmViewportScreenWidth.

◆ alarmViewportUnits()

ScatterPlotWindow::AlarmRangeUnits Isis::ScatterPlotWindow::alarmViewportUnits ( ) const

This is the active alarming units for plot->viewport.

We either alarm a screen pixel box size or a cube sample/line range around the mouse.

Returns
The units used for alarming plot->viewport

Definition at line 241 of file ScatterPlotWindow.cpp.

References m_alarmViewportUnits.

◆ autoScaleCheckboxToggled

void Isis::PlotWindow::autoScaleCheckboxToggled ( )
privateslotinherited

This is a helper method for the set scale configuration dialog.

This enables or disables options inside of the dialog when a checkbox is clicked in the dialog. This does not change the state of the plot or plot zoomer.

Definition at line 1674 of file PlotWindow.cpp.

References Isis::PlotWindow::m_autoScaleCheckBox, Isis::PlotWindow::m_xMaxEdit, Isis::PlotWindow::m_xMinEdit, Isis::PlotWindow::m_yMaxEdit, and Isis::PlotWindow::m_yMinEdit.

Referenced by Isis::PlotWindow::setDefaultRange().

◆ canAdd()

bool Isis::PlotWindow::canAdd ( CubePlotCurve * curveToTest) const
inherited

This method tests whethere or not a CubePlotCurve can be successfully added to this window.

Plot curves with mismatched X/Y data from the plot's x/y axis types can not be added to the window. This does not test whether or not a user is allowed to add the curve manually, just if the curve can be added programatically.

Parameters
curveToTestThe plot curve to test for compatibility with this window
Returns
True if the curve is compatible with this window, false otherwise

Definition at line 305 of file PlotWindow.cpp.

References Isis::PlotWindow::m_xAxisUnits, and Isis::PlotWindow::m_yAxisUnits.

Referenced by Isis::PlotWindow::add(), and Isis::PlotWindow::userCanAddCurve().

◆ changePlotLabels

void Isis::PlotWindow::changePlotLabels ( )
slotinherited

This method creates the dialog box which allows the user to relabel the plot window.

Definition at line 855 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot, Isis::PlotWindow::m_plotTitleText, Isis::PlotWindow::m_xAxisText, Isis::PlotWindow::m_yAxisText, Isis::PlotWindow::plot(), and Isis::PlotWindow::setLabels().

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ clearPlot

void Isis::PlotWindow::clearPlot ( )
slotinherited

This method completely clears the plot of all plot items.

i.e. curves and markers, which also deletes the legend also calls the necessary method to delete the table stuff

Definition at line 492 of file PlotWindow.cpp.

References Isis::PlotWindow::clearPlotCurves(), Isis::PlotWindow::m_tableWindow, and Isis::TableMainWindow::table().

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ clearPlotCurves()

void Isis::PlotWindow::clearPlotCurves ( )
virtualinherited

This method also clears the plot of all plot items, but does not call the table delete stuff This method is called from plotTool each time the changePlot() method is called.

Definition at line 540 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot, and Isis::PlotWindow::replot().

Referenced by Isis::PlotWindow::clearPlot().

◆ closed

void Isis::PlotWindow::closed ( )
signalinherited

Emitted when there is a close event on this window that will be accepted.

Referenced by Isis::PlotWindow::eventFilter().

◆ closeEvent()

void Isis::MainWindow::closeEvent ( QCloseEvent * event)
protectedvirtualinherited

This method is overridden so that we can be sure to write the current settings of the Main window.

Parameters
event

Reimplemented in Isis::TableMainWindow, and Isis::ViewportMainWindow.

Definition at line 37 of file MainWindow.cpp.

References Isis::MainWindow::writeSettings().

Referenced by Isis::TableMainWindow::closeEvent(), and Isis::ViewportMainWindow::closeEvent().

◆ colorPlot

void Isis::ScatterPlotWindow::colorPlot ( )
protectedslot

This method switches the color mode of the scatter plot from black and white to color and visa versa.

Definition at line 551 of file ScatterPlotWindow.cpp.

References m_colorize, m_spectrogram, Isis::PlotWindow::plot(), Isis::PlotWindow::replot(), and updateContourPen().

Referenced by ScatterPlotWindow().

◆ configureAlarming

void Isis::ScatterPlotWindow::configureAlarming ( )
privateslot

Give the users an alarm config dialog to change the alarming settings.

Definition at line 711 of file ScatterPlotWindow.cpp.

Referenced by ScatterPlotWindow().

◆ configurePlotCurves

void Isis::PlotWindow::configurePlotCurves ( )
slotinherited

This method creates a CubePlotCurveConfigureDialog object.

When there are no curves in this PlotWindow, the dialog will not be created.

Definition at line 508 of file PlotWindow.cpp.

References Isis::PlotWindow::plotChanged(), and Isis::PlotWindow::plotCurves().

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ createBestFitLine

void Isis::PlotWindow::createBestFitLine ( )
slotinherited

This method prompts the user to select the best fit line criterea.

The PlotWindowBestFitDialog will create the best fit line automatically when the user asks for one, so we don't need to worry about doing any more than showing a dialog here.

Definition at line 529 of file PlotWindow.cpp.

References Isis::PlotWindow::plot().

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ createWidgets()

void Isis::PlotWindow::createWidgets ( MenuOptions optionsToProvide)
protectedinherited

This method is called by the constructor to create the plot, legend.

zoomer, and main window.

Parameters
optionsToProvideThis is a bit-flag containing information on which menu options to give the user/put in the GUI.

Definition at line 145 of file PlotWindow.cpp.

References Isis::PlotWindow::m_grid, Isis::PlotWindow::m_legend, Isis::PlotWindow::m_plot, Isis::PlotWindow::m_zoomer, and Isis::PlotWindow::setupDefaultMenu().

Referenced by Isis::PlotWindow::PlotWindow().

◆ defaultWindowTitle()

QString Isis::PlotWindow::defaultWindowTitle ( )
staticinherited

This is the typical suffix for plot windows, it's here in case we want to update all plot windows to have a different ending than just 'Plot' on them (for example, 'Plot Window').

Returns
A string to be appended to your window title

Definition at line 1809 of file PlotWindow.cpp.

Referenced by Isis::HistogramTool::createWindow(), Isis::SpatialPlotTool::createWindow(), and Isis::SpectralPlotTool::createWindow().

◆ disableAxisAutoScale()

void Isis::PlotWindow::disableAxisAutoScale ( )
protectedinherited

This turns off scaling the x/y axes automatically.

Use this if you have a very specific axis range you want to use, but keep in mind that users (potentially) have an option to re-enable axis auto scaling if they want to.

Definition at line 1663 of file PlotWindow.cpp.

References Isis::PlotWindow::m_autoscaleAxes.

Referenced by ScatterPlotWindow().

◆ dragEnterEvent()

void Isis::PlotWindow::dragEnterEvent ( QDragEnterEvent * event)
protectedvirtualinherited

When a user drags data into our plot window, we need to indicate whether or not this data is compatible with this window.

This checks userCanAddCurve() on the drag & drop data and allows or disallowed the event accordingly.

Parameters
eventThe drag event to test

Definition at line 1822 of file PlotWindow.cpp.

References Isis::PlotWindow::m_legend, and Isis::PlotWindow::userCanAddCurve().

◆ dropEvent()

void Isis::PlotWindow::dropEvent ( QDropEvent * event)
protectedvirtualinherited

This is called when a user drops data into our window.

The dragEnterEvent() must have said that this curve is compatible with this window. This provides all of the available options to the user (if any) set by the creator of the drag & drop event (i.e. whether or not we can move or just copy). If there are options, we create a context menu - otherwise the default action is taken.

Parameters
eventThe drop event containing the curve to put into the current window.

Definition at line 1843 of file PlotWindow.cpp.

References Isis::PlotWindow::add(), Isis::PlotWindow::m_allowUserToAddCurves, and Isis::PlotWindow::plotChanged().

◆ eventFilter()

bool Isis::ScatterPlotWindow::eventFilter ( QObject * o,
QEvent * e )
virtual

We override events done on the plot canvas for alarming purposes.

This method will forward mouse moves and leaves to the appropriate methods.

Parameters
oThe object on which the event happened
eThe event that triggered this method call
Returns
True if no more processing should happen with this event

Reimplemented from Isis::PlotWindow.

Definition at line 285 of file ScatterPlotWindow.cpp.

References Isis::PlotWindow::eventFilter(), mouseLeaveEvent(), mouseMoveEvent(), and Isis::PlotWindow::plot().

◆ fillTable

◆ findDataRange()

QPair< double, double > Isis::PlotWindow::findDataRange ( int axisId) const
privateinherited

This calculates the data range of the specified axis (works with xBottom and yLeft only).

This is used to provide unit context (band #'s shouldn't ever pad) and to fix the lack of an axis when only one value exists (if there is only one x-value, this will always pad with +/- 0.5).

Parameters
axisIdThis must be yLeft or xBottom
Returns
The double range of the data contained by the given axis.

Definition at line 1721 of file PlotWindow.cpp.

References Isis::PlotWindow::plotCurves().

Referenced by Isis::PlotWindow::resetScale().

◆ forgetCubes

void Isis::ScatterPlotWindow::forgetCubes ( )
slot

This causes the window to lose it's pointers to the input cubes.

When a viewport is closed, this will prevent using the cube pointers still for alarming.

Definition at line 540 of file ScatterPlotWindow.cpp.

References m_xAxisCube, and m_yAxisCube.

◆ isXCube()

bool Isis::ScatterPlotWindow::isXCube ( MdiCubeViewport * vp) const
private

Returns true if the viewport's cube is the cube currently being used on the x-axis.

Parameters
vpThe viewport to test for a cube match
Returns
True if the vp is showing the x axis cube data

Definition at line 607 of file ScatterPlotWindow.cpp.

References m_xAxisCube, and m_xAxisCubeBand.

Referenced by paint(), and setMousePosition().

◆ isYCube()

bool Isis::ScatterPlotWindow::isYCube ( MdiCubeViewport * vp) const
private

Returns true if the viewport's cube is the cube currently being used on the y-axis.

Parameters
vpThe viewport to test for a cube match
Returns
True if the vp is showing the y axis cube data

Definition at line 621 of file ScatterPlotWindow.cpp.

References m_yAxisCube, and m_yAxisCubeBand.

Referenced by paint(), and setMousePosition().

◆ mouseLeaveEvent()

void Isis::ScatterPlotWindow::mouseLeaveEvent ( QMouseEvent * e)
private

When the mouse leaves the plot canvas we disable all alarming from plot->viewport.

Parameters
eThe event that caused this method to be called

Definition at line 683 of file ScatterPlotWindow.cpp.

References m_xCubeDnAlarmRange, m_yCubeDnAlarmRange, Isis::Null, and Isis::PlotWindow::plotChanged().

Referenced by eventFilter().

◆ mouseMoveEvent()

void Isis::ScatterPlotWindow::mouseMoveEvent ( QMouseEvent * e)
private

When the mosue moves, this updates the alarming information and causes repaints on the cube viewports in order to show the alarming appropriately.

Parameters
eThe event that caused this method to be called

Definition at line 635 of file ScatterPlotWindow.cpp.

References alarmingViewport(), m_alarmViewportScreenHeight, m_alarmViewportScreenWidth, m_alarmViewportUnits, m_alarmViewportXDnBoxSize, m_alarmViewportYDnBoxSize, m_xCubeDnAlarmRange, m_yCubeDnAlarmRange, Isis::Null, Isis::PlotWindow::plot(), Isis::PlotWindow::plotChanged(), and ScreenUnits.

Referenced by eventFilter().

◆ mousePressEvent()

void Isis::PlotWindow::mousePressEvent ( QObject * object,
QMouseEvent * event )
protectedinherited

This is a helper method for the eventFilter() method.

When a mouse press event is seen, this handles it. For example, if the user right clicks and the clipboard contains compatible data then this will give a paste option.

Parameters
objectThe object which was pressed
eventThe mouse event which contains button information

Definition at line 1627 of file PlotWindow.cpp.

References Isis::PlotWindow::pasteCurve(), and Isis::PlotWindow::userCanAddCurve().

Referenced by Isis::PlotWindow::eventFilter().

◆ numericStringLessThan()

bool Isis::PlotWindow::numericStringLessThan ( QString left,
QString right )
staticprivateinherited

Definition at line 1767 of file PlotWindow.cpp.

◆ onClipboardChanged

void Isis::PlotWindow::onClipboardChanged ( )
privateslotinherited

This slot will be called when the system clipboard is changed.

Definition at line 1685 of file PlotWindow.cpp.

References Isis::PlotWindow::m_pasteAct, and Isis::PlotWindow::userCanAddCurve().

Referenced by Isis::PlotWindow::PlotWindow().

◆ paint()

void Isis::ScatterPlotWindow::paint ( MdiCubeViewport * vp,
QPainter * painter )
virtual

If the viewport is showing the x axis cube data or y axis cube data, and alarming is enabled, this paints alarmed values from the plot onto the viewport.

Parameters
vpThe viewport that might need to be alarmed/painted red
painterThe painter to paint with

Reimplemented from Isis::PlotWindow.

Definition at line 317 of file ScatterPlotWindow.cpp.

References alarmingViewport(), Isis::ViewportBuffer::bufferXYRect(), Isis::ViewportBuffer::getLine(), Isis::IsSpecial(), isXCube(), isYCube(), m_lineRange, m_sampleRange, m_xAxisCube, m_xAxisCubeBand, m_xCubeDnAlarmRange, m_yAxisCube, m_yAxisCubeBand, m_yCubeDnAlarmRange, Isis::Null, Isis::PlotWindow::paint(), Isis::Cube::pixelType(), Isis::Cube::read(), and Isis::ViewportBuffer::working().

◆ pasteCurve

void Isis::PlotWindow::pasteCurve ( )
privateslotinherited

When the user pastes a curve try to put it into this plot window.

This shouldn't be called when the curve on the system clipboard isn't compatible.

Definition at line 1696 of file PlotWindow.cpp.

References Isis::PlotWindow::add(), Isis::PlotWindow::m_allowUserToAddCurves, and Isis::PlotWindow::plotChanged().

Referenced by Isis::PlotWindow::mousePressEvent(), and Isis::PlotWindow::setupDefaultMenu().

◆ plot()

◆ plotBackgroundColor()

QColor Isis::PlotWindow::plotBackgroundColor ( ) const
inherited

Returns the plot's background color.

Returns
QColor

Definition at line 317 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

◆ plotChanged

◆ plotCurves() [1/2]

QList< CubePlotCurve * > Isis::PlotWindow::plotCurves ( )
inherited

Get a comprehensive list of the plot curves inside of this plot window, excluding plot curves that are in the process of being removed.

Returns
The plot curves contained inside of this plot window

Definition at line 328 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

Referenced by Isis::PlotWindow::configurePlotCurves(), Isis::PlotWindow::fillTable(), Isis::PlotWindow::findDataRange(), Isis::PlotWindow::paint(), and Isis::PlotWindow::showTable().

◆ plotCurves() [2/2]

QList< const CubePlotCurve * > Isis::PlotWindow::plotCurves ( ) const
inherited

Get a comprehensive const list of the plot curves inside of this plot window, excluding plot curves that are in the process of being removed.

Returns
The const plot curves contained inside of this plot window

Definition at line 354 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

◆ plotSpectrograms() [1/2]

QList< QwtPlotSpectrogram * > Isis::PlotWindow::plotSpectrograms ( )
inherited

Get a comprehensive list of the scatter plots (spectrograms) inside of this plot window.

Returns
The spectrograms (scatter plots) contained inside of this plot window

Definition at line 381 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

◆ plotSpectrograms() [2/2]

QList< const QwtPlotSpectrogram * > Isis::PlotWindow::plotSpectrograms ( ) const
inherited

Get a comprehensive const list of the scatter plots (spectrograms) inside of this plot window.

Returns
The const spectrograms (scatter plots) contained inside of this plot window

Definition at line 409 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

◆ plotTitle()

QString Isis::PlotWindow::plotTitle ( ) const
inherited

Returns the plot title.

Returns
QwtText

Definition at line 241 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

◆ printPlot

void Isis::PlotWindow::printPlot ( )
slotinherited

Provides printing support of the plot image.

Definition at line 573 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ readSettings()

void Isis::MainWindow::readSettings ( QSize defaultSize = QSize())
protectedvirtualinherited

This method ensure that the settings get written even if the Main window was only hidden, not closed.

Parameters
eventThis method is called from the constructor so that when the Main window is created, it know's it's size and location.

Reimplemented in Isis::MosaicMainWindow.

Definition at line 80 of file MainWindow.cpp.

Referenced by Isis::PlotWindow::PlotWindow(), Isis::TableMainWindow::TableMainWindow(), and Isis::ViewportMainWindow::ViewportMainWindow().

◆ replot()

void Isis::PlotWindow::replot ( )
inherited

◆ resetScale

◆ savePlot

void Isis::PlotWindow::savePlot ( )
slotinherited

This method allows the user to save the plot as a png, jpg, or tif image file.

Definition at line 606 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ scheduleFillTable

void Isis::PlotWindow::scheduleFillTable ( )
slotinherited

Fills in the table with the data from the current curves in the plotWindow once all current actions/activations are done.

This is provided for performance reasons - re-plotting 4 curves only requires one fillTable at the end, instead of after each curve change.

Definition at line 1400 of file PlotWindow.cpp.

Referenced by Isis::PlotWindow::PlotWindow().

◆ setAlarmingPlot()

void Isis::ScatterPlotWindow::setAlarmingPlot ( bool alarming)

This enables or disables alarming viewport->plot.

Parameters
alarmingTrue to enable alarming viewport->plot, false to disable alarming viewport->plot

Definition at line 460 of file ScatterPlotWindow.cpp.

References m_alarmPlot.

◆ setAlarmingViewport()

void Isis::ScatterPlotWindow::setAlarmingViewport ( bool alarming)

This enables or disables alarming plot->viewport.

Parameters
alarmingTrue to enable alarming plot->viewport, false to disable alarming plot->viewport

Definition at line 471 of file ScatterPlotWindow.cpp.

References m_alarmViewport.

◆ setAlarmPlotBoxSize()

void Isis::ScatterPlotWindow::setAlarmPlotBoxSize ( int samples,
int lines )

This sets the box size for alarming viewport->plot in cube samples/lines.

Parameters
samplesHow many samples (total) the alarming box size should be. This should be odd because the mouse is in the center.
linesHow many lines (total) the alarming box size should be. This should be odd because the mouse is in the center.

Definition at line 484 of file ScatterPlotWindow.cpp.

References m_alarmPlotLines, and m_alarmPlotSamples.

◆ setAlarmViewportDnBoxSize()

void Isis::ScatterPlotWindow::setAlarmViewportDnBoxSize ( double xDnBoxSize,
double yDnBoxSize )

This sets the cube DN box size for alarming plot->viewport.

If the current alarming units for plot->viewport isn't cube pixels, these values will still be stored off and just not be active until the units are changed.

Parameters
xDnBoxSizeThe Cube DN box size (total) around the mouse in the X direction to be used for alarming.
yDnBoxSizeThe Cube DN box size (total) around the mouse in the Y direction to be used for alarming.

Definition at line 528 of file ScatterPlotWindow.cpp.

References m_alarmViewportXDnBoxSize, and m_alarmViewportYDnBoxSize.

◆ setAlarmViewportScreenBoxSize()

void Isis::ScatterPlotWindow::setAlarmViewportScreenBoxSize ( int width,
int height )

This sets the screen pixel box size for alarming plot->viewport.

If the current alarming units for plot->viewport isn't screen pixels, these values will still be stored off and just not be active until the units are changed.

Parameters
widthThe screen pixels (total) around the mouse in the X direction to be used for alarming.
heightThe screen pixels (total) around the mouse in the Y direction to be used for alarming.

Definition at line 511 of file ScatterPlotWindow.cpp.

References m_alarmViewportScreenHeight, and m_alarmViewportScreenWidth.

◆ setAlarmViewportUnits()

void Isis::ScatterPlotWindow::setAlarmViewportUnits ( AlarmRangeUnits units)

This sets the units to be used for alarming plot->viewport.

Parameters
unitsThe units (screen or cube DN range) to use for alarming.

Definition at line 495 of file ScatterPlotWindow.cpp.

References m_alarmViewportUnits.

◆ setAxisLabel()

void Isis::PlotWindow::setAxisLabel ( int axisId,
QString title )
inherited

Sets the plots given axis title to the given string.

Parameters
axisId
title

Definition at line 208 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

◆ setDefaultRange

◆ setLabels

void Isis::PlotWindow::setLabels ( )
slotinherited

Makes the user specified changes to the plot labels.

Definition at line 911 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot, Isis::PlotWindow::m_plotTitleText, Isis::PlotWindow::m_xAxisText, and Isis::PlotWindow::m_yAxisText.

Referenced by Isis::PlotWindow::changePlotLabels().

◆ setMenus()

void Isis::PlotWindow::setMenus ( QList< QMenu * > menu,
QList< QAction * > actions )
protectedinherited

Sets up the menus added from a parent object.

Parameters
menu
actions

Definition at line 1359 of file PlotWindow.cpp.

References Isis::PlotWindow::m_menubar, and Isis::PlotWindow::m_toolBar.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ setMousePosition()

void Isis::ScatterPlotWindow::setMousePosition ( MdiCubeViewport * vp,
QPoint mouseLoc )

Saves the current mouse position in the viewport so that the plot can be alarmed around that position.

Parameters
vpThe viewport that received the mouse event
mouseLocThe location on the viewport wheere the mouse is, in screen coordinates.

Definition at line 406 of file ScatterPlotWindow.cpp.

References alarmingPlot(), Isis::ScatterPlotData::clearAlarms(), Isis::IsSpecial(), isXCube(), isYCube(), m_alarmPlotLines, m_alarmPlotSamples, m_lineRange, m_sampleRange, m_spectrogram, m_xAxisCube, m_xAxisCubeBand, m_yAxisCube, m_yAxisCubeBand, Isis::Null, Isis::Cube::pixelType(), Isis::PlotWindow::plot(), and Isis::Cube::read().

◆ setPlotBackground()

void Isis::PlotWindow::setPlotBackground ( QColor c)
inherited

Sets the plot background color to the given color.

Parameters
c

Definition at line 289 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

Referenced by Isis::HistogramPlotWindow::HistogramPlotWindow(), and Isis::PlotWindow::PlotWindow().

◆ setPlotTitle()

void Isis::PlotWindow::setPlotTitle ( QString pt)
inherited

Sets the plot title to the given string.

This does not update the window title.

Parameters
ptThe plot title to use

Definition at line 219 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

Referenced by Isis::PlotWindow::PlotWindow().

◆ settingsFileName() [1/2]

QString Isis::MainWindow::settingsFileName ( ) const
protectedinherited

Definition at line 96 of file MainWindow.cpp.

◆ settingsFileName() [2/2]

QString Isis::MainWindow::settingsFileName ( QString objectTitle)
staticinherited

Definition at line 43 of file MainWindow.cpp.

◆ setupDefaultMenu()

void Isis::PlotWindow::setupDefaultMenu ( MenuOptions optionsToProvide)
privateinherited

The user can add menu items from parent classes, but there are some menu items that are common between many types of plot windows.

Parameters
optionsToProvideA bit-flag containing information on which options to provide to the users.

Definition at line 1049 of file PlotWindow.cpp.

References Isis::PlotWindow::BackgroundSwitchMenuOption, Isis::PlotWindow::changePlotLabels(), Isis::PlotWindow::clearPlot(), Isis::PlotWindow::ClearPlotMenuOption, Isis::PlotWindow::configurePlotCurves(), Isis::PlotWindow::ConfigurePlotMenuOption, Isis::PlotWindow::createBestFitLine(), Isis::PlotWindow::LineFitMenuOption, Isis::PlotWindow::m_pasteAct, Isis::PlotWindow::m_plot, Isis::PlotWindow::m_showHideAllCurves, Isis::PlotWindow::m_showHideAllMarkers, Isis::PlotWindow::m_showHideGrid, Isis::PlotWindow::pasteCurve(), Isis::PlotWindow::PrintMenuOption, Isis::PlotWindow::printPlot(), Isis::PlotWindow::RenameLabelsMenuOption, Isis::PlotWindow::resetScale(), Isis::PlotWindow::ResetScaleMenuOption, Isis::PlotWindow::SaveMenuOption, Isis::PlotWindow::savePlot(), Isis::PlotWindow::setDefaultRange(), Isis::PlotWindow::SetDisplayRangeMenuOption, Isis::PlotWindow::setMenus(), Isis::PlotWindow::showHelp(), Isis::PlotWindow::showHideAllCurves(), Isis::PlotWindow::showHideAllMarkers(), Isis::PlotWindow::ShowHideCurvesMenuOption, Isis::PlotWindow::showHideGrid(), Isis::PlotWindow::ShowHideGridMenuOption, Isis::PlotWindow::ShowHideMarkersMenuOption, Isis::PlotWindow::showTable(), Isis::PlotWindow::ShowTableMenuOption, Isis::PlotWindow::switchBackground(), Isis::PlotWindow::trackerEnabled(), and Isis::PlotWindow::TrackMenuOption.

Referenced by Isis::PlotWindow::createWidgets().

◆ setUserCanAddCurves()

void Isis::PlotWindow::setUserCanAddCurves ( bool userHasControl)
inherited

Allow or disallow users from manually putting curves into this plot window through either copy-and-paste or drag-and-drop.

Parameters
userHasControlTrue if users can add curves manually, false otherwise

Definition at line 231 of file PlotWindow.cpp.

References Isis::PlotWindow::m_allowUserToAddCurves.

◆ setUserValues

◆ showHelp

void Isis::PlotWindow::showHelp ( )
slotinherited

This method creates and shows the help dialog box for the plot window.

this is called from the Help-->Basic Help menu.

Definition at line 1000 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ showHideAllCurves

void Isis::PlotWindow::showHideAllCurves ( )
slotinherited

This method shows or hides all of the curves in the plotWindow.

Definition at line 968 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot, and Isis::PlotWindow::m_showHideAllCurves.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ showHideAllMarkers

void Isis::PlotWindow::showHideAllMarkers ( )
slotinherited

Shows/Hides all the markers(symbols)

Definition at line 940 of file PlotWindow.cpp.

References Isis::PlotWindow::m_plot, and Isis::PlotWindow::m_showHideAllMarkers.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ showHideContour

void Isis::ScatterPlotWindow::showHideContour ( )
protectedslot

This method hides or displays the contour lines on the spectrogram.

Definition at line 585 of file ScatterPlotWindow.cpp.

References m_contour, m_spectrogram, Isis::PlotWindow::replot(), and updateContourPen().

Referenced by ScatterPlotWindow().

◆ showHideGrid

void Isis::PlotWindow::showHideGrid ( )
slotinherited

This method hides/shows the grid on the plotWindow and changes the text for the action.

Definition at line 924 of file PlotWindow.cpp.

References Isis::PlotWindow::m_grid, Isis::PlotWindow::m_plot, and Isis::PlotWindow::m_showHideGrid.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ showTable

void Isis::PlotWindow::showTable ( )
slotinherited

This method is called from the showTable action on the tool bar There are some checks done to make sure there are data to fill the table.

Definition at line 1565 of file PlotWindow.cpp.

References Isis::PlotWindow::fillTable(), Isis::PlotWindow::m_parent, Isis::PlotWindow::m_tableWindow, Isis::PlotWindow::plotCurves(), Isis::TableMainWindow::setTrackListItems(), and Isis::TableMainWindow::syncColumns().

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ showWindow()

void Isis::PlotWindow::showWindow ( )
inherited

Shows the plot window, and raises it to the front of any overlapping sibling widgets.

Definition at line 185 of file PlotWindow.cpp.

Referenced by Isis::AbstractPlotTool::selectedWindowChanged(), and Isis::AbstractPlotTool::showPlotWindow().

◆ switchBackground

void Isis::PlotWindow::switchBackground ( )
slotinherited

This method toggles the plot background color between black and white.

Definition at line 636 of file PlotWindow.cpp.

References Isis::PlotWindow::m_grid, Isis::PlotWindow::m_plot, and Isis::PlotWindow::m_zoomer.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ trackerEnabled

void Isis::PlotWindow::trackerEnabled ( )
slotinherited

Enables the plot mouse tracker.

Definition at line 560 of file PlotWindow.cpp.

References Isis::PlotWindow::m_zoomer.

Referenced by Isis::PlotWindow::setupDefaultMenu().

◆ update()

void Isis::PlotWindow::update ( MdiCubeViewport * activeViewport)
virtualinherited

This is provided to allow children to react to tool updates.

This is useful for example for band markers in the spectral plots.

Parameters
activeViewportThe currently selected viewport

Reimplemented in Isis::SpectralPlotWindow.

Definition at line 197 of file PlotWindow.cpp.

◆ updateContourPen()

void Isis::ScatterPlotWindow::updateContourPen ( )
private

This sets the contour pen to an appropriate color based on the color of the plot (B/W v.

Color). The contour pen is set to red for color, white for B/W.

Definition at line 698 of file ScatterPlotWindow.cpp.

References m_colorize, and m_spectrogram.

Referenced by colorPlot(), and showHideContour().

◆ updateVisibility()

void Isis::PlotWindow::updateVisibility ( PlotCurve * curve)
privateinherited

This method sets the visibility states in the curve (and it's symbols) to match with this window's current visibility settings.

Every means of adding a curve to the window needs to call this with the curve that is being added, otherwise visibility states will not be consistent.

Parameters
curveCurve (with symbols) to set the visibility states on

Definition at line 1331 of file PlotWindow.cpp.

References Isis::PlotWindow::m_showHideAllCurves, Isis::PlotWindow::m_showHideAllMarkers, and Isis::PlotWindow::plotChanged().

Referenced by Isis::PlotWindow::add().

◆ userCanAddCurve()

bool Isis::PlotWindow::userCanAddCurve ( const QMimeData * curve)
privateinherited

Ask if a user action can add this curve to this window.

This verifies that the user is allowed to add curves to this window and that programmatically the curve can be added (i.e. things such as the X/Y data units match).

Parameters
curveMime-data containing a plot curve to be added
Returns
True if the user should be allowed to paste/drop the curve into this window

Definition at line 1307 of file PlotWindow.cpp.

References Isis::PlotWindow::canAdd(), and Isis::PlotWindow::m_allowUserToAddCurves.

Referenced by Isis::PlotWindow::dragEnterEvent(), Isis::PlotWindow::mousePressEvent(), and Isis::PlotWindow::onClipboardChanged().

◆ userCanAddCurves()

bool Isis::PlotWindow::userCanAddCurves ( ) const
inherited

Ask if a user action can add this curve to this window in general.

This verifies that the user is allowed to add curves to this window but not that a particular curve is compatible with this window.

Returns
True if the user should be allowed to paste/drop curves in general into this window

Definition at line 254 of file PlotWindow.cpp.

References Isis::PlotWindow::m_allowUserToAddCurves.

◆ writeSettings()

void Isis::MainWindow::writeSettings ( ) const
privatevirtualinherited

This method is called when the Main window is closed or hidden to write the size and location settings to a config file in the user's home directory.

Definition at line 124 of file MainWindow.cpp.

Referenced by Isis::MainWindow::closeEvent().

◆ xAxisUnits()

PlotCurve::Units Isis::PlotWindow::xAxisUnits ( ) const
inherited

This is the data-type of the curves' x data in this plot window.

All of the cube plot curves must have the same units for x axis data or the display will not make sense.

Returns
X-Axis Curve Data Units

Definition at line 266 of file PlotWindow.cpp.

References Isis::PlotWindow::m_xAxisUnits.

Referenced by Isis::SpectralPlotWindow::drawBandMarkers(), and Isis::PlotWindow::PlotWindow().

◆ yAxisUnits()

PlotCurve::Units Isis::PlotWindow::yAxisUnits ( ) const
inherited

This is the data-type of the curves' y data in this plot window.

All of the cube plot curves must have the same units for y-left axis data (y-right sometimes has different units) or the display will not make sense.

Returns
Left Y-Axis Data Units

Definition at line 278 of file PlotWindow.cpp.

References Isis::PlotWindow::m_yAxisUnits.

Referenced by Isis::PlotWindow::PlotWindow().

◆ zoomer()

QwtPlotZoomer * Isis::PlotWindow::zoomer ( )
protectedinherited

Get this window's plot's zoomer.

Returns
A QwtPlotZoomer which is associated with this PlotWindow's QwtPlot

Definition at line 1389 of file PlotWindow.cpp.

References Isis::PlotWindow::m_zoomer.

Referenced by ScatterPlotWindow().

Member Data Documentation

◆ m_action

QPointer<QAction> Isis::PlotWindow::m_action
privateinherited

Plot window's action.

Definition at line 312 of file PlotWindow.h.

◆ m_alarmPlot

bool Isis::ScatterPlotWindow::m_alarmPlot
private

Alarm onto plot... aka alarm viewport->plot.

Definition at line 115 of file ScatterPlotWindow.h.

Referenced by alarmingPlot(), ScatterPlotWindow(), and setAlarmingPlot().

◆ m_alarmPlotLines

int Isis::ScatterPlotWindow::m_alarmPlotLines
private

Alarm viewport->plot viewport line box size.

Definition at line 122 of file ScatterPlotWindow.h.

Referenced by alarmPlotBoxSize(), ScatterPlotWindow(), setAlarmPlotBoxSize(), and setMousePosition().

◆ m_alarmPlotSamples

int Isis::ScatterPlotWindow::m_alarmPlotSamples
private

Alarm viewport->plot viewport sample box size.

Definition at line 120 of file ScatterPlotWindow.h.

Referenced by alarmPlotBoxSize(), ScatterPlotWindow(), setAlarmPlotBoxSize(), and setMousePosition().

◆ m_alarmViewport

bool Isis::ScatterPlotWindow::m_alarmViewport
private

Alarm onto viewport... aka alarm plot->viewport.

Definition at line 117 of file ScatterPlotWindow.h.

Referenced by alarmingViewport(), ScatterPlotWindow(), and setAlarmingViewport().

◆ m_alarmViewportScreenHeight

int Isis::ScatterPlotWindow::m_alarmViewportScreenHeight
private

Alarm plot->viewport Y (screen pixels) box size.

Definition at line 129 of file ScatterPlotWindow.h.

Referenced by alarmViewportScreenBoxSize(), mouseMoveEvent(), ScatterPlotWindow(), and setAlarmViewportScreenBoxSize().

◆ m_alarmViewportScreenWidth

int Isis::ScatterPlotWindow::m_alarmViewportScreenWidth
private

Alarm plot->viewport X (screen pixels) box size.

Definition at line 127 of file ScatterPlotWindow.h.

Referenced by alarmViewportScreenBoxSize(), mouseMoveEvent(), ScatterPlotWindow(), and setAlarmViewportScreenBoxSize().

◆ m_alarmViewportUnits

AlarmRangeUnits Isis::ScatterPlotWindow::m_alarmViewportUnits
private

Alarm plot->viewport current units.

Definition at line 125 of file ScatterPlotWindow.h.

Referenced by alarmViewportUnits(), mouseMoveEvent(), ScatterPlotWindow(), and setAlarmViewportUnits().

◆ m_alarmViewportXDnBoxSize

double Isis::ScatterPlotWindow::m_alarmViewportXDnBoxSize
private

Alarm plot->viewport X (Cube DN) box size.

Definition at line 131 of file ScatterPlotWindow.h.

Referenced by alarmViewportDnBoxSize(), mouseMoveEvent(), ScatterPlotWindow(), and setAlarmViewportDnBoxSize().

◆ m_alarmViewportYDnBoxSize

double Isis::ScatterPlotWindow::m_alarmViewportYDnBoxSize
private

Alarm plot->viewport Y (Cube DN) box size.

Definition at line 133 of file ScatterPlotWindow.h.

Referenced by alarmViewportDnBoxSize(), mouseMoveEvent(), ScatterPlotWindow(), and setAlarmViewportDnBoxSize().

◆ m_allowUserToAddCurves

bool Isis::PlotWindow::m_allowUserToAddCurves
privateinherited

◆ m_autoscaleAxes

bool Isis::PlotWindow::m_autoscaleAxes
privateinherited

◆ m_autoScaleCheckBox

QCheckBox* Isis::PlotWindow::m_autoScaleCheckBox
privateinherited

Set Scale Dialog's checkbox for enabling automatic scaling on x & y.

Definition at line 281 of file PlotWindow.h.

Referenced by Isis::PlotWindow::autoScaleCheckboxToggled(), Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_colorize

QPointer<QAction> Isis::ScatterPlotWindow::m_colorize
private

The action for switching the scatter plot from B/W to color.

Definition at line 93 of file ScatterPlotWindow.h.

Referenced by colorPlot(), ScatterPlotWindow(), and updateContourPen().

◆ m_contour

QPointer<QAction> Isis::ScatterPlotWindow::m_contour
private

The action for switching on and off contour lines.

Definition at line 95 of file ScatterPlotWindow.h.

Referenced by ScatterPlotWindow(), and showHideContour().

◆ m_grid

QwtPlotGrid* Isis::PlotWindow::m_grid
privateinherited

◆ m_legend

QwtLegend* Isis::PlotWindow::m_legend
privateinherited

The legend inserted in this plot.

Definition at line 331 of file PlotWindow.h.

Referenced by Isis::PlotWindow::add(), Isis::PlotWindow::createWidgets(), and Isis::PlotWindow::dragEnterEvent().

◆ m_lineRange

QwtInterval Isis::ScatterPlotWindow::m_lineRange
private

The line range (1-based inclusive) of data used for the scatter plot.

Definition at line 112 of file ScatterPlotWindow.h.

Referenced by paint(), ScatterPlotWindow(), and setMousePosition().

◆ m_menubar

QMenuBar* Isis::PlotWindow::m_menubar
privateinherited

Plot window's menu bar.

Definition at line 302 of file PlotWindow.h.

Referenced by Isis::PlotWindow::PlotWindow(), and Isis::PlotWindow::setMenus().

◆ m_parent

QWidget* Isis::PlotWindow::m_parent
privateinherited

Parent widget.

Definition at line 275 of file PlotWindow.h.

Referenced by Isis::PlotWindow::PlotWindow(), and Isis::PlotWindow::showTable().

◆ m_pasteAct

QAction* Isis::PlotWindow::m_pasteAct
privateinherited

This is the paste action in the edit menu to paste a curve into the plot window.

This is enabled or disabled based on what is in the clipboard.

Definition at line 309 of file PlotWindow.h.

Referenced by Isis::PlotWindow::onClipboardChanged(), Isis::PlotWindow::PlotWindow(), and Isis::PlotWindow::setupDefaultMenu().

◆ m_plot

◆ m_plotTitleText

QLineEdit* Isis::PlotWindow::m_plotTitleText
privateinherited

Set Labels Dialog's edit for the plot title.

Definition at line 299 of file PlotWindow.h.

Referenced by Isis::PlotWindow::changePlotLabels(), and Isis::PlotWindow::setLabels().

◆ m_plotXLogScale

bool Isis::PlotWindow::m_plotXLogScale
privateinherited

Tracks if the plot X axis is using a log (true) or linear (false) scale.

Definition at line 332 of file PlotWindow.h.

Referenced by Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_plotYLogScale

bool Isis::PlotWindow::m_plotYLogScale
privateinherited

Tracks if the plot Y axis is using a log (true) or linear (false) scale.

Definition at line 333 of file PlotWindow.h.

Referenced by Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_sampleRange

QwtInterval Isis::ScatterPlotWindow::m_sampleRange
private

The sample range (1-based inclusive) of data used for the scatter plot.

Definition at line 110 of file ScatterPlotWindow.h.

Referenced by paint(), ScatterPlotWindow(), and setMousePosition().

◆ m_scheduledFillTable

bool Isis::PlotWindow::m_scheduledFillTable
privateinherited

Definition at line 337 of file PlotWindow.h.

◆ m_showHideAllCurves

QPointer<QAction> Isis::PlotWindow::m_showHideAllCurves
privateinherited

◆ m_showHideAllMarkers

QPointer<QAction> Isis::PlotWindow::m_showHideAllMarkers
privateinherited

◆ m_showHideGrid

QPointer<QAction> Isis::PlotWindow::m_showHideGrid
privateinherited

Show plot grid lines action.

Definition at line 318 of file PlotWindow.h.

Referenced by Isis::PlotWindow::setupDefaultMenu(), and Isis::PlotWindow::showHideGrid().

◆ m_spectrogram

QwtPlotSpectrogram* Isis::ScatterPlotWindow::m_spectrogram
private

This is the scatter plot's Qwt plot item.

Definition at line 90 of file ScatterPlotWindow.h.

Referenced by colorPlot(), ScatterPlotWindow(), setMousePosition(), showHideContour(), and updateContourPen().

◆ m_tableWindow

TableMainWindow* Isis::PlotWindow::m_tableWindow
privateinherited

◆ m_toolBar

QToolBar* Isis::PlotWindow::m_toolBar
privateinherited

Tool bar on the plot window.

Definition at line 335 of file PlotWindow.h.

Referenced by Isis::PlotWindow::PlotWindow(), and Isis::PlotWindow::setMenus().

◆ m_xAxisCube

Cube* Isis::ScatterPlotWindow::m_xAxisCube
private

The cube associated with the X-Axis DN values.

Definition at line 98 of file ScatterPlotWindow.h.

Referenced by forgetCubes(), isXCube(), paint(), ScatterPlotWindow(), and setMousePosition().

◆ m_xAxisCubeBand

int Isis::ScatterPlotWindow::m_xAxisCubeBand
private

The band on the X-Axis cube used for the scatter plot.

Definition at line 106 of file ScatterPlotWindow.h.

Referenced by isXCube(), paint(), ScatterPlotWindow(), and setMousePosition().

◆ m_xAxisText

QLineEdit* Isis::PlotWindow::m_xAxisText
privateinherited

Set Labels Dialog's edit for the x-axis label.

Definition at line 295 of file PlotWindow.h.

Referenced by Isis::PlotWindow::changePlotLabels(), and Isis::PlotWindow::setLabels().

◆ m_xAxisUnits

PlotCurve::Units Isis::PlotWindow::m_xAxisUnits
privateinherited

The units of the data on the x-bottom axis.

Definition at line 321 of file PlotWindow.h.

Referenced by Isis::PlotWindow::canAdd(), Isis::PlotWindow::PlotWindow(), Isis::PlotWindow::resetScale(), and Isis::PlotWindow::xAxisUnits().

◆ m_xCubeDnAlarmRange

QPair<double, double> Isis::ScatterPlotWindow::m_xCubeDnAlarmRange
private

The DN range of the X-Axis Cube to be alarmed when painting.

Definition at line 102 of file ScatterPlotWindow.h.

Referenced by mouseLeaveEvent(), mouseMoveEvent(), paint(), and ScatterPlotWindow().

◆ m_xLogCheckBox

QCheckBox* Isis::PlotWindow::m_xLogCheckBox
privateinherited

Set Scale Dialog's checkbox for using logarithmic scale for the x axis.

Definition at line 283 of file PlotWindow.h.

Referenced by Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_xMaxEdit

QLineEdit* Isis::PlotWindow::m_xMaxEdit
privateinherited

Set Scale Dialog's edit for the max X-axis value.

Definition at line 289 of file PlotWindow.h.

Referenced by Isis::PlotWindow::autoScaleCheckboxToggled(), Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_xMinEdit

QLineEdit* Isis::PlotWindow::m_xMinEdit
privateinherited

Set Scale Dialog's edit for the min X-axis value.

Definition at line 287 of file PlotWindow.h.

Referenced by Isis::PlotWindow::autoScaleCheckboxToggled(), Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_yAxisCube

Cube* Isis::ScatterPlotWindow::m_yAxisCube
private

The cube associated with the Y-Axis DN values.

Definition at line 100 of file ScatterPlotWindow.h.

Referenced by forgetCubes(), isYCube(), paint(), ScatterPlotWindow(), and setMousePosition().

◆ m_yAxisCubeBand

int Isis::ScatterPlotWindow::m_yAxisCubeBand
private

The band on the Y-Axis cube used for the scatter plot.

Definition at line 108 of file ScatterPlotWindow.h.

Referenced by isYCube(), paint(), ScatterPlotWindow(), and setMousePosition().

◆ m_yAxisText

QLineEdit* Isis::PlotWindow::m_yAxisText
privateinherited

Set Labels Dialog's edit for the y-axis label.

Definition at line 297 of file PlotWindow.h.

Referenced by Isis::PlotWindow::changePlotLabels(), and Isis::PlotWindow::setLabels().

◆ m_yAxisUnits

PlotCurve::Units Isis::PlotWindow::m_yAxisUnits
privateinherited

The units of the data on the y-left axis.

Definition at line 323 of file PlotWindow.h.

Referenced by Isis::PlotWindow::canAdd(), Isis::PlotWindow::PlotWindow(), Isis::PlotWindow::resetScale(), and Isis::PlotWindow::yAxisUnits().

◆ m_yCubeDnAlarmRange

QPair<double, double> Isis::ScatterPlotWindow::m_yCubeDnAlarmRange
private

The DN range of the Y-Axis Cube to be alarmed when painting.

Definition at line 104 of file ScatterPlotWindow.h.

Referenced by mouseLeaveEvent(), mouseMoveEvent(), paint(), and ScatterPlotWindow().

◆ m_yLogCheckBox

QCheckBox* Isis::PlotWindow::m_yLogCheckBox
privateinherited

Set Scale Dialog's checkbox for using logarithmic scale for the y axis.

Definition at line 285 of file PlotWindow.h.

Referenced by Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_yMaxEdit

QLineEdit* Isis::PlotWindow::m_yMaxEdit
privateinherited

Set Scale Dialog's edit for the max Y-axis value.

Definition at line 293 of file PlotWindow.h.

Referenced by Isis::PlotWindow::autoScaleCheckboxToggled(), Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_yMinEdit

QLineEdit* Isis::PlotWindow::m_yMinEdit
privateinherited

Set Scale Dialog's edit for the min Y-axis value.

Definition at line 291 of file PlotWindow.h.

Referenced by Isis::PlotWindow::autoScaleCheckboxToggled(), Isis::PlotWindow::setDefaultRange(), and Isis::PlotWindow::setUserValues().

◆ m_zoomer


The documentation for this class was generated from the following files: