/*=========================================================================
+ Program: vv http://www.creatis.insa-lyon.fr/rio/vv
- Program: vv
- Module: $RCSfile: vvToolBase.h,v $
- Language: C++
- Date: $Date: 2010/02/09 14:19:32 $
- Version: $Revision: 1.2 $
- Author : David Sarrut (david.sarrut@creatis.insa-lyon.fr)
+ Authors belong to:
+ - University of LYON http://www.universite-lyon.fr/
+ - Léon Bérard cancer center http://www.centreleonberard.fr
+ - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr
- Copyright (C) 2008
- Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
- CREATIS http://www.creatis.insa-lyon.fr
+ This software is distributed WITHOUT ANY WARRANTY; without even
+ the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ PURPOSE. See the copyright notices for more information.
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, version 3 of the License.
+ It is distributed under dual licence
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program. If not, see <http://www.gnu.org/licenses/>.
-
- =========================================================================*/
+ - BSD See included LICENSE.txt file
+ - CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+===========================================================================**/
#ifndef VVTOOLBASE_H
#define VVTOOLBASE_H
-#include "vvToolCreatorBase.h"
-#include "vvToolInputSelectorWidget.h"
-#include "clitkImageToImageGenericFilter.h"
+#include "vvToolBaseBase.h"
+#include "vvToolCreator.h"
+#include <QIcon>
//------------------------------------------------------------------------------
template<class ToolType>
-class vvToolBase {
+class vvToolBase : public vvToolBaseBase {
public:
+ vvToolBase(vvMainWindowBase * m);
+ virtual ~vvToolBase() {};
+
static void Initialize(); // can't be virtual, must be overwritten
- void UpdateInfoFromMainWindow();
- vvMainWindowToolInfo * mMainWindowToolInfo;
-
- static void SetToolName(QString n) { vvToolCreator<ToolType>::mSingleton->mToolName = n; }
- static void SetToolMenuName(QString n) { vvToolCreator<ToolType>::mSingleton->mToolMenuName = n; }
- static void SetToolIconFilename(QString n) { vvToolCreator<ToolType>::mSingleton->mToolIconFilename = n; }
- static void SetToolTip(QString n) { vvToolCreator<ToolType>::mSingleton->mToolTip = n; }
-
- void InitializeListOfInputImages();
- void InitializeListOfInputImages(vvToolInputSelectorWidget * w,
- clitk::ImageToImageGenericFilterBase * f);
- std::vector<vvSlicerManager*> mSlicerManagersCompatible;
- unsigned int mCurrentIndex;
-
- vvImage::Pointer mCurrentImage;
- vvSlicerManager * mCurrentSliceManager;
- clitk::ImageToImageGenericFilterBase * mFilter;
-
-};
-//------------------------------------------------------------------------------
-
-
-//------------------------------------------------------------------------------
-template<class ToolType>
-void vvToolBase<ToolType>::UpdateInfoFromMainWindow() {
- mMainWindowToolInfo = vvToolCreator<ToolType>::mSingleton->mMainWindow->GetInfoForTool();
-}
-//------------------------------------------------------------------------------
+ static void SetToolName(QString n) { vvToolCreator<ToolType>::GetInstance()->mToolName = n; }
+ static void SetToolMenuName(QString n) { vvToolCreator<ToolType>::GetInstance()->mToolMenuName = n; }
+ static void SetToolIconFilename(QString n) { vvToolCreator<ToolType>::GetInstance()->mToolIconFilename = n; }
+ static void SetToolTip(QString n) { vvToolCreator<ToolType>::GetInstance()->mToolTip = n; }
+ static void SetToolExperimental(bool exp) { vvToolCreator<ToolType>::GetInstance()->mExperimental = exp; }
+ static void SetToolInMenu(std::string menu) { vvToolCreator<ToolType>::GetInstance()->SetMenuName(menu); }
-//------------------------------------------------------------------------------
-template<class ToolType>
-void vvToolBase<ToolType>::Initialize() {
- SetToolName("Unnamed tool");
- SetToolMenuName("Unnamed tool");
- SetToolIconFilename("");
- SetToolTip("Unamed tool.");
-}
-//------------------------------------------------------------------------------
-
+ static QIcon GetToolIcon() { return QIcon(vvToolCreator<ToolType>::GetInstance()->mToolIconFilename); }
+ static QString & GetToolName() { return vvToolCreator<ToolType>::GetInstance()->mToolName; }
-//------------------------------------------------------------------------------
-template<class ToolType>
-void vvToolBase<ToolType>::InitializeListOfInputImages(vvToolInputSelectorWidget * w,
- clitk::ImageToImageGenericFilterBase * f) {
- mFilter = f;
- InitializeListOfInputImages();
- w->Initialize(mSlicerManagersCompatible, mCurrentIndex);
- w->SetToolTip(mFilter->GetAvailableImageTypes().c_str());
-}
-//------------------------------------------------------------------------------
-
-//------------------------------------------------------------------------------
-template<class ToolType>
-void vvToolBase<ToolType>::InitializeListOfInputImages() {
- UpdateInfoFromMainWindow();
-
- std::vector<vvSlicerManager*> & mSlicerManagers = *mMainWindowToolInfo->mSlicerManagers;
- mCurrentIndex = mMainWindowToolInfo->mSlicerManagerCurrentIndex;
- DD("InputUpdate");
- DD(mCurrentIndex);
- // HERE : Check if image is ok (dimension, type etc ...)
-
- if (mFilter) {
- mFilter->PrintAvailableImageTypes();
-
- }
- else {
- /// if not set, do not check filter type
- std::cerr << "*** ERROR, set mFilter member in the vvTool class before calling InitializeListOfInputImages" << std::endl;
- exit(0);
+ vvSlicerManager * AddImage(vvImage::Pointer image,std::string filename) {
+ return CREATOR(ToolType)->GetMainWindow()->AddImage(image,filename);
}
- //unsigned int previousIndex = mInputSequenceBox->mCurrentIndex();
- mSlicerManagersCompatible.clear();
- // mInputSequenceBox->clear();
- for (unsigned int i = 0; i < mSlicerManagers.size(); i++) {
-
- vvImage * image = mSlicerManagers[i]->GetImage();
-
- if (mFilter->CheckImageType(image->GetNumberOfDimensions(),
- image->GetNumberOfScalarComponents(),
- image->GetScalarTypeAsString())) {
- mSlicerManagersCompatible.push_back(mSlicerManagers[i]);
- if (mCurrentIndex == i) {
- mCurrentIndex = mSlicerManagersCompatible.size()-1;
- }
- }
- else {
- std::cerr << mSlicerManagers[i]->GetFileName().c_str() << " not compatible image" << std::endl;
- if (mCurrentIndex == i) {
- mCurrentIndex = 0;
- }
- }
- }
-}
+ void setSender(QObject *s) { mSender = s; }
+
+ protected:
+ QObject * mSender;
+};
//------------------------------------------------------------------------------
+#include "vvToolBase.txx"
#endif