35 #include <QDomDocument> 39 #include <QTextStream> 40 #include <QApplication> 50 #include <vtkPolyData.h> 51 #include <vtkPointData.h> 66 mDataManager(dataManager),
81 return mSession->getRootFolder();
86 return mSession->isValid();
89 void PatientData::onCleared()
91 mDataManager->clear();
94 void PatientData::onSessionLoad(QDomElement &node)
97 QDomElement dataManagerNode = root.
descend(
"managers/datamanager").
node().toElement();
99 if (!dataManagerNode.isNull())
100 mDataManager->parseXml(dataManagerNode, mSession->getRootFolder());
103 void PatientData::onSessionSave(QDomElement &node)
106 QDomElement managerNode = root.
descend(
"managers").
node().toElement();
108 mDataManager->addXml(managerNode);
113 for (DataManager::ImagesMap::iterator iter = images.begin(); iter != images.end(); ++iter)
115 if(!iter->second->getFilename().isEmpty())
118 customReader->setTransform(iter->second->get_rMd());
126 if (
settings()->value(
"Automation/autoSave").toBool())
132 QString targetFolder = mSession->getRootFolder() +
"/Export/" 136 for (DataManager::ImagesMap::iterator iter = images.begin(); iter != images.end(); ++iter)
138 iter->second->save(targetFolder);
142 for (DataManager::MeshMap::iterator iter = meshes.begin(); iter != meshes.end(); ++iter)
152 mesh = mDataManager->getDataFactory()->createSpecific<
Mesh>(mesh->getUid(), mesh->getName());
154 mesh->setFilename(
"Images");
155 mesh->save(targetFolder);
158 report(
"Exported patient data to " + targetFolder +
".");
163 if (fileName.isEmpty())
165 QString text =
"Import canceled";
167 infoText =
"<font color=red>" + text +
"</font>";
171 QFileInfo fileInfo(fileName);
175 if (mDataManager->getData(uid))
177 QString text =
"Data with uid " + uid +
" already exists. Import canceled.";
179 infoText =
"<font color=red>" + text +
"</font>";
184 DataPtr data = mDataManager->loadData(uid, fileName);
187 QString text =
"Error with data file: " + fileName +
" Import canceled.";
189 infoText =
"<font color=red>" + text +
"</font>";
192 data->setAcquisitionTime(QDateTime::currentDateTime());
194 data->save(mSession->getRootFolder());
197 infoText = infoText.split(
"<br>", QString::SkipEmptyParts).join(
"<br>");
QString getActivePatientFolder() const
void isLoading(QDomElement &root)
emitted while loading a session. Xml storage is available, getRootFolder() is set to loaded value...
XMLNodeAdder descend(QString path)
Transform3D Transform3D
Transform3D is a representation of an affine 3D transform.
cxResource_EXPORT Transform3D createTransformFromReferenceToExternal(PATIENT_COORDINATE_SYSTEM external)
void exportPatient(PATIENT_COORDINATE_SYSTEM externalSpace)
std::map< QString, MeshPtr > MeshMap
QString timestampSecondsFormat()
DataPtr importData(QString fileName, QString &infoText)
Import data into CustusX.
boost::shared_ptr< class DataManager > DataServicePtr
void sessionChanged()
emitted after change to a new session (new or loaded or cleared)
boost::shared_ptr< class Data > DataPtr
boost::shared_ptr< class CustomMetaImage > CustomMetaImagePtr
void reportWarning(QString msg)
void setVtkPolyData(const vtkPolyDataPtr &polyData)
std::map< QString, ImagePtr > ImagesMap
XMLNodeParser descend(QString path)
Settings * settings()
Shortcut for accessing the settings instance.
void cleared()
emitted when session is cleared, before isLoading is called
vtkSmartPointer< vtkPolyData > vtkPolyDataPtr
QString changeExtension(QString name, QString ext)
void removeData(QString uid)
PatientData(DataServicePtr dataManager, SessionStorageServicePtr session)
bool isPatientValid() const
boost::shared_ptr< class Mesh > MeshPtr
void isSaving(QDomElement &root)
xml storage is available
boost::shared_ptr< class SessionStorageService > SessionStorageServicePtr
Namespace for all CustusX production code.