1RTC_GEOMETRY_TYPE_QUAD(3)Embree Ray Tracing Kernels 4RTC_GEOMETRY_TYPE_QUAD(3)
2
3
4
5   NAME
6              RTC_GEOMETRY_TYPE_QUAD - quad geometry type
7
8   SYNOPSIS
9              #include <embree4/rtcore.h>
10
11              RTCGeometry geometry =
12                rtcNewGeometry(device, RTC_GEOMETRY_TYPE_QUAD);
13
14   DESCRIPTION
15       Quad  meshes  are created by passing RTC_GEOMETRY_TYPE_QUAD to the rtc‐
16       NewGeometry function call.  The quad indices can be specified  by  set‐
17       ting an index buffer (RTC_BUFFER_TYPE_INDEX type) and the quad vertices
18       by setting a vertex buffer (RTC_BUFFER_TYPE_VERTEX type).  See  rtcSet‐
19       GeometryBuffer  and  rtcSetSharedGeometryBuffer for more details on how
20       to set buffers.  The index buffer contains an array of four 32-bit  in‐
21       dices  per quad (RTC_FORMAT_UINT4 format), and the number of primitives
22       is inferred from the size of that buffer.  The vertex  buffer  contains
23       an  array  of  single  precision  x,  y,  z  floating point coordinates
24       (RTC_FORMAT_FLOAT3 format), and the number of vertices is inferred from
25       the size of that buffer.  The vertex buffer can be at most 16 GB large.
26
27       A  quad  is  internally handled as a pair of two triangles v0,v1,v3 and
28       v2,v3,v1, with the u'/v' coordinates of the second  triangle  corrected
29       by  u = 1-u' and v = 1-v' to produce a quad parametrization where u and
30       v are in the range 0 to 1.  Thus the parametrization of a quad uses the
31       first  vertex  p0 as base point, and the vector p1 - p0 as u-direction,
32       and p3 - p0 as v-direction.  Thus vertex attributes t0,t1,t2,t3 can  be
33       bilinearly interpolated over the quadrilateral the following way:
34
35              t_uv = (1-v)((1-u)*t0 + u*t1) + v*((1-u)*t3 + u*t2)
36
37       Mixed  triangle/quad  meshes  are supported by encoding a triangle as a
38       quad, which can be achieved by replicating  the  last  triangle  vertex
39       (v0,v1,v2  ->  v0,v1,v2,v2).   This  way  the second triangle is a line
40       (which can never get hit), and the parametrization of the first  trian‐
41       gle is compatible with the standard triangle parametrization.
42
43       A  quad  whose vertices are laid out counter-clockwise has its geometry
44       normal pointing upwards outside the front face, like illustrated in the
45       following picture.
46
47       For  multi-segment  motion blur, the number of time steps must be first
48       specified using the rtcSetGeometryTimeStepCount call.   Then  a  vertex
49       buffer  for each time step can be set using different buffer slots, and
50       all these buffers must have the same stride and size.
51
52   EXIT STATUS
53       On failure NULL is returned and an  error  code  is  set  that  can  be
54       queried using rtcGetDeviceError.
55
56   SEE ALSO
57       [rtcNewGeometry]
58
59
60
61                                                     RTC_GEOMETRY_TYPE_QUAD(3)
Impressum