geos_390_docs/classgeos_1_1planargraph_1_...

925 lines
56 KiB
HTML

<!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"/>
<meta name="generator" content="Doxygen 1.8.11"/>
<title>GEOS: geos::planargraph::PlanarGraph Class Reference</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="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 id="projectalign" style="padding-left: 0.5em;">
<div id="projectname">GEOS
&#160;<span id="projectnumber">3.9.1dev</span>
</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.11 -->
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="pages.html"><span>Related&#160;Pages</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li class="current"><a href="annotated.html"><span>Classes</span></a></li>
<li><a href="files.html"><span>Files</span></a></li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="annotated.html"><span>Class&#160;List</span></a></li>
<li><a href="inherits.html"><span>Class&#160;Hierarchy</span></a></li>
<li><a href="functions.html"><span>Class&#160;Members</span></a></li>
</ul>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><a class="el" href="namespacegeos.html">geos</a></li><li class="navelem"><a class="el" href="namespacegeos_1_1planargraph.html">planargraph</a></li><li class="navelem"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html">PlanarGraph</a></li> </ul>
</div>
</div><!-- top -->
<div class="header">
<div class="summary">
<a href="#pub-types">Public Types</a> &#124;
<a href="#pub-methods">Public Member Functions</a> &#124;
<a href="#pro-methods">Protected Member Functions</a> &#124;
<a href="#pro-attribs">Protected Attributes</a> &#124;
<a href="classgeos_1_1planargraph_1_1PlanarGraph-members.html">List of all members</a> </div>
<div class="headertitle">
<div class="title">geos::planargraph::PlanarGraph Class Reference</div> </div>
</div><!--header-->
<div class="contents">
<p>Represents a directed graph which is embeddable in a planar surface.
<a href="classgeos_1_1planargraph_1_1PlanarGraph.html#details">More...</a></p>
<p><code>#include &lt;<a class="el" href="planargraph_2PlanarGraph_8h_source.html">PlanarGraph.h</a>&gt;</code></p>
<div class="dynheader">
Inheritance diagram for geos::planargraph::PlanarGraph:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph__inherit__graph.svg" width="403" height="123"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
<center><span class="legend">[<a href="graph_legend.html">legend</a>]</span></center></div>
<div class="dynheader">
Collaboration diagram for geos::planargraph::PlanarGraph:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph__coll__graph.svg" width="158" height="163"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
<center><span class="legend">[<a href="graph_legend.html">legend</a>]</span></center></div>
<table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
Public Types</h2></td></tr>
<tr class="memitem:a40f7bb547ee1f957c716bcac6eade462"><td class="memItemLeft" align="right" valign="top">typedef std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> * &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a40f7bb547ee1f957c716bcac6eade462">EdgeContainer</a></td></tr>
<tr class="separator:a40f7bb547ee1f957c716bcac6eade462"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a4648cd7b6b17aca8d4d5a877762b5982"><td class="memItemLeft" align="right" valign="top">typedef EdgeContainer::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a4648cd7b6b17aca8d4d5a877762b5982">EdgeIterator</a></td></tr>
<tr class="separator:a4648cd7b6b17aca8d4d5a877762b5982"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr class="memitem:a01eaae76182f6582461a7a6e391269bc"><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a01eaae76182f6582461a7a6e391269bc">PlanarGraph</a> ()</td></tr>
<tr class="memdesc:a01eaae76182f6582461a7a6e391269bc"><td class="mdescLeft">&#160;</td><td class="mdescRight">Constructs a <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a> without any Edges, DirectedEdges, or Nodes. <a href="#a01eaae76182f6582461a7a6e391269bc">More...</a><br /></td></tr>
<tr class="separator:a01eaae76182f6582461a7a6e391269bc"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a33c3d2b7169a9a793d29bf9fd960d628"><td class="memItemLeft" align="right" valign="top">virtual&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a33c3d2b7169a9a793d29bf9fd960d628">~PlanarGraph</a> ()</td></tr>
<tr class="separator:a33c3d2b7169a9a793d29bf9fd960d628"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a08ddec6cb0d67c5837227475058ebdd4"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a08ddec6cb0d67c5837227475058ebdd4">findNode</a> (const <a class="el" href="classgeos_1_1geom_1_1Coordinate.html">geom::Coordinate</a> &amp;pt)</td></tr>
<tr class="memdesc:a08ddec6cb0d67c5837227475058ebdd4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the <a class="el" href="classgeos_1_1planargraph_1_1Node.html" title="A node in a PlanarGraph is a location where 0 or more Edge meet. ">Node</a> at the given location, or null if no <a class="el" href="classgeos_1_1planargraph_1_1Node.html" title="A node in a PlanarGraph is a location where 0 or more Edge meet. ">Node</a> was there. <a href="#a08ddec6cb0d67c5837227475058ebdd4">More...</a><br /></td></tr>
<tr class="separator:a08ddec6cb0d67c5837227475058ebdd4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5e041772de46fbd0d04b9adced4eddc4"><td class="memItemLeft" align="right" valign="top">NodeMap::container::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a5e041772de46fbd0d04b9adced4eddc4">nodeIterator</a> ()</td></tr>
<tr class="memdesc:a5e041772de46fbd0d04b9adced4eddc4"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an Iterator over the Nodes in this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. <a href="#a5e041772de46fbd0d04b9adced4eddc4">More...</a><br /></td></tr>
<tr class="separator:a5e041772de46fbd0d04b9adced4eddc4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3f53a024abe1fc34d5d9a2254c7aeac9"><td class="memItemLeft" align="right" valign="top">NodeMap::container::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a3f53a024abe1fc34d5d9a2254c7aeac9">nodeBegin</a> ()</td></tr>
<tr class="separator:a3f53a024abe1fc34d5d9a2254c7aeac9"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a78fa2f35af83a15dfe103a3f2330e126"><td class="memItemLeft" align="right" valign="top">NodeMap::container::const_iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a78fa2f35af83a15dfe103a3f2330e126">nodeBegin</a> () const </td></tr>
<tr class="separator:a78fa2f35af83a15dfe103a3f2330e126"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ad0e720302026c83b11904029f0017e0f"><td class="memItemLeft" align="right" valign="top">NodeMap::container::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#ad0e720302026c83b11904029f0017e0f">nodeEnd</a> ()</td></tr>
<tr class="separator:ad0e720302026c83b11904029f0017e0f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aed4a690505edbb0421d2758bc71864a6"><td class="memItemLeft" align="right" valign="top">NodeMap::container::const_iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#aed4a690505edbb0421d2758bc71864a6">nodeEnd</a> () const </td></tr>
<tr class="separator:aed4a690505edbb0421d2758bc71864a6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:ae2a0cbc53de6ee7191cf2a19156f7053"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#ae2a0cbc53de6ee7191cf2a19156f7053">getNodes</a> (std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> * &gt; &amp;nodes)</td></tr>
<tr class="memdesc:ae2a0cbc53de6ee7191cf2a19156f7053"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns the Nodes in this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. <a href="#ae2a0cbc53de6ee7191cf2a19156f7053">More...</a><br /></td></tr>
<tr class="separator:ae2a0cbc53de6ee7191cf2a19156f7053"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a3acaf9fdbb54655fdf1e097462dc49d6"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a> * &gt;::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a3acaf9fdbb54655fdf1e097462dc49d6">dirEdgeIterator</a> ()</td></tr>
<tr class="memdesc:a3acaf9fdbb54655fdf1e097462dc49d6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an Iterator over the DirectedEdges in this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>, in the order in which they were added. <a href="#a3acaf9fdbb54655fdf1e097462dc49d6">More...</a><br /></td></tr>
<tr class="separator:a3acaf9fdbb54655fdf1e097462dc49d6"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a90498ae812494e804effb9f244679212"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> * &gt;::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a90498ae812494e804effb9f244679212">edgeIterator</a> ()</td></tr>
<tr class="memdesc:a90498ae812494e804effb9f244679212"><td class="mdescLeft">&#160;</td><td class="mdescRight">Alias for <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#aab2c1afdc638406f50b88c33aa592d86" title="Returns an iterator to first Edge in this graph. ">edgeBegin()</a> <a href="#a90498ae812494e804effb9f244679212">More...</a><br /></td></tr>
<tr class="separator:a90498ae812494e804effb9f244679212"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aab2c1afdc638406f50b88c33aa592d86"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> * &gt;::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#aab2c1afdc638406f50b88c33aa592d86">edgeBegin</a> ()</td></tr>
<tr class="memdesc:aab2c1afdc638406f50b88c33aa592d86"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an iterator to first <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> in this graph. <a href="#aab2c1afdc638406f50b88c33aa592d86">More...</a><br /></td></tr>
<tr class="separator:aab2c1afdc638406f50b88c33aa592d86"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abf4facc89036fbd09552c3edc8ab8d57"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> * &gt;::iterator&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#abf4facc89036fbd09552c3edc8ab8d57">edgeEnd</a> ()</td></tr>
<tr class="memdesc:abf4facc89036fbd09552c3edc8ab8d57"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an iterator to one-past last <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> in this graph. <a href="#abf4facc89036fbd09552c3edc8ab8d57">More...</a><br /></td></tr>
<tr class="separator:abf4facc89036fbd09552c3edc8ab8d57"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a46c8a6e3d8f79b1eab86fa542c073157"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> * &gt; *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a46c8a6e3d8f79b1eab86fa542c073157">getEdges</a> ()</td></tr>
<tr class="separator:a46c8a6e3d8f79b1eab86fa542c073157"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:aa166b3ada82735e14acbe4f03bafc9a7"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#aa166b3ada82735e14acbe4f03bafc9a7">remove</a> (<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> *edge)</td></tr>
<tr class="memdesc:aa166b3ada82735e14acbe4f03bafc9a7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Removes an <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> and its associated DirectedEdges from their from-Nodes and from this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. <a href="#aa166b3ada82735e14acbe4f03bafc9a7">More...</a><br /></td></tr>
<tr class="separator:aa166b3ada82735e14acbe4f03bafc9a7"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a464db5ab65d3162b11636f2cc91e8209"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a464db5ab65d3162b11636f2cc91e8209">remove</a> (<a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a> *de)</td></tr>
<tr class="memdesc:a464db5ab65d3162b11636f2cc91e8209"><td class="mdescLeft">&#160;</td><td class="mdescRight">Removes <a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html" title="Represents a directed edge in a PlanarGraph. ">DirectedEdge</a> from its from-Node and from this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. <a href="#a464db5ab65d3162b11636f2cc91e8209">More...</a><br /></td></tr>
<tr class="separator:a464db5ab65d3162b11636f2cc91e8209"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:abce614860682ea033b3c6a48fe3e6fbe"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#abce614860682ea033b3c6a48fe3e6fbe">remove</a> (<a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> *node)</td></tr>
<tr class="memdesc:abce614860682ea033b3c6a48fe3e6fbe"><td class="mdescLeft">&#160;</td><td class="mdescRight">Removes a node from the graph, along with any associated DirectedEdges and Edges. <a href="#abce614860682ea033b3c6a48fe3e6fbe">More...</a><br /></td></tr>
<tr class="separator:abce614860682ea033b3c6a48fe3e6fbe"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a401916302cf0d46ccafa61413b5de67f"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> * &gt; *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a401916302cf0d46ccafa61413b5de67f">findNodesOfDegree</a> (std::size_t degree)</td></tr>
<tr class="memdesc:a401916302cf0d46ccafa61413b5de67f"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns all Nodes with the given number of Edges around it. The return value is a newly allocated vector of existing nodes. <a href="#a401916302cf0d46ccafa61413b5de67f">More...</a><br /></td></tr>
<tr class="separator:a401916302cf0d46ccafa61413b5de67f"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:acc1cd6e0d73e442d08ec563bfdba9454"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#acc1cd6e0d73e442d08ec563bfdba9454">findNodesOfDegree</a> (std::size_t degree, std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> * &gt; &amp;to)</td></tr>
<tr class="memdesc:acc1cd6e0d73e442d08ec563bfdba9454"><td class="mdescLeft">&#160;</td><td class="mdescRight">Get all Nodes with the given number of Edges around it. <a href="#acc1cd6e0d73e442d08ec563bfdba9454">More...</a><br /></td></tr>
<tr class="separator:acc1cd6e0d73e442d08ec563bfdba9454"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-methods"></a>
Protected Member Functions</h2></td></tr>
<tr class="memitem:a930a3d2e45f4a2caef6cb86cbe7fd731"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a930a3d2e45f4a2caef6cb86cbe7fd731">add</a> (<a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> *node)</td></tr>
<tr class="memdesc:a930a3d2e45f4a2caef6cb86cbe7fd731"><td class="mdescLeft">&#160;</td><td class="mdescRight">Adds a node to the std::map, replacing any that is already at that location. <a href="#a930a3d2e45f4a2caef6cb86cbe7fd731">More...</a><br /></td></tr>
<tr class="separator:a930a3d2e45f4a2caef6cb86cbe7fd731"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a5217df65deeba7c4834709d44854066b"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a5217df65deeba7c4834709d44854066b">add</a> (<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> *edge)</td></tr>
<tr class="memdesc:a5217df65deeba7c4834709d44854066b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Adds the <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> and its DirectedEdges with this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. <a href="#a5217df65deeba7c4834709d44854066b">More...</a><br /></td></tr>
<tr class="separator:a5217df65deeba7c4834709d44854066b"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a92507cdab36f99269e388d190b01e227"><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a92507cdab36f99269e388d190b01e227">add</a> (<a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a> *dirEdge)</td></tr>
<tr class="memdesc:a92507cdab36f99269e388d190b01e227"><td class="mdescLeft">&#160;</td><td class="mdescRight">Adds the <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> to this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. <a href="#a92507cdab36f99269e388d190b01e227">More...</a><br /></td></tr>
<tr class="separator:a92507cdab36f99269e388d190b01e227"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table><table class="memberdecls">
<tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pro-attribs"></a>
Protected Attributes</h2></td></tr>
<tr class="memitem:a6faf3a6fe3f5e3023470fbb6c34247fd"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> * &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a6faf3a6fe3f5e3023470fbb6c34247fd">edges</a></td></tr>
<tr class="separator:a6faf3a6fe3f5e3023470fbb6c34247fd"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a69775a29920eea17e7760fd58a31afb4"><td class="memItemLeft" align="right" valign="top">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a> * &gt;&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a69775a29920eea17e7760fd58a31afb4">dirEdges</a></td></tr>
<tr class="separator:a69775a29920eea17e7760fd58a31afb4"><td class="memSeparator" colspan="2">&#160;</td></tr>
<tr class="memitem:a59d27326b0abb7e5bb28a784cb490279"><td class="memItemLeft" align="right" valign="top"><a class="el" href="classgeos_1_1planargraph_1_1NodeMap.html">NodeMap</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a59d27326b0abb7e5bb28a784cb490279">nodeMap</a></td></tr>
<tr class="separator:a59d27326b0abb7e5bb28a784cb490279"><td class="memSeparator" colspan="2">&#160;</td></tr>
</table>
<a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
<div class="textblock"><p>Represents a directed graph which is embeddable in a planar surface. </p>
<p>This class and the other classes in this package serve as a framework for building planar graphs for specific algorithms. This class must be subclassed to expose appropriate methods to construct the graph. This allows controlling the types of graph components (<a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html" title="Represents a directed edge in a PlanarGraph. ">DirectedEdge</a>, <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> and <a class="el" href="classgeos_1_1planargraph_1_1Node.html" title="A node in a PlanarGraph is a location where 0 or more Edge meet. ">Node</a>) which can be added to the graph. An application which uses the graph framework will almost always provide subclasses for one or more graph components, which hold application-specific data and graph algorithms. </p>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00060">60</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div><h2 class="groupheader">Member Typedef Documentation</h2>
<a class="anchor" id="a40f7bb547ee1f957c716bcac6eade462"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">typedef std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a>*&gt; <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a40f7bb547ee1f957c716bcac6eade462">geos::planargraph::PlanarGraph::EdgeContainer</a></td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00108">108</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="a4648cd7b6b17aca8d4d5a877762b5982"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">typedef EdgeContainer::iterator <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a4648cd7b6b17aca8d4d5a877762b5982">geos::planargraph::PlanarGraph::EdgeIterator</a></td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00109">109</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<h2 class="groupheader">Constructor &amp; Destructor Documentation</h2>
<a class="anchor" id="a01eaae76182f6582461a7a6e391269bc"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">geos::planargraph::PlanarGraph::PlanarGraph </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Constructs a <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a> without any Edges, DirectedEdges, or Nodes. </p>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00116">116</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="a33c3d2b7169a9a793d29bf9fd960d628"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">virtual geos::planargraph::PlanarGraph::~PlanarGraph </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">virtual</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00119">119</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<h2 class="groupheader">Member Function Documentation</h2>
<a class="anchor" id="a930a3d2e45f4a2caef6cb86cbe7fd731"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::add </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> *&#160;</td>
<td class="paramname"><em>node</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Adds a node to the std::map, replacing any that is already at that location. </p>
<p>Only subclasses can add Nodes, to ensure Nodes are of the right type. </p>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00077">77</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="classgeos_1_1planargraph_1_1NodeMap.html#a25dfb6ef76f15e9480225e8dd54ed271">geos::planargraph::NodeMap::add()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_a930a3d2e45f4a2caef6cb86cbe7fd731_cgraph.svg" width="352" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="a5217df65deeba7c4834709d44854066b"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::add </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> *&#160;</td>
<td class="paramname"><em>edge</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Adds the <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> and its DirectedEdges with this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. </p>
<p>Assumes that the <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> has already been created with its associated DirectEdges. Only subclasses can add Edges, to ensure the edges added are of the right class. </p>
</div>
</div>
<a class="anchor" id="a92507cdab36f99269e388d190b01e227"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::add </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a> *&#160;</td>
<td class="paramname"><em>dirEdge</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span><span class="mlabel">protected</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Adds the <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> to this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. </p>
<p>Only subclasses can add DirectedEdges, to ensure the edges added are of the right class. </p>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00101">101</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="a3acaf9fdbb54655fdf1e097462dc49d6"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a>*&gt;::iterator geos::planargraph::PlanarGraph::dirEdgeIterator </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns an Iterator over the DirectedEdges in this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>, in the order in which they were added. </p>
<dl class="section see"><dt>See also</dt><dd>add(Edge) </dd>
<dd>
add(DirectedEdge) </dd></dl>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00187">187</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="aab2c1afdc638406f50b88c33aa592d86"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a>*&gt;::iterator geos::planargraph::PlanarGraph::edgeBegin </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns an iterator to first <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> in this graph. </p>
<p>Edges are stored in the order they were added. </p><dl class="section see"><dt>See also</dt><dd>add(Edge) </dd></dl>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00205">205</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="abf4facc89036fbd09552c3edc8ab8d57"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a>*&gt;::iterator geos::planargraph::PlanarGraph::edgeEnd </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns an iterator to one-past last <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> in this graph. </p>
<p>Edges are stored in the order they were added. </p><dl class="section see"><dt>See also</dt><dd>add(Edge) </dd></dl>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00216">216</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="a90498ae812494e804effb9f244679212"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a>*&gt;::iterator geos::planargraph::PlanarGraph::edgeIterator </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Alias for <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#aab2c1afdc638406f50b88c33aa592d86" title="Returns an iterator to first Edge in this graph. ">edgeBegin()</a> </p>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00194">194</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="a08ddec6cb0d67c5837227475058ebdd4"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a>* geos::planargraph::PlanarGraph::findNode </td>
<td>(</td>
<td class="paramtype">const <a class="el" href="classgeos_1_1geom_1_1Coordinate.html">geom::Coordinate</a> &amp;&#160;</td>
<td class="paramname"><em>pt</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the <a class="el" href="classgeos_1_1planargraph_1_1Node.html" title="A node in a PlanarGraph is a location where 0 or more Edge meet. ">Node</a> at the given location, or null if no <a class="el" href="classgeos_1_1planargraph_1_1Node.html" title="A node in a PlanarGraph is a location where 0 or more Edge meet. ">Node</a> was there. </p>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00127">127</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="classgeos_1_1planargraph_1_1NodeMap.html#a99f3018a76d489041bed3a57f291255d">geos::planargraph::NodeMap::find()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_a08ddec6cb0d67c5837227475058ebdd4_cgraph.svg" width="376" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="a401916302cf0d46ccafa61413b5de67f"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a>*&gt;* geos::planargraph::PlanarGraph::findNodesOfDegree </td>
<td>(</td>
<td class="paramtype">std::size_t&#160;</td>
<td class="paramname"><em>degree</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns all Nodes with the given number of Edges around it. The return value is a newly allocated vector of existing nodes. </p>
</div>
</div>
<a class="anchor" id="acc1cd6e0d73e442d08ec563bfdba9454"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::findNodesOfDegree </td>
<td>(</td>
<td class="paramtype">std::size_t&#160;</td>
<td class="paramname"><em>degree</em>, </td>
</tr>
<tr>
<td class="paramkey"></td>
<td></td>
<td class="paramtype">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> * &gt; &amp;&#160;</td>
<td class="paramname"><em>to</em>&#160;</td>
</tr>
<tr>
<td></td>
<td>)</td>
<td></td><td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Get all Nodes with the given number of Edges around it. </p>
<p>Found nodes are pushed to the given vector </p>
</div>
</div>
<a class="anchor" id="a46c8a6e3d8f79b1eab86fa542c073157"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a>*&gt;* geos::planargraph::PlanarGraph::getEdges </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the Edges that have been added to this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a> </p><dl class="section see"><dt>See also</dt><dd><a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html#a5217df65deeba7c4834709d44854066b" title="Adds the Edge and its DirectedEdges with this PlanarGraph. ">PlanarGraph::add(Edge* edge)</a> </dd></dl>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00226">226</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="ae2a0cbc53de6ee7191cf2a19156f7053"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::getNodes </td>
<td>(</td>
<td class="paramtype">std::vector&lt; <a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> * &gt; &amp;&#160;</td>
<td class="paramname"><em>nodes</em></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns the Nodes in this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. </p>
<dl class="params"><dt>Parameters</dt><dd>
<table class="params">
<tr><td class="paramname">nodes</td><td>: the nodes are push_back'ed here </td></tr>
</table>
</dd>
</dl>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00173">173</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="classgeos_1_1planargraph_1_1NodeMap.html#a470523a134670babebe642bbcc2e346f">geos::planargraph::NodeMap::getNodes()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_ae2a0cbc53de6ee7191cf2a19156f7053_cgraph.svg" width="388" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="a3f53a024abe1fc34d5d9a2254c7aeac9"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">NodeMap::container::iterator geos::planargraph::PlanarGraph::nodeBegin </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00143">143</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="planargraph_2NodeMap_8h_source.html#l00098">geos::planargraph::NodeMap::begin()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_a3f53a024abe1fc34d5d9a2254c7aeac9_cgraph.svg" width="387" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="a78fa2f35af83a15dfe103a3f2330e126"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">NodeMap::container::const_iterator geos::planargraph::PlanarGraph::nodeBegin </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td> const</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00149">149</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="planargraph_2NodeMap_8h_source.html#l00098">geos::planargraph::NodeMap::begin()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_a78fa2f35af83a15dfe103a3f2330e126_cgraph.svg" width="387" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="ad0e720302026c83b11904029f0017e0f"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">NodeMap::container::iterator geos::planargraph::PlanarGraph::nodeEnd </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00155">155</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="planargraph_2NodeMap_8h_source.html#l00109">geos::planargraph::NodeMap::end()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_ad0e720302026c83b11904029f0017e0f_cgraph.svg" width="376" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="aed4a690505edbb0421d2758bc71864a6"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">NodeMap::container::const_iterator geos::planargraph::PlanarGraph::nodeEnd </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td> const</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00161">161</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="planargraph_2NodeMap_8h_source.html#l00109">geos::planargraph::NodeMap::end()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_aed4a690505edbb0421d2758bc71864a6_cgraph.svg" width="376" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="a5e041772de46fbd0d04b9adced4eddc4"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">NodeMap::container::iterator geos::planargraph::PlanarGraph::nodeIterator </td>
<td>(</td>
<td class="paramname"></td><td>)</td>
<td></td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">inline</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Returns an Iterator over the Nodes in this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. </p>
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00137">137</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
<p>References <a class="el" href="planargraph_2NodeMap_8h_source.html#l00098">geos::planargraph::NodeMap::begin()</a>.</p>
<p><div class="dynheader">
Here is the call graph for this function:</div>
<div class="dyncontent">
<div class="center"><iframe scrolling="no" frameborder="0" src="classgeos_1_1planargraph_1_1PlanarGraph_a5e041772de46fbd0d04b9adced4eddc4_cgraph.svg" width="396" height="55"><p><b>This browser is not able to show SVG: try Firefox, Chrome, Safari, or Opera instead.</b></p></iframe>
</div>
</div>
</p>
</div>
</div>
<a class="anchor" id="aa166b3ada82735e14acbe4f03bafc9a7"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::remove </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a> *&#160;</td>
<td class="paramname"><em>edge</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Removes an <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> and its associated DirectedEdges from their from-Nodes and from this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. </p>
<p>Note: This method does not remove the Nodes associated with the <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a>, even if the removal of the <a class="el" href="classgeos_1_1planargraph_1_1Edge.html" title="Represents an undirected edge of a PlanarGraph. ">Edge</a> reduces the degree of a <a class="el" href="classgeos_1_1planargraph_1_1Node.html" title="A node in a PlanarGraph is a location where 0 or more Edge meet. ">Node</a> to zero. </p>
</div>
</div>
<a class="anchor" id="a464db5ab65d3162b11636f2cc91e8209"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::remove </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a> *&#160;</td>
<td class="paramname"><em>de</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Removes <a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html" title="Represents a directed edge in a PlanarGraph. ">DirectedEdge</a> from its from-Node and from this <a class="el" href="classgeos_1_1planargraph_1_1PlanarGraph.html" title="Represents a directed graph which is embeddable in a planar surface. ">PlanarGraph</a>. </p>
<p>Note: This method does not remove the Nodes associated with the <a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html" title="Represents a directed edge in a PlanarGraph. ">DirectedEdge</a>, even if the removal of the <a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html" title="Represents a directed edge in a PlanarGraph. ">DirectedEdge</a> reduces the degree of a <a class="el" href="classgeos_1_1planargraph_1_1Node.html" title="A node in a PlanarGraph is a location where 0 or more Edge meet. ">Node</a> to zero. </p>
</div>
</div>
<a class="anchor" id="abce614860682ea033b3c6a48fe3e6fbe"></a>
<div class="memitem">
<div class="memproto">
<table class="memname">
<tr>
<td class="memname">void geos::planargraph::PlanarGraph::remove </td>
<td>(</td>
<td class="paramtype"><a class="el" href="classgeos_1_1planargraph_1_1Node.html">Node</a> *&#160;</td>
<td class="paramname"><em>node</em></td><td>)</td>
<td></td>
</tr>
</table>
</div><div class="memdoc">
<p>Removes a node from the graph, along with any associated DirectedEdges and Edges. </p>
</div>
</div>
<h2 class="groupheader">Member Data Documentation</h2>
<a class="anchor" id="a69775a29920eea17e7760fd58a31afb4"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1DirectedEdge.html">DirectedEdge</a>*&gt; geos::planargraph::PlanarGraph::dirEdges</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00065">65</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="a6faf3a6fe3f5e3023470fbb6c34247fd"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname">std::vector&lt;<a class="el" href="classgeos_1_1planargraph_1_1Edge.html">Edge</a>*&gt; geos::planargraph::PlanarGraph::edges</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00064">64</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<a class="anchor" id="a59d27326b0abb7e5bb28a784cb490279"></a>
<div class="memitem">
<div class="memproto">
<table class="mlabels">
<tr>
<td class="mlabels-left">
<table class="memname">
<tr>
<td class="memname"><a class="el" href="classgeos_1_1planargraph_1_1NodeMap.html">NodeMap</a> geos::planargraph::PlanarGraph::nodeMap</td>
</tr>
</table>
</td>
<td class="mlabels-right">
<span class="mlabels"><span class="mlabel">protected</span></span> </td>
</tr>
</table>
</div><div class="memdoc">
<p>Definition at line <a class="el" href="planargraph_2PlanarGraph_8h_source.html#l00066">66</a> of file <a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a>.</p>
</div>
</div>
<hr/>The documentation for this class was generated from the following file:<ul>
<li><a class="el" href="planargraph_2PlanarGraph_8h_source.html">planargraph/PlanarGraph.h</a></li>
</ul>
</div><!-- contents -->
<!-- start footer part -->
<hr class="footer"/><address class="footer"><small>
Generated by &#160;<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/>
</a> 1.8.11
</small></address>
</body>
</html>