]> Creatis software - creaMaracasVisu.git/blob - bbtk/src/bbcreaMaracasVisuVolumeRendering.cxx
0a9305baa0425f3173072da0d3ed16609c5b5faa
[creaMaracasVisu.git] / bbtk / src / bbcreaMaracasVisuVolumeRendering.cxx
1 #include "bbcreaMaracasVisuVolumeRendering.h"
2 #include "bbcreaMaracasVisuPackage.h"
3
4 #include "wxMaracasMultipleVolumeRendererView.h"
5
6 namespace bbcreaMaracasVisu
7 {
8
9 BBTK_ADD_BLACK_BOX_TO_PACKAGE(creaMaracasVisu,VolumeRendering)
10 BBTK_BLACK_BOX_IMPLEMENTATION(VolumeRendering,bbtk::WxBlackBox);
11 void VolumeRendering::Process()
12 {
13  
14 // THE MAIN PROCESSING METHOD BODY 
15 //   Here we simply set the input 'In' value to the output 'Out' 
16 //   And print out the output value 
17 // INPUT/OUTPUT ACCESSORS ARE OF THE FORM : 
18 //    void bbSet{Input|Output}NAME(const TYPE&) 
19 //    const TYPE& bbGet{Input|Output}NAME() const  
20 //    Where : 
21 //    * NAME is the name of the input/output 
22 //      (the one provided in the attribute 'name' of the tag 'input') 
23 //    * TYPE is the C++ type of the input/output 
24 //      (the one provided in the attribute 'type' of the tag 'input') 
25         wxMaracasMultipleVolumeRendererView* volview = (wxMaracasMultipleVolumeRendererView*)bbGetOutputWidget();
26         vtkImageData* _img1 = bbGetInputIn0();
27         vtkImageData* _img2 = bbGetInputIn1();
28         vtkImageData* _img3 = bbGetInputIn2();
29         vtkImageData* _img4 = bbGetInputIn3();
30         vtkRenderer* renderer = bbGetInputRenderer();
31
32         if(volview!=NULL){
33                 if(renderer!=NULL&&_currentrenderer != renderer){
34                         volview->setRenderer(renderer);                 
35                         _currentrenderer = renderer;
36                 }
37                 if(_currentrenderer!=NULL){
38                         if(_img1 !=NULL){
39                         volview->addVolume(_img1, "INPUT 1");
40                         }
41                         if(_img2 !=NULL){
42                                 volview->addVolume(_img2, "INPUT 2");
43                         }
44                         if(_img3 !=NULL){
45                                 volview->addVolume(_img3, "INPUT 3");
46                         }
47                         if(_img4 !=NULL){
48                                 volview->addVolume(_img4, "INPUT 4");
49                         }
50                 }       
51
52                 vtkImageData* img1 = volview->GetOutputImages()[0];
53
54                 bbSetOutputOut0(img1);
55                 bbSetOutputOut1(volview->GetOutputImages()[1]);
56                 bbSetOutputOut2(volview->GetOutputImages()[2]);
57                 bbSetOutputOut3(volview->GetOutputImages()[3]);
58         } 
59         
60         
61         
62
63 }
64 void VolumeRendering::CreateWidget(wxWindow* parent)
65 {
66         wxMaracasMultipleVolumeRendererView* volview = wxMaracasMultipleVolumeRendererView::getInstance(parent);
67         bbSetOutputWidget(volview);
68 }
69 void VolumeRendering::bbUserSetDefaultValues()
70 {
71  
72 //  SET HERE THE DEFAULT INPUT/OUTPUT VALUES OF YOUR BOX  
73 //  Here we initialize the input 'In' to 0 
74     bbSetInputIn0(0); 
75     bbSetInputIn1(0); 
76     bbSetInputIn2(0); 
77     bbSetInputIn3(0); 
78     bbSetInputRenderer(0);  
79   
80 }
81 void VolumeRendering::bbUserInitializeProcessing()
82
83         _currentrenderer = NULL;
84 }
85 void VolumeRendering::bbUserFinalizeProcessing()
86 {
87  
88 //  THE FINALIZATION METHOD BODY : 
89 //    Here does nothing  
90 //    but this is where you should desallocate the internal/output pointers  
91 //    if any 
92   
93 }
94 }
95 // EO namespace bbcreaMaracasVisu
96