# <vgl-torus-knot-geometry>
A mesh, line, or point geometry representation.
# Example Usage
<template>
<div>
<vgl-renderer antialias>
<template #scene>
<vgl-scene>
<vgl-mesh>
<template #geometry>
<vgl-torus-knot-geometry
:radius="radius"
:tube="tube"
:p="p"
:q="q"
/>
</template>
<template #material>
<vgl-mesh-standard-material />
</template>
</vgl-mesh>
<vgl-ambient-light color="#ffeecc" />
<vgl-directional-light
:position-y="1"
:position-z="2"
/>
</vgl-scene>
</template>
<template #camera>
<vgl-perspective-camera
position="spherical"
:position-radius="100"
:position-phi="1"
:position-theta="0.5"
rotation="lookAt"
/>
</template>
</vgl-renderer>
<aside>
<label>Radius<input
v-model.number="radius"
type="range"
max="50"
step="0.5"
></label>
<label>Tube radius<input
v-model.number="tube"
type="range"
max="20"
step="0.2"
></label>
<label>p<input
v-model.number="p"
type="range"
max="10"
step="1"
></label>
<label>q<input
v-model.number="q"
type="range"
max="10"
step="1"
></label>
</aside>
</div>
</template>
<script>
import * as components from 'vue-gl';
export default {
components,
data: () => ({
radius: 10,
tube: 5,
p: 2,
q: 3,
}),
};
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# Props
name
: string
An arbitrary name of the instance.
Defaults to [object Object]drawRangeStart
: number
The start index of drawn part in the geometry.
Defaults to [object Object]drawRangeCount
: number
The number of indices to be drawn.
Defaults to [object Object]groups
: array
An array of objects those represent index groups to be rendered in separate draw calls.
Defaults to [object Object]radius
: number
The radius of the torus.
Defaults to [object Object]tube
: number
The diamiter of the tube.
Defaults to [object Object]radialSegments
: number
The number of segments of the tube section.
Defaults to [object Object]tubularSegments
: number
The number of segments along to the tube length direction.
Defaults to [object Object]p
: number
The winding times around the axis of rotational symmetry.
Defaults to [object Object]q
: number
The winding times around a circle in the interior of the torus.
Defaults to [object Object]
# Slots
Any
Each attribute in a named slot will be added to the geometry with the same name as the slot.