<div>Dear Bjoern,</div>
<div>&nbsp;</div>
<div>Thank you again for your reply, I have not touched it for a while now but&nbsp;I do need to finish the project and I still find myself confused. Please do correct me if I am wrong in my thought pipeline ... :)</div>
<div>&nbsp;</div>
<div>1)&nbsp;There&nbsp;are&nbsp;N connected polygons, which are the output&nbsp;from&nbsp;the collision detection algorithm.</div>
<div>2) for the force reflections I need to find the middle of the area and the direction of the force, therefore to find the direction I am trying to calculate the Vertex Normal (the average of the normals) to decide on where to apply the forces.</div>

<div>3) it seems that vtkPolyDataNormals can do it easily but I do not know how ... hmm .. :(</div>
<div>&nbsp;</div>
<div>If I use the following code :</div>
<div>--</div>
<div><span class="hl-identifier">vtkPolyDataNormals</span><span class="hl-code"> *</span><span class="hl-identifier">PDnormals</span><span class="hl-code"> = </span><span class="hl-identifier">vtkPolyDataNormals</span><span class="hl-code">::</span><span class="hl-identifier">New</span><span class="hl-brackets">()</span><span class="hl-code">;<br>
</span><span class="hl-identifier">PDnormals</span><span class="hl-code">-&gt;</span><span class="hl-identifier">SetInput</span><span class="hl-brackets">(</span><span class="hl-identifier">myMesh</span><span class="hl-brackets">)</span><span class="hl-code">;<br>
</span><span class="hl-identifier">PDnormals</span><span class="hl-code">-&gt;</span><span class="hl-identifier">Update</span><span class="hl-brackets">()</span><span class="hl-code">;<br></span><span class="hl-identifier">vtkNormals</span><span class="hl-code"> *</span><span class="hl-identifier">normals</span><span class="hl-code"> = </span><span class="hl-identifier">PDnormals</span><span class="hl-code">-&gt;</span><span class="hl-identifier">GetPointData</span><span class="hl-brackets">()</span><span class="hl-code">-&gt;</span><span class="hl-identifier">GetNormals</span><span class="hl-brackets">()</span><span class="hl-code">;<br>
</span><span class="hl-types">float</span><span class="hl-code"> *</span><span class="hl-identifier">n</span><span class="hl-code"> = </span><span class="hl-identifier">normals</span><span class="hl-code">-&gt;</span><span class="hl-identifier">GetNormal</span><span class="hl-brackets">(</span><span class="hl-identifier">i</span><span class="hl-brackets">)</span><span class="hl-code">;</span><br>
--<br></div>
<div>It only gives me the normals of the polygons ... </div>
<div>but how do I get the averaged one ? the vertex normal ? it seems that it does calcualte it somehow ... </div>
<div>&nbsp;</div>
<div>any ideas ?</div>
<div>thank you,</div>
<div>yaroslav</div>
<div>&nbsp;</div>
<div class="gmail_quote">On Thu, Sep 25, 2008 at 10:32 AM, &quot;Björn Zehner&quot; <span dir="ltr">&lt;<a href="mailto:bjoern.zehner@ufz.de">bjoern.zehner@ufz.de</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="PADDING-LEFT: 1ex; MARGIN: 0px 0px 0px 0.8ex; BORDER-LEFT: #ccc 1px solid">
<div class="Ih2E3d">Dear Yaroslav, <br>I am not sure, what do you mean by &quot;but vtkPolyDataNormals calculates the&nbsp;average normal for all normals as well&quot; and where does it say that vtkPolyDataNormals calculates this.<br>
&nbsp;<br>In the documentation it says: &quot;The algorithm works by determining normals for each polygon and then averaging them at shared points&quot;. Is it this what you mean? This would be the way to calculate the normals of a surfaces at its vertices. So with vtkPolyDataNormals you need to set vtkPolyDataNormals-&gt;ComputerPointNormalsOn();<br>
&nbsp;<br>For the Visualization I guess that you could use vtkGlyph3D with -&gt;SetVectorModeToUseNormal()<br>&nbsp;<br>Hope that helps,<br>Bjoern Zehner<br><br><br>----- Ursprüngliche Nachricht -----<br>Von: Yaroslav Tenzer &lt;<a href="mailto:krakadil.gena@gmail.com" target="_blank">krakadil.gena@gmail.com</a>&gt;<br>
Datum: Mittwoch, 24. September 2008, 15:32<br>Betreff: [vtkusers] How to extract the average normal from vtkPolyDataNormals ?<br>An: <a href="mailto:vtkusers@vtk.org" target="_blank">vtkusers@vtk.org</a><br>Cc: <a href="mailto:amy.squillacote@kitware.com" target="_blank">amy.squillacote@kitware.com</a><br>
<br></div>
<div dir="ltr">&nbsp; 
<div>
<div></div>
<div class="Wj3C7c"><br><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>Hello Vtk Users,<br>&nbsp;<br><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>I have seen a post by Amy in 2005 on how to access the normals of each polygon ... but vtkPolyDataNormals calculates the&nbsp;average normal for all normals as well ... how do I extract&nbsp;the averaged one from the filter ?<br>
&nbsp;<br><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>Is there any way to show the normals on the screen ?<br>&nbsp;<br><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>I have four polygons ... and I want to find the average normal for them ... and show it on the screen ... and I do not want to reinvent&nbsp;the wheel :)<br>
&nbsp;<br><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>thank you,<br><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>yaroslav<br clear="all">
<br>
<h1><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>[vtkusers] How should I get the right normal of a polygon defined in vtkCellArray?</h1><b>Amy Squillacote</b> <a>amy.squillacote at kitware.com </a><br>
<i><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>Thu Sep 29 08:59:36 EDT 2005</i> </div></div>
<p>
<div>
<div></div>
<div class="Wj3C7c">
<ul>
<li><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>Previous message: <a href="http://www.vtk.org/pipermail/vtkusers/2005-September/081956.html" target="_blank">[vtkusers] How should I get the right normal of a polygon defined in vtkCellArray? </a>
<li>Next message: <a href="http://www.vtk.org/pipermail/vtkusers/2005-September/081958.html" target="_blank">[vtkusers] Is it a VTK bug of vtkDelaunay2D ? </a>
<li><b>Messages sorted by:</b> <a href="http://www.vtk.org/pipermail/vtkusers/2005-September/date.html#81957" target="_blank">[ date ]</a> <a href="http://www.vtk.org/pipermail/vtkusers/2005-September/thread.html#81957" target="_blank">[ thread ]</a> <a href="http://www.vtk.org/pipermail/vtkusers/2005-September/subject.html#81957" target="_blank">[ subject ]</a> <a href="http://www.vtk.org/pipermail/vtkusers/2005-September/author.html#81957" target="_blank">[ author ]</a> </li>
</li></li></ul>
<hr>
<pre><font style="FONT-WEIGHT: normal; FONT-SIZE: 14px; FONT-STYLE: normal; BACKGROUND-COLOR: #f5f8f0">&gt; </font>The normals created by this filter are in a float array in CellData,   &gt; not in a vtkCellArray (which only provides information about how   &gt; points are connected to form each cell). To apply the filter to your   &gt; data and then access the normal of each polygon, do the following.  &gt;   &gt; vtkPolyDataNormals *normals = vtkPolyDataNormals::New();  &gt; normals-&gt;SetInput(yourData);  &gt; normals-&gt;ComputeCellNormalsOn();  &gt; normals-&gt;ComputePointNormalsOff();  &gt; normals-&gt;Update();  &gt;   &gt; vtkFloatArray *normArray =   &gt; vtkFloatArray::SafeDownCast(normals-&gt;GetOutput()-&gt;GetCellData()-&gt;GetNormals());  &gt; int i;  &gt;   &gt; float point[3];  &gt; for (i = 0; i &lt; normArray-&gt;GetNumberOfTuples(); i++)  &gt; {  &gt;      point[0] = normArray-&gt;GetValue(i, 0);  // x-component of normal  &gt;      point[1] = normArray-&gt;GetValue(i, 1);  // y-component of normal  &gt;      point[2] = normArray-&gt;GetValue(i, 2);  // z-component of normal  &gt;   &gt; // Do whatever you need to do to write this value to a file here.  &gt; }  &gt;   &gt; - Amy  &gt;   &gt; </pre>

<p></p><br></div></div>
<div class="Ih2E3d">&gt; _______________________________________________<br>&gt; This is the private VTK discussion list.<br>&gt; Please keep messages on-topic. Check the FAQ at: <br>&gt; <a href="http://www.vtk.org/Wiki/VTK_FAQFollow" target="_blank">http://www.vtk.org/Wiki/VTK_FAQFollow</a> this link to <br>
&gt; subscribe/unsubscribe:<a href="http://www.vtk.org/mailman/listinfo/vtkusers" target="_blank">http://www.vtk.org/mailman/listinfo/vtkusers</a><br><br>------------------------------------------------------------------------- <br>
Dr. Bjoern Zehner <br>UFZ Centre for Environmental Research Leipzig-Halle <br>Permoserstrasse 15 <br>04318 Leipzig <br>Germany <br><a href="http://www.ufz.de/index.php?en=5673" target="_blank">http://www.ufz.de/index.php?en=5673</a> <br>
Tel: ++49 (341) 235 1979 <br>Fax: ++49 (341) 235 1939<br><br><br></div>
<p></p></p></div><br>_______________________________________________<br>This is the private VTK discussion list.<br>Please keep messages on-topic. Check the FAQ at: <a href="http://www.vtk.org/Wiki/VTK_FAQ" target="_blank">http://www.vtk.org/Wiki/VTK_FAQ</a><br>
Follow this link to subscribe/unsubscribe:<br><a href="http://www.vtk.org/mailman/listinfo/vtkusers" target="_blank">http://www.vtk.org/mailman/listinfo/vtkusers</a><br><br></blockquote></div><br><br clear="all"><br>-- <br>
yaroslav<br><a href="http://www.bgu.ac.il/~tenzer">www.bgu.ac.il/~tenzer</a><br>