Isis 3 Programmer Reference
|
This represents an ISIS control net in a project-based GUI interface. More...
#include <Control.h>
Classes | |
class | XmlHandler |
Nested class used to write the Control object information to an XML file for the purpose of saving and restoring the state of the project. More... | |
Public Slots | |
void | updateFileName (Project *) |
Change the on-disk file name for this control to be where the control ought to be in the given project. More... | |
void | closeControlNet () |
Cleans up the ControlNet pointer. More... | |
Public Member Functions | |
Control (QString cnetFileName, QObject *parent=0) | |
Create a Control from control net located on disk. More... | |
Control (Project *project, QString cnetFileName, QObject *parent=0) | |
Create a Control from control net located on disk associated with a Project. More... | |
Control (ControlNet *controlNet, QString cnetFileName, QObject *parent=0) | |
Create a Control from a control network that has already been created and read from disk. More... | |
Control (FileName cnetFolder, XmlStackedHandlerReader *xmlReader, QObject *parent=0) | |
Construct this control from XML. More... | |
~Control () | |
Destroys Control object. More... | |
ControlNet * | controlNet () |
Open and return a pointer to the ControlNet for this Control. More... | |
void | openControlNet () |
Sets the ControlNet from the control net file name provided in the constructor. More... | |
ControlDisplayProperties * | displayProperties () |
Access a pointer to the display properties for the control network. More... | |
const ControlDisplayProperties * | displayProperties () const |
Access a const pointer to the display properties for the control network. More... | |
QString | fileName () const |
Access the name of the control network file associated with this Control. More... | |
QString | id () const |
Access the unique ID associated with this Control. More... | |
bool | isModified () |
Has this control been modified? More... | |
void | setModified (bool modified=true) |
Sets the modification state of this control. More... | |
bool | write () |
Write control net to disk. More... | |
void | save (QXmlStreamWriter &stream, const Project *project, FileName newProjectRoot) const |
Method to write this Control object's member data to an XML stream. More... | |
void | copyToNewProjectRoot (const Project *project, FileName newProjectRoot) |
Copies the files of the given Project to the given location. More... | |
void | deleteFromDisk () |
Delete the control net from disk. More... | |
Public Attributes | |
ControlNet * | m_controlNet |
A pointer to the ControlNet object associated with this Control object. More... | |
Private Member Functions | |
Control (const Control &other) | |
Control & | operator= (const Control &rhs) |
Private Attributes | |
bool | m_modified |
ControlDisplayProperties * | m_displayProperties |
Contains the display properties for this Control object. More... | |
Project * | m_project |
QString | m_fileName |
Project associated with this control. More... | |
QUuid * | m_id |
A unique ID for this Control. More... | |
This represents an ISIS control net in a project-based GUI interface.
This encapsulates ideas about a control net such as it's filename and display properties.
2012-08-02 Kimberly Oyama - Added comments to some of the methods and member variables.
2012-09-11 Tracie Sucharski - Added new constructor that takes a ControlNet *.
2015-10-14 Jeffrey Covington - Declared Control * as a Qt metatype for use with QVariant. References #3949
2016-06-02 Jeannie Backer - Updated documentation. Fixes #3949
2017-08-02 Cole Neuabuer - Added new constructor. This constructor takes a Project and a filename of a controlnet. This was added because the Control object needs to assign a mutex when the control net is opened and by doing this internally we can Close control nets and not have to track whether this step has happened Fixes #5026
2017-08-11 Cole Neuabuer - Added try catch throw to make it so importing an invalid control net throws some type of error/warning Fixes #5064
2017-11-09 Tyler Wilson - Modified the copyToNewProjectRoot function so that the control net is copied to it's new location like a binary file, instead of being recreated from scratch by calling it's write method. Fixes #5212.
2017-12-20 Tracie Sucharski - In ::copyToNewProjectRoot use string comparison to compare project roots. References #4804, #4849.
2018-01-19 Tracie Sucharski - Do not copy control unless the project root has changed. References #5212.
2018-03-30 Tracie Sucharski - Added setModified and is Modified methods to keep track of the modification state of the control net. Add write method to write the control net to disk. This write method should be called by ipce classes instead of calling the ControlNet::Write directly so that control knows the state of the control net. If a project is performing a "Save As", and there is a modified active control,the cnet is written out to the new location, it is not save in the old project location.
|
explicit |
Create a Control from control net located on disk.
cNetFileName | The name of the control net on disk |
parent | The Qt-relationship parent |
Definition at line 27 of file Control.cpp.
References _FILEINFO_, m_controlNet, m_displayProperties, m_fileName, m_id, openControlNet(), and Isis::IException::Programmer.
Create a Control from control net located on disk associated with a Project.
cNetFileName | The name of the control net on disk |
parent | The Qt-relationship parent |
Definition at line 56 of file Control.cpp.
References m_controlNet, m_displayProperties, m_fileName, and m_id.
|
explicit |
Create a Control from a control network that has already been created and read from disk.
controlNet | The actual control network |
cnetFileName | The name of the control net on disk |
parent | The Qt-relationship parent |
Definition at line 79 of file Control.cpp.
References controlNet(), m_controlNet, m_displayProperties, m_fileName, and m_id.
Isis::Control::Control | ( | FileName | cnetFolder, |
XmlStackedHandlerReader * | xmlReader, | ||
QObject * | parent = 0 |
||
) |
Construct this control from XML.
cnetFolder | Location of control xml |
xmlReader | An XML reader that's up to an <control> tag. |
parent | The Qt-relationship parent |
Definition at line 103 of file Control.cpp.
References m_controlNet, m_displayProperties, m_id, and Isis::XmlStackedHandlerReader::pushContentHandler().
Isis::Control::~Control | ( | ) |
Destroys Control object.
Definition at line 118 of file Control.cpp.
References m_controlNet, m_displayProperties, and m_id.
|
slot |
Cleans up the ControlNet pointer.
This method should be called once there is no more need for this network because the OS will limit how many of these can be open.
Definition at line 206 of file Control.cpp.
References m_controlNet.
Referenced by Isis::Directory::cleanupCnetEditorViewWidgets(), Isis::ImportControlNetWorkOrder::CreateControlsFunctor::operator()(), and updateFileName().
ControlNet * Isis::Control::controlNet | ( | ) |
Open and return a pointer to the ControlNet for this Control.
Definition at line 142 of file Control.cpp.
References m_controlNet, and openControlNet().
Referenced by Control(), Isis::CnetEditorWidget::control(), Isis::ControlHealthMonitorView::ControlHealthMonitorView(), copyToNewProjectRoot(), Isis::CnetEditorWidget::createConnectionTreeView(), Isis::CnetEditorWidget::createPointTreeView(), Isis::CnetEditorWidget::createSerialTreeView(), Isis::CnetEditorWidget::filteredNetwork(), Isis::MosaicControlNetTool::loadNetwork(), Isis::Project::setActiveImageList(), and Isis::ControlPointEditWidget::setControl().
Copies the files of the given Project to the given location.
project | A pointer to the Project. |
newProjectRoot | The name of the new root directory where the project will be copied. |
Definition at line 286 of file Control.cpp.
References _FILEINFO_, Isis::Project::cnetRoot(), controlNet(), Isis::FileName::dir(), Isis::IException::Io, isModified(), m_fileName, Isis::FileName::name(), Isis::Project::projectRoot(), setModified(), Isis::FileName::toString(), Isis::toString(), write(), and Isis::ControlNet::Write().
Referenced by Isis::ControlList::CopyControlDataFunctor::operator()().
void Isis::Control::deleteFromDisk | ( | ) |
Delete the control net from disk.
The control net will no longer be accessible until you call updateFileName().
IException::Io | "Could not remove file." |
Definition at line 326 of file Control.cpp.
References _FILEINFO_, Isis::IException::Io, and m_fileName.
Referenced by Isis::ControlList::deleteFromDisk().
ControlDisplayProperties * Isis::Control::displayProperties | ( | ) |
Access a pointer to the display properties for the control network.
Definition at line 244 of file Control.cpp.
References m_displayProperties.
Referenced by Isis::Directory::addCnetEditorView(), and Isis::ExportControlNetWorkOrder::setupExecution().
const ControlDisplayProperties * Isis::Control::displayProperties | ( | ) | const |
Access a const pointer to the display properties for the control network.
Definition at line 254 of file Control.cpp.
References m_displayProperties.
QString Isis::Control::fileName | ( | ) | const |
Access the name of the control network file associated with this Control.
Definition at line 264 of file Control.cpp.
References m_fileName.
Referenced by Isis::Project::addControl(), Isis::BundleAdjust::BundleAdjust(), Isis::ExportControlNetWorkOrder::execute(), Isis::JigsawRunWidget::JigsawRunWidget(), Isis::MosaicControlNetTool::openControlNet(), Isis::BundleSolutionInfo::outputControlNetFileName(), Isis::BundleSolutionInfo::save(), Isis::ControlPointEditWidget::setControl(), Isis::ProjectItem::setControl(), Isis::ExportControlNetWorkOrder::setupExecution(), Isis::Control::XmlHandler::startElement(), Isis::BundleSolutionInfo::updateFileName(), and write().
QString Isis::Control::id | ( | ) | const |
Access the unique ID associated with this Control.
Definition at line 274 of file Control.cpp.
References m_id.
Referenced by Isis::Project::addControl(), Isis::ProjectItemModel::onControlAdded(), and Isis::ExportControlNetWorkOrder::setupExecution().
bool Isis::Control::isModified | ( | ) |
Has this control been modified?
Definition at line 221 of file Control.cpp.
Referenced by copyToNewProjectRoot(), and Isis::Project::save().
void Isis::Control::openControlNet | ( | ) |
Sets the ControlNet from the control net file name provided in the constructor.
IException::Programmer | "Error opening control net." |
Definition at line 157 of file Control.cpp.
References _FILEINFO_, m_controlNet, m_fileName, Isis::Project::mutex(), Isis::IException::Programmer, and Isis::ControlNet::SetMutex().
Referenced by Control(), and controlNet().
void Isis::Control::save | ( | QXmlStreamWriter & | stream, |
const Project * | project, | ||
FileName | newProjectRoot | ||
) | const |
Method to write this Control object's member data to an XML stream.
stream | The stream to which the Control will be saved. |
project | The Project to which this Control will be added. |
newProjectRoot | The location of the project root directory. |
Definition at line 365 of file Control.cpp.
References m_displayProperties, m_fileName, and m_id.
Referenced by Isis::BundleSolutionInfo::save().
void Isis::Control::setModified | ( | bool | modified = true | ) |
Sets the modification state of this control.
This is needed for now since many classes make changes to the control net contained in this object, but the control does not know the state of the control net. TODO: Change this class to always know the state of the control Net.
Definition at line 233 of file Control.cpp.
Referenced by copyToNewProjectRoot(), and Isis::CnetEditorWidget::setCnetModified().
|
slot |
Change the on-disk file name for this control to be where the control ought to be in the given project.
project | The project that this control is stored in |
Definition at line 347 of file Control.cpp.
References closeControlNet(), Isis::Project::cnetRoot(), Isis::FileName::dir(), m_fileName, and Isis::FileName::name().
bool Isis::Control::write | ( | ) |
Write control net to disk.
This method is used instead of calling ControlNet::Write directly so that Control knows the modification state of the control net. Note that if there is not a control net opened, there should no be any changes to write.
IException::Programmer | "Cannot write control net to disk" |
Definition at line 183 of file Control.cpp.
References _FILEINFO_, fileName(), m_controlNet, Isis::IException::Programmer, and Isis::ControlNet::Write().
Referenced by copyToNewProjectRoot(), and Isis::Project::save().
ControlNet* Isis::Control::m_controlNet |
A pointer to the ControlNet object associated with this Control object.
Definition at line 82 of file Control.h.
Referenced by closeControlNet(), Control(), controlNet(), openControlNet(), write(), and ~Control().
|
private |
Contains the display properties for this Control object.
Definition at line 140 of file Control.h.
Referenced by Control(), displayProperties(), save(), and ~Control().
|
private |
Project associated with this control.
File name of the control net associated with this control.
Definition at line 143 of file Control.h.
Referenced by Control(), copyToNewProjectRoot(), deleteFromDisk(), fileName(), openControlNet(), save(), and updateFileName().
|
private |