X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FEditorGraphicBBS%2FbbsKernelEditorGraphic%2FGBlackBoxModel.cxx;h=a806ea8d347e44aea9fa3c9a7ce371f6ffc53eaa;hb=7a77e00abe30e71c3a97f7a43b106c999ce9db87;hp=fa165c00025cb01af49b93ed80de4d5cad4abee5;hpb=5df5effdcd9f09c81c68fd63b1f0359593a823bd;p=bbtkGEditor.git diff --git a/lib/EditorGraphicBBS/bbsKernelEditorGraphic/GBlackBoxModel.cxx b/lib/EditorGraphicBBS/bbsKernelEditorGraphic/GBlackBoxModel.cxx index fa165c0..a806ea8 100644 --- a/lib/EditorGraphicBBS/bbsKernelEditorGraphic/GBlackBoxModel.cxx +++ b/lib/EditorGraphicBBS/bbsKernelEditorGraphic/GBlackBoxModel.cxx @@ -28,107 +28,204 @@ Version: $Revision$ * knowledge of the CeCILL-B license and that you accept its terms. * ------------------------------------------------------------------------ */ -/** -* \file -* \brief Class bbtk::GBlackBox -*/ +/**** +* Design and Developpement of BBTK GEditor +* Ricardo A Corredor J +* RaC - 2010 +****/ + #include "GBlackBoxModel.h" namespace bbtk { - - //========================================================================= + GBlackBoxModel::GBlackBoxModel() { + _isExecutable = false; } //========================================================================= + GBlackBoxModel::~GBlackBoxModel() { } - //========================================================================= - void GBlackBoxModel::setInicPoint(double& x, double& y, double& z) + //========================================================================= + + std::string GBlackBoxModel::getBBTKPackage() { - GObjectModel::setInicPoint(x,y,z); - - double xFin=x+BOX_WIDTH,yFin=y-BOX_HEIGHT; - setFinalPoint(xFin,yFin,z); + return _bbtkPackage; } //========================================================================= - void GBlackBoxModel::addInputPort(GPortModel *inputport) + void GBlackBoxModel::setBBTKPackage(std::string obpackage) { - _inputs.push_back(inputport); + _bbtkPackage = obpackage; } //========================================================================= - - void GBlackBoxModel::addOutputPort(GPortModel *outputport) + + bool GBlackBoxModel::isExecutable() { - _outputs.push_back(outputport); + return _isExecutable; } //========================================================================= - int GBlackBoxModel::getNumInputPorts() + void GBlackBoxModel::setExecutable(bool executable) { - return _inputs.size(); + _isExecutable = executable; } //========================================================================= - - int GBlackBoxModel::getNumOutputPorts() + + std::string GBlackBoxModel::getStatusText() { - return _outputs.size(); + std::string temp = ""; + temp+=_bbtkPackage; + temp+=":"; + temp+=_bbtkType; + temp+=":"; + temp+=_bbtkName; + + return temp; } //========================================================================= - void GBlackBoxModel::move(double xx,double yy,double zz) + void GBlackBoxModel::setValueToInputPort(int pos,std::string value) { - setInicPoint(xx,yy,zz); + _inputs[pos]->setValue(value); + } + + //========================================================================= - //Refresh inputs position - int i; - for(i=0;i<_inputs.size();i++) + void GBlackBoxModel::save(std::string &content) + { + content+="BOX\n"; + // Box info + content+=_bbtkPackage; + content+=":"; + content+=_bbtkType; + content+=":"; + content+=_bbtkName; + content+="\n"; + content+="ISEXEC:"; + if(_isExecutable) { - _inputs[i]->updatePortPosition(i); + content+="TRUE"; } - - //Refresh outputs position - for(i=0;i<_outputs.size();i++) + else { - _outputs[i]->updatePortPosition(i); + content+="FALSE"; } + content+="\n"; + + + //Box Position + char buffer [50]; + sprintf (buffer, "%f", _xInic); + content+=buffer; + content+=":"; + sprintf (buffer, "%f", _yInic); + content+=buffer; + content+=":"; + sprintf (buffer, "%f", _zInic); + content+=buffer; + content+="\n"; + + sprintf (buffer, "%f", _xFin); + content+=buffer; + content+=":"; + sprintf (buffer, "%f", _yFin); + content+=buffer; + content+=":"; + sprintf (buffer, "%f", _zFin); + content+=buffer; + content+="\n"; + + //Ports with a value + for(int i = 0; i<(int)_inputs.size();i++) + { + if(_inputs[i]->isValueSet()) + { + _inputs[i]->save(content); + } + } + content+="FIN_BOX\n"; } //========================================================================= - GPortModel* GBlackBoxModel::getStartOutputPort() + void GBlackBoxModel::setValueToInput(std::string name,std::string value) + { + for(int i = 0; i<(int)_inputs.size();i++) + { + if(_inputs[i]->getBBTKName()==name) + { + _inputs[i]->setValue(value); + } + } + } + + //========================================================================= + + std::string GBlackBoxModel::getValueInputPort(int pos) { - GPortModel* temp = NULL; + return _inputs[pos]->getValue(); + } - for(int i=0; i<_inputs.size() && temp == NULL;i++) + //========================================================================= + + std::string GBlackBoxModel::getValueInput(std::string name) + { + for(int i = 0; i<(int)_inputs.size();i++) { - if(_outputs[i]->getState() == CREATING_CONTOUR) + if(_inputs[i]->getBBTKName()==name) { - temp = _outputs[i]; + return _inputs[i]->getValue(); } } + return NULL; + } - return temp; + //========================================================================= + + std::vector GBlackBoxModel::getConnectedInputs() + { + std::vector connected; + for(int i = 0; i<(int)_inputs.size();i++) + { + if(_inputs[i]->isConnected()) + { + connected.push_back(i); + } + } + return connected; } //========================================================================= + std::vector GBlackBoxModel::getConnectedOutputs() + { + std::vector connected; + for(int i = 0; i<(int)_outputs.size();i++) + { + if(_outputs[i]->isConnected()) + { + connected.push_back(i); + } + } + return connected; + } -} // EO namespace bbtk + //========================================================================= +} // EO namespace bbtk // EOF