Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018 #include "mitkRenderWindow.h"
00019
00020 #include <mitkDataNodeFactory.h>
00021 #include <mitkStandaloneDataStorage.h>
00022 #include <mitkProperties.h>
00023 #include <mitkTransferFunction.h>
00024 #include <mitkTransferFunctionProperty.h>
00025 #include <mitkRenderingManager.h>
00026 #include <mitkGlobalInteraction.h>
00027
00028 #include <itksys/SystemTools.hxx>
00029
00030 #include "vtkRenderWindow.h"
00031 #include "vtkRenderWindowInteractor.h"
00032 #include "vtkAnnotatedCubeActor.h"
00033 #include "vtkOrientationMarkerWidget.h"
00034 #include "vtkProperty.h"
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048
00049
00050
00051 int main(int argc, char* argv[])
00052 {
00053 if(argc<2)
00054 {
00055 fprintf( stderr, "Usage: %s [filename1] [filename2] ...\n\n", itksys::SystemTools::GetFilenameName(argv[0]).c_str() );
00056 return 1;
00057 }
00058
00059
00060
00061
00062
00063
00064 mitk::StandaloneDataStorage::Pointer ds = mitk::StandaloneDataStorage::New();
00065
00066
00067
00068
00069 int i;
00070 for(i=1; i<argc; ++i)
00071 {
00072
00073 if(strcmp(argv[i], "-testing")==0) continue;
00074
00075
00076
00077 mitk::DataNodeFactory::Pointer nodeReader=mitk::DataNodeFactory::New();
00078 const char * filename = argv[i];
00079 try
00080 {
00081 nodeReader->SetFileName(filename);
00082 nodeReader->Update();
00083
00084
00085
00086
00087
00088
00089
00090 mitk::DataNode::Pointer node = nodeReader->GetOutput();
00091 ds->Add(node);
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104 mitk::Image::Pointer image = dynamic_cast<mitk::Image*>(node->GetData());
00105 if(image.IsNotNull())
00106 {
00107
00108 node->SetProperty("volumerendering", mitk::BoolProperty::New(true));
00109
00110
00111 mitk::TransferFunction::Pointer tf = mitk::TransferFunction::New();
00112 tf->InitializeByMitkImage ( image );
00113
00114
00115 tf->GetColorTransferFunction()->AddRGBPoint ( tf->GetColorTransferFunction()->GetRange() [0], 1.0, 0.0, 0.0 );
00116 tf->GetColorTransferFunction()->AddRGBPoint ( tf->GetColorTransferFunction()->GetRange() [1], 1.0, 1.0, 0.0 );
00117
00118
00119 tf->GetScalarOpacityFunction()->AddPoint ( 0, 0 );
00120 tf->GetScalarOpacityFunction()->AddPoint ( tf->GetColorTransferFunction()->GetRange() [1], 1 );
00121
00122 node->SetProperty ( "TransferFunction", mitk::TransferFunctionProperty::New ( tf.GetPointer() ) );
00123 }
00124
00125
00126
00127
00128
00129 }
00130 catch(...)
00131 {
00132 fprintf( stderr, "Could not open file %s \n\n", filename );
00133 exit(2);
00134 }
00135 }
00136
00137
00138
00139
00140
00141
00142
00143 mitk::GlobalInteraction::GetInstance()->Initialize("global");
00144
00145
00146 mitk::RenderWindow::Pointer mitkRenWin = mitk::RenderWindow::New();
00147
00148
00149 mitkRenWin->GetRenderer()->SetDataStorage(ds);
00150
00151
00152
00153
00154
00155
00156 mitkRenWin->GetRenderer()->SetMapperID(mitk::BaseRenderer::Standard2D);
00157
00158
00159
00160 mitkRenWin->GetRenderer()->SetMapperID(mitk::BaseRenderer::Standard3D);
00161
00162
00163
00164
00165
00166
00167
00168
00169
00170
00171 vtkAnnotatedCubeActor* cube = vtkAnnotatedCubeActor::New();
00172 cube->SetXPlusFaceText("R");
00173 cube->SetXMinusFaceText("L");
00174 cube->SetYPlusFaceText("A");
00175 cube->SetYMinusFaceText("P");
00176 cube->SetZPlusFaceText("I");
00177 cube->SetZMinusFaceText("S");
00178
00179 cube->SetXFaceTextRotation(180);
00180 cube->SetYFaceTextRotation(180);
00181 cube->SetZFaceTextRotation(-90);
00182
00183 cube->GetCubeProperty()->SetColor(0.5,1,1);
00184 cube->GetTextEdgesProperty()->SetLineWidth(1);
00185 cube->GetTextEdgesProperty()->SetDiffuse(0);
00186 cube->GetTextEdgesProperty()->SetAmbient(1);
00187 cube->GetTextEdgesProperty()->SetColor(0.18,0.28,0.23);
00188
00189 vtkOrientationMarkerWidget* widget = vtkOrientationMarkerWidget::New();
00190 widget->SetOutlineColor(0.93, 0.57, 0.13);
00191 widget->SetOrientationMarker(cube);
00192
00193 widget->SetInteractor(mitkRenWin->GetVtkRenderWindow()->GetInteractor());
00194 widget->SetEnabled(1);
00195
00196
00197
00198 mitkRenWin->GetVtkRenderWindow()->SetSize(400, 400);
00199 mitkRenWin->GetVtkRenderWindow()->Render();
00200
00201 mitkRenWin->GetVtkRenderWindowInteractor()->Start();
00202
00203 return 0;
00204 }
00205