Studio/Visualization/Viewer.h
Namespaces
Name |
---|
shapeworks User usage reporting (telemetry) |
Classes
Name | |
---|---|
class | shapeworks::PickResult |
class | shapeworks::Viewer 3D Viewer |
Source code
#pragma once
#include <Shape.h>
#include <Visualization/ColorMap.h>
#include <Visualization/ColorSchemes.h>
#include <Visualization/SliceView.h>
#include <QPointF>
#include <QSharedPointer>
class vtkRenderer;
class vtkLookupTable;
class vtkRenderWindowInteractor;
class vtkImageData;
class vtkCamera;
class vtkGlyph3D;
class vtkSphereSource;
class vtkArrowSource;
class vtkTransformPolyDataFilter;
class vtkScalarBarActor;
class vtkCornerAnnotation;
class vtkPolyDataMapper;
class vtkActor;
class vtkTransform;
class vtkReverseSense;
class vtkHandleWidget;
class vtkPolygonalSurfacePointPlacer;
class vtkImageSlice;
class vtkImageSliceMapper;
class vtkImageData;
class vtkCellPicker;
class vtkPropPicker;
class vtkColorSeries;
namespace shapeworks {
class Shape;
class Viewer;
class Visualizer;
class StudioInteractorStyle;
class LandmarkWidget;
class PlaneWidget;
class PaintWidget;
class Session;
typedef QSharedPointer<Viewer> ViewerHandle;
typedef QVector<ViewerHandle> ViewerList;
class PickResult {
public:
Shape::Point pos_;
int domain_ = -1;
int subject_ = -1;
};
class Viewer {
public:
Viewer();
~Viewer() = default;
void set_renderer(vtkSmartPointer<vtkRenderer> renderer);
vtkSmartPointer<vtkRenderer> get_renderer();
void display_shape(std::shared_ptr<Shape> shape);
void update_annotations();
void clear_viewer();
void reset_camera(std::array<double, 3> c);
void reset_camera();
void set_color_series(ColorMap color_series);
void set_glyph_size_and_quality(double size, double quality);
double get_glyph_size();
double get_glyph_quality();
void set_session(QSharedPointer<Session> session);
QSharedPointer<Session> get_session();
void set_show_glyphs(bool show);
void set_show_surface(bool show);
void set_scale_arrows(bool scale);
void update_points();
void update_glyph_properties();
int handle_pick(int* click_pos);
PickResult handle_ctrl_click(int* click_pos);
void set_selected_point(int id);
void set_glyph_lut(vtkSmartPointer<vtkLookupTable> lut);
void set_loading_screen(vtkSmartPointer<vtkImageData> loading_screen);
void set_color_scheme(int i);
void handle_new_mesh();
bool is_viewer_ready();
void set_visualizer(Visualizer* visualizer);
void update_feature_range(double* range);
void reset_feature_range();
void update_opacities();
std::shared_ptr<Shape> get_shape();
void update_landmarks();
void update_planes();
void update_paint_mode();
std::vector<vtkSmartPointer<vtkActor>> get_surface_actors();
std::vector<vtkSmartPointer<vtkActor>> get_unclipped_surface_actors();
MeshGroup get_meshes();
vtkSmartPointer<vtkTransform> get_transform(int alignment_domain, int domain);
vtkSmartPointer<vtkTransform> get_landmark_transform(int domain);
vtkSmartPointer<vtkTransform> get_inverse_landmark_transform(int domain);
vtkSmartPointer<vtkTransform> get_image_transform();
SliceView& slice_view();
void update_image_volume(bool force = false);
vtkSmartPointer<vtkPoints> get_glyph_points();
vtkSmartPointer<vtkTransform> get_alignment_transform();
void update_clipping_planes();
vtkSmartPointer<vtkPolygonalSurfacePointPlacer> get_point_placer();
void handle_paint(double display_pos[2], double world_pos[3]);
static bool is_reverse(vtkSmartPointer<vtkTransform> transform);
void update_actors();
void remove_scalar_bar();
bool is_ready() { return mesh_ready_; }
vtkFloatArray* get_particle_scalars();
vtkSmartPointer<vtkPolyData> get_particle_poly_data();
void insert_compare_meshes();
void set_scalar_visibility(vtkSmartPointer<vtkPolyData> poly_data, vtkSmartPointer<vtkPolyDataMapper> mapper,
std::string scalar);
vtkSmartPointer<vtkLookupTable> get_surface_lut() { return surface_lut_; }
bool showing_feature_map();
private:
void initialize_surfaces();
void display_vector_field();
void compute_point_differences(const Eigen::VectorXd& points, vtkSmartPointer<vtkFloatArray> magnitudes,
vtkSmartPointer<vtkFloatArray> vectors);
void compute_surface_differences(vtkSmartPointer<vtkFloatArray> magnitudes, vtkSmartPointer<vtkFloatArray> vectors);
void update_difference_lut(float r0, float r1);
std::string get_displayed_feature_map();
vtkSmartPointer<vtkPlane> transform_plane(vtkSmartPointer<vtkPlane> plane, vtkSmartPointer<vtkTransform> transform);
bool visible_ = false;
std::shared_ptr<Shape> shape_;
bool show_glyphs_ = true;
bool show_surface_ = true;
double glyph_size_ = 1.0f;
double glyph_quality_ = 5.0f;
bool scale_arrows_{true};
ColorMap color_series_;
vtkSmartPointer<vtkRenderer> renderer_;
vtkSmartPointer<vtkSphereSource> sphere_source_;
vtkSmartPointer<vtkReverseSense> reverse_sphere_;
vtkSmartPointer<vtkPoints> glyph_points_;
vtkSmartPointer<vtkPolyData> glyph_point_set_;
vtkSmartPointer<vtkGlyph3D> glyphs_;
vtkSmartPointer<vtkPolyDataMapper> glyph_mapper_;
vtkSmartPointer<vtkActor> glyph_actor_;
std::vector<vtkSmartPointer<vtkPolyDataMapper>> surface_mappers_;
std::vector<vtkSmartPointer<vtkActor>> surface_actors_;
std::vector<vtkSmartPointer<vtkPolyDataMapper>> unclipped_surface_mappers_;
std::vector<vtkSmartPointer<vtkActor>> unclipped_surface_actors_;
std::vector<vtkSmartPointer<vtkLookupTable>> ffc_luts_;
// for comparing to other shapes (e.g. original vs groomed)
std::vector<vtkSmartPointer<vtkPolyDataMapper>> compare_mappers_;
std::vector<vtkSmartPointer<vtkActor>> compare_actors_;
vtkSmartPointer<vtkLookupTable> glyph_lut_;
vtkSmartPointer<vtkLookupTable> surface_lut_;
vtkSmartPointer<vtkArrowSource> arrow_source_;
vtkSmartPointer<vtkTransformPolyDataFilter> arrow_flip_filter_;
vtkSmartPointer<vtkGlyph3D> arrow_glyphs_;
vtkSmartPointer<vtkPolyDataMapper> arrow_glyph_mapper_;
vtkSmartPointer<vtkActor> arrow_glyph_actor_;
vtkSmartPointer<vtkTransform> transform_180_;
vtkSmartPointer<vtkScalarBarActor> scalar_bar_actor_;
vtkSmartPointer<vtkCornerAnnotation> corner_annotation_;
bool arrows_visible_ = false;
ColorSchemes color_schemes_;
int scheme_ = 0;
bool mesh_ready_ = false;
bool viewer_ready_ = false;
bool loading_displayed_ = false;
MeshGroup meshes_;
MeshGroup compare_meshes_;
Visualizer* visualizer_{nullptr};
int number_of_domains_ = 0;
double lut_min_ = 0;
double lut_max_ = 0;
std::shared_ptr<LandmarkWidget> landmark_widget_;
std::shared_ptr<PlaneWidget> plane_widget_;
vtkSmartPointer<PaintWidget> paint_widget_;
QSharedPointer<Session> session_;
std::string current_image_name_ = "-none-";
vtkSmartPointer<vtkCellPicker> cell_picker_;
vtkSmartPointer<vtkPropPicker> prop_picker_;
vtkSmartPointer<vtkPolygonalSurfacePointPlacer> point_placer_;
vtkSmartPointer<vtkImageActorPointPlacer> slice_point_placer_;
// slice viewer
SliceView slice_view_{this};
};
} // namespace shapeworks
Updated on 2024-11-11 at 19:51:46 +0000