+/*
+ # ---------------------------------------------------------------------
+ #
+ # 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.
+ # ------------------------------------------------------------------------ */
+
+
/*=========================================================================
Program: bbtk
Module: $RCSfile: bbwxvtkViewer3D.cxx,v $
Language: C++
- Date: $Date: 2009/05/15 14:58:08 $
- Version: $Revision: 1.16 $
-
- Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
- l'Image). All rights reserved. See Doc/License.txt or
- http://www.creatis.insa-lyon.fr/Public/bbtk/License.html for details.
-
- This software is distributed WITHOUT ANY WARRANTY; without even
- the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
- PURPOSE. See the above copyright notices for more information.
-
+ Date: $Date: 2012/11/16 08:52:36 $
+ Version: $Revision: 1.23 $
+
=========================================================================*/
/**
* \file
if (stereo==true){
renderwindow->SetStereoCapableWindow(1);
- //renderwindow->SetStereoTypeToCrystalEyes();
- renderwindow->SetStereoTypeToRedBlue();
+
+// renderwindow->SetStereoTypeToCrystalEyes();
+// renderwindow->SetStereoTypeToRedBlue(); // OK 2.
+
+ renderwindow->SetAnaglyphColorMask(4,3);
+ renderwindow->SetAnaglyphColorSaturation(0.65);
+ renderwindow->SetStereoTypeToAnaglyph(); // OK 1.
+
+// renderwindow->SetStereoTypeToInterlaced(); // ??
+// renderwindow->SetStereoTypeToCheckerboard();
+// renderwindow->SetStereoTypeToDresden();
+
renderwindow->SetStereoRender(1);
}
camera->SetViewUp ( spx*0, -spy*1, spz*0);
camera->SetPosition( spx*(x1+x2)/2, spy*(y1+y2)/2, -spz*10000000);
camera->SetFocalPoint ( spx*(x1+x2)/2 , spy*(y1+y2)/2 , spz*0);
+
+
// camera->SetParallelScale( spx*(x2-x1)/2.0 );
renderer->ResetCamera(x1,x2,y1,y2,z1,z2);
//-------------------------------------------------------------------------
Viewer3DWidget::~Viewer3DWidget()
{
+ mBox->DisableObservers();
+ mBox->bbSetOutputWidget(NULL);
renderwindow->Delete();
renderer->Delete();
interactorstyle->Delete();
bbSetOutputRenderer( NULL );
bbSetOutputInteractor( NULL );
bbSetOutputWidget(NULL);
+ std::vector<double> bckgrndColor(3);
+ bckgrndColor[0] = 0.1;
+ bckgrndColor[1] = 0.1;
+ bckgrndColor[2] = 0.2;
+ bbSetInputBackgroundColor(bckgrndColor);
}
//-----------------------------------------------------------------
//-----------------------------------------------------------------
void Viewer3D::bbUserFinalizeProcessing()
- {
- }
+ {
+ DisableObservers();
+ }
+
+ void Viewer3D::DisableObservers()
+ {
+ Viewer3DWidget* w = (Viewer3DWidget*)bbGetOutputWidget();
+ if (w!=NULL)
+ {
+ vtkRenderWindowInteractor *interactor = w->GetInteractor();
+ if (interactor!=NULL)
+ {
+ if (bbGetInputObs1()!=NULL)
+ {
+ if (bbGetInputObs1()->GetInteractor()!=NULL)
+ bbGetInputObs1()->EnabledOff();
+ }
+ if (bbGetInputObs2()!=NULL)
+ {
+ if (bbGetInputObs2()->GetInteractor()!=NULL)
+ //bbGetInputObs2()->SetInteractor(NULL);
+ bbGetInputObs2()->EnabledOff();
+ }
+ if (bbGetInputObs3()!=NULL)
+ {
+ if (bbGetInputObs3()->GetInteractor()!=NULL)
+ //bbGetInputObs3()->SetInteractor(NULL);
+ bbGetInputObs3()->EnabledOff();
+ }
+ if (bbGetInputObs4()!=NULL)
+ {
+ if (bbGetInputObs4()->GetInteractor()!=NULL)
+ //bbGetInputObs4()->SetInteractor(NULL);
+ bbGetInputObs4()->EnabledOff();
+ }
+ if (bbGetInputObs5()!=NULL)
+ {
+ if (bbGetInputObs5()->GetInteractor()!=NULL)
+ //bbGetInputObs5()->SetInteractor(NULL);
+ bbGetInputObs5()->EnabledOff();
+ }
+ }
+ }
+ }
//--------------------------------------------------------------------------
void Viewer3D::Process()
{
+ if (!bbIsShown()) return;
//EED
// Viewer3DWidget* w = (Viewer3DWidget*)bbGetOutputWidget();
// if (w) w->Update();
-
+
Viewer3DWidget* w = (Viewer3DWidget*)bbGetOutputWidget();
if ((firsttime==true) && (w!=NULL)){
vtkRenderWindowInteractor *interactor = w->GetInteractor();
if (interactor!=NULL)
{
+
if (bbGetInputObs1()!=NULL)
{
bbGetInputObs1()->SetInteractor(interactor);
vtkRenderer *renderer = w->GetRenderer();
if (renderer!=NULL)
{
+ std::vector<double> bckgrndColor = bbGetInputBackgroundColor();
+ renderer->SetBackground(bckgrndColor[0], bckgrndColor[1], bckgrndColor[2]);
bbSetOutputRenderer( renderer );
- if (bbGetInputIn1()!=NULL) {renderer->AddActor( bbGetInputIn1() ); }
+ /*if (bbGetInputIn1()!=NULL) {renderer->AddActor( bbGetInputIn1() ); }
if (bbGetInputIn2()!=NULL) {renderer->AddActor( bbGetInputIn2() ); }
if (bbGetInputIn3()!=NULL) {renderer->AddActor( bbGetInputIn3() ); }
if (bbGetInputIn4()!=NULL) {renderer->AddActor( bbGetInputIn4() ); }
renderer->ResetCamera();
double bounds[6];
renderer->ComputeVisiblePropBounds(bounds);
- renderer->ResetCameraClippingRange(bounds);
+ renderer->ResetCameraClippingRange(bounds);*/
} // renderer
} // w && firsttime
+ if(bbGetOutputRenderer()!=NULL){
+ vtkRenderer *renderer = w->GetRenderer();
+ if (bbGetInputIn1()!=NULL) {renderer->AddActor( bbGetInputIn1() ); }
+ if (bbGetInputIn2()!=NULL) {renderer->AddActor( bbGetInputIn2() ); }
+ if (bbGetInputIn3()!=NULL) {renderer->AddActor( bbGetInputIn3() ); }
+ if (bbGetInputIn4()!=NULL) {renderer->AddActor( bbGetInputIn4() ); }
+ if (bbGetInputIn5()!=NULL) {renderer->AddActor( bbGetInputIn5() ); }
+ renderer->ResetCamera();
+ double bounds[6];
+ renderer->ComputeVisiblePropBounds(bounds);
+ renderer->ResetCameraClippingRange(bounds);
+
+ }
+
if (w!=NULL) w->Update();
}
bbtkDebugMessageInc("Core",9,"Viewer3D::CreateWidget()"<<std::endl);
- Viewer3DWidget* w = new Viewer3DWidget(this,parent,
- //bbGetWxParent(),
- bbGetInputStereo());
- //EED w->Update();
- //...
+ Viewer3DWidget* w = new Viewer3DWidget(this,
+ parent,
+ //bbGetWxParent(),
+ bbGetInputStereo());
+ //EED w->Update();
+ //...
bbSetOutputWidget(w);
// when window is shown
void Viewer3D::OnShowWidget()
{
-
+ Process();
// Viewer3DWidget* w = (Viewer3DWidget*)bbGetOutputWidget();
// if (w) w->Update();
}