DGtal 1.3.0
Loading...
Searching...
No Matches
Display3DFactory.h
1
17#pragma once
18
31#if defined(Display3DFactory_RECURSES)
32#error Recursive header files inclusion detected in Display3DFactory.h
33#else // defined(Display3DFactory_RECURSES)
35#define Display3DFactory_RECURSES
36
37#if !defined Display3DFactory_h
39#define Display3DFactory_h
40
42// Inclusions
43
44#include "DGtal/helpers/StdDefs.h"
45#include "DGtal/base/Common.h"
46
47#include "DGtal/io/DrawWithDisplay3DModifier.h"
48#include "DGtal/geometry/curves/StandardDSS6Computer.h"
49#include "DGtal/geometry/curves/Naive3DDSSComputer.h"
50#include "DGtal/kernel/sets/DigitalSetBySTLSet.h"
51#include "DGtal/kernel/sets/DigitalSetBySTLVector.h"
52#include "DGtal/kernel/domains/HyperRectDomain.h"
53#include "DGtal/topology/KhalimskySpaceND.h"
54#include "DGtal/topology/Object.h"
55#include "DGtal/kernel/PointVector.h"
56#include "DGtal/geometry/curves/GridCurve.h"
57#include "DGtal/shapes/Mesh.h"
58#include "DGtal/geometry/tools/SphericalAccumulator.h"
59#include "DGtal/io/colormaps/GradientColorMap.h"
60#include "DGtal/io/colormaps/HueShadeColorMap.h"
61#include "DGtal/io/colormaps/CColorMap.h"
62#include "DGtal/images/ImageContainerBySTLVector.h"
63#include "DGtal/images/ImageContainerBySTLMap.h"
64#include "DGtal/images/ConstImageAdapter.h"
65#include "DGtal/images/ImageAdapter.h"
66#include "DGtal/helpers/StdDefs.h"
67#include "DGtal/topology/CanonicSCellEmbedder.h"
68#include "DGtal/dec/VectorField.h"
69#include "DGtal/dec/KForm.h"
70#include "DGtal/dec/DiscreteExteriorCalculus.h"
71
72#include "DGtal/kernel/sets/DigitalSetByAssociativeContainer.h"
73
74//
76
77namespace DGtal
78{
80 // struct Display3DFactory
85 template <typename TSpace=Z3i::Space, typename TKSpace=Z3i::KSpace>
87 {
88
90 BOOST_STATIC_CONSTANT(unsigned int, POINT_AS_BALL_RADIUS = 5);
92 BOOST_STATIC_CONSTANT(unsigned int, POINT_AS_BALL_RES = 5);
93
94 typedef TSpace Space;
95 typedef TKSpace KSpace;
98 typedef typename Display::RealPoint RealPoint;
100
101 // DiscreteExteriorCalculus
102 template <Dimension dimEmbedded, Dimension dimAmbient, typename TLinearAlgebraBackend, typename TInteger>
103 static
104 void
106 // DiscreteExteriorCalculus
107
108 // KForm
109 template <typename Calculus, DGtal::Order order, DGtal::Duality duality>
110 static
111 void
112 draw(Display3D<Space, KSpace>& display, const DGtal::KForm<Calculus, order, duality>& kform, double cmap_min = 0, double cmap_max = 0);
113
114 template <typename Calculus, DGtal::Order order, DGtal::Duality duality, typename ColorMap>
115 static
116 void
118 // KForm
119
120 // VectorField
121 template <typename Calculus, DGtal::Duality duality>
122 static
123 void
124 draw(Display3D<Space, KSpace>& display, const DGtal::VectorField<Calculus, duality>& vector_field, const double& scale = 0.5, const double& epsilon = 1e-5, const DGtal::Color color = DGtal::Color::Black);
125 // VectorField
126
127 // SphericalAccumulator
139 template <typename TVector>
140 static void draw( Display & display, const DGtal::SphericalAccumulator<TVector> & accumulator,
142 const double radius=1.0);
143 // SphericalAccumulator
144
145 // Mesh
151 template <typename TPoint>
152 static void drawAsFaces( Display & display, const DGtal::Mesh<TPoint> & aMesh);
153
159 template <typename TPoint>
160 static void draw( Display & display, const DGtal::Mesh<TPoint> & aMesh);
161 // Mesh
162
163
164 // StandardDSS6Computer
171 template <typename TIterator, typename TInteger, int connectivity>
173
179 template <typename TIterator, typename TInteger, int connectivity>
181
187 template <typename TIterator, typename TInteger, int connectivity>
189
195 template <typename TIterator, typename TInteger, int connectivity>
197 // StandardDSS6Computer
198
199 // Naive3DDSSComputer
207 template <typename TIterator, typename TInteger, int connectivity>
209
215 template <typename TIterator, typename TInteger, int connectivity>
217
223 template <typename TIterator, typename TInteger, int connectivity>
225
231 template <typename TIterator, typename TInteger, int connectivity>
233 // Naive3DDSSComputer
234
235
236 // DigitalSetByAssociativeContainer
243 template<typename Domain, typename Container>
245
251 template<typename Domain, typename Container>
253
259 template<typename Domain, typename Container>
261
267 template<typename Domain, typename Container>
269
275 template<typename Domain, typename Container>
277 // DigitalSetByAssociativeContainer
278
279
280 // DigitalSetBySTLSet
287 template<typename Domain, typename Compare>
289
295 template<typename Domain, typename Compare>
297
303 template<typename Domain, typename Compare>
305
311 template<typename Domain, typename Compare>
313
319 template<typename Domain, typename Compare>
321 // DigitalSetBySTLSet
322
323
324 // DigitalSetBySTLVector
331 template<typename Domain>
333
339 template<typename Domain>
341
347 template<typename Domain>
349
355 template<typename Domain>
357
363 template<typename Domain>
364 static void draw( Display & display, const DGtal::DigitalSetBySTLVector<Domain> & anObject );
365 // DigitalSetBySTLVector
366
367
368 // HyperRectDomain
375 template <typename SpaceDom>
377
383 template <typename SpaceDom>
385
391 template <typename SpaceDom>
392 static void drawAsGrid( Display & display, const DGtal::HyperRectDomain<SpaceDom> & anObject );
393
399 template <typename SpaceDom>
401
407 template <typename SpaceDom>
409
410
416 template <typename SpaceDom>
417 static void draw( Display & display, const DGtal::HyperRectDomain<SpaceDom> & anObject );
418
419
420 // HyperRectDomain
421
422
423 // KhalimskyCell
430 static DGtal::DrawableWithDisplay3D * defaultStyle( std::string str, const typename KSpace::Cell & anObject );
431
437 static void draw( Display & display, const typename KSpace::Cell & anObject );
438
453 static void drawUnorientedSurfelWithNormal( Display & display, const typename KSpace::Cell & anObject,
454 const RealVector & aNormal,
455 const bool enableDoubleFace = false);
456 // KhalimskyCell
457
458 // SignedKhalimskyCell
465 static DGtal::DrawableWithDisplay3D * defaultStyle( std::string str, const typename KSpace::SCell & anObject );
466
472 static void draw( Display & display, const typename KSpace::SCell & anObject );
473
486 const typename KSpace::SCell & aSignedCell,
487 const RealVector & aNormal,
488 const bool enableDoubleFace = false);
489 // SignedKhalimskyCell
490
491 // Object
498 template <typename TDigitalTopology, typename TDigitalSet>
500
506 template <typename TDigitalTopology, typename TDigitalSet>
508
514 template <typename TDigitalTopology, typename TDigitalSet>
516 // Object
517
518
519 // PointVector
526 template<Dimension dim, typename TComponent, typename TContainer>
528
534 template<Dimension dim, typename TComponent, typename TContainer>
536
542 template<Dimension dim, typename TComponent, typename TContainer>
544
550 template<Dimension dim, typename TComponent, typename TContainer>
552
558 template<Dimension dim, typename TComponent, typename TContainer>
560
566 template<Dimension dim, typename TComponent1, typename TComponent2, typename TContainer1, typename TContainer2>
568 // PointVector
569
570 // GridCurve
576 static void draw( Display & display, const DGtal::GridCurve<KSpace> & anObject );
577 // GridCurve
578
579 // SCellsRange
585 template < typename TIterator, typename TSCell>
586 static void draw( Display & display,
588 // SCellsRange
589
590 // PointsRange
596 template <typename TIterator>
597 static void draw( Display & display,
598 const DGtal::ConstRangeAdapter<TIterator, DGtal::functors::SCellToPoint<KSpace>, typename TKSpace::Point> & anObject );
599 // PointsRange
600
601 // MidPointsRange
602 template <typename TIterator>
608 static void draw( Display & display,
610 typename TKSpace::Space::RealPoint> & anObject );
611 // MidPointsRange
612
613 // ArrowsRange
619 template <typename TIterator>
620 static void draw( Display & display,
622 std::pair<typename TKSpace::Point, typename TKSpace::Vector > > & anObject );
623 // ArrowsRange
624
625 // InnerPointsRange
631 template <typename TIterator>
632 static void draw( Display & display,
633 const DGtal::ConstRangeAdapter<TIterator, DGtal::functors::SCellToInnerPoint<KSpace>, typename TKSpace::Point> & anObject );
634 // InnerPointsRange
635
636 // OuterPointsRange
642 template <typename TIterator>
643 static void draw( Display & display,
644 const DGtal::ConstRangeAdapter<TIterator, DGtal::functors::SCellToOuterPoint<KSpace>, typename TKSpace::Point> & anObject );
645 // OuterPointsRange
646
647 // IncidentPointsRange
653 template <typename TIterator>
654 static void draw( Display & display,
656 std::pair<typename KSpace::Point, typename KSpace::Point > > & anObject );
657 // IncidentPointsRange
658
665 static void
666 draw( Display & display, const DGtal::SetMode3D & anObject );
667
674 static void
675 draw( Display & display, const DGtal::CustomStyle3D & anObject );
676
683 static void
685
691 static void
692 draw( Display & display, const DGtal::ClippingPlane & anObject );
693
694
700 static void
701 draw( Display & display, const DGtal::TransformedPrism & aTransformedPrism);
702
708 static void
709 draw( Display & display, const DGtal::SetName3D& aName3d );
710
718 static void
720
721 }; // end of struct Display3DFactory
722
723} // namespace DGtal
724
726// Includes inline functions/methods
727
728#include "DGtal/io/Display3DFactory.ih"
729
730// //
732
733#endif // !defined Display3DFactory_h
734
735#undef Display3DFactory_RECURSES
736#endif // else defined(Display3DFactory_RECURSES)
Structure representing an RGB triple with alpha component.
Definition: Color.h:68
static const Color Black
Definition: Color.h:413
Aim: model of CConstBidirectionalRange that adapts any range of elements bounded by two iterators [it...
Aim: A wrapper class around a STL associative container for storing sets of digital points within som...
Aim: A container class for storing sets of digital points within some given domain.
Aim: Realizes the concept CDigitalSet by using the STL container std::vector.
Aim: DiscreteExteriorCalculus represents a calculus in the dec package. This is the main structure in...
Aim: This semi abstract class defines the stream mechanism to display 3d primitive (like BallVector,...
Definition: Display3D.h:93
Aim: describes, in a cellular space of dimension n, a closed or open sequence of signed d-cells (or d...
Definition: GridCurve.h:173
Aim: Parallelepidec region of a digital space, model of a 'CDomain'.
Aim: KForm represents discrete kforms in the dec package.
Definition: KForm.h:66
SignedKhalimskyCell< dim, Integer > SCell
KhalimskyCell< dim, Integer > Cell
Aim: This class is defined to represent a surface mesh through a set of vertices and faces....
Definition: Mesh.h:92
Aim: Dynamic recognition of a 3d-digital straight segment (DSS)
Aim: An object (or digital object) represents a set in some digital space associated with a digital t...
Definition: Object.h:120
Aim: Implements basic operations that will be used in Point and Vector classes.
Definition: PointVector.h:593
Aim: implements an accumulator (as histograms for 1D scalars) adapted to spherical point samples.
Aim: Dynamic recognition of a 3d-digital straight segment (DSS)
Aim: VectorField represents a discrete vector field in the dec package. Vector field values are attac...
Definition: VectorField.h:68
Aim: transforms a signed cell into an arrow, ie. a pair point-vector.
Aim: transforms a signed cell c into a pair of points corresponding to the signed cells of greater di...
Aim: transforms a signed cell c into a point corresponding to the signed cell of greater dimension th...
Aim: transforms a signed cell c into a point corresponding to the signed cell of greater dimension th...
Aim: transforms a scell into a point.
DGtal is the top-level namespace which contains all DGtal functions and types.
Aim: A trivial embedder for signed cell, which corresponds to the canonic injection of cell centroids...
Class for adding a Clipping plane through the Viewer3D stream. Realizes the concept CDrawableWithView...
Modifier class in a Display3D stream. Useful to choose your own style for a given class....
Factory for GPL Display3D:
BOOST_STATIC_CONSTANT(unsigned int, POINT_AS_BALL_RADIUS=5)
The ball radius (the actual radius being 1/POINT_AS_BALL_RADIUS )when used to display a 3D point.
static void draw(Display &display, const DGtal::ConstRangeAdapter< TIterator, DGtal::functors::SCellToPoint< KSpace >, typename TKSpace::Point > &anObject)
draw
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::Object< TDigitalTopology, TDigitalSet > &anObject)
static void draw(Display &display, const DGtal::TransformedPrism &aTransformedPrism)
static void drawAsPaving(Display &display, const DGtal::DigitalSetByAssociativeContainer< Domain, Container > &anObject)
drawAsPaving
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::Naive3DDSSComputer< TIterator, TInteger, connectivity > &anObject)
defaultStyle Default drawing style object.
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::PointVector< dim, TComponent, TContainer > &anObject)
static void draw(Display &display, const DGtal::HyperRectDomain< SpaceDom > &anObject)
draw
static void drawWithAdjacencies(Display &display, const DGtal::Object< TDigitalTopology, TDigitalSet > &anObject)
drawWithAdjacencies
static void drawAsPavingTransparent(Display &display, const DGtal::DigitalSetByAssociativeContainer< Domain, Container > &anObject)
drawAsPavingTransparent
static void draw(Display &display, const DGtal::ClippingPlane &anObject)
draw
static void drawAsFaces(Display &display, const DGtal::Mesh< TPoint > &aMesh)
drawAsFaces
static void drawAsGrid(Display &display, const DGtal::PointVector< dim, TComponent, TContainer > &anObject)
drawAsGrid
static void draw(Display &display, const DGtal::ConstRangeAdapter< TIterator, DGtal::functors::SCellToArrow< KSpace >, std::pair< typename TKSpace::Point, typename TKSpace::Vector > > &anObject)
draw
static void drawAsBoundingBox(Display &display, const DGtal::HyperRectDomain< SpaceDom > &anObject)
drawAsBoundingBox
static void draw(Display &display, const DGtal::Naive3DDSSComputer< TIterator, TInteger, connectivity > &anObject)
draw
Display3D< Space, KSpace > Display
static void drawAsBalls(Display &display, const DGtal::StandardDSS6Computer< TIterator, TInteger, connectivity > &anObject)
drawAsBalls
static void draw(Display &display, const DGtal::ConstRangeAdapter< TIterator, DGtal::functors::Identity, TSCell > &anObject)
draw
static void drawAsGrid(Display &display, const DGtal::DigitalSetBySTLVector< Domain > &anObject)
drawAsGrid
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::DigitalSetBySTLVector< Domain > &anObject)
Default drawing style object.
Display::RealVector RealVector
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::HyperRectDomain< SpaceDom > &anObject)
static void drawWithColorMap(Display3D< Space, KSpace > &display, const DGtal::KForm< Calculus, order, duality > &kform, const ColorMap &colormap)
static void drawAsPaving(Display &display, const DGtal::PointVector< dim, TComponent, TContainer > &anObject)
drawAsPaving
static void draw(Display &display, const DGtal::PointVector< dim, TComponent, TContainer > &anObject)
draw
static void draw(Display &display, const DGtal::ConstRangeAdapter< TIterator, DGtal::functors::SCellToIncidentPoints< KSpace >, std::pair< typename KSpace::Point, typename KSpace::Point > > &anObject)
draw
static void drawAsGrid(Display &display, const DGtal::HyperRectDomain< SpaceDom > &anObject)
drawAsGrid
static void draw(Display &display, const typename KSpace::SCell &anObject)
draw
static void drawAsPaving(Display &display, const DGtal::DigitalSetBySTLVector< Domain > &anObject)
drawAsPaving
static void draw(Display &display, const DGtal::CustomColors3D &anObject)
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const typename KSpace::Cell &anObject)
static void draw(Display &display, const DGtal::StandardDSS6Computer< TIterator, TInteger, connectivity > &anObject)
draw
static void draw(Display &display, const DGtal::Mesh< TPoint > &aMesh)
draw
static void drawAsPavingWired(Display &display, const DGtal::PointVector< dim, TComponent, TContainer > &anObject)
drawAsPavingWired
static void drawAsBalls(Display &display, const DGtal::Naive3DDSSComputer< TIterator, TInteger, connectivity > &anObject)
drawAsBalls
static void draw(Display3D< Space, KSpace > &display, const DGtal::DiscreteExteriorCalculus< dimEmbedded, dimAmbient, TLinearAlgebraBackend, TInteger > &calculus)
static void draw(Display &display, const DGtal::ConstRangeAdapter< TIterator, CanonicSCellEmbedder< KSpace >, typename TKSpace::Space::RealPoint > &anObject)
draw
static void drawAsPaving(Display &display, const DGtal::DigitalSetBySTLSet< Domain, Compare > &anObject)
drawAsPaving
static void drawAsPaving(Display &display, const DGtal::HyperRectDomain< SpaceDom > &anObject)
drawAsPaving
static void draw(Display &display, const DGtal::DigitalSetBySTLVector< Domain > &anObject)
draw
static void draw(Display &display, const DGtal::GridCurve< KSpace > &anObject)
draw
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const typename KSpace::SCell &anObject)
static void drawOrientedSurfelWithNormal(Display &display, const typename KSpace::SCell &aSignedCell, const RealVector &aNormal, const bool enableDoubleFace=false)
static void drawAsGrid(Display &display, const DGtal::DigitalSetBySTLSet< Domain, Compare > &anObject)
drawAsGrid
static void drawAsBoundingBox(Display &display, const DGtal::StandardDSS6Computer< TIterator, TInteger, connectivity > &anObject)
drawAsBoundingBox
static void draw(Display &display, const DGtal::SetMode3D &anObject)
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::DigitalSetBySTLSet< Domain, Compare > &anObject)
defaultStyle
static void draw(Display &display, const DGtal::ConstRangeAdapter< TIterator, DGtal::functors::SCellToOuterPoint< KSpace >, typename TKSpace::Point > &anObject)
draw
static void drawAsPavingBalls(Display &display, const DGtal::HyperRectDomain< SpaceDom > &anObject)
drawAsPavingBalls
static void draw(Display &display, const DGtal::PointVector< dim, TComponent1, TContainer1 > &, const DGtal::PointVector< dim, TComponent2, TContainer2 > &anObject)
draw
static void draw(Display3D< Space, KSpace > &display, const DGtal::KForm< Calculus, order, duality > &kform, double cmap_min=0, double cmap_max=0)
static void draw(Display &display, const DGtal::DigitalSetByAssociativeContainer< Domain, Container > &anObject)
draw
static void draw(Display &display, const DGtal::ConstRangeAdapter< TIterator, DGtal::functors::SCellToInnerPoint< KSpace >, typename TKSpace::Point > &anObject)
draw
Display3DFactory< Space, KSpace > Self
static void draw(Display &display, const DGtal::DigitalSetBySTLSet< Domain, Compare > &anObject)
draw
static void drawUnorientedSurfelWithNormal(Display &display, const typename KSpace::Cell &anObject, const RealVector &aNormal, const bool enableDoubleFace=false)
static void draw(Display &display, const DGtal::CustomStyle3D &anObject)
static void draw(Display &display, const DGtal::SphericalAccumulator< TVector > &accumulator, const DGtal::Z3i::RealVector &shift=DGtal::Z3i::RealVector(0, 0, 0), const double radius=1.0)
static void drawAsGrid(Display &display, const DGtal::DigitalSetByAssociativeContainer< Domain, Container > &anObject)
drawAsGrid
static void draw(Display &display, const typename KSpace::Cell &anObject)
draw
static void draw(Display3D< Space, KSpace > &display, const DGtal::VectorField< Calculus, duality > &vector_field, const double &scale=0.5, const double &epsilon=1e-5, const DGtal::Color color=DGtal::Color::Black)
static void drawAsPavingTransparent(Display &display, const DGtal::DigitalSetBySTLSet< Domain, Compare > &anObject)
drawAsPavingTransparent
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::StandardDSS6Computer< TIterator, TInteger, connectivity > &anObject)
Display::RealPoint RealPoint
static void drawAsPavingTransparent(Display &display, const DGtal::DigitalSetBySTLVector< Domain > &anObject)
drawAsPavingTransparent
static void draw(Display &display, const DGtal::Object< TDigitalTopology, TDigitalSet > &anObject)
draw
BOOST_STATIC_CONSTANT(unsigned int, POINT_AS_BALL_RES=5)
The ball resolution when used to display a point.
static DGtal::DrawableWithDisplay3D * defaultStyle(std::string str, const DGtal::DigitalSetByAssociativeContainer< Domain, Container > &anObject)
defaultStyle
static void drawAsBoundingBox(Display &display, const DGtal::Naive3DDSSComputer< TIterator, TInteger, connectivity > &anObject)
drawAsBoundingBox
static void draw(Display &display, const DGtal::SetSelectCallback3D &aFct)
static void draw(Display &display, const DGtal::SetName3D &aName3d)
Modifier class in a Display3D stream. Useful to choose your own mode for a given class....
class to modify the position and scale to construct better illustration mode.
void display(ostream &out, const AContainer &C)