X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=packages%2Fvtk%2Fsrc%2FbbvtkPolyDataToActor.cxx;h=fefe8eb5887febd3cfed5989061091eaf8c4a70e;hb=dfcd0b84f01eb96e43c2180a35d626cc123a7231;hp=569bcb25b0832dad19bc1e3dc9f4a38ab9cd4687;hpb=2041845854a8995d3987de68896251ae72cc2eb4;p=bbtk.git diff --git a/packages/vtk/src/bbvtkPolyDataToActor.cxx b/packages/vtk/src/bbvtkPolyDataToActor.cxx index 569bcb2..fefe8eb 100644 --- a/packages/vtk/src/bbvtkPolyDataToActor.cxx +++ b/packages/vtk/src/bbvtkPolyDataToActor.cxx @@ -44,6 +44,13 @@ #include "vtkProperty.h" #include "vtkLinearTransform.h" #include "vtkCleanPolyData.h" +#include "vtkFieldData.h" + +//-- +#include +#include +#include +//-- #include "bbvtkPolyDataToActor.h" #include "bbvtkPackage.h" @@ -73,6 +80,10 @@ namespace bbvtk bbSetInputScalarVisibility(false); polydatamapper = NULL; vtkactor = NULL; + + bbSetInputScalarVisibilityOn_LookupTable(NULL); + bbSetInputScalarVisibilityOn_NameColorArray(""); + bbSetInputIn(NULL); } @@ -81,10 +92,10 @@ namespace bbvtk { polydatamapper = vtkPolyDataMapper::New(); vtkactor = vtkActor::New(); - // polydatamapper->SetInput(marchingcubes->GetOutput()); vtkactor->SetMapper(polydatamapper); +//EED 2020-04-21 vtk8 deprecated // polydatamapper->ImmediateModeRenderingOn(); } @@ -104,99 +115,175 @@ namespace bbvtk } -//--------------------------------------------------------------------- - - void PolyDataToActor::DoProcess() - { - -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -printf("EED WARNNIN!!!!! PolyDataToActor::DoProcess For better transparent ... Clean this code in the correct part ..........\n"); -//https://stackoverflow.com/questions/47528086/problems-with-rendering-transparent-objects-in-vtk -//https://itk.org/Wiki/VTK/Depth_Peeling -bbGetInputRenderer()->SetUseDepthPeeling(1); -bbGetInputRenderer()->SetOcclusionRatio(0.1); -bbGetInputRenderer()->SetMaximumNumberOfPeels(100); -bbGetInputRenderer()->GetRenderWindow()->SetMultiSamples(0); -bbGetInputRenderer()->GetRenderWindow()->SetAlphaBitPlanes(1); - - - if (bbGetInputActive()==true) - { + + +/* +----------------------------------------------- + +https://vtk.org/Wiki/VTK/Examples/Cxx/Visualization/ScalarBarActor +https://vtk.org/Wiki/VTK/Examples/Cxx/VisualizationAlgorithms/TubesFromSplines +https://vtk.org/Wiki/VTK/Examples/Cxx/Visualization/ElevationBandsWithGlyphs + +vtkSmartPointer scalars = vtkSmartPointer::New(); + scalars set value .... +poly->GetPointData()->SetScalars(scalars); or poly->GetPointData()->SetActiveScalars(""); + +vtkSmartPointer hueLut = vtkSmartPoint | ^~ +er::New(); + hueLut Build .... + + mapper->SetInputData(poly); + mapper->ScalarVisibilityOn(); + mapper->SetScalarModeToUsePointData(); Point of Cell ... + + default: mapper->SetColorModeToDirectScalars() Busca scalars 3 componentes [R,G,B] float 0..1 or integer 0..255 + else: + mapper->SetColorModeToMapScalars() El vector scalar solo tiene un componente + mapper->SetLookupTable( hueLut ); + + To change Array + mapper->SelectColorArray(""); + + mapper->SetUseLookupTableScalarRange( true/false ) true:Para compartir lookuptable con otros mappers + si false then + mapper->SetScalarRange( min, max); Range especifico este mapper + mapper->SetScalarRange( tubePolyData->GetScalarRange() ); + +------------------------------------------ + + mapper->ScalarVisibilityOff(); -> SetScalarModeToDefault() + Utiliza el color del actor + +---------------------------------------- + +*/ + + +//--------------------------------------------------------------------- +void PolyDataToActor::DoProcess() +{ + bool ok_removeActor=false; + if (bbGetInputRenderer()==NULL) + { + printf("EED Warnning! PolyDataToActor::DoProcess missing Renderer.\n"); + } + if (bbGetInputActive()==true) + { + if (bbGetInputIn()!=NULL) + { //EED 2017-01-01 Migration VTK7 #if VTK_MAJOR_VERSION <= 5 - polydatamapper->SetInput( bbGetInputIn() ); + polydatamapper->SetInput( bbGetInputIn() ); #else - polydatamapper->SetInputData( bbGetInputIn() ); + polydatamapper->SetInputData( bbGetInputIn() ); #endif - - vtkactor->GetProperty()->SetRepresentation( bbGetInputRepresentation() ); - - if (bbGetInputRepresentation()==0) - { - vtkactor->GetProperty()->SetAmbient(1); - vtkactor->GetProperty()->SetDiffuse(1); - vtkactor->GetProperty()->SetSpecular(0); + vtkactor->GetProperty()->SetRepresentation( bbGetInputRepresentation() ); + if (bbGetInputRepresentation()==0) + { + vtkactor->GetProperty()->SetAmbient(1); + vtkactor->GetProperty()->SetDiffuse(1); + vtkactor->GetProperty()->SetSpecular(0); printf("EED WARNNING! PolyDataToActor::DoProcess which is the default values of Ambient, Diffuse, Specular for points option? \n"); - } else if (bbGetInputRepresentation()==1) - { - vtkactor->GetProperty()->SetAmbient(1); - vtkactor->GetProperty()->SetDiffuse(1); - vtkactor->GetProperty()->SetSpecular(0); - } else if (bbGetInputRepresentation()==2) - { - vtkactor->GetProperty()->SetAmbient(0); - vtkactor->GetProperty()->SetDiffuse(1); - vtkactor->GetProperty()->SetSpecular(0); - } - - vtkactor->GetProperty()->SetLineWidth( bbGetInputLineWidth() ); - - vtkactor->GetProperty()->SetColor( bbGetInputColour()[0], - bbGetInputColour()[1], - bbGetInputColour()[2] ); - - vtkactor->GetProperty()->SetOpacity( bbGetInputOpacity() ); - - - if ( bbGetInputTransform()!=NULL ) - { - vtkactor->SetUserTransform( bbGetInputTransform() ); - } - - bbSetOutputOut( vtkactor ); - - // Interface Update - if ((actorAdded==false) && (bbGetInputRenderer()!=NULL )) - { - actorAdded=true; - bbGetInputRenderer()->AddActor( vtkactor ); - } // actorAdded - - if (bbGetInputScalarVisibility()==true ) - { - polydatamapper->ScalarVisibilityOn(); - } else { - polydatamapper->ScalarVisibilityOff(); - } // ScalarVisibility - } else { - // Interface Update - if ((actorAdded==true) && (bbGetInputRenderer()!=NULL )) - { - actorAdded=false; - bbGetInputRenderer()->RemoveActor( vtkactor ); - } // actorAdded - } // Active - } - - + } else if (bbGetInputRepresentation()==1) + { + vtkactor->GetProperty()->SetAmbient(1); + vtkactor->GetProperty()->SetDiffuse(1); + vtkactor->GetProperty()->SetSpecular(0); + } else if (bbGetInputRepresentation()==2) + { + vtkactor->GetProperty()->SetAmbient(0); + vtkactor->GetProperty()->SetDiffuse(1); + vtkactor->GetProperty()->SetSpecular(0); + } + vtkactor->GetProperty()->SetLineWidth( bbGetInputLineWidth() ); + vtkactor->GetProperty()->SetColor( bbGetInputColour()[0], + bbGetInputColour()[1], + bbGetInputColour()[2] ); + vtkactor->GetProperty()->SetOpacity( bbGetInputOpacity() ); + if ( bbGetInputTransform()!=NULL ) + { + vtkactor->SetUserTransform( bbGetInputTransform() ); + } + bbSetOutputOut( vtkactor ); + + +/* / >>>> + AAAAA + vtkArrowSource *arrow = vtkArrowSource::New(); + vtkPolyDataNormals *normals = vtkPolyDataNormals::New(); + normals->SetInputData( bbGetInputIn() ); + vtkGlyph3D *glyph = vtkGlyph3D::New(); + glyph->SetInputData(normals->GetOutput() ); + glyph->SetSourceData(arrow->GetOutput() ); + glyph->SetVectorModeToUseNormal(); + glyph->SetScaleModeToScaleByVector(); + glyph->SetScaleFactor(10); + vtkPolyDataMapper *mapper2 = vtkPolyDataMapper::New(); + mapper2->SetInputData( glyph->GetOutput() ); + vtkActor *actor2 = vtkActor::New(); + actor2->SetMapper(mapper2); + actor2->GetProperty()->SetColor(1, 0, 0); +*/ + + + + // Interface Update + if ((actorAdded==false) && (bbGetInputRenderer()!=NULL )) + { + actorAdded=true; + bbGetInputRenderer()->AddActor( vtkactor ); +//-- +// bbGetInputRenderer()->AddActor( actor2 ); +//-- + + + } // actorAdded + if (bbGetInputScalarVisibility()==true ) + { + polydatamapper->ScalarVisibilityOn(); + if (bbGetInputScalarVisibilityOn_LookupTable()!=NULL) + { +// polydatamapper->SetScalarModeToDefault(); +// polydatamapper->SetScalarModeToUseCellData(); +// polydatamapper->SetScalarModeToUseCellFieldData(); +// polydatamapper->SetScalarModeToUseFieldData(); // 1/2 hausdorff->SetTargetDistanceMethodToPointToCell(); +// polydatamapper->SetScalarModeToUsePointData(); // * + polydatamapper->SetScalarModeToUsePointFieldData(); + polydatamapper->SetColorModeToMapScalars(); + polydatamapper->SetLookupTable( bbGetInputScalarVisibilityOn_LookupTable() ); + if (bbGetInputScalarVisibilityOn_NameColorArray()!="") + { + polydatamapper->SelectColorArray( bbGetInputScalarVisibilityOn_NameColorArray().c_str() ); + } + if (bbGetInputScalarVisibilityOn_ScalarRange().size()==2) + { + polydatamapper->SetScalarRange( bbGetInputScalarVisibilityOn_ScalarRange()[0] , bbGetInputScalarVisibilityOn_ScalarRange()[1] ); + } + } // if ScalarVisibilityOn_LookupTable + } else { + polydatamapper->ScalarVisibilityOff(); + } // ScalarVisibility + } else { + ok_removeActor=true; +// printf("EED Warnning! PolyDataToActor::DoProcess In (PolyData) not defined. \n" ); + }// if In !=NULL + } else { + ok_removeActor=true; + } // Active + + if (ok_removeActor==true) + { + // Interface Update + if ((actorAdded==true) && (bbGetInputRenderer()!=NULL )) + { + actorAdded=false; + bbGetInputRenderer()->RemoveActor( vtkactor ); + } // actorAdded + } // if ok_removeActor + +} } // EO namespace bbtk