Isis 3 Programmer Reference
Isis::MosaicControlNetTool Class Reference

//TODO: Remove debug printout & comment // 2016-08-25 Tracie Sucharski - Checking Directory pointer for IPCE code not ideal. More...

#include <MosaicControlNetTool.h>

Inheritance diagram for Isis::MosaicControlNetTool:
Inheritance graph
Collaboration diagram for Isis::MosaicControlNetTool:
Collaboration graph

Public Types

enum  MovementColorSource { NoMovement = 0, NoColor, MeasureCount, ResidualMagnitude }
 This enum defines how to draw the movement arrows (arrows from CP A Priori location to adjusted location). More...
 

Public Slots

void loadNetwork ()
 Load m_controlNetFile into memory - this will re-load the network if it's already open. More...
 
void rebuildPointGraphics ()
 Slot used to re-create the graphics items that depict the control points. More...
 
void displayNewControlPoint (QString pointId)
 
void displayChangedControlPoint (QString pointId)
 
void displayUponControlPointDeletion ()
 
void activate (bool)
 Activates the tool. More...
 

Signals

void modifyControlPoint (ControlPoint *controlPoint)
 
void deleteControlPoint (ControlPoint *controlPoint)
 
void createControlPoint (double latitude, double longitude)
 
void controlPointSelected (ControlPoint *)
 
void deleteControlPoint (QString controlPointId)
 
void activated (bool)
 

Public Member Functions

 MosaicControlNetTool (MosaicSceneWidget *)
 MosaicControlNetTool constructor. More...
 
void addToMenu (QMenu *menu)
 
PvlObject toPvl () const
 
void fromPvl (const PvlObject &obj)
 
QString projectPvlObjectName () const
 
void setMovementArrowColorSource (MovementColorSource, int, double)
 Define how the movement arrows should be drawn. More...
 
MovementColorSource movementArrowColorSource () const
 Get the current setting for the movement arrows. More...
 
int maxMovementColorMeasureCount () const
 Get the current measure count to become fully colored. More...
 
double maxMovementColorResidualMagnitude () const
 Get the current max. More...
 
bool isActive () const
 Returns the activeness of this toool. More...
 
QPixmap getIcon (QString iconName) const
 returns the path to the icon directory. More...
 
virtual void addTo (QMenu *menu)
 
virtual void addTo (ToolPad *toolPad)
 
virtual void addTo (QToolBar *toolBar)
 
virtual QList< QAction * > getViewActions ()
 

Static Public Member Functions

static QString toString (MovementColorSource)
 Convert a MovementColorSource to a string for serialization purposes. More...
 
static MovementColorSource fromMovementColorSourceString (QString)
 Convert a string back to a MovementColorSource (for serialization purposes). More...
 

Static Public Attributes

static const int NUM_MOVEMENT_COLOR_SOURCE_VALUES = 4
 This is the count of possible values of MovementColorSource (useful for loops). More...
 

Protected Member Functions

QActiongetPrimaryAction ()
 Adds the action to the toolpad. More...
 
QWidgetgetToolBarWidget ()
 This method returns a widget that will be put in a tool bar when the tool is activated. More...
 
void mouseButtonRelease (QPointF, Qt::MouseButton s)
 
virtual void mouseEnter ()
 
virtual void mouseMove (QPointF)
 
virtual void mouseLeave ()
 
virtual void mouseDoubleClick (QPointF)
 
virtual void mouseButtonPress (QPointF, Qt::MouseButton s)
 
virtual void mouseWheel (QPointF, int delta)
 
virtual void rubberBandComplete (QRectF r, Qt::MouseButton s)
 
void toolBarDestroyed (QObject *obj)
 
MosaicSceneWidgetgetWidget ()
 

Private Slots

void configMovement ()
 Bring up a movement arrow configuration dialog. More...
 
void updateTool ()
 This slot opens and reopens this tool properly. More...
 
void openControlNet ()
 Loads a control net from a file. More...
 
void displayControlNet ()
 The user toggled the cnet visibility - re-sync the graphics item visibility with the action. More...
 
void displayConnectivity ()
 Displays the connectivity of Control Points. More...
 
void closeNetwork ()
 Close the open network, if one is open. More...
 
void randomizeColors ()
 
void objectDestroyed (QObject *)
 An object was destroyed, NULL it out. More...
 

Private Member Functions

void createDialog ()
 
ImagetakeImage (QString sn, ImageList &images)
 
void enableToolBar ()
 Enables entire tool bar. More...
 
void disableToolBar ()
 Disables entire tool bar. More...
 

Private Attributes

QPushButton * m_loadControlNetButton
 
QPushButton * m_displayControlNetButton
 
QPushButton * m_displayConnectivity
 
QPushButton * m_configMovement
 
QPushButton * m_closeNetwork
 
QPushButton * m_randomizeColors
 
QActionm_connectivity
 
ControlNetm_controlNet
 
ControlNetGraphicsItemm_controlNetGraphics
 
QLabel * m_controlNetFileLabel
 
QString m_controlNetFile
 
MovementColorSource m_movementArrowColorSource
 This defines the drawing mode of the apriori to adjusted arrows. More...
 
int m_measureCount
 This is the measure count at which we start coloring the movement arrows. More...
 
double m_residualMagnitude
 This is the residual magnitude at which we coloring the movement arrows. More...
 
bool p_active
 Is the tool active? More...
 
MosaicSceneWidgetp_widget
 
QActionp_primaryAction
 
QActionp_toolBarAction
 

Detailed Description

//TODO: Remove debug printout & comment // 2016-08-25 Tracie Sucharski - Checking Directory pointer for IPCE code not ideal.

Is there a better design? This might go away if we emit signals, which only IPCE classes would connect to.

Handles Control Net displays

Author
????-??-?? Christopher Austin
History:
2010-06-24 Christopher Austin - Added |x| functionality and fixed control net loading
History:
2011-05-07 Steven Lambright - Refactored.
History:
2011-05-10 Steven Lambright - Reduced useless code, open cnet button is now always enabled.
History:
2011-05-10 Steven Lambright - Added label for currently open network.
History:
2011-09-27 Steven Lambright - Improved user documentation. Made the open control network button more obvious.
History:
2013-01-02 Steven Lambright - Implemented movement arrow colorization. This is a quick and dirty implementation designed to get the most basic functionality working with minimal options. Added the enum MovementColorSource and the methods setMovementArrowColorSource(), movementArrowColorSource(), maxMovementColorMeasureCount(), maxMovementColorResidualMagnitude(), toString(), and fromMovementColorSourceString(). Fixes #479.
History:
2013-01-31 Steven Lambright - Removed some debugging statements that were left around from the last change. Fixes #1459.
History:
2016-09-14 Tracie Sucharski - Added signals for mouse clicks for modifying, deleting and creating control points. These are passed on to MosaicSceneWidget signals, then on to Directory slots.
History:
2016-08-25 Tracie Sucharski - Fixed IPCE code which caused qmos to segfault. Added checks for the existence of a Directory pointer in the openControlNet and mouseButtonRelease methods. If Directory point is NULL, IPCE code not executed. Fixes #4063.
History:
2017-01-03 Tracie Sucharski - If IPCE, set m_controlNet to active control net in the loadNetwork method and do not display Load/Close Network button if IPCE.
History:
2017-05-11 Tracie Sucharski - Tools can be created with a Null value for the MosaicSceneWidget, so need to check for Null value getWidget() in Tool constructor. This was causing a segfault when accessing qmos help and a Qt connection error.
History:
2017-07-06 Tracie Sucharski - Added documentation for conditional code necessary for ipce application.
History:
2017-08-02 Tracie Sucharski - Added slot to rebuild the graphics items that depict the control points. This is used to update these items if a control point was added or deleted. Fixes #5007, #5008.
History:
2017-08-15 Tracie Sucharski - Added check in ::rebuildPointGraphics() to check for existence of graphics items. Fixes #4984.
History:
2018-07-12 Tracie Sucharski - Made the slot loadNetwork public so that ipce can load a new network.
History:
2018-09-19 Tracie Sucharski - For the ipce application, update the control net file name in the toolbar when a new active control is set. Fixes #5518.

Definition at line 74 of file MosaicControlNetTool.h.

Member Enumeration Documentation

◆ MovementColorSource

This enum defines how to draw the movement arrows (arrows from CP A Priori location to adjusted location).

These settings include whether the arrows are shown and how to color them.

NOTE: It's important to start at zero. Also, if you add to this enumeration, be sure to update NUM_MOVEMENT_COLOR_SOURCE_VALUES.

Enumerator
NoMovement 

Do not show movement arrows.

NoColor 

Show black movement arrows.

MeasureCount 

Show movement arrows colored by measure count.

ResidualMagnitude 

Show movement arrows colored by residual magnitude.

Definition at line 86 of file MosaicControlNetTool.h.

Constructor & Destructor Documentation

◆ MosaicControlNetTool()

Isis::MosaicControlNetTool::MosaicControlNetTool ( MosaicSceneWidget scene)

Member Function Documentation

◆ activate

void Isis::MosaicTool::activate ( bool  on)
slotinherited

Activates the tool.

Parameters
on

Definition at line 148 of file MosaicTool.cpp.

References Isis::MosaicTool::disableToolBar(), Isis::MosaicTool::enableToolBar(), and Isis::MosaicTool::p_active.

◆ closeNetwork

void Isis::MosaicControlNetTool::closeNetwork ( )
privateslot

Close the open network, if one is open.

m_controlNetFile is set to an empty string.

Definition at line 503 of file MosaicControlNetTool.cpp.

Referenced by loadNetwork(), and MosaicControlNetTool().

◆ configMovement

void Isis::MosaicControlNetTool::configMovement ( )
privateslot

Bring up a movement arrow configuration dialog.

Definition at line 381 of file MosaicControlNetTool.cpp.

Referenced by MosaicControlNetTool().

◆ disableToolBar()

void Isis::MosaicTool::disableToolBar ( )
privateinherited

Disables entire tool bar.

Definition at line 174 of file MosaicTool.cpp.

Referenced by Isis::MosaicTool::activate().

◆ displayConnectivity

◆ displayControlNet

void Isis::MosaicControlNetTool::displayControlNet ( )
privateslot

The user toggled the cnet visibility - re-sync the graphics item visibility with the action.

Definition at line 413 of file MosaicControlNetTool.cpp.

Referenced by MosaicControlNetTool().

◆ enableToolBar()

void Isis::MosaicTool::enableToolBar ( )
privateinherited

Enables entire tool bar.

Definition at line 185 of file MosaicTool.cpp.

Referenced by Isis::MosaicTool::activate().

◆ fromMovementColorSourceString()

MosaicControlNetTool::MovementColorSource Isis::MosaicControlNetTool::fromMovementColorSourceString ( QString  string)
static

Convert a string back to a MovementColorSource (for serialization purposes).

Definition at line 306 of file MosaicControlNetTool.cpp.

References NoMovement, NUM_MOVEMENT_COLOR_SOURCE_VALUES, and toString().

◆ getIcon()

◆ getPrimaryAction()

QAction * Isis::MosaicControlNetTool::getPrimaryAction ( )
protectedvirtual

Adds the action to the toolpad.

Parameters
toolpad
Returns
QAction*

Implements Isis::MosaicTool.

Definition at line 327 of file MosaicControlNetTool.cpp.

References Isis::MosaicTool::getIcon().

◆ getToolBarWidget()

QWidget * Isis::MosaicControlNetTool::getToolBarWidget ( )
protectedvirtual

This method returns a widget that will be put in a tool bar when the tool is activated.

This method will only be called once so it can new the widget without a problem.

Reimplemented from Isis::MosaicTool.

Definition at line 344 of file MosaicControlNetTool.cpp.

◆ isActive()

bool Isis::MosaicTool::isActive ( ) const
inlineinherited

◆ loadNetwork

void Isis::MosaicControlNetTool::loadNetwork ( )
slot

◆ maxMovementColorMeasureCount()

int Isis::MosaicControlNetTool::maxMovementColorMeasureCount ( ) const

Get the current measure count to become fully colored.

This will return -1 if it's undefined.

Definition at line 251 of file MosaicControlNetTool.cpp.

References m_measureCount.

◆ maxMovementColorResidualMagnitude()

double Isis::MosaicControlNetTool::maxMovementColorResidualMagnitude ( ) const

Get the current max.

residual magnitude to become fully colored. This will return Null if it's undefined.

Definition at line 265 of file MosaicControlNetTool.cpp.

References Isis::IsSpecial(), m_residualMagnitude, and Isis::Null.

◆ movementArrowColorSource()

MosaicControlNetTool::MovementColorSource Isis::MosaicControlNetTool::movementArrowColorSource ( ) const

Get the current setting for the movement arrows.

Definition at line 243 of file MosaicControlNetTool.cpp.

References m_movementArrowColorSource.

◆ objectDestroyed

void Isis::MosaicControlNetTool::objectDestroyed ( QObject obj)
privateslot

An object was destroyed, NULL it out.

Definition at line 544 of file MosaicControlNetTool.cpp.

Referenced by loadNetwork(), and MosaicControlNetTool().

◆ openControlNet

void Isis::MosaicControlNetTool::openControlNet ( )
privateslot

◆ rebuildPointGraphics

void Isis::MosaicControlNetTool::rebuildPointGraphics ( )
slot

Slot used to re-create the graphics items that depict the control points.

Definition at line 471 of file MosaicControlNetTool.cpp.

References Isis::ControlNetGraphicsItem::buildChildren().

◆ setMovementArrowColorSource()

void Isis::MosaicControlNetTool::setMovementArrowColorSource ( MovementColorSource  colorSource,
int  maxMeasureCount,
double  maxResidualMagnitude 
)

Define how the movement arrows should be drawn.

This includes if movement arrows should be drawn, what criteria should be used, and how to stretch (where to transition colors) the arrows.

NOTE: This is just a quick implementation and is probably not designed correctly. This is subject to change.

Parameters
colorSourceIf and how to draw and color the arrows
maxMeasureCountThe measure count to become fully colored
maxResidualMagnitudeThe max residual magnitude to become fully colored

Definition at line 226 of file MosaicControlNetTool.cpp.

References m_measureCount, m_movementArrowColorSource, m_residualMagnitude, MeasureCount, NoMovement, ResidualMagnitude, and Isis::ControlNetGraphicsItem::setArrowsVisible().

Referenced by loadNetwork().

◆ toString()

QString Isis::MosaicControlNetTool::toString ( MovementColorSource  source)
static

Convert a MovementColorSource to a string for serialization purposes.

Definition at line 278 of file MosaicControlNetTool.cpp.

References MeasureCount, NoColor, NoMovement, and ResidualMagnitude.

Referenced by fromMovementColorSourceString().

◆ updateTool

void Isis::MosaicControlNetTool::updateTool ( )
privateslot

This slot opens and reopens this tool properly.

Definition at line 392 of file MosaicControlNetTool.cpp.

References Isis::MosaicTool::isActive(), and openControlNet().

Member Data Documentation

◆ m_measureCount

int Isis::MosaicControlNetTool::m_measureCount
private

This is the measure count at which we start coloring the movement arrows.

Definition at line 169 of file MosaicControlNetTool.h.

Referenced by loadNetwork(), maxMovementColorMeasureCount(), MosaicControlNetTool(), and setMovementArrowColorSource().

◆ m_movementArrowColorSource

MovementColorSource Isis::MosaicControlNetTool::m_movementArrowColorSource
private

This defines the drawing mode of the apriori to adjusted arrows.

Definition at line 167 of file MosaicControlNetTool.h.

Referenced by loadNetwork(), MosaicControlNetTool(), movementArrowColorSource(), and setMovementArrowColorSource().

◆ m_residualMagnitude

double Isis::MosaicControlNetTool::m_residualMagnitude
private

This is the residual magnitude at which we coloring the movement arrows.

Definition at line 171 of file MosaicControlNetTool.h.

Referenced by loadNetwork(), maxMovementColorResidualMagnitude(), MosaicControlNetTool(), and setMovementArrowColorSource().

◆ NUM_MOVEMENT_COLOR_SOURCE_VALUES

const int Isis::MosaicControlNetTool::NUM_MOVEMENT_COLOR_SOURCE_VALUES = 4
static

This is the count of possible values of MovementColorSource (useful for loops).

Definition at line 97 of file MosaicControlNetTool.h.

Referenced by fromMovementColorSourceString().

◆ p_active

bool Isis::MosaicTool::p_active
privateinherited

Is the tool active?

Definition at line 120 of file MosaicTool.h.

Referenced by Isis::MosaicTool::activate(), and Isis::MosaicTool::isActive().


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