Changeset 257c77 for src/UIElements
- Timestamp:
- Jun 17, 2010, 2:55:56 PM (15 years ago)
- Branches:
- Action_Thermostats, Add_AtomRandomPerturbation, Add_FitFragmentPartialChargesAction, Add_RotateAroundBondAction, Add_SelectAtomByNameAction, Added_ParseSaveFragmentResults, AddingActions_SaveParseParticleParameters, Adding_Graph_to_ChangeBondActions, Adding_MD_integration_tests, Adding_ParticleName_to_Atom, Adding_StructOpt_integration_tests, AtomFragments, Automaking_mpqc_open, AutomationFragmentation_failures, Candidate_v1.5.4, Candidate_v1.6.0, Candidate_v1.6.1, ChangeBugEmailaddress, ChangingTestPorts, ChemicalSpaceEvaluator, CombiningParticlePotentialParsing, Combining_Subpackages, Debian_Package_split, Debian_package_split_molecuildergui_only, Disabling_MemDebug, Docu_Python_wait, EmpiricalPotential_contain_HomologyGraph, EmpiricalPotential_contain_HomologyGraph_documentation, Enable_parallel_make_install, Enhance_userguide, Enhanced_StructuralOptimization, Enhanced_StructuralOptimization_continued, Example_ManyWaysToTranslateAtom, Exclude_Hydrogens_annealWithBondGraph, FitPartialCharges_GlobalError, Fix_BoundInBox_CenterInBox_MoleculeActions, Fix_ChargeSampling_PBC, Fix_ChronosMutex, Fix_FitPartialCharges, Fix_FitPotential_needs_atomicnumbers, Fix_ForceAnnealing, Fix_IndependentFragmentGrids, Fix_ParseParticles, Fix_ParseParticles_split_forward_backward_Actions, Fix_PopActions, Fix_QtFragmentList_sorted_selection, Fix_Restrictedkeyset_FragmentMolecule, Fix_StatusMsg, Fix_StepWorldTime_single_argument, Fix_Verbose_Codepatterns, Fix_fitting_potentials, Fixes, ForceAnnealing_goodresults, ForceAnnealing_oldresults, ForceAnnealing_tocheck, ForceAnnealing_with_BondGraph, ForceAnnealing_with_BondGraph_continued, ForceAnnealing_with_BondGraph_continued_betteresults, ForceAnnealing_with_BondGraph_contraction-expansion, FragmentAction_writes_AtomFragments, FragmentMolecule_checks_bonddegrees, GeometryObjects, Gui_Fixes, Gui_displays_atomic_force_velocity, ImplicitCharges, IndependentFragmentGrids, IndependentFragmentGrids_IndividualZeroInstances, IndependentFragmentGrids_IntegrationTest, IndependentFragmentGrids_Sole_NN_Calculation, JobMarket_RobustOnKillsSegFaults, JobMarket_StableWorkerPool, JobMarket_unresolvable_hostname_fix, MoreRobust_FragmentAutomation, ODR_violation_mpqc_open, PartialCharges_OrthogonalSummation, PdbParser_setsAtomName, PythonUI_with_named_parameters, QtGui_reactivate_TimeChanged_changes, Recreated_GuiChecks, Rewrite_FitPartialCharges, RotateToPrincipalAxisSystem_UndoRedo, SaturateAtoms_findBestMatching, SaturateAtoms_singleDegree, StoppableMakroAction, Subpackage_CodePatterns, Subpackage_JobMarket, Subpackage_LinearAlgebra, Subpackage_levmar, Subpackage_mpqc_open, Subpackage_vmg, Switchable_LogView, ThirdParty_MPQC_rebuilt_buildsystem, TrajectoryDependenant_MaxOrder, TremoloParser_IncreasedPrecision, TremoloParser_MultipleTimesteps, TremoloParser_setsAtomName, Ubuntu_1604_changes, stable
- Children:
- b47bfc
- Parents:
- 992fd7 (diff), 5f5a7b (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the(diff)
links above to see all the changes relative to each parent. - Location:
- src/UIElements
- Files:
-
- 11 added
- 2 deleted
- 12 edited
- 28 moved
Legend:
- Unmodified
- Added
- Removed
-
src/UIElements/Dialog.cpp
r992fd7 r257c77 6 6 */ 7 7 8 #include "Helpers/MemDebug.hpp" 9 8 10 #include <cassert> 9 11 10 #include "UIElements/Dialog.hpp" 11 12 #include "Dialog.hpp" 13 14 #include "atom.hpp" 15 #include "element.hpp" 16 #include "molecule.hpp" 12 17 #include "vector.hpp" 13 18 … … 46 51 retval &= (*iter)->handle(); 47 52 // if any query fails (is canceled), we can end the handling process 48 if(!retval) 53 if(!retval) { 54 DoeLog(1) && (eLog() << Verbose(1) << "The following query failed: " << (**iter).getTitle() << "." << endl); 49 55 break; 56 } 50 57 } 51 58 return retval; … … 62 69 63 70 // Base class 64 Dialog::Query::Query(string _title) : 65 title(_title) 71 Dialog::Query::Query(string _title, string _description) : 72 title(_title), 73 description(_description) 66 74 {} 67 75 … … 72 80 } 73 81 82 const std::string Dialog::Query::getDescription() const{ 83 return description; 84 } 85 // empty Queries 86 87 Dialog::EmptyQuery::EmptyQuery(string title, std::string description) : 88 Query(title, description) 89 {} 90 91 Dialog::EmptyQuery::~EmptyQuery() {} 92 93 void Dialog::EmptyQuery::setResult() { 94 } 95 74 96 // Int Queries 75 97 76 Dialog::IntQuery::IntQuery(string title,int *_target ) :77 Query(title ), target(_target)98 Dialog::IntQuery::IntQuery(string title,int *_target, std::string description) : 99 Query(title, description), target(_target) 78 100 {} 79 101 … … 84 106 } 85 107 108 // Int Queries 109 110 Dialog::BooleanQuery::BooleanQuery(string title,bool *_target, std::string description) : 111 Query(title, description), target(_target) 112 {} 113 114 Dialog::BooleanQuery::~BooleanQuery() {} 115 116 void Dialog::BooleanQuery::setResult() { 117 *target = tmp; 118 } 119 86 120 // String Queries 87 121 88 Dialog::StringQuery::StringQuery(string title,string *_target) : 89 Query(title), 90 target(_target), 91 tmp("") 122 Dialog::StringQuery::StringQuery(string title,string *_target, std::string _description) : 123 Query(title, _description), target(_target) 92 124 {} 93 125 … … 100 132 // Double Queries 101 133 102 Dialog::DoubleQuery::DoubleQuery(string title,double *_target ) :103 Query(title ), target(_target)134 Dialog::DoubleQuery::DoubleQuery(string title,double *_target, std::string _description) : 135 Query(title, _description), target(_target) 104 136 {} 105 137 … … 111 143 112 144 145 // Atom Queries 146 147 Dialog::AtomQuery::AtomQuery(string title, atom **_target, std::string _description) : 148 Query(title, _description), 149 tmp(0), 150 target(_target) 151 152 {} 153 154 Dialog::AtomQuery::~AtomQuery() {} 155 156 void Dialog::AtomQuery::setResult() { 157 *target = tmp; 158 } 159 113 160 // Molecule Queries 114 161 115 Dialog::MoleculeQuery::MoleculeQuery(string title, molecule **_target, MoleculeListClass *_molecules) :116 Query(title ),162 Dialog::MoleculeQuery::MoleculeQuery(string title, molecule **_target, std::string _description) : 163 Query(title, _description), 117 164 tmp(0), 118 molecules(_molecules),119 165 target(_target) 120 166 … … 129 175 // Vector Queries 130 176 131 Dialog::VectorQuery::VectorQuery(std::string title,Vector *_target,const double *const _cellSize,bool _check ) :132 Query(title ),177 Dialog::VectorQuery::VectorQuery(std::string title,Vector *_target,const double *const _cellSize,bool _check, std::string _description) : 178 Query(title, _description), 133 179 cellSize(_cellSize), 134 180 check(_check), 135 181 target(_target) 136 182 { 137 tmp = new Vector();183 tmp = new Vector(); 138 184 } 139 185 … … 147 193 } 148 194 195 // Box Queries 196 197 Dialog::BoxQuery::BoxQuery(std::string title, double ** const _cellSize, std::string _description) : 198 Query(title, _description), 199 target(_cellSize) 200 { 201 tmp = new double[6]; 202 } 203 204 Dialog::BoxQuery::~BoxQuery() 205 { 206 delete[] tmp; 207 } 208 209 void Dialog::BoxQuery::setResult() { 210 for (int i=0;i<6;i++) { 211 (*target)[i] = tmp[i]; 212 } 213 } 214 149 215 // Element Queries 150 Dialog::ElementQuery::ElementQuery(std::string title, const element **_target) : 151 Query(title), 152 tmp(0), 216 Dialog::ElementQuery::ElementQuery(std::string title, std::vector<element *> *_target, std::string _description) : 217 Query(title, _description), 153 218 target(_target) 154 219 {} … … 157 222 158 223 void Dialog::ElementQuery::setResult(){ 159 *target= tmp;160 } 224 *target=elements; 225 } -
src/UIElements/Dialog.hpp
r992fd7 r257c77 11 11 #include<string> 12 12 #include<list> 13 #include<vector> 13 14 14 class MoleculeListClass; 15 class atom; 16 class element; 15 17 class molecule; 16 18 class Vector; 17 class element;18 19 19 20 class Dialog … … 23 24 virtual ~Dialog(); 24 25 25 virtual void queryInt(const char *, int *)=0; 26 virtual void queryDouble(const char*,double *)=0; 27 virtual void queryString(const char*, std::string *)=0; 28 virtual void queryMolecule(const char*,molecule**,MoleculeListClass*)=0; 29 virtual void queryVector(const char*,Vector *,const double *const,bool)=0; 30 virtual void queryElement(const char*,const element **)=0; 26 virtual void queryEmpty(const char *, std::string = "")=0; 27 virtual void queryBoolean(const char *, bool *, std::string = "")=0; 28 virtual void queryInt(const char *, int *, std::string = "")=0; 29 virtual void queryDouble(const char*,double *, std::string = "")=0; 30 virtual void queryString(const char*, std::string *, std::string = "")=0; 31 virtual void queryAtom(const char*,atom**,std::string = "")=0; 32 virtual void queryMolecule(const char*,molecule**, std::string = "")=0; 33 virtual void queryVector(const char*,Vector *,const double *const,bool, std::string = "")=0; 34 virtual void queryBox(const char*,double ** const, std::string = "")=0; 35 virtual void queryElement(const char*, std::vector<element *> *, std::string = "")=0; 31 36 32 37 virtual bool display(); … … 48 53 //base class for all queries 49 54 class Query { 55 friend class Dialog; 50 56 public: 51 Query(std::string _title );57 Query(std::string _title, std::string _description = ""); 52 58 virtual ~Query(); 53 59 virtual bool handle()=0; … … 55 61 protected: 56 62 const std::string getTitle() const; 63 const std::string getDescription() const; 57 64 private: 58 std::string title; 65 std::string title; //!< short title of the query 66 std::string description; //!< longer description for tooltips or for help 67 }; 68 69 // Empty Query is just meant for showing text, such as version, help, initial message or alike 70 class EmptyQuery : public Query { 71 public: 72 EmptyQuery(std::string title, std::string _description = ""); 73 virtual ~EmptyQuery(); 74 virtual bool handle()=0; 75 virtual void setResult(); 59 76 }; 60 77 61 78 //Specialized classes for certain types. GUI-Types are not specialized at this time 79 class BooleanQuery : public Query { 80 public: 81 BooleanQuery(std::string title,bool *_target, std::string _description = ""); 82 virtual ~BooleanQuery(); 83 virtual bool handle()=0; 84 virtual void setResult(); 85 protected: 86 bool tmp; 87 private: 88 bool *target; 89 }; 90 62 91 class IntQuery : public Query { 63 92 public: 64 IntQuery(std::string title,int *_target );93 IntQuery(std::string title,int *_target, std::string _description = ""); 65 94 virtual ~IntQuery(); 66 95 virtual bool handle()=0; … … 74 103 class DoubleQuery : public Query { 75 104 public: 76 DoubleQuery(std::string title,double *_target );105 DoubleQuery(std::string title,double *_target, std::string _description = ""); 77 106 virtual ~DoubleQuery(); 78 107 virtual bool handle()=0; … … 86 115 class StringQuery : public Query { 87 116 public: 88 StringQuery(std::string title,std::string *_target );117 StringQuery(std::string title,std::string *_target, std::string _description = ""); 89 118 virtual ~StringQuery(); 90 119 virtual bool handle()=0; … … 96 125 }; 97 126 98 99 127 class MoleculeQuery : public Query { 100 128 public: 101 MoleculeQuery(std::string title, molecule **_target, MoleculeListClass *_molecules);129 MoleculeQuery(std::string title, molecule **_target, std::string _description = ""); 102 130 virtual ~MoleculeQuery(); 103 131 virtual bool handle()=0; … … 105 133 protected: 106 134 molecule *tmp; 107 MoleculeListClass *molecules;108 135 private: 109 136 molecule **target; 110 137 }; 111 138 139 class AtomQuery : public Query { 140 public: 141 AtomQuery(std::string title, atom **_target, std::string _description = ""); 142 virtual ~AtomQuery(); 143 virtual bool handle()=0; 144 virtual void setResult(); 145 protected: 146 atom *tmp; 147 private: 148 atom **target; 149 }; 150 112 151 class VectorQuery : public Query { 113 152 public: 114 VectorQuery(std::string title,Vector *_target,const double *const _cellSize,bool _check );153 VectorQuery(std::string title,Vector *_target,const double *const _cellSize,bool _check, std::string _description = ""); 115 154 virtual ~VectorQuery(); 116 155 virtual bool handle()=0; … … 124 163 }; 125 164 165 class BoxQuery : public Query { 166 public: 167 BoxQuery(std::string title,double ** const _cellSize, std::string _description = ""); 168 virtual ~BoxQuery(); 169 virtual bool handle()=0; 170 virtual void setResult(); 171 protected: 172 double *tmp; 173 private: 174 double **target; 175 }; 176 126 177 class ElementQuery : public Query { 127 178 public: 128 ElementQuery(std::string title, const element**_target);179 ElementQuery(std::string title, std::vector<element *> *_target, std::string _description = ""); 129 180 virtual ~ElementQuery(); 130 181 virtual bool handle()=0; 131 182 virtual void setResult(); 132 183 protected: 133 const element *tmp;184 std::vector<element *> elements; 134 185 private: 135 const element **target;186 std::vector<element *> * const target; 136 187 }; 137 188 … … 143 194 }; 144 195 196 145 197 #endif /* DIALOG_HPP_ */ -
src/UIElements/MainWindow.cpp
r992fd7 r257c77 6 6 */ 7 7 8 #include "UIElements/MainWindow.hpp"9 8 #include "Helpers/MemDebug.hpp" 9 10 #include "MainWindow.hpp" 10 11 11 12 MainWindow::MainWindow() -
src/UIElements/MainWindow.hpp
r992fd7 r257c77 25 25 }; 26 26 27 /**28 * The type of menuPopulators29 */30 typedef void (*MenuMaker)(Menu*,MoleculeListClass*, config*, periodentafel*);31 32 /**33 * This contains all Functions that are used to create the menus.34 * Needs a specific funtion for each menu. All populators will be called35 * by the UIFactory upon creation of the main menu. Thus the actuall construction36 * of the Menus can be kept independent of the concrete type of UI that is being37 * built.38 */39 struct menuPopulaters{40 MenuMaker MakeEditMoleculesMenu;41 };42 27 43 28 #endif /* MAINWINDOW_HPP_ */ -
src/UIElements/Menu/ActionMenuItem.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include <iostream> -
src/UIElements/Menu/DisplayMenuItem.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include <sstream> -
src/UIElements/Menu/Menu.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include "Menu.hpp" -
src/UIElements/Menu/MenuItem.cpp
r992fd7 r257c77 6 6 */ 7 7 8 8 #include "Helpers/MemDebug.hpp" 9 9 10 10 #include "Menu/MenuItem.hpp" -
src/UIElements/Menu/SeperatorItem.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 9 7 10 #include <string> 8 11 #include <sstream> -
src/UIElements/Menu/SubMenuItem.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include "SubMenuItem.hpp" -
src/UIElements/Menu/TextMenu.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include <boost/bind.hpp> -
src/UIElements/QT4/QTDialog.cpp
r992fd7 r257c77 21 21 #include <Qt/qcombobox.h> 22 22 23 #include "Helpers/MemDebug.hpp" 24 23 25 #include "World.hpp" 24 26 #include "periodentafel.hpp" … … 26 28 #include "element.hpp" 27 29 #include "molecule.hpp" 28 #include " Helpers/MemDebug.hpp"30 #include "Descriptors/MoleculeIdDescriptor.hpp" 29 31 30 32 … … 76 78 /************************** Query Infrastructure ************************/ 77 79 78 void QTDialog::queryInt(const char *title, int *target) 80 void QTDialog::queryEmpty(char const*, string){ 81 // TODO 82 ASSERT(false, "Not implemented yet"); 83 } 84 85 void QTDialog::queryBoolean(char const*, bool*,string){ 86 // TODO 87 ASSERT(false, "Not implemented yet"); 88 } 89 90 void QTDialog::queryAtom(char const*, atom**, string){ 91 // TODO 92 ASSERT(false, "Not implemented yet"); 93 } 94 95 void QTDialog::queryBox(char const*, double**, string){ 96 // TODO 97 ASSERT(false, "Not implemented yet"); 98 } 99 100 101 void QTDialog::queryInt(const char *title, int *target,string) 79 102 { 80 103 registerQuery(new IntQTQuery(title,target,inputLayout,this)); 81 104 } 82 105 83 void QTDialog::queryDouble(const char* title, double* target ){106 void QTDialog::queryDouble(const char* title, double* target,string){ 84 107 registerQuery(new DoubleQTQuery(title,target,inputLayout,this)); 85 108 } 86 109 87 void QTDialog::queryString(const char* title, std::string *target )110 void QTDialog::queryString(const char* title, std::string *target,string) 88 111 { 89 112 registerQuery(new StringQTQuery(title,target,inputLayout,this)); 90 113 } 91 114 92 void QTDialog::queryMolecule(const char *title,molecule **target, MoleculeListClass *molecules)93 { 94 registerQuery(new MoleculeQTQuery(title,target, molecules,inputLayout,this));95 } 96 97 void QTDialog::queryVector(const char* title, Vector *target,const double *const cellSize, bool check ) {115 void QTDialog::queryMolecule(const char *title,molecule **target,string) 116 { 117 registerQuery(new MoleculeQTQuery(title,target,inputLayout,this)); 118 } 119 120 void QTDialog::queryVector(const char* title, Vector *target,const double *const cellSize, bool check,string) { 98 121 registerQuery(new VectorQTQuery(title,target,cellSize,check,inputLayout,this)); 99 122 } 100 123 101 void QTDialog::queryElement(const char* title, const element **target){124 void QTDialog::queryElement(const char* title, std::vector<element *> *target,string){ 102 125 registerQuery(new ElementQTQuery(title,target,inputLayout,this)); 103 126 } … … 189 212 } 190 213 191 QTDialog::MoleculeQTQuery::MoleculeQTQuery(string _title, molecule **_target, MoleculeListClass *_molecules, QBoxLayout *_parent,QTDialog *_dialog) : 192 Dialog::MoleculeQuery(_title,_target,_molecules), 193 parent(_parent) 194 { 195 MoleculeList::iterator iter; 214 QTDialog::MoleculeQTQuery::MoleculeQTQuery(string _title, molecule **_target, QBoxLayout *_parent,QTDialog *_dialog) : 215 Dialog::MoleculeQuery(_title,_target), 216 parent(_parent) 217 { 196 218 thisLayout = new QHBoxLayout(); 197 219 titleLabel = new QLabel(QString(getTitle().c_str())); 198 220 inputBox = new QComboBox(); 199 221 // add all molecules to the combo box 200 for(iter = molecules->ListOfMolecules.begin(); 201 iter != molecules->ListOfMolecules.end(); 222 vector<molecule*> molecules = World::getInstance().getAllMolecules(); 223 for(vector<molecule*>::iterator iter = molecules.begin(); 224 iter != molecules.end(); 202 225 ++iter) { 203 226 stringstream sstr; … … 209 232 thisLayout->addWidget(inputBox); 210 233 211 pipe = new MoleculeQTQueryPipe(&tmp,_dialog,inputBox ,_molecules);234 pipe = new MoleculeQTQueryPipe(&tmp,_dialog,inputBox); 212 235 pipe->update(inputBox->currentIndex()); 213 236 connect(inputBox,SIGNAL(currentIndexChanged(int)),pipe,SLOT(update(int))); … … 263 286 264 287 265 QTDialog::ElementQTQuery::ElementQTQuery(std::string _title, const element **_target, QBoxLayout *_parent, QTDialog *_dialog) :288 QTDialog::ElementQTQuery::ElementQTQuery(std::string _title, vector<element *> *_target, QBoxLayout *_parent, QTDialog *_dialog) : 266 289 Dialog::ElementQuery(_title,_target), 267 290 parent(_parent) … … 283 306 thisLayout->addWidget(inputBox); 284 307 285 pipe = new ElementQTQueryPipe(& tmp,_dialog,inputBox);308 pipe = new ElementQTQueryPipe(&elements,_dialog,inputBox); 286 309 pipe->update(inputBox->currentIndex()); 287 310 connect(inputBox,SIGNAL(currentIndexChanged(int)),pipe,SLOT(update(int))); … … 338 361 } 339 362 340 MoleculeQTQueryPipe::MoleculeQTQueryPipe(molecule **_content, QTDialog *_dialog, QComboBox *_theBox , MoleculeListClass *_molecules) :363 MoleculeQTQueryPipe::MoleculeQTQueryPipe(molecule **_content, QTDialog *_dialog, QComboBox *_theBox) : 341 364 content(_content), 342 365 dialog(_dialog), 343 theBox(_theBox), 344 molecules(_molecules) 366 theBox(_theBox) 345 367 {} 346 368 … … 351 373 QVariant data = theBox->itemData(newIndex); 352 374 int idx = data.toInt(); 353 (*content) = molecules->ReturnIndex(idx);354 dialog->update(); 355 } 356 357 ElementQTQueryPipe::ElementQTQueryPipe( const element **_content, QTDialog *_dialog, QComboBox *_theBox) :375 (*content) = World::getInstance().getMolecule(MoleculeById(idx)); 376 dialog->update(); 377 } 378 379 ElementQTQueryPipe::ElementQTQueryPipe(std::vector<element *> *_content, QTDialog *_dialog, QComboBox *_theBox) : 358 380 content(_content), 359 381 dialog(_dialog), 360 382 theBox(_theBox) 361 {} 383 { 384 content->resize(1); 385 } 362 386 363 387 ElementQTQueryPipe::~ElementQTQueryPipe() … … 367 391 QVariant data = theBox->itemData(newIndex); 368 392 int idx = data.toInt(); 369 (*content) = World::getInstance().getPeriode()->FindElement(idx);370 dialog->update(); 371 } 372 393 (*content)[0] = World::getInstance().getPeriode()->FindElement(idx); 394 dialog->update(); 395 } 396 -
src/UIElements/QT4/QTDialog.hpp
r992fd7 r257c77 35 35 virtual ~QTDialog(); 36 36 37 virtual void queryInt(const char *, int *); 38 virtual void queryString(const char*, std::string *); 39 virtual void queryDouble(const char*,double *); 40 virtual void queryMolecule(const char*,molecule**,MoleculeListClass*); 41 virtual void queryVector(const char*,Vector *,const double *const,bool); 42 virtual void queryElement(const char*,const element **); 37 virtual void queryEmpty(const char*, std::string); 38 virtual void queryBoolean(const char *, bool *, std::string = ""); 39 virtual void queryInt(const char *, int *,std::string = ""); 40 virtual void queryDouble(const char*,double *,std::string = ""); 41 virtual void queryString(const char*, std::string *,std::string = ""); 42 virtual void queryAtom(const char*,atom**,std::string = ""); 43 virtual void queryMolecule(const char*,molecule**,std::string = ""); 44 virtual void queryVector(const char*,Vector *,const double *const,bool,std::string = ""); 45 virtual void queryBox(const char*,double ** const, std::string = ""); 46 virtual void queryElement(const char*,std::vector<element *> *_target,std::string = ""); 43 47 44 48 virtual bool display(); … … 91 95 class MoleculeQTQuery : public Dialog::MoleculeQuery { 92 96 public: 93 MoleculeQTQuery(std::string _title, molecule **_target, MoleculeListClass *_molecules,QBoxLayout *_parent,QTDialog *_dialog);97 MoleculeQTQuery(std::string _title, molecule **_target, QBoxLayout *_parent,QTDialog *_dialog); 94 98 virtual ~MoleculeQTQuery(); 95 99 virtual bool handle(); … … 122 126 class ElementQTQuery : public Dialog::ElementQuery { 123 127 public: 124 ElementQTQuery(std::string _title, const element **_target, QBoxLayout *_parent, QTDialog *_dialog);128 ElementQTQuery(std::string _title, std::vector<element *> *_target, QBoxLayout *_parent, QTDialog *_dialog); 125 129 virtual ~ElementQTQuery(); 126 130 virtual bool handle(); … … 193 197 Q_OBJECT 194 198 public: 195 MoleculeQTQueryPipe(molecule **_content, QTDialog *_dialog, QComboBox *_theBox , MoleculeListClass *_molecules);199 MoleculeQTQueryPipe(molecule **_content, QTDialog *_dialog, QComboBox *_theBox); 196 200 virtual ~MoleculeQTQueryPipe(); 197 201 … … 201 205 private: 202 206 molecule **content; 203 MoleculeListClass *molecules;204 207 QTDialog *dialog; 205 208 QComboBox *theBox; … … 210 213 Q_OBJECT 211 214 public: 212 ElementQTQueryPipe( const element **_content, QTDialog *_dialog, QComboBox *_theBox);215 ElementQTQueryPipe(std::vector<element *> *_content, QTDialog *_dialog, QComboBox *_theBox); 213 216 virtual ~ElementQTQueryPipe(); 214 217 … … 217 220 218 221 private: 219 const element **content;222 std::vector<element *> *content; 220 223 QTDialog *dialog; 221 224 QComboBox *theBox; -
src/UIElements/QT4/QTMainWindow.cpp
r992fd7 r257c77 29 29 using namespace std; 30 30 31 QTMainWindow::QTMainWindow( menuPopulaters populaters,MoleculeListClass *molecules, config *configuration, periodentafel *periode, char *ConfigFileName,QApplication *_theApp) :31 QTMainWindow::QTMainWindow(QApplication *_theApp) : 32 32 theApp(_theApp) 33 33 { … … 35 35 QSplitter *splitter2 = new QSplitter (Qt::Vertical, splitter1 ); 36 36 37 worldDisplay = new QTWorldView( molecules,splitter2);37 worldDisplay = new QTWorldView(splitter2); 38 38 39 39 moleculeDisplay = new QTMoleculeView(); … … 48 48 statusBar = new QTStatusBar(this); 49 49 setStatusBar(statusBar); 50 51 editMoleculesMenu = new QTMenu("Edit Molecules");52 populaters.MakeEditMoleculesMenu(editMoleculesMenu,molecules,configuration,periode);53 menuBar()->addMenu(editMoleculesMenu);54 50 55 51 connect(worldDisplay,SIGNAL(moleculeSelected(molecule*)),moleculeDisplay,SLOT(moleculeSelected(molecule*))); -
src/UIElements/QT4/QTMainWindow.hpp
r992fd7 r257c77 24 24 25 25 public: 26 QTMainWindow(menuPopulaters populaters,MoleculeListClass *molecules, config *configuration, 27 periodentafel *periode, char *ConfigFileName, QApplication *_theApp); 26 QTMainWindow(QApplication *_theApp); 28 27 virtual ~QTMainWindow(); 29 28 -
src/UIElements/QT4/QTUIFactory.cpp
r992fd7 r257c77 41 41 } 42 42 43 MainWindow* QTUIFactory::makeMainWindow( menuPopulaters populaters,MoleculeListClass *molecules, config *configuration, periodentafel *periode, char *ConfigFileName) {44 return new QTMainWindow( populaters,molecules,configuration,periode,ConfigFileName,app);43 MainWindow* QTUIFactory::makeMainWindow() { 44 return new QTMainWindow(app); 45 45 } 46 46 -
src/UIElements/QT4/QTUIFactory.hpp
r992fd7 r257c77 21 21 22 22 virtual Dialog* makeDialog(); 23 virtual MainWindow* makeMainWindow( menuPopulaters,MoleculeListClass *, config *, periodentafel *, char *);23 virtual MainWindow* makeMainWindow(); 24 24 25 25 struct description : public UIFactory::factoryDescription { -
src/UIElements/TextUI/TextStatusIndicator.cpp
r992fd7 r257c77 6 6 */ 7 7 8 #include "TextStatusIndicator.hpp" 8 #include "Helpers/MemDebug.hpp" 9 10 #include "TextUI/TextStatusIndicator.hpp" 9 11 10 12 #include <iostream> … … 14 16 using namespace std; 15 17 16 TextStatusIndicator::TextStatusIndicator() 18 TextStatusIndicator::TextStatusIndicator() : 19 Observer("TextStatusIndicator") 17 20 { 18 21 Process::AddObserver(this); -
src/UIElements/TextUI/TextUIFactory.cpp
r992fd7 r257c77 6 6 */ 7 7 8 #include "UIElements/TextUIFactory.hpp" 9 #include "UIElements/TextWindow.hpp" 10 #include "UIElements/TextDialog.hpp" 11 #include "Helpers/MemDebug.hpp" 8 #include "UIElements/TextUI/TextUIFactory.hpp" 9 #include "UIElements/TextUI/TextWindow.hpp" 10 #include "UIElements/TextUI/TextDialog.hpp" 12 11 13 12 TextUIFactory::TextUIFactory() … … 22 21 } 23 22 24 MainWindow* TextUIFactory::makeMainWindow( menuPopulaters populaters,MoleculeListClass *molecules, config *configuration, periodentafel *periode, char *ConfigFileName) {25 return new TextWindow( populaters,molecules,configuration,periode,ConfigFileName);23 MainWindow* TextUIFactory::makeMainWindow() { 24 return new TextWindow(); 26 25 } 27 26 -
src/UIElements/TextUI/TextUIFactory.hpp
r992fd7 r257c77 9 9 #define TEXTUIFACTORY_HPP_ 10 10 11 #include "UI Elements/UIFactory.hpp"11 #include "UIFactory.hpp" 12 12 13 13 class TextUIFactory : public UIFactory … … 19 19 20 20 virtual Dialog* makeDialog(); 21 virtual MainWindow* makeMainWindow( menuPopulaters,MoleculeListClass *, config *, periodentafel *, char *);21 virtual MainWindow* makeMainWindow(); 22 22 23 23 struct description : public UIFactory::factoryDescription { -
src/UIElements/TextUI/TextWindow.cpp
r992fd7 r257c77 6 6 */ 7 7 8 #include "UIElements/TextWindow.hpp" 8 #include "Helpers/MemDebug.hpp" 9 10 #include "TextUI/TextWindow.hpp" 9 11 10 12 #include <boost/bind.hpp> … … 24 26 #include "linkedcell.hpp" 25 27 #include "log.hpp" 26 #include "memoryusageobserver unittest.hpp"28 #include "memoryusageobserver.hpp" 27 29 #include "molecule.hpp" 28 30 #include "periodentafel.hpp" 31 #include "World.hpp" 29 32 30 33 #include "Legacy/oldmenu.hpp" … … 36 39 #include "Menu/DisplayMenuItem.hpp" 37 40 #include "Menu/SubMenuItem.hpp" 38 #include " UIElements/TextStatusIndicator.hpp"41 #include "TextUI/TextStatusIndicator.hpp" 39 42 #include "Actions/MethodAction.hpp" 43 #include "Actions/MoleculeAction/ChangeNameAction.hpp" 40 44 #include "Actions/ErrorAction.hpp" 41 45 #include "Actions/ActionRegistry.hpp" … … 49 53 50 54 // TODO: see what code can be moved to a base class for Graphic and Text Windows 51 TextWindow::TextWindow( menuPopulaters populaters,MoleculeListClass *molecules, config *configuration, periodentafel *periode, char *ConfigFileName)55 TextWindow::TextWindow() 52 56 { 57 MoleculeListClass *molecules = World::getInstance().getMolecules(); 58 config *configuration = World::getInstance().getConfig(); 59 periodentafel *periode = World::getInstance().getPeriode(); 60 char *ConfigFileName = NULL; 53 61 old_menu = new oldmenu; 54 62 … … 102 110 // call all functions used to build the submenus 103 111 104 populate rs.MakeEditMoleculesMenu(editMoleculesMenu,molecules,configuration,periode);112 populateEditMoleculesMenu(editMoleculesMenu); 105 113 106 114 Action *returnFromEditMoleculeAction = new TextMenu::LeaveAction(editMoleculesMenu); … … 126 134 main_menu->display(); 127 135 } 136 137 void TextWindow::populateEditMoleculesMenu(Menu* editMoleculesMenu) 138 { 139 MoleculeListClass *molecules = World::getInstance().getMolecules(); 140 periodentafel *periode = World::getInstance().getPeriode(); 141 142 // build the EditMoleculesMenu 143 Action *createMoleculeAction = new MethodAction("createMoleculeAction",boost::bind(&MoleculeListClass::createNewMolecule,molecules,periode)); 144 new ActionMenuItem('c',"create new molecule",editMoleculesMenu,createMoleculeAction); 145 146 Action *loadMoleculeAction = new MethodAction("loadMoleculeAction",boost::bind(&MoleculeListClass::loadFromXYZ,molecules,periode)); 147 new ActionMenuItem('l',"load molecule from xyz file",editMoleculesMenu,loadMoleculeAction); 148 149 Action *changeFilenameAction = new MoleculeChangeNameAction(); 150 new ActionMenuItem('n',"change molecule's name",editMoleculesMenu,changeFilenameAction); 151 152 Action *giveFilenameAction = new MethodAction("giveFilenameAction",boost::bind(&MoleculeListClass::setMoleculeFilename,molecules)); 153 new ActionMenuItem('N',"give molecules filename",editMoleculesMenu,giveFilenameAction); 154 155 Action *parseAtomsAction = new MethodAction("parseAtomsAction",boost::bind(&MoleculeListClass::parseXYZIntoMolecule,molecules)); 156 new ActionMenuItem('p',"parse atoms in xyz file into molecule",editMoleculesMenu,parseAtomsAction); 157 158 Action *eraseMoleculeAction = new MethodAction("eraseMoleculeAction",boost::bind(&MoleculeListClass::eraseMolecule,molecules)); 159 new ActionMenuItem('r',"remove a molecule",editMoleculesMenu,eraseMoleculeAction); 160 161 } -
src/UIElements/TextUI/TextWindow.hpp
r992fd7 r257c77 9 9 #define TEXTWINDOW_HPP_ 10 10 11 #include " UIElements/MainWindow.hpp"11 #include "MainWindow.hpp" 12 12 13 13 class TextMenu; … … 17 17 class TextStatusIndicator; 18 18 19 19 20 class TextWindow : public MainWindow 20 21 { 21 22 public: 22 TextWindow( menuPopulaters,MoleculeListClass *, config *, periodentafel *, char *);23 TextWindow(); 23 24 virtual ~TextWindow(); 24 25 25 26 virtual void display(); 26 27 private: 28 // populaters 29 void populateEditMoleculesMenu(Menu* editMoleculesMenu); 30 27 31 TextMenu *main_menu; 28 32 -
src/UIElements/UIFactory.cpp
r992fd7 r257c77 6 6 */ 7 7 8 #include "Helpers/MemDebug.hpp" 8 9 9 10 #include <utility> -
src/UIElements/UIFactory.hpp
r992fd7 r257c77 11 11 class MainWindow; 12 12 class Dialog; 13 14 class MoleculeListClass; 15 class config; 16 class periodentafel; 17 18 struct menuPopulaters; 13 class DialogDescription; 19 14 20 15 #include "Patterns/Singleton.hpp" … … 39 34 * Produce some kind of main window, of whichever type was chosen when the factory was created 40 35 */ 41 virtual MainWindow* makeMainWindow( menuPopulaters,MoleculeListClass *, config *, periodentafel *, char *)=0;36 virtual MainWindow* makeMainWindow()=0; 42 37 43 38 /** -
src/UIElements/Views/MethodStringView.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include "MethodStringView.hpp" -
src/UIElements/Views/StreamStringView.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include <sstream> -
src/UIElements/Views/StringView.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include "StringView.hpp" -
src/UIElements/Views/View.cpp
r992fd7 r257c77 5 5 * Author: crueger 6 6 */ 7 8 #include "Helpers/MemDebug.hpp" 7 9 8 10 #include "View.hpp"
Note:
See TracChangeset
for help on using the changeset viewer.