Developer Documentation
TextureControl1DTextureHandlingOVMT_impl.hh
1
/*===========================================================================*\
2
* *
3
* OpenFlipper *
4
* Copyright (c) 2001-2015, RWTH-Aachen University *
5
* Department of Computer Graphics and Multimedia *
6
* All rights reserved. *
7
* www.openflipper.org *
8
* *
9
*---------------------------------------------------------------------------*
10
* This file is part of OpenFlipper. *
11
*---------------------------------------------------------------------------*
12
* *
13
* Redistribution and use in source and binary forms, with or without *
14
* modification, are permitted provided that the following conditions *
15
* are met: *
16
* *
17
* 1. Redistributions of source code must retain the above copyright notice, *
18
* this list of conditions and the following disclaimer. *
19
* *
20
* 2. Redistributions in binary form must reproduce the above copyright *
21
* notice, this list of conditions and the following disclaimer in the *
22
* documentation and/or other materials provided with the distribution. *
23
* *
24
* 3. Neither the name of the copyright holder nor the names of its *
25
* contributors may be used to endorse or promote products derived from *
26
* this software without specific prior written permission. *
27
* *
28
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS *
29
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED *
30
* TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A *
31
* PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER *
32
* OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, *
33
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, *
34
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR *
35
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
36
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING *
37
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS *
38
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. *
39
* *
40
\*===========================================================================*/
41
42
43
44
#if defined(ENABLE_HEXAHEDRALMESH_SUPPORT) || defined(ENABLE_POLYHEDRALMESH_SUPPORT) || defined(ENABLE_TETRAHEDRALMESH_SUPPORT)
45
46
#define TEXTURECONTROL_1D_TEXTURE_HANDLING_OVM_C
47
48
#include "TextureControl.hh"
49
#include "TextureMath.hh"
50
51
template
<
typename
VolumeMeshT,
typename
VolumeMeshObjectT >
52
void
TextureControlPlugin::copyTexture
(
Texture
& _texture , VolumeMeshT& _mesh, VolumeMeshObjectT& _obj,
OpenVolumeMesh::VertexPropertyT< double >
_texProp )
53
{
54
// Compute the minimal and maximal values for this texture
55
double
max = -FLT_MIN;
56
double
min = FLT_MAX;;
57
58
// Compute minimal and maximal value of the coordinates
59
// Keep track of absolute values!
60
for
(
OpenVolumeMesh::VertexIter
v_it = _mesh.vertices_begin() ; v_it != _mesh.vertices_end(); ++v_it) {
61
62
max = std::max( _texProp[*v_it] , max);
63
min = std::min( _texProp[*v_it] , min);
64
65
}
66
67
OpenVolumeMesh::TexCoordAttrib<ACG::Vec2f>
& texcoord = _obj.texcoords();
68
69
TextureMath
convert(_texture.
parameters
,min,max);
70
71
for
(
OpenVolumeMesh::VertexIter
v_it = _mesh.vertices_begin(); v_it != _mesh.vertices_end(); ++v_it) {
72
// Get the value of the property
73
double
value = _texProp[*v_it];
74
75
// Mangle it with the predefined user options (including absolute, clamping, ...)
76
value = convert.transform(value);
77
78
// Write result to the OpenMesh texture coordinates ( 2d accessing the diagonal of a 2d texture)
79
texcoord[*v_it] =
ACG::Vec2f
(
float
(value),
float
(value) );
80
}
81
}
82
83
#endif
OpenVolumeMesh::TexCoordAttrib< ACG::Vec2f >
OpenVolumeMesh::VertexIter
Definition:
Iterators.hh:837
ACG::Vec2f
VectorT< float, 2 > Vec2f
Definition:
VectorT.hh:102
TextureMath
Definition:
TextureMath.hh:49
Texture
Definition:
TextureData.hh:68
TextureControlPlugin::copyTexture
void copyTexture(Texture &_texture, MeshT &_mesh, OpenMesh::VPropHandleT< double > _texProp)
Copy the supplied 1D vertex property to both coordinates of the 2D vertex OM texture property...
Definition:
TextureControl1DTextureHandlingT_impl.hh:50
OpenVolumeMesh::PropertyTT
Definition:
ForwardDeclarations.hh:15
Texture::parameters
TexParameters parameters
Parameters of the texture.
Definition:
TextureData.hh:138
Plugin-TextureControl
TextureControl1DTextureHandlingOVMT_impl.hh
Generated on Fri Dec 13 2019 13:12:13 for Developer Documentation by
1.8.13