]> Creatis software - bbtk.git/blob - packages/vtk/src/bbvtkVolumeRenderer.cxx
Merge branch 'vtk8itk5wx3-mingw64' of ssh://git.creatis.insa-lyon.fr/bbtk into vtk8it...
[bbtk.git] / packages / vtk / src / bbvtkVolumeRenderer.cxx
1 /*
2  # ---------------------------------------------------------------------
3  #
4  # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5  #                        pour la SantÈ)
6  # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
7  # Previous Authors : Laurent Guigues, Jean-Pierre Roux
8  # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9  #
10  #  This software is governed by the CeCILL-B license under French law and
11  #  abiding by the rules of distribution of free software. You can  use,
12  #  modify and/ or redistribute the software under the terms of the CeCILL-B
13  #  license as circulated by CEA, CNRS and INRIA at the following URL
14  #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
15  #  or in the file LICENSE.txt.
16  #
17  #  As a counterpart to the access to the source code and  rights to copy,
18  #  modify and redistribute granted by the license, users are provided only
19  #  with a limited warranty  and the software's author,  the holder of the
20  #  economic rights,  and the successive licensors  have only  limited
21  #  liability.
22  #
23  #  The fact that you are presently reading this means that you have had
24  #  knowledge of the CeCILL-B license and that you accept its terms.
25  # ------------------------------------------------------------------------ */
26
27
28 /*=========================================================================
29   Program:   bbtk
30   Module:    $RCSfile: bbvtkVolumeRenderer.cxx,v $
31   Language:  C++
32   Date:      $Date: 2012/11/16 08:51:58 $
33   Version:   $Revision: 1.6 $
34 =========================================================================*/
35
36 /**
37  *  \file 
38  *  \brief 
39  */
40
41
42
43 #ifdef _USE_VTK_
44
45
46 #include "bbvtkVolumeRenderer.h"
47 #include "bbvtkPackage.h"
48
49 namespace bbvtk
50 {
51
52
53    BBTK_ADD_BLACK_BOX_TO_PACKAGE(vtk,VolumeRenderer)
54    BBTK_BLACK_BOX_IMPLEMENTATION(VolumeRenderer,bbtk::AtomicBlackBox);
55
56
57
58
59
60    void VolumeRenderer::bbUserSetDefaultValues() 
61    { 
62 //EED 2017-01-01 Migration VTK7
63 #if VTK_MAJOR_VERSION <= 5
64            mRayCastFunction = NULL;
65 #else
66         //
67 #endif
68            mMapper                      = NULL;
69            mVolume                      = NULL;
70            bbSetInputColorFunction(0);
71                 bbSetInputColorFunction1(0);
72            bbSetInputOpacityFunction(0);
73    }
74         
75    void VolumeRenderer::bbUserInitializeProcessing() 
76    { 
77
78     // Create the pipeline
79      //    mCast = vtkImageShiftScale::New();
80      //    mCast->SetOutputScalarTypeToUnsignedChar();
81      //    mCast->ClampOverflowOn();
82     
83     //    mMIP = vtkVolumeRayCastMIPFunction::New();
84     //    mMIP->SetMaximizeMethodToScalarValue();
85
86 //EED 2018-07-20 Migration VTK8
87 #if (VTK_MAJOR_VERSION <= 7) 
88     mRayCastFunction = vtkVolumeRayCastCompositeFunction::New();
89     mMapper = vtkVolumeRayCastMapper::New();
90            mMapper->SetVolumeRayCastFunction(mRayCastFunction);
91            mMapper->AutoAdjustSampleDistancesOn();
92 #else 
93           mMapper = vtkFixedPointVolumeRayCastMapper::New();
94 #endif
95                    
96            _volumeProperty = vtkVolumeProperty::New();  
97         _volumeProperty->SetInterpolationTypeToLinear();
98         _volumeProperty->ShadeOn();
99         _volumeProperty->DisableGradientOpacityOn();    
100         //_volumeProperty->SetColor(_ctfun);
101         //_volumeProperty->SetScalarOpacity(_tfun );
102
103     mVolume = vtkVolume::New();
104            mVolume->SetMapper(mMapper);
105            mVolume->SetProperty(_volumeProperty );
106
107     //  mMapper->ScalarVisibilityOff();
108     //    mMapper->ImmediateModeRenderingOn();
109
110 }
111
112         //---------------------------------------------------------------------
113    void VolumeRenderer::bbUserFinalizeProcessing() 
114    { 
115 //EED 2017-01-01 Migration VTK7
116 #if VTK_MAJOR_VERSION <= 5
117            if (mRayCastFunction!=NULL)
118            {
119                    mRayCastFunction->Delete();
120                    mRayCastFunction=NULL;
121            }      
122 #else
123         //
124 #endif
125            if (mMapper!=NULL)
126            {
127                    mMapper->Delete();
128                    mMapper=NULL;
129            }      
130            if (mVolume!=NULL)
131            {
132                    mVolume->Delete();
133                    mVolume=NULL;
134            }      
135
136    }
137 //---------------------------------------------------------------------
138
139 void VolumeRenderer::Process()
140 {
141     bool changed = false;
142     if ( bbGetInputStatus("In") != bbtk::UPTODATE )
143         {
144
145 //EED 2017-01-01 Migration VTK7
146 #if VTK_MAJOR_VERSION <= 5
147                 mMapper->SetInput( bbGetInputIn() );
148 #else
149                 mMapper->SetInputData( bbGetInputIn() );
150 #endif
151                 changed = true;
152     }
153
154         if ( ( bbGetInputStatus("ColorFunction") != bbtk::UPTODATE ) &&
155           ( bbGetInputColorFunction() != 0 ) )
156     {
157                 mVolume->GetProperty()->SetColor( bbGetInputColorFunction() );
158                 changed = true;
159     }
160
161      if ( ( bbGetInputStatus("ColorFunction1") != bbtk::UPTODATE ) &&
162           ( bbGetInputColorFunction1() != 0 ) )
163      {
164                 mVolume->GetProperty()->SetColor( bbGetInputColorFunction1() );
165                 changed = true;
166      }
167
168      if ( ( bbGetInputStatus("OpacityFunction") != bbtk::UPTODATE ) &&
169           ( bbGetInputOpacityFunction() != 0 ) )
170      {
171                 mVolume->GetProperty()->SetScalarOpacity(bbGetInputOpacityFunction());
172                 changed = true;
173      }
174
175         if (changed)
176         { 
177                 mMapper->Update();
178         }
179         bbSetOutputOut(mVolume); 
180 }
181
182
183 }//namespace bbtk
184
185 #endif // _USE_VTK_
186