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
|
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<title>FreeMat: vtkKdNode</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td style="padding-left: 0.5em;">
<div id="projectname">FreeMat
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.1.1 -->
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main Page</span></a></li>
<li class="current"><a href="pages.html"><span>Related Pages</span></a></li>
</ul>
</div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('vtkfiltering_vtkkdnode.html','');});
</script>
<div id="doc-content">
<div class="header">
<div class="headertitle">
<div class="title">vtkKdNode </div> </div>
</div><!--header-->
<div class="contents">
<div class="textblock"><p>Section: <a class="el" href="sec_vtkfiltering.html">Visualization Toolkit Filtering Classes</a> </p>
<h1><a class="anchor" id="Usage"></a>
Usage</h1>
<p>To create an instance of class vtkKdNode, simply invoke its constructor as follows </p>
<pre class="fragment"> obj = vtkKdNode
</pre> <h1><a class="anchor" id="Methods"></a>
Methods</h1>
<p>The class vtkKdNode has several methods that can be used. They are listed below. Note that the documentation is translated automatically from the VTK sources, and may not be completely intelligible. When in doubt, consult the VTK website. In the methods listed below, <code>obj</code> is an instance of the vtkKdNode class. </p>
<ul>
<li>
<code>string = obj.GetClassName ()</code> </li>
<li>
<code>int = obj.IsA (string name)</code> </li>
<li>
<code>vtkKdNode = obj.NewInstance ()</code> </li>
<li>
<code>vtkKdNode = obj.SafeDownCast (vtkObject o)</code> </li>
<li>
<code>obj.SetDim (int )</code> - Set/Get the dimension along which this region is divided. (0 - x, 1 - y, 2 - z, 3 - leaf node (default)). </li>
<li>
<code>int = obj.GetDim ()</code> - Set/Get the dimension along which this region is divided. (0 - x, 1 - y, 2 - z, 3 - leaf node (default)). </li>
<li>
<code>double = obj.GetDivisionPosition ()</code> - Get the location of the division plane along the axis the region is divided. See also GetDim(). The result is undertermined if this node is not divided (a leaf node). </li>
<li>
<code>obj.SetNumberOfPoints (int )</code> - Set/Get the number of points contained in this region. </li>
<li>
<code>int = obj.GetNumberOfPoints ()</code> - Set/Get the number of points contained in this region. </li>
<li>
<code>obj.SetBounds (double x1, double x2, double y1, double y2, double z1, double z2)</code> - Set/Get the bounds of the spatial region represented by this node. Caller allocates storage for 6-vector in GetBounds. </li>
<li>
<code>obj.SetBounds (double b[6])</code> - Set/Get the bounds of the spatial region represented by this node. Caller allocates storage for 6-vector in GetBounds. </li>
<li>
<code>obj.GetBounds (double b) const</code> - Set/Get the bounds of the spatial region represented by this node. Caller allocates storage for 6-vector in GetBounds. </li>
<li>
<code>obj.SetDataBounds (double x1, double x2, double y1, double y2, double z1, double z2)</code> - Set/Get the bounds of the points contained in this spatial region. This may be smaller than the bounds of the region itself. Caller allocates storage for 6-vector in GetDataBounds. </li>
<li>
<code>obj.GetDataBounds (double b) const</code> - Set/Get the bounds of the points contained in this spatial region. This may be smaller than the bounds of the region itself. Caller allocates storage for 6-vector in GetDataBounds. </li>
<li>
<code>obj.SetDataBounds (float v)</code> - Given a pointer to NumberOfPoints points, set the DataBounds of this node to the bounds of these points. </li>
<li>
<code>double = obj.GetMinBounds ()</code> - Get a pointer to the 3 bound minima (xmin, ymin and zmin) or the 3 bound maxima (xmax, ymax, zmax). Don't free this pointer. </li>
<li>
<code>double = obj.GetMaxBounds ()</code> - Set the xmin, ymin and zmin value of the bounds of this region </li>
<li>
<code>obj.SetMinBounds (double mb)</code> - Set the xmin, ymin and zmin value of the bounds of this region </li>
<li>
<code>obj.SetMaxBounds (double mb)</code> - Set the xmax, ymax and zmax value of the bounds of this region </li>
<li>
<code>double = obj.GetMinDataBounds ()</code> - Get a pointer to the 3 data bound minima (xmin, ymin and zmin) or the 3 data bound maxima (xmax, ymax, zmax). Don't free this pointer. </li>
<li>
<code>double = obj.GetMaxDataBounds ()</code> - Set the xmin, ymin and zmin value of the bounds of this data within this region </li>
<li>
<code>obj.SetMinDataBounds (double mb)</code> - Set the xmin, ymin and zmin value of the bounds of this data within this region </li>
<li>
<code>obj.SetMaxDataBounds (double mb)</code> - Set the xmax, ymax and zmax value of the bounds of this data within this region </li>
<li>
<code>obj.SetID (int )</code> - Set/Get the ID associated with the region described by this node. If this is not a leaf node, this value should be -1. </li>
<li>
<code>int = obj.GetID ()</code> - Set/Get the ID associated with the region described by this node. If this is not a leaf node, this value should be -1. </li>
<li>
<code>int = obj.GetMinID ()</code> - If this node is not a leaf node, there are leaf nodes below it whose regions represent a partitioning of this region. The IDs of these leaf nodes form a contigous set. Set/Get the range of the IDs of the leaf nodes below this node. If this is already a leaf node, these values should be the same as the ID. </li>
<li>
<code>int = obj.GetMaxID ()</code> - If this node is not a leaf node, there are leaf nodes below it whose regions represent a partitioning of this region. The IDs of these leaf nodes form a contigous set. Set/Get the range of the IDs of the leaf nodes below this node. If this is already a leaf node, these values should be the same as the ID. </li>
<li>
<code>obj.SetMinID (int )</code> - If this node is not a leaf node, there are leaf nodes below it whose regions represent a partitioning of this region. The IDs of these leaf nodes form a contigous set. Set/Get the range of the IDs of the leaf nodes below this node. If this is already a leaf node, these values should be the same as the ID. </li>
<li>
<code>obj.SetMaxID (int )</code> - If this node is not a leaf node, there are leaf nodes below it whose regions represent a partitioning of this region. The IDs of these leaf nodes form a contigous set. Set/Get the range of the IDs of the leaf nodes below this node. If this is already a leaf node, these values should be the same as the ID. </li>
<li>
<code>obj.AddChildNodes (vtkKdNode left, vtkKdNode right)</code> - Add the left and right children. </li>
<li>
<code>obj.DeleteChildNodes ()</code> - Delete the left and right children. </li>
<li>
<code>vtkKdNode = obj.GetLeft ()</code> - Set/Get a pointer to the left child of this node. </li>
<li>
<code>obj.SetLeft (vtkKdNode left)</code> - Set/Get a pointer to the left child of this node. </li>
<li>
<code>vtkKdNode = obj.GetRight ()</code> - Set/Get a pointer to the right child of this node. </li>
<li>
<code>obj.SetRight (vtkKdNode right)</code> - Set/Get a pointer to the right child of this node. </li>
<li>
<code>vtkKdNode = obj.GetUp ()</code> - Set/Get a pointer to the parent of this node. </li>
<li>
<code>obj.SetUp (vtkKdNode up)</code> - Set/Get a pointer to the parent of this node. </li>
<li>
<code>int = obj.IntersectsBox (double x1, double x2, double y1, double y2, double z1, double z2, int useDataBounds)</code> - Return 1 if this spatial region intersects the axis-aligned box given by the bounds passed in. Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero. </li>
<li>
<code>int = obj.IntersectsSphere2 (double x, double y, double z, double rSquared, int useDataBounds)</code> - Return 1 if this spatial region intersects a sphere described by it's center and the square of it's radius. Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero. </li>
<li>
<code>int = obj.IntersectsRegion (vtkPlanesIntersection pi, int useDataBounds)</code> - A vtkPlanesIntersection object represents a convex 3D region bounded by planes, and it is capable of computing intersections of boxes with itself. Return 1 if this spatial region intersects the spatial region described by the vtkPlanesIntersection object. Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero. </li>
<li>
<code>int = obj.IntersectsCell (vtkCell cell, int useDataBounds, int cellRegion, double cellBoundsNULL)</code> - Return 1 if the cell specified intersects this region. If you already know the ID of the region containing the cell's centroid, provide that as an argument. If you already know the bounds of the cell, provide that as well, in the form of xmin,xmax,ymin,ymax,zmin, zmax. Either of these may speed the calculation. Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero. </li>
<li>
<code>int = obj.ContainsBox (double x1, double x2, double y1, double y2, double z1, double z2, int useDataBounds)</code> - Return 1 if this spatial region entirely contains a box specified by it's bounds. Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero. </li>
<li>
<code>int = obj.ContainsPoint (double x, double y, double z, int useDataBounds)</code> - Return 1 if this spatial region entirely contains the given point. Use the possibly smaller bounds of the points within the region if useDataBounds is non-zero. </li>
<li>
<code>double = obj.GetDistance2ToBoundary (double x, double y, double z, int useDataBounds)</code> - Calculate the distance squared from any point to the boundary of this region. Use the boundary of the points within the region if useDataBounds is non-zero. </li>
<li>
<code>double = obj.GetDistance2ToBoundary (double x, double y, double z, double boundaryPt, int useDataBounds)</code> - Calculate the distance squared from any point to the boundary of this region. Use the boundary of the points within the region if useDataBounds is non-zero. Set boundaryPt to the point on the boundary. </li>
<li>
<code>double = obj.GetDistance2ToInnerBoundary (double x, double y, double z)</code> - Calculate the distance from the specified point (which is required to be inside this spatial region) to an interior boundary. An interior boundary is one that is not also an boundary of the entire space partitioned by the tree of vtkKdNode's. </li>
<li>
<code>obj.PrintNode (int depth)</code> - For debugging purposes, print out this node. </li>
<li>
<code>obj.PrintVerboseNode (int depth)</code> - For debugging purposes, print out this node. </li>
</ul>
</div></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
<ul>
<li class="navelem"><a class="el" href="index.html">FreeMat Documentation</a></li><li class="navelem"><a class="el" href="sec_vtkfiltering.html">Visualization Toolkit Filtering Classes</a></li>
<li class="footer">Generated on Thu Jul 25 2013 17:18:31 for FreeMat by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.1.1 </li>
</ul>
</div>
</body>
</html>
|