X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=inline;f=vv%2FvvToolBase.h;h=a6629504bb23329e038a9e0ffa56ca0b11fc2d3f;hb=4ea2c946973c570cbe540a27cf44d6acdf44867c;hp=dc62849a32c209ff6ef619e5c9f343ecbe8602a4;hpb=f7dee5f397e4efa933ef32507698ff1c1e573c2e;p=clitk.git
diff --git a/vv/vvToolBase.h b/vv/vvToolBase.h
index dc62849..a662950 100644
--- a/vv/vvToolBase.h
+++ b/vv/vvToolBase.h
@@ -1,139 +1,51 @@
/*=========================================================================
+ Program: vv http://www.creatis.insa-lyon.fr/rio/vv
- Program: vv
- Module: $RCSfile: vvToolBase.h,v $
- Language: C++
- Date: $Date: 2010/01/29 13:54:37 $
- Version: $Revision: 1.1 $
- 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://oncora1.lyon.fnclcc.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 .
-
- =========================================================================*/
+ - 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"
//------------------------------------------------------------------------------
template
-class vvToolBase {
+class vvToolBase : public vvToolBaseBase {
public:
+ vvToolBase(vvMainWindowBase * m);
static void Initialize(); // can't be virtual, must be overwritten
- void UpdateInfoFromMainWindow();
- vvMainWindowToolInfo * mMainWindowToolInfo;
static void SetToolName(QString n) { vvToolCreator::mSingleton->mToolName = n; }
static void SetToolMenuName(QString n) { vvToolCreator::mSingleton->mToolMenuName = n; }
static void SetToolIconFilename(QString n) { vvToolCreator::mSingleton->mToolIconFilename = n; }
static void SetToolTip(QString n) { vvToolCreator::mSingleton->mToolTip = n; }
+ static void SetToolExperimental(bool exp) { vvToolCreator::mSingleton->mExperimental = exp; }
- void InitializeListOfInputImages();
- void InitializeListOfInputImages(vvToolInputSelectorWidget * w,
- clitk::ImageToImageGenericFilterBase * f);
- std::vector mSlicerManagersCompatible;
- unsigned int mCurrentIndex;
+ void AddImage(vvImage::Pointer image,std::string filename) {
+ CREATOR(ToolType)->GetMainWindow()->AddImage(image,filename);
+ }
- vvImage::Pointer mCurrentImage;
- vvSlicerManager * mCurrentSliceManager;
- clitk::ImageToImageGenericFilterBase * mFilter;
+ void setSender(QObject *s) { mSender = s; }
+ protected:
+ QObject * mSender;
};
//------------------------------------------------------------------------------
-
-//------------------------------------------------------------------------------
-template
-void vvToolBase::UpdateInfoFromMainWindow() {
- mMainWindowToolInfo = vvToolCreator::mSingleton->mMainWindow->GetInfoForTool();
-}
-//------------------------------------------------------------------------------
-
-
-//------------------------------------------------------------------------------
-template
-void vvToolBase::Initialize() {
- SetToolName("Unnamed tool");
- SetToolMenuName("Unnamed tool");
- SetToolIconFilename("");
- SetToolTip("Unamed tool.");
-}
-//------------------------------------------------------------------------------
-
-
-//------------------------------------------------------------------------------
-template
-void vvToolBase::InitializeListOfInputImages(vvToolInputSelectorWidget * w,
- clitk::ImageToImageGenericFilterBase * f) {
- mFilter = f;
- InitializeListOfInputImages();
- w->Initialize(mSlicerManagersCompatible, mCurrentIndex);
- w->SetToolTip(mFilter->GetAvailableImageTypes().c_str());
-}
-//------------------------------------------------------------------------------
-
-//------------------------------------------------------------------------------
-template
-void vvToolBase::InitializeListOfInputImages() {
- UpdateInfoFromMainWindow();
-
- std::vector & 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);
- }
-
- //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->CheckDimension(image->GetNumberOfDimensions()) &&
- mFilter->CheckPixelType(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;
- }
- }
- }
-}
-//------------------------------------------------------------------------------
-
+#include "vvToolBase.txx"
#endif