Visualization Library v1.0.3

A lightweight C++ OpenGL middleware for 2D/3D graphics

VL     Star     Watch     Fork     Issue

[Download] [Tutorials] [All Classes] [Grouped Classes]
Public Member Functions | Protected Attributes

vl::SlicedVolume Class Reference

A ActorEventCallback used to render a volume using viewport aligned slices. More...

#include <SlicedVolume.hpp>

Inheritance diagram for vl::SlicedVolume:
vl::ActorEventCallback vl::Object

List of all members.

Public Member Functions

 SlicedVolume ()
 Constructor.
void onActorRenderStarted (Actor *actor, real frame_clock, const Camera *cam, Renderable *renderable, const Shader *shader, int pass)
 Event generated just before an Actor is rendered but after the render states are ready and setup.
void onActorDelete (Actor *)
 Event notifying that an Actor is being deleted.
void bindActor (Actor *)
 Binds a SlicedVolume to an Actor so that the SlicedVolume can generate the viewport aligned slices' geometry for the Actor as appropriate.
virtual void updateUniforms (Actor *actor, real clock, const Camera *camera, Renderable *rend, const Shader *shader)
 Updates the uniforms used by the GLSLProgram to render the volume each time the onActorRenderStarted() method is called.
void setSliceCount (int count)
 Defines the number of slices used to render the volume: more slices generate a better (and slower) rendering.
int sliceCount () const
 Returns the number of slices used to render the volume.
Geometrygeometry ()
 Returns the Geometry associated to a SlicedVolume and its bound Actor.
const Geometrygeometry () const
 Returns the Geometry associated to a SlicedVolume and its bound Actor.
void setBox (const AABB &box)
 Defines the dimensions of the box enclosing the volume.
const AABBbox () const
 The dimensions of the box enclosing the volume.
const fvec3texCoords () const
 Returns the texture coordinates assigned to each of the 8 box corners of the volume.
fvec3texCoords ()
 Returns the texture coordinates assigned to each of the 8 box corners of the volume.
void generateTextureCoordinates (const ivec3 &size)
 Generates a default set of texture coordinates for the 8 box corners of the volume based on the given texture dimensions.
void generateTextureCoordinates (const ivec3 &img_size, const ivec3 &min_corner, const ivec3 &max_corner)
 Generates a default set of texture coordinates for the 8 box corners of the volume based on the given texture dimensions.

Protected Attributes

int mSliceCount
ref< GeometrymGeometry
AABB mBox
fmat4 mCache
fvec3 mTexCoord [8]

Detailed Description

A ActorEventCallback used to render a volume using viewport aligned slices.

Pictures from: Sliced Volume Rendering with Transfer Functions and Lighting Tutorial tutorial.

pagGuideSlicedVolume_1.jpg
pagGuideSlicedVolume_2.jpg
pagGuideSlicedVolume_4.jpg
pagGuideSlicedVolume_5.jpg
pagGuideSlicedVolume_6.jpg
pagGuideSlicedVolume_7.jpg

Using the SlicedVolume class is very simple, see Sliced Volume Rendering with Transfer Functions and Lighting Tutorial for a complete example.

Basically all SlicedVolume does is to compute the correct texture coordinates and generates on the fly N viewport aligned slices, where N can be specified by the user with setSliceCount(). Such slices then can be rendered using a GLSLProgram specified by the user, thus you can achieve virtually any kind of visual effect with it.

The user can reimplement the updateUniforms() method to update his own uniform variables before the volume is rendered. By default updateUniforms() updates the position of up to 4 lights in object space. Such positions are stored in the "uniform vec3 light_position[4]" variable. The updateUniforms() method also fills the "uniform bool light_enable[4]" variable with a flag marking if the Nth light is active or not. These light values are computed based on the lights bound to the current Shader. The updateUniforms() method also fills the "uniform vec3 eye_position" variable which contains the camera position in object space, useful to compute specular highlights etc.

See also:

Definition at line 42 of file SlicedVolume.hpp.


Constructor & Destructor Documentation

SlicedVolume::SlicedVolume (  )

Constructor.

Definition at line 79 of file SlicedVolume.cpp.

References mGeometry, mSliceCount, mTexCoord, and VL_DEBUG_SET_OBJECT_NAME.


Member Function Documentation

void SlicedVolume::onActorRenderStarted ( Actor actor,
real  frame_clock,
const Camera cam,
Renderable renderable,
const Shader shader,
int  pass 
) [virtual]

Event generated just before an Actor is rendered but after the render states are ready and setup.

Reimplement to react to this event.

Parameters:
actorThe Actor bound to this rendering callback.
frame_clockThe current rendering frame time, usually used for animation purposes.
camThe camera used for the current rendering.
renderableThe currently selected Actor LOD.
shaderThe currently active Shader.
passThe current Actor[s] rendering pass.

Implements vl::ActorEventCallback.

Definition at line 168 of file SlicedVolume.cpp.

References box(), vl::dot(), vl::ref< T >::get(), vl::Shader::getGLSLProgram(), vl::Matrix4< T_Scalar >::getInverse(), mCache, mGeometry, vl::PT_TRIANGLES, sliceCount(), texCoords(), vl::Actor::transform(), updateUniforms(), vl::Camera::viewMatrix(), VL_CHECK, vl::Transform::worldMatrix(), and vl::Vector3< T_Scalar >::z().

void vl::SlicedVolume::onActorDelete ( Actor actor ) [inline, virtual]

Event notifying that an Actor is being deleted.

Implements vl::ActorEventCallback.

Definition at line 52 of file SlicedVolume.hpp.

void SlicedVolume::bindActor ( Actor actor )

Binds a SlicedVolume to an Actor so that the SlicedVolume can generate the viewport aligned slices' geometry for the Actor as appropriate.

Definition at line 162 of file SlicedVolume.cpp.

References vl::Actor::actorEventCallbacks(), vl::ref< T >::get(), mGeometry, vl::Collection< T >::push_back(), and vl::Actor::setLod().

void SlicedVolume::updateUniforms ( Actor actor,
real  clock,
const Camera camera,
Renderable rend,
const Shader shader 
) [virtual]

Updates the uniforms used by the GLSLProgram to render the volume each time the onActorRenderStarted() method is called.

Reimplement this method to update the uniform variables of your GLSL program before the volume is rendered.

By default updateUniforms() updates the position of up to 4 lights in object space. Such positions are stored in the "uniform vec3 light_position[4]" variable. The updateUniforms() method also fills the "uniform bool light_enable[4]" variable with a flag marking if the Nth light is active or not. These light values are computed based on the lights bound to the current Shader. The updateUniforms() method also fills the "uniform vec3 eye_position" variable which contains the camera position in object space, useful to compute specular highlights etc.

Definition at line 102 of file SlicedVolume.cpp.

References vl::Light::boundTransform(), vl::Shader::getGLSLProgram(), vl::Matrix4< T_Scalar >::getInverse(), vl::Shader::getLight(), vl::Matrix4< T_Scalar >::getT(), vl::GLSLProgram::getUniformLocation(), vl::Actor::gocUniform(), vl::Camera::modelingMatrix(), NULL, vl::Light::position(), vl::Uniform::setUniform(), vl::Uniform::setUniform1i(), vl::Actor::transform(), vl::Transform::worldMatrix(), and vl::Vector4< T_Scalar >::xyz().

Referenced by onActorRenderStarted().

void vl::SlicedVolume::setSliceCount ( int  count ) [inline]

Defines the number of slices used to render the volume: more slices generate a better (and slower) rendering.

Definition at line 61 of file SlicedVolume.hpp.

int vl::SlicedVolume::sliceCount (  ) const [inline]

Returns the number of slices used to render the volume.

Definition at line 64 of file SlicedVolume.hpp.

Referenced by onActorRenderStarted().

Geometry* vl::SlicedVolume::geometry (  ) [inline]

Returns the Geometry associated to a SlicedVolume and its bound Actor.

Definition at line 67 of file SlicedVolume.hpp.

const Geometry* vl::SlicedVolume::geometry (  ) const [inline]

Returns the Geometry associated to a SlicedVolume and its bound Actor.

Definition at line 70 of file SlicedVolume.hpp.

void SlicedVolume::setBox ( const AABB box )

Defines the dimensions of the box enclosing the volume.

Definition at line 389 of file SlicedVolume.cpp.

References box(), vl::Matrix4< T_Scalar >::fill(), mBox, mCache, and mGeometry.

const AABB& vl::SlicedVolume::box (  ) const [inline]

The dimensions of the box enclosing the volume.

Definition at line 76 of file SlicedVolume.hpp.

Referenced by onActorRenderStarted(), and setBox().

const fvec3* vl::SlicedVolume::texCoords (  ) const [inline]

Returns the texture coordinates assigned to each of the 8 box corners of the volume.

Definition at line 79 of file SlicedVolume.hpp.

Referenced by onActorRenderStarted().

fvec3* vl::SlicedVolume::texCoords (  ) [inline]

Returns the texture coordinates assigned to each of the 8 box corners of the volume.

Definition at line 82 of file SlicedVolume.hpp.

void SlicedVolume::generateTextureCoordinates ( const ivec3 size )

Generates a default set of texture coordinates for the 8 box corners of the volume based on the given texture dimensions.

Definition at line 335 of file SlicedVolume.cpp.

References vl::Log::error(), mTexCoord, vl::Vector3< T_Scalar >::x(), vl::Vector3< T_Scalar >::y(), and vl::Vector3< T_Scalar >::z().

void SlicedVolume::generateTextureCoordinates ( const ivec3 img_size,
const ivec3 min_corner,
const ivec3 max_corner 
)

Generates a default set of texture coordinates for the 8 box corners of the volume based on the given texture dimensions.

Use this function to visualize a subset of the volume. The subset is defined by min_corner and max_corner.

Definition at line 362 of file SlicedVolume.cpp.

References vl::Log::error(), mTexCoord, vl::Vector3< T_Scalar >::x(), vl::Vector3< T_Scalar >::y(), and vl::Vector3< T_Scalar >::z().


Member Data Documentation

Definition at line 92 of file SlicedVolume.hpp.

Referenced by SlicedVolume().

Definition at line 93 of file SlicedVolume.hpp.

Referenced by bindActor(), onActorRenderStarted(), setBox(), and SlicedVolume().

Definition at line 94 of file SlicedVolume.hpp.

Referenced by setBox().

Definition at line 95 of file SlicedVolume.hpp.

Referenced by onActorRenderStarted(), and setBox().

Definition at line 96 of file SlicedVolume.hpp.

Referenced by generateTextureCoordinates(), and SlicedVolume().


The documentation for this class was generated from the following files:

Visualization Library v1.0.3 Reference Documentation
Copyright Michele Bosi. All rights reserved.
Updated on Tue Feb 7 2017 00:55:12.
Permission is granted to use this page to write and publish articles regarding Visualization Library.