Skip to content
Navigation Menu
{{ message }}
-
Notifications
You must be signed in to change notification settings - Fork 27
Expand file tree
/
Copy pathgroup.html
More file actions
182 lines (140 loc) · 10.7 KB
/
Copy pathgroup.html
File metadata and controls
182 lines (140 loc) · 10.7 KB
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="generator" content="Docutils 0.18.1: http://docutils.sourceforge.net/" />
<title>group — VPython 3.2 documentation</title>
<link rel="stylesheet" type="text/css" href="_static/pygments.css" />
<link rel="stylesheet" type="text/css" href="_static/alabaster.css" />
<script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>
<script src="_static/jquery.js"></script>
<script src="_static/underscore.js"></script>
<script src="_static/_sphinx_javascript_frameworks_compat.js"></script>
<script src="_static/doctools.js"></script>
<link rel="index" title="Index" href="genindex.html" />
<link rel="search" title="Search" href="search.html" />
<link rel="next" title="vertex, triangle, and quad" href="vertex.html" />
<link rel="prev" title="compound" href="compound.html" />
<link rel="stylesheet" href="_static/custom.css" type="text/css" />
<meta name="viewport" content="width=device-width, initial-scale=0.9, maximum-scale=0.9" />
</head><body>
<div class="document">
<div class="documentwrapper">
<div class="bodywrapper">
<div class="body" role="main">
<section id="group">
<h1>group<a class="headerlink" href="#group" title="Permalink to this heading">¶</a></h1>
<p>A <em>group</em> is a collection of objects that can be manipulated together. Unlike a <a class="reference internal" href="compound.html"><span class="doc">compound</span></a>, the constituent objects of a group retain their individual identities and can be moved, rotated, or otherwise altered individually. Group is more expensive computationally than compound.</p>
<p>Objects are added to a group by specifying <code class="docutils literal notranslate"><span class="pre">group=mygroup</span></code> when the object is created.</p>
<dl class="py function">
<dt class="sig sig-object py" id="id0">
<span class="sig-name descname"><span class="pre">mygroup</span></span><span class="sig-paren"> = </span><span class="sig-name descname"><span class="pre">group</span></span><span class="sig-paren">()</span><a class="headerlink" href="#id0" title="Permalink to this definition">¶</a></dt>
<dd><dl class="field-list simple">
<dt class="field-odd">Parameters<span class="colon">:</span></dt>
<dd class="field-odd"><ul class="simple">
<li><p><strong>pos</strong> (<em>vector</em>) – Position of the group. Default <code class="docutils literal notranslate"><span class="pre">vec(0,0,0)</span></code>. Moving <em>pos</em> moves all objects in the group.</p></li>
<li><p><strong>axis</strong> (<em>vector</em>) – Orientation of the group. Default <code class="docutils literal notranslate"><span class="pre">vec(1,0,0)</span></code>. Changing <em>axis</em> rotates all objects in the group.</p></li>
<li><p><strong>up</strong> (<em>vector</em>) – A vector perpendicular to the axis. Setting <em>up</em> sets <em>up</em> for all objects in the group.</p></li>
<li><p><strong>color</strong> (<em>vector</em>) – Setting <em>color</em> sets the color of all objects in the group.</p></li>
<li><p><strong>visible</strong> (<em>boolean</em>) – If False, all objects in the group are hidden. Default True.</p></li>
</ul>
</dd>
</dl>
</dd></dl>
<p>Example: create a group and add objects to it:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">mygroup</span> <span class="o">=</span> <span class="n">group</span><span class="p">()</span>
<span class="n">b</span> <span class="o">=</span> <span class="n">box</span><span class="p">(</span> <span class="n">group</span><span class="o">=</span><span class="n">mygroup</span> <span class="p">)</span>
<span class="n">s</span> <span class="o">=</span> <span class="n">sphere</span><span class="p">(</span> <span class="n">pos</span><span class="o">=</span><span class="n">vec</span><span class="p">(</span><span class="mi">2</span><span class="p">,</span><span class="mi">0</span><span class="p">,</span><span class="mi">0</span><span class="p">),</span> <span class="n">group</span><span class="o">=</span><span class="n">mygroup</span> <span class="p">)</span>
<span class="n">mygroup</span><span class="o">.</span><span class="n">pos</span> <span class="o">=</span> <span class="n">vec</span><span class="p">(</span><span class="mi">1</span><span class="p">,</span><span class="mi">0</span><span class="p">,</span><span class="mi">0</span><span class="p">)</span> <span class="c1"># moves both objects</span>
</pre></div>
</div>
<section id="group-and-world-coordinates">
<h2>Group and world coordinates<a class="headerlink" href="#group-and-world-coordinates" title="Permalink to this heading">¶</a></h2>
<p>The <em>pos</em> of each object in a group is stored relative to the group’s <em>pos</em> (group coordinates). The group provides two conversion functions:</p>
<p><code class="docutils literal notranslate"><span class="pre">world_pos = mygroup.group_to_world( v )</span></code> converts a position in group coordinates to world coordinates.</p>
<p><code class="docutils literal notranslate"><span class="pre">group_pos = mygroup.world_to_group( v )</span></code> converts a position in world coordinates to group coordinates.</p>
</section>
<section id="rotating-a-group">
<h2>Rotating a group<a class="headerlink" href="#rotating-a-group" title="Permalink to this heading">¶</a></h2>
<p>All objects in a group can be rotated together:</p>
<p><code class="docutils literal notranslate"><span class="pre">mygroup.rotate( angle=a, axis=vec(0,1,0) )</span></code></p>
<p>The optional <code class="docutils literal notranslate"><span class="pre">origin</span></code> parameter specifies the center of rotation. Default is <code class="docutils literal notranslate"><span class="pre">mygroup.pos</span></code>.</p>
<p>Changing <code class="docutils literal notranslate"><span class="pre">mygroup.axis</span></code> also rotates all member objects.</p>
</section>
<section id="restrictions-on-groups">
<h2>Restrictions on groups<a class="headerlink" href="#restrictions-on-groups" title="Permalink to this heading">¶</a></h2>
<p>Labels cannot be members of a group. Objects must be assigned to a group at creation time using the <code class="docutils literal notranslate"><span class="pre">group=</span></code> parameter; objects cannot be added to or removed from a group after creation.</p>
<div class="admonition seealso">
<p class="admonition-title">See also</p>
<p><a class="reference internal" href="canvas.html"><span class="doc">canvas</span></a>; <a class="reference internal" href="color.html"><span class="doc">color</span></a>; <a class="reference internal" href="compound.html"><span class="doc">compound</span></a>; <a class="reference internal" href="rotation.html"><span class="doc">rotate</span></a>;</p>
</div>
</section>
</section>
</div>
</div>
</div>
<div class="sphinxsidebar" role="navigation" aria-label="main navigation">
<div class="sphinxsidebarwrapper">
<h1 class="logo"><a href="index.html">VPython</a></h1>
<h3>Navigation</h3>
<p class="caption" role="heading"><span class="caption-text">Contents:</span></p>
<ul class="current">
<li class="toctree-l1"><a class="reference internal" href="objects.html">3D Objects</a></li>
<li class="toctree-l1"><a class="reference internal" href="rate.html">Animations</a></li>
<li class="toctree-l1"><a class="reference internal" href="canvas.html">Canvases</a></li>
<li class="toctree-l1"><a class="reference internal" href="cameraAndLights.html">Camera and Lighting</a></li>
<li class="toctree-l1"><a class="reference internal" href="colorOpacityGlow.html">Color/Opacity/Glow</a></li>
<li class="toctree-l1 current"><a class="reference internal" href="makeshapes.html">Design New Objects</a><ul class="current">
<li class="toctree-l2"><a class="reference internal" href="compound.html">compound</a></li>
<li class="toctree-l2 current"><a class="current reference internal" href="#">group</a></li>
<li class="toctree-l2"><a class="reference internal" href="vertex.html">vertex, triangle, and quad</a></li>
<li class="toctree-l2"><a class="reference internal" href="extrusion.html">extrusion</a></li>
<li class="toctree-l2"><a class="reference internal" href="shapes_and_paths.html">shapes and paths</a></li>
<li class="toctree-l2"><a class="reference internal" href="clone.html">cloning an object</a></li>
</ul>
</li>
<li class="toctree-l1"><a class="reference internal" href="file.html">Files/Libraries</a></li>
<li class="toctree-l1"><a class="reference internal" href="graph.html">Graphs</a></li>
<li class="toctree-l1"><a class="reference internal" href="math.html">Math Functions</a></li>
<li class="toctree-l1"><a class="reference internal" href="workwithobjects.html">Object Attachments</a></li>
<li class="toctree-l1"><a class="reference internal" href="rotation.html">Rotation</a></li>
<li class="toctree-l1"><a class="reference internal" href="textoutput.html">Text output</a></li>
<li class="toctree-l1"><a class="reference internal" href="texture.html">Textures</a></li>
<li class="toctree-l1"><a class="reference internal" href="userinput.html">User Input</a></li>
<li class="toctree-l1"><a class="reference internal" href="webvs7.html">VPython/WebVpython</a></li>
<li class="toctree-l1"><a class="reference internal" href="license.html">VPython license</a></li>
<li class="toctree-l1"><a class="reference internal" href="resources.html">Additional Resources</a></li>
</ul>
<div class="relations">
<h3>Related Topics</h3>
<ul>
<li><a href="index.html">Documentation overview</a><ul>
<li><a href="makeshapes.html">Making New Objects</a><ul>
<li>Previous: <a href="compound.html" title="previous chapter">compound</a></li>
<li>Next: <a href="vertex.html" title="next chapter">vertex, triangle, and quad</a></li>
</ul></li>
</ul></li>
</ul>
</div>
<div id="searchbox" style="display: none" role="search">
<h3 id="searchlabel">Quick search</h3>
<div class="searchformwrapper">
<form class="search" action="search.html" method="get">
<input type="text" name="q" aria-labelledby="searchlabel" autocomplete="off" autocorrect="off" autocapitalize="off" spellcheck="false"/>
<input type="submit" value="Go" />
</form>
</div>
</div>
<script>document.getElementById('searchbox').style.display = "block"</script>
</div>
</div>
<div class="clearer"></div>
</div>
<div class="footer">
©2023, Ruth Chabay and Bruce Sherwood.
|
Powered by <a href="http://sphinx-doc.org/">Sphinx 5.0.2</a>
& <a href="https://github.com/bitprophet/alabaster">Alabaster 0.7.12</a>
</div>
</body>
</html>
You can’t perform that action at this time.
