Difference between revisions of "User:Le Forgeron/UVMeshable"
Jump to navigation
Jump to search
Le Forgeron (talk | contribs) |
Le Forgeron (talk | contribs) |
||
Line 28: | Line 28: | ||
* <code>torus</code> | * <code>torus</code> | ||
* <code>disc</code> | * <code>disc</code> | ||
+ | * <code>parametric</code> | ||
=== Access to data of UVMeshable objects === | === Access to data of UVMeshable objects === |
Revision as of 16:21, 14 June 2020
- Everything about HgPovray38 in User:Le_Forgeron/HgPovray38
- Code is available on branch hgpovray38 at https://github.com/LeForgeron/povray
UVMeshable
A bit of programming
UVMeshable objects are shapes that provides the UVMeshable interface:
class UVMeshable
{
public:
virtual void evalVertex( Vector3d& r, const DBL u, const DBL v )const;
virtual void evalNormal( Vector3d& r, const DBL u, const DBL v )const;
virtual void minUV( Vector2d& r )const;
virtual void maxUV( Vector2d& r )const;
};
Which shapes are UVMeshable
So far the following shapes are UVMeshable:
nurbs
(see User:Le_Forgeron/nurbs)rational_bezier_patch
(see User:Le_Forgeron/rational_bezier_patch)sphere
cone
cylinder
ovus
lemon
torus
disc
parametric
Access to data of UVMeshable objects
- Returns the minimal uv-coordinates uv_min( UVMeshableObject )
- Returns the maximal uv-coordinates uv_max( UVMeshableObject )
- Returns the vertex vector that corresponds to the given uv-coordinates uv_vertex( UVMeshableObject, Ucoordinate, Vcoordinate )
- Returns the normal vector that corresponds to the given uv-coordinates uv_normal( UVMeshableObject, Ucoordinate, Vcoordinate )
Turning UVMeshable into mesh
#include "NurbsMesh.inc"
#declare UResolution = 92;
#declare VResolution = 92;
mesh {
UVMeshable( UVMeshableObject, UResolution, VResolution )
}