X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=packages%2Fvtk%2Fsrc%2FbbvtkVecImageGaussianSmooth.cxx;h=a2ccc9a5f9a1eeb8425a5fbffcad9d84881c460d;hb=cfad95b6e08e6e53846ffcda7fbc5932065f2c47;hp=01b9019499783226c8d9f32c25cc346fbce099d0;hpb=1e2df7fb6ae571ce1cf72e6af1715f0e34675cbf;p=bbtk.git diff --git a/packages/vtk/src/bbvtkVecImageGaussianSmooth.cxx b/packages/vtk/src/bbvtkVecImageGaussianSmooth.cxx index 01b9019..a2ccc9a 100644 --- a/packages/vtk/src/bbvtkVecImageGaussianSmooth.cxx +++ b/packages/vtk/src/bbvtkVecImageGaussianSmooth.cxx @@ -1,3 +1,30 @@ +/* + # --------------------------------------------------------------------- + # + # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image + # pour la SantÈ) + # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton + # Previous Authors : Laurent Guigues, Jean-Pierre Roux + # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil + # + # This software is governed by the CeCILL-B license under French law and + # abiding by the rules of distribution of free software. You can use, + # modify and/ or redistribute the software under the terms of the CeCILL-B + # license as circulated by CEA, CNRS and INRIA at the following URL + # http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html + # or in the file LICENSE.txt. + # + # As a counterpart to the access to the source code and rights to copy, + # modify and redistribute granted by the license, users are provided only + # with a limited warranty and the software's author, the holder of the + # economic rights, and the successive licensors have only limited + # liability. + # + # The fact that you are presently reading this means that you have had + # knowledge of the CeCILL-B license and that you accept its terms. + # ------------------------------------------------------------------------ */ + + #include "bbvtkVecImageGaussianSmooth.h" #include "bbvtkPackage.h" @@ -9,58 +36,67 @@ namespace bbvtk BBTK_ADD_BLACK_BOX_TO_PACKAGE(vtk,VecImageGaussianSmooth) BBTK_BLACK_BOX_IMPLEMENTATION(VecImageGaussianSmooth,bbtk::AtomicBlackBox); -void VecImageGaussianSmooth::Process() -{ - vtkImageGaussianSmooth *vtkimagegaussiansmooth; - int i,size = VecVtkimagegaussiansmooth.size(); - for (i=0 ; iDelete(); + + + //--------------------------------------------------------------------- + void VecImageGaussianSmooth::bbUserSetDefaultValues() + { + bbSetInputStdDevX(2); + bbSetInputStdDevY(2); + bbSetInputStdDevZ(2); + bbSetInputiImage(0); } - VecVtkimagegaussiansmooth.clear(); - VecResult.clear(); - - double stdvX=bbGetInputStdDevX(); - double stdvY=bbGetInputStdDevY(); - double stdvZ=bbGetInputStdDevZ(); - size=bbGetInputIn().size(); - for (i=0 ; iSetInput( bbGetInputIn()[i] ); - vtkimagegaussiansmooth->SetStandardDeviation( stdvX,stdvY, stdvZ ); - vtkimagegaussiansmooth->Update(); - VecResult.push_back( vtkimagegaussiansmooth->GetOutput() ); - VecVtkimagegaussiansmooth.push_back(vtkimagegaussiansmooth); - } //for i - bbSetOutputOut(VecResult); - if (bbGetInputiImage() < VecResult.size()) + void VecImageGaussianSmooth::bbUserInitializeProcessing() { - bbSetOutputOutImage(VecResult[bbGetInputiImage()]); - } //if + } -} - -void VecImageGaussianSmooth::bbUserConstructor() -{ - - bbSetInputStdDevX(2); - bbSetInputStdDevY(2); - bbSetInputStdDevZ(2); - - bbSetInputiImage(0); - -} + //--------------------------------------------------------------------- + void VecImageGaussianSmooth::bbUserFinalizeProcessing() + { + int i,size = (int)VecVtkimagegaussiansmooth.size(); + for (i=0 ; iDelete(); + } + VecVtkimagegaussiansmooth.clear(); + } + + + + //--------------------------------------------------------------------- + + void VecImageGaussianSmooth::Process() + { + bbUserFinalizeProcessing(); + + vtkImageGaussianSmooth *vtkimagegaussiansmooth; + VecResult.clear(); -void VecImageGaussianSmooth::bbUserCopyConstructor(bbtk::BlackBox::Pointer) -{ -} + double stdvX=bbGetInputStdDevX(); + double stdvY=bbGetInputStdDevY(); + double stdvZ=bbGetInputStdDevZ(); + + int i,size=(int)bbGetInputIn().size(); + for (i=0 ; iSetInput( bbGetInputIn()[i] ); + vtkimagegaussiansmooth->SetStandardDeviation( stdvX,stdvY, stdvZ ); + vtkimagegaussiansmooth->Update(); + VecResult.push_back( vtkimagegaussiansmooth->GetOutput() ); + VecVtkimagegaussiansmooth.push_back(vtkimagegaussiansmooth); + } //for i + + bbSetOutputOut(VecResult); + if (bbGetInputiImage() < (int)VecResult.size()) + { + bbSetOutputOutImage(VecResult[bbGetInputiImage()]); + } //if + + } -void VecImageGaussianSmooth::bbUserDestructor() -{ -} } // EO namespace bbvtk