PySimultan 0.1.54__py3-none-any.whl → 0.2__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
Files changed (182) hide show
  1. PySimultan-0.2.dist-info/LICENSE.txt +17 -0
  2. PySimultan-0.2.dist-info/METADATA +36 -0
  3. PySimultan-0.2.dist-info/RECORD +82 -0
  4. {PySimultan-0.1.54.dist-info → PySimultan-0.2.dist-info}/WHEEL +1 -1
  5. PySimultan-0.2.dist-info/top_level.txt +1 -0
  6. {PySimultan → PySimultan2}/__init__.py +11 -6
  7. PySimultan2/config.py +52 -0
  8. PySimultan2/data_model.py +713 -0
  9. PySimultan2/default_types.py +507 -0
  10. PySimultan2/files.py +371 -0
  11. PySimultan2/geometry/__init__.py +4 -0
  12. PySimultan2/geometry/geometry_base.py +654 -0
  13. PySimultan2/geometry/utils.py +181 -0
  14. PySimultan2/multi_values.py +277 -0
  15. PySimultan2/object_mapper.py +200 -0
  16. PySimultan2/resources/AssimpNet.dll +0 -0
  17. PySimultan2/resources/AvalonDock.dll +0 -0
  18. PySimultan2/resources/BruTile.dll +0 -0
  19. PySimultan2/resources/ClosedXML.dll +0 -0
  20. PySimultan2/resources/ComponentBuilder.dll +0 -0
  21. PySimultan/resources/ComponentBuilder.exe.config → PySimultan2/resources/ComponentBuilder.dll.config +6 -2
  22. PySimultan2/resources/ComponentBuilder.runtimeconfig.json +18 -0
  23. {PySimultan → PySimultan2}/resources/ComponentBuilder.xml +11877 -6754
  24. PySimultan2/resources/ControlzEx.dll +0 -0
  25. PySimultan2/resources/Cyotek.Drawing.BitmapFont.dll +0 -0
  26. PySimultan2/resources/DocumentFormat.OpenXml.dll +0 -0
  27. PySimultan2/resources/ExcelNumberFormat.dll +0 -0
  28. PySimultan2/resources/Fluent.dll +0 -0
  29. PySimultan2/resources/GeometryViewer.dll +0 -0
  30. {PySimultan → PySimultan2}/resources/GeometryViewer.xml +2201 -1155
  31. PySimultan2/resources/HelixToolkit.Core.Wpf.dll +0 -0
  32. PySimultan2/resources/HelixToolkit.SharpDX.Core.Wpf.dll +0 -0
  33. PySimultan2/resources/HelixToolkit.SharpDX.Core.dll +0 -0
  34. PySimultan2/resources/HelixToolkit.dll +0 -0
  35. PySimultan2/resources/MathNet.Numerics.dll +0 -0
  36. PySimultan2/resources/Microsoft.AspNetCore.Authorization.dll +0 -0
  37. PySimultan2/resources/Microsoft.AspNetCore.Metadata.dll +0 -0
  38. PySimultan2/resources/Microsoft.Extensions.DependencyInjection.Abstractions.dll +0 -0
  39. PySimultan2/resources/Microsoft.Extensions.Logging.Abstractions.dll +0 -0
  40. PySimultan2/resources/Microsoft.Extensions.Options.dll +0 -0
  41. PySimultan2/resources/Microsoft.Extensions.Primitives.dll +0 -0
  42. PySimultan2/resources/Microsoft.WindowsAPICodePack.Shell.dll +0 -0
  43. PySimultan2/resources/Microsoft.WindowsAPICodePack.dll +0 -0
  44. PySimultan2/resources/Microsoft.Xaml.Behaviors.dll +0 -0
  45. PySimultan2/resources/Newtonsoft.Json.Bson.dll +0 -0
  46. PySimultan2/resources/Newtonsoft.Json.dll +0 -0
  47. PySimultan2/resources/SIMULTAN.AutoUpdate.Client.dll +0 -0
  48. PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll +0 -0
  49. PySimultan2/resources/SIMULTAN.AutoUpdate.DataTransferLibrary.dll.config +15 -0
  50. PySimultan2/resources/SIMULTAN.Lang.dll +0 -0
  51. {PySimultan → PySimultan2}/resources/SIMULTAN.Lang.xml +5282 -3252
  52. PySimultan2/resources/SIMULTAN.Plugins.dll +0 -0
  53. {PySimultan → PySimultan2}/resources/SIMULTAN.Plugins.xml +110 -0
  54. PySimultan2/resources/SIMULTAN.UI.dll +0 -0
  55. {PySimultan → PySimultan2}/resources/SIMULTAN.UI.xml +10483 -4937
  56. PySimultan2/resources/SIMULTAN.dll +0 -0
  57. PySimultan2/resources/SIMULTAN.xml +34122 -0
  58. PySimultan2/resources/SharpDX.D3DCompiler.dll +0 -0
  59. PySimultan2/resources/SharpDX.DXGI.dll +0 -0
  60. PySimultan2/resources/SharpDX.Direct2D1.dll +0 -0
  61. PySimultan2/resources/SharpDX.Direct3D11.dll +0 -0
  62. PySimultan2/resources/SharpDX.Direct3D9.dll +0 -0
  63. {PySimultan → PySimultan2}/resources/SharpDX.Mathematics.dll +0 -0
  64. PySimultan2/resources/SharpDX.dll +0 -0
  65. {PySimultan → PySimultan2}/resources/SitePlanner.dll +0 -0
  66. {PySimultan → PySimultan2}/resources/SitePlanner.xml +959 -1110
  67. PySimultan2/resources/Sprache.dll +0 -0
  68. PySimultan2/resources/System.Data.OleDb.dll +0 -0
  69. PySimultan2/resources/System.Net.Http.Formatting.dll +0 -0
  70. PySimultan2/resources/XAMLMarkupExtensions.dll +0 -0
  71. PySimultan2/resources/assimp.dll +0 -0
  72. {PySimultan → PySimultan2}/resources/defaultsettings.xml +0 -0
  73. PySimultan2/simultan_object.py +366 -0
  74. PySimultan2/taxonomy_maps.py +169 -0
  75. PySimultan2/utils.py +1383 -0
  76. PySimultan/config.py +0 -57
  77. PySimultan/data_model.py +0 -376
  78. PySimultan/default_types.py +0 -1771
  79. PySimultan/geo_default_types.py +0 -763
  80. PySimultan/geometry.py +0 -309
  81. PySimultan/resources/AssimpNet.dll +0 -0
  82. PySimultan/resources/AssimpNet.xml +0 -12074
  83. PySimultan/resources/BruTile.dll +0 -0
  84. PySimultan/resources/BruTile.xml +0 -1845
  85. PySimultan/resources/ControlzEx.dll +0 -0
  86. PySimultan/resources/Cyotek.Drawing.BitmapFont.dll +0 -0
  87. PySimultan/resources/DXFImportExport.dll +0 -0
  88. PySimultan/resources/DotSpatial.Projections.xml +0 -5879
  89. PySimultan/resources/EXCELImportExport.dll +0 -0
  90. PySimultan/resources/Fluent.dll +0 -0
  91. PySimultan/resources/Fluent.xml +0 -9103
  92. PySimultan/resources/GeoJSON.Net.dll +0 -0
  93. PySimultan/resources/GeometryViewer.Data.dll +0 -0
  94. PySimultan/resources/GeometryViewer.Data.xml +0 -4443
  95. PySimultan/resources/GeometryViewer.Shared.dll +0 -0
  96. PySimultan/resources/GeometryViewer.Shared.xml +0 -588
  97. PySimultan/resources/GeometryViewer.dll +0 -0
  98. PySimultan/resources/HelixToolkit.Wpf.SharpDX.dll +0 -0
  99. PySimultan/resources/HelixToolkit.Wpf.SharpDX.xml +0 -43219
  100. PySimultan/resources/HelixToolkit.Wpf.dll +0 -0
  101. PySimultan/resources/HelixToolkit.Wpf.xml +0 -22363
  102. PySimultan/resources/HelixToolkit.dll +0 -0
  103. PySimultan/resources/HelixToolkit.xml +0 -144
  104. PySimultan/resources/ImportLog_SMART_CAMPUS_TU_WIEN_BIBLIOTHEK_20210305_ZONENMODELL_23_11_2021-06_54_54.txt +0 -1
  105. PySimultan/resources/LibGit2Sharp.dll +0 -0
  106. PySimultan/resources/LibGit2Sharp.dll.config +0 -4
  107. PySimultan/resources/LibGit2Sharp.xml +0 -13770
  108. PySimultan/resources/MathNet.Numerics.dll +0 -0
  109. PySimultan/resources/MathNet.Numerics.xml +0 -57152
  110. PySimultan/resources/Microsoft.WindowsAPICodePack.Shell.dll +0 -0
  111. PySimultan/resources/Microsoft.WindowsAPICodePack.Shell.xml +0 -25496
  112. PySimultan/resources/Microsoft.WindowsAPICodePack.dll +0 -0
  113. PySimultan/resources/Microsoft.WindowsAPICodePack.xml +0 -2934
  114. PySimultan/resources/Newtonsoft.Json.dll +0 -0
  115. PySimultan/resources/Newtonsoft.Json.xml +0 -11305
  116. PySimultan/resources/ParameterStructure.dll +0 -0
  117. PySimultan/resources/ParameterStructure.xml +0 -10750
  118. PySimultan/resources/SIMULTAN.AutoUpdate.Client.dll +0 -0
  119. PySimultan/resources/SIMULTAN.DataExchange.dll +0 -0
  120. PySimultan/resources/SIMULTAN.Lang.dll +0 -0
  121. PySimultan/resources/SIMULTAN.Legacy.dll +0 -0
  122. PySimultan/resources/SIMULTAN.Legacy.xml +0 -254
  123. PySimultan/resources/SIMULTAN.Plugins.dll +0 -0
  124. PySimultan/resources/SIMULTAN.Project.dll +0 -0
  125. PySimultan/resources/SIMULTAN.Project.dll.config +0 -11
  126. PySimultan/resources/SIMULTAN.UI.dll +0 -0
  127. PySimultan/resources/SIMULTAN.Util.dll +0 -0
  128. PySimultan/resources/SIMULTAN.Util.xml +0 -3430
  129. PySimultan/resources/SharpDX.D3DCompiler.dll +0 -0
  130. PySimultan/resources/SharpDX.D3DCompiler.xml +0 -5897
  131. PySimultan/resources/SharpDX.DXGI.dll +0 -0
  132. PySimultan/resources/SharpDX.DXGI.xml +0 -8737
  133. PySimultan/resources/SharpDX.Direct2D1.dll +0 -0
  134. PySimultan/resources/SharpDX.Direct2D1.xml +0 -46691
  135. PySimultan/resources/SharpDX.Direct3D11.dll +0 -0
  136. PySimultan/resources/SharpDX.Direct3D11.xml +0 -31826
  137. PySimultan/resources/SharpDX.Direct3D9.dll +0 -0
  138. PySimultan/resources/SharpDX.Direct3D9.xml +0 -36489
  139. PySimultan/resources/SharpDX.Mathematics.xml +0 -16449
  140. PySimultan/resources/SharpDX.dll +0 -0
  141. PySimultan/resources/Sprache.dll +0 -0
  142. PySimultan/resources/Sprache.xml +0 -1199
  143. PySimultan/resources/System.Net.Http.Formatting.dll +0 -0
  144. PySimultan/resources/System.Net.Http.Formatting.xml +0 -2094
  145. PySimultan/resources/System.Windows.Interactivity.dll +0 -0
  146. PySimultan/resources/TalkGit.dll +0 -0
  147. PySimultan/resources/TalkGit.dll.config +0 -11
  148. PySimultan/resources/WebServiceConnector.dll +0 -0
  149. PySimultan/resources/WebServiceConnector.dll.config +0 -11
  150. PySimultan/resources/XAMLMarkupExtensions.dll +0 -0
  151. PySimultan/resources/XAMLMarkupExtensions.xml +0 -862
  152. PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.Aero.dll +0 -0
  153. PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.Metro.dll +0 -0
  154. PySimultan/resources/Xceed.Wpf.AvalonDock.Themes.VS2010.dll +0 -0
  155. PySimultan/resources/Xceed.Wpf.AvalonDock.dll +0 -0
  156. PySimultan/resources/Xceed.Wpf.Toolkit.dll +0 -0
  157. PySimultan/resources/assimp.dll +0 -0
  158. PySimultan/resources/schema.yaml +0 -13
  159. PySimultan/resources/simultan_exception_07_10_2021-08_34_24.txt +0 -17
  160. PySimultan/resources/simultan_exception_07_10_2021-10_13_31.txt +0 -17
  161. PySimultan/resources/simultan_exception_11_10_2021-19_45_42.txt +0 -17
  162. PySimultan/resources/simultan_exception_22_11_2021-16_41_52.txt +0 -14
  163. PySimultan/resources/simultan_exception_22_11_2021-17_37_40.txt +0 -14
  164. PySimultan/simultan_geometry_utils.py +0 -81
  165. PySimultan/simultan_utils.py +0 -165
  166. PySimultan/slots.py +0 -51
  167. PySimultan/template_tools.py +0 -631
  168. PySimultan/utils.py +0 -298
  169. PySimultan-0.1.54.dist-info/LICENSE +0 -674
  170. PySimultan-0.1.54.dist-info/LICENSE.txt +0 -674
  171. PySimultan-0.1.54.dist-info/METADATA +0 -690
  172. PySimultan-0.1.54.dist-info/RECORD +0 -119
  173. PySimultan-0.1.54.dist-info/entry_points.txt +0 -3
  174. PySimultan-0.1.54.dist-info/top_level.txt +0 -1
  175. PySimultan-0.1.54.dist-info/zip-safe +0 -1
  176. {PySimultan → PySimultan2}/resources/DotSpatial.Projections.dll +0 -0
  177. {PySimultan → PySimultan2}/resources/GeometryViewer.dll.config +0 -0
  178. {PySimultan → PySimultan2}/resources/SIMULTAN.AutoUpdate.Client.dll.config +0 -0
  179. {PySimultan → PySimultan2}/resources/SitePlanner.dll.config +0 -0
  180. {PySimultan → PySimultan2}/resources/Sprache.Calc.dll +0 -0
  181. {PySimultan → PySimultan2}/resources/__init__.py +0 -0
  182. {PySimultan → PySimultan2}/resources/setup.bat +0 -0
@@ -1,4443 +0,0 @@
1
- <?xml version="1.0"?>
2
- <doc>
3
- <assembly>
4
- <name>GeometryViewer.Data</name>
5
- </assembly>
6
- <members>
7
- <member name="T:GeometryViewer.Algorithms.Geometric.OffsetSurfaceAlgorithms">
8
- <summary>
9
- Methods for working with/converting offset models
10
- </summary>
11
- </member>
12
- <member name="M:GeometryViewer.Algorithms.Geometric.OffsetSurfaceAlgorithms.ConvertToModel(System.Collections.Generic.IEnumerable{GeometryViewer.Model.OffsetSurface.OffsetFace},System.Windows.Media.Media3D.Matrix3D,System.Double)">
13
- <summary>
14
- Converts a set of offset faces into a new geometry model. Holes are ignored.
15
- Vertices and Edges are merged if they are at the same location after transformation.
16
- Intersections are not handled.
17
- </summary>
18
- <param name="faces">The offset faces that should be converted</param>
19
- <param name="transformation">An additional transformation which is applied to all vertices</param>
20
- <param name="tolerance">Tolerance for merging vertices</param>
21
- <returns>A geometry model containing all the faces</returns>
22
- </member>
23
- <member name="T:GeometryViewer.Algorithms.Geometric.BaseGeometryAlgorithms">
24
- <summary>
25
- Provides methods that operate on BaseGeometries (on all types of Geometry)
26
- </summary>
27
- </member>
28
- <member name="M:GeometryViewer.Algorithms.Geometric.BaseGeometryAlgorithms.GetVertices(GeometryViewer.Model.Geometry.BaseGeometry)">
29
- <summary>
30
- Returns a list of all vertices in a Geometry. Only supports Vertex, Edge, Face, Volume
31
- </summary>
32
- <param name="geometry">The geometry for which the vertices should be returned</param>
33
- <returns>A list of all vertices in hte geometry</returns>
34
- </member>
35
- <member name="T:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms">
36
- <summary>
37
- Provides methods for detecting geometric properties in a model
38
- </summary>
39
- </member>
40
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.DetectXZFaces(GeometryViewer.Model.Geometry.GeometryModelData,System.Double)">
41
- <summary>
42
- Detects faces in the XZ plane
43
- </summary>
44
- <param name="model">The model</param>
45
- <param name="tolerance">Calculation tolerance</param>
46
- </member>
47
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.DetectXZFaces(GeometryViewer.Model.Geometry.GeometryModelData,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge},System.Double)">
48
- <summary>
49
- Detects faces in the XZ plane for a given set of edges
50
- </summary>
51
- <param name="model">The model</param>
52
- <param name="edges">The edges</param>
53
- <param name="tolerance">Calculation tolerance</param>
54
- </member>
55
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.DetectFromVertexEdge(System.Collections.Generic.List{GeometryViewer.Model.Geometry.Vertex},System.Collections.Generic.List{GeometryViewer.Model.Geometry.Edge},GeometryViewer.Model.Geometry.GeometryModelData,System.Double)">
56
- <summary>
57
- Tries to find edges and faces from set of vertices and/or edges. All vertices have to be on one plane
58
- </summary>
59
- <param name="vertices">The vertices(can be null)</param>
60
- <param name="edges">The edges (can be null)</param>
61
- <param name="model">The model this vertices belong to</param>
62
- <param name="tolerance">Calculation tolerance</param>
63
- </member>
64
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.BestFittingPlane(System.Collections.Generic.IEnumerable{System.Windows.Media.Media3D.Point3D})">
65
- <summary>
66
- Fits a plane through points in least square sense.
67
- </summary>
68
- <param name="points">Collection of 3D points to fit plane through</param>
69
- <returns></returns>
70
- </member>
71
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.DetectVolumes(GeometryViewer.Model.Geometry.GeometryModelData)">
72
- <summary>
73
- Tries to automatically detect and register volumes for a given geometry model.
74
- </summary>
75
- <param name="gm">GeometryModel to detect volumes in</param>
76
- </member>
77
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.DirectionFromFaceAndEdge(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.PEdge)">
78
- <summary>
79
- Computes a direction vector along a face relative to a given edge.
80
- </summary>
81
- <param name="face">The final vector lies on the plane of this face</param>
82
- <param name="edge">The final vector is orthogonal to this edge</param>
83
- <returns>Normalized direction vector</returns>
84
- </member>
85
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.DetectFromFaces(System.Collections.Generic.List{GeometryViewer.Model.Geometry.Face},GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.Geometry.Layer,System.Double)">
86
- <summary>
87
- Tries to find a volume by connecting faces.
88
-
89
- Priority:
90
- 1. One face contains all others -> cut holes
91
- 2. Two faces with a common edge -> merge
92
- 3. faces form a closed hull -> create volume
93
- 4. 2 faces -> crate volume by connecting edges of the two faces
94
-
95
- </summary>
96
- <param name="faces">The faces</param>
97
- <param name="model">The model</param>
98
- <param name="activeLayer">Layer in which new geometry is generated</param>
99
- <param name="tolerance">Calculation tolerance</param>
100
- <returns>True when the operation has found something to connect</returns>
101
- </member>
102
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.DetectFacesFromEdges(System.Collections.Generic.List{GeometryViewer.Model.Geometry.Edge},GeometryViewer.Model.Geometry.GeometryModelData)">
103
- <summary>
104
- Detects faces from a set of edges. First removes dangling edges, then tries to find one closed edge loop.
105
- </summary>
106
- <param name="edges">List of edges which could define a face</param>
107
- <param name="model">The model into which the face should be generated</param>
108
- <returns></returns>
109
- </member>
110
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.SignedAngle(System.Windows.Vector,System.Windows.Vector)">
111
- <summary>
112
- Computes the signed angle (in counter clockwise direction) between two vectors in 2D.
113
- </summary>
114
- <param name="v1">vector 1</param>
115
- <param name="v2">vector 2</param>
116
- <returns>Signed angle between two 2D vectors in the range [-pi, pi].</returns>
117
- </member>
118
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.ShortAngleDist(System.Double,System.Double)">
119
- <summary>
120
- Computes the shortest distance between angles in degrees, i.e. distance is always less than 180°
121
- https://gist.github.com/shaunlebron/8832585
122
- </summary>
123
- <param name="a0">First angle in degrees</param>
124
- <param name="a1">Second angle in degrees</param>
125
- <returns>Shortest distance between angles in degrees</returns>
126
- </member>
127
- <member name="M:GeometryViewer.Algorithms.Geometric.DetectionAlgorithms.FindConnection(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.Face,System.Double,System.Collections.Generic.List{System.Double}@,System.Collections.Generic.List{System.Double}@)">
128
- <summary>
129
- Determines whether two faces can be connected.
130
- Criterias:
131
- - Same number of straight lines
132
- - At least two edges with same direction when projecting f2 to f1
133
- </summary>
134
- </member>
135
- <member name="T:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms">
136
- <summary>
137
- Provides algorithms that operate on edges
138
- </summary>
139
- </member>
140
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.IsSimilarEdge(GeometryViewer.Model.Geometry.Edge,GeometryViewer.Model.Geometry.Edge)">
141
- <summary>
142
- Determines whether two edges describe the same information
143
- </summary>
144
- <param name="e1">First edge</param>
145
- <param name="e2">Second edge</param>
146
- <returns>True when the two edges describe the same information, False otherwise</returns>
147
- </member>
148
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.EdgePointIntersection(GeometryViewer.Model.Geometry.Edge,System.Windows.Media.Media3D.Point3D)">
149
- <summary>
150
- Calculates the distance of the point to the line (d) and the line equation parameter of the closed point (t)
151
- </summary>
152
- <param name="e1">The edge</param>
153
- <param name="p">The point</param>
154
- <returns>Distance of the point to the line (d) and the line equation parameter of the closed point (t)</returns>
155
- </member>
156
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.EdgeEdgeIntersection(GeometryViewer.Model.Geometry.Edge,GeometryViewer.Model.Geometry.Edge,System.Double)">
157
- <summary>
158
- Calculates the intersection between two lines
159
- </summary>
160
- <param name="e1">First edge</param>
161
- <param name="e2">Second edge</param>
162
- <param name="endLineTolerance">Defines which region at start and end of lines are considered outside.
163
- The line parameter t has to be in [tolerance, 1-tolerance] to be considered intersecting</param>
164
- <returns>A bool indicating whether the two edges intersect and the line parameters t1 for e1 and t2 for e2</returns>
165
- </member>
166
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.IsOnSameLine(GeometryViewer.Model.Geometry.Edge,GeometryViewer.Model.Geometry.Edge,System.Double)">
167
- <summary>
168
- Determines whether to edges are on the same line
169
- </summary>
170
- <param name="e1">First edge</param>
171
- <param name="e2">Second edge</param>
172
- <param name="tolerance">Accepted tolerance</param>
173
- <returns>True when both edges are on the same line, False otherwise</returns>
174
- </member>
175
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.Direction(GeometryViewer.Model.Geometry.PEdge)">
176
- <summary>
177
- Calculates the direction of a PEdge
178
- </summary>
179
- <param name="e">The edge</param>
180
- <returns>The direction of the edge</returns>
181
- </member>
182
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.Direction(GeometryViewer.Model.Geometry.Edge)">
183
- <summary>
184
- Returns the normalized direction of an edge. It is undefined which of the two possible directions is returned.
185
- </summary>
186
- <param name="e">The edge</param>
187
- <returns>One of the two possible directions of the edge</returns>
188
- </member>
189
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.ContainedGeometry(GeometryViewer.Model.Geometry.Edge,System.Collections.Generic.List{GeometryViewer.Model.Geometry.BaseGeometry}@)">
190
- <summary>
191
- Returns all the geometry contained in this edge (edge + vertices)
192
- </summary>
193
- <param name="e">The edge</param>
194
- <param name="geometries">The resulting geometry list</param>
195
- </member>
196
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.OrderLoop(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge})">
197
- <summary>
198
- Tries to order the edges such that they form a closed loop by following the edges.
199
- </summary>
200
- <param name="edges">The edges</param>
201
- <returns>A bool indicating if the edges form a closed loop. The list contains the ordered edges or null when they don't form a loop.</returns>
202
- </member>
203
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.OrderLoop(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.PEdge})">
204
- <summary>
205
- Tries to order the pedges such that they form a closed loop by following the edges.
206
- </summary>
207
- <param name="edges">The PEdges</param>
208
- <returns>A bool indicating if the edges form a closed loop. The list contains the ordered edges or null when they don't form a loop.</returns>
209
- </member>
210
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.OrderedPointLoop(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge},System.Windows.Media.Media3D.Matrix3D)">
211
- <summary>
212
- Orders a list of edges and returns an ordered list of corner points
213
- </summary>
214
- <param name="edges">The edges</param>
215
- <param name="matrix">An optional mapping matrix. Only used to transform the resulting point list.</param>
216
- <returns></returns>
217
- </member>
218
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.OrderedVertexLoop(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge})">
219
- <summary>
220
- Orders a list of edges and returns an ordered list of vertices
221
- </summary>
222
- <param name="edges">The edges</param>
223
- <returns></returns>
224
- </member>
225
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.EdgeEdgeIntersection2D(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Double)">
226
- <summary>
227
- Tests for Edge-Edge intersections in the 2D plane. Z is ignored
228
- https://stackoverflow.com/questions/563198/how-do-you-detect-where-two-line-segments-intersect
229
- </summary>
230
- <param name="e0p0">First line first point</param>
231
- <param name="e0p1">First line second point</param>
232
- <param name="e1p0">Second line first point</param>
233
- <param name="e1p1">Second line second point</param>
234
- <param name="tolerance">Tolerance for calculations</param>
235
- <returns>True when the two edges intersect, False otherwise.
236
- t1 is intersection parameter along first line, t2 is intersection parameter along second line</returns>
237
- </member>
238
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.ReplaceEdge(GeometryViewer.Model.Geometry.Edge,System.Collections.Generic.List{GeometryViewer.Model.Geometry.Edge})">
239
- <summary>
240
- Replaces an edges with multiple new edges (also handles parent geometry)
241
- </summary>
242
- <param name="original">Original edge</param>
243
- <param name="replacements">List of edges that replace original</param>
244
- </member>
245
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.SplitEdge(GeometryViewer.Model.Geometry.Edge,System.Windows.Media.Media3D.Point3D)">
246
- <summary>
247
- Splits an edge at a specific position
248
- </summary>
249
- <param name="e">The edge</param>
250
- <param name="splitPosition">The position for the split (should be close to the line)</param>
251
- </member>
252
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeAlgorithms.IsConnectedEdge(GeometryViewer.Model.Geometry.Edge,GeometryViewer.Model.Geometry.Edge)">
253
- <summary>
254
- Returns whether two given edges are connected
255
- </summary>
256
- <param name="e1">Edge 1</param>
257
- <param name="e2">Edge 2</param>
258
- <returns>true if edges share a vertex</returns>
259
- </member>
260
- <member name="T:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms">
261
- <summary>
262
- Provides algorithms that work on EdgeLoop instances
263
- </summary>
264
- </member>
265
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.NormalCCW(GeometryViewer.Model.Geometry.EdgeLoop)">
266
- <summary>
267
- Calculates the normal of an EdgeLoop.
268
- <para>The method assumes that the EdgeLoop describes a planar surface and is oriented counter clockwise</para>
269
- When no normal could be found (or NaN/Inf is generated during calculation), this methods returns (0,0,0).
270
- </summary>
271
- <param name="loop">The EdgeLoop to operate on</param>
272
- <returns>The normal vector</returns>
273
- </member>
274
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.NormalCCW(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D})">
275
- <summary>
276
- Calculates the normal of an EdgeLoop given as a set of points.
277
- <para>The method assumes that the EdgeLoop describes a planar surface and is oriented counter clockwise</para>
278
- When no normal could be found (or NaN/Inf is generated during calculation), this methods returns (0,0,0).
279
- </summary>
280
- <param name="edgeLoopPositions">The set of positions in the EdgeLoop to operate on</param>
281
- <returns>The normal vector</returns>
282
- </member>
283
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.StraightEdgeCount(GeometryViewer.Model.Geometry.EdgeLoop,System.Double)">
284
- <summary>
285
- Returns the number of straight lines in a loop. Basically combines consecutive edges with the same direction.
286
- </summary>
287
- <param name="loop">The loop</param>
288
- <param name="tolerance">Calculation tolerance</param>
289
- <returns>The number of straight lines</returns>
290
- </member>
291
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.IsSimilar(GeometryViewer.Model.Geometry.EdgeLoop,GeometryViewer.Model.Geometry.EdgeLoop)">
292
- <summary>
293
- Determines if two edgeloops are similar. Similar means that they contain the same Edges
294
- </summary>
295
- <param name="loop1">First edge</param>
296
- <param name="loop2">Second edge</param>
297
- <returns>True when the loops are similar, False otherwise</returns>
298
- </member>
299
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Area(GeometryViewer.Model.Geometry.EdgeLoop)">
300
- <summary>
301
- Calculates the area of a EdgeLoop
302
- </summary>
303
- <param name="loop">The loop</param>
304
- <returns>The area (always positive)</returns>
305
- </member>
306
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Area(System.Collections.Generic.IEnumerable{System.Windows.Media.Media3D.Point3D})">
307
- <summary>
308
- Calculates the area of a EdgeLoop
309
- </summary>
310
- <param name="boundary">A list of boundary points</param>
311
- <returns>The area (always positive)</returns>
312
- </member>
313
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Size(GeometryViewer.Model.Geometry.EdgeLoop)">
314
- <summary>
315
- Returns the estimated size of the loop. For floor/ceiling loops, the direction of the axis can vary.
316
- </summary>
317
- <param name="loop"></param>
318
- <returns></returns>
319
- </member>
320
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.HeightMinMax(GeometryViewer.Model.Geometry.EdgeLoop)">
321
- <summary>
322
- Returns the minimum and maximum Y value of all vertices in the loop
323
- </summary>
324
- <param name="loop">The edgeloop</param>
325
- <returns>Minimum and maximum Y value of all vertices</returns>
326
- </member>
327
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Flip(GeometryViewer.Model.Geometry.EdgeLoop)">
328
- <summary>
329
- Flips an edge loop
330
- </summary>
331
- <param name="loop">The edge loop</param>
332
- </member>
333
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Contains(GeometryViewer.Model.Geometry.EdgeLoop,System.Windows.Media.Media3D.Point3D,System.Double,System.Double)">
334
- <summary>
335
- Tests if an edge-loop contains a point
336
- </summary>
337
- <param name="l">The loop</param>
338
- <param name="v">The point</param>
339
- <param name="tolerance">Tolerance to edges</param>
340
- <param name="zTolerance">Tolerance between point and the plane spanned by the edgeloop</param>
341
- <returns></returns>
342
- </member>
343
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.LoopToXYMapping(GeometryViewer.Model.Geometry.EdgeLoop)">
344
- <summary>
345
- Calculates the mapping of a EdgeLoop into the XY plane
346
- </summary>
347
- <param name="loop"></param>
348
- <returns></returns>
349
- </member>
350
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Contains2D(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Windows.Media.Media3D.Point3D,System.Double,System.Double)">
351
- <summary>
352
- Tests if a point lies inside a polygon.
353
- This method assumes that the polygon lies in the XY plane.
354
- </summary>
355
- http://geomalgorithms.com/a03-_inclusion.html
356
- </member>
357
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Perimeter(GeometryViewer.Model.Geometry.EdgeLoop)">
358
- <summary>
359
- Calculates the perimeter of an EdgeLoop.
360
- Sums up the length of all edges
361
- </summary>
362
- <param name="loop">The loop</param>
363
- <returns>The perimeter length</returns>
364
- </member>
365
- <member name="M:GeometryViewer.Algorithms.Geometric.EdgeLoopAlgorithms.Perimeter(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D})">
366
- <summary>
367
- Calculates the perimeter of an EdgeLoop (given as polygon corners).
368
- Sums up the length of all edges
369
- </summary>
370
- <param name="polygon">The polygon</param>
371
- <returns>The perimeter length</returns>
372
- </member>
373
- <member name="T:GeometryViewer.Algorithms.Geometric.GeometricRelation">
374
- <summary>
375
- Enumeration for describing geometric realtions for intersection tests
376
- </summary>
377
- </member>
378
- <member name="F:GeometryViewer.Algorithms.Geometric.GeometricRelation.Contained">
379
- <summary>
380
- Fully contained
381
- </summary>
382
- </member>
383
- <member name="F:GeometryViewer.Algorithms.Geometric.GeometricRelation.Intersecting">
384
- <summary>
385
- Intersecting
386
- </summary>
387
- </member>
388
- <member name="F:GeometryViewer.Algorithms.Geometric.GeometricRelation.None">
389
- <summary>
390
- No intersection, not contained
391
- </summary>
392
- </member>
393
- <member name="T:GeometryViewer.Algorithms.Geometric.FaceAlgorithms">
394
- <summary>
395
- Provides algorithms that operate on Face instances
396
- </summary>
397
- </member>
398
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Triangulate(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.GeometricOrientation)">
399
- <summary>
400
- Segments a PFace into triangles. Orientation is derived from the PFace.Orientation property.
401
- </summary>
402
- <param name="face">The face to triangulate</param>
403
- <param name="orientation">Orientation of the face</param>
404
- <returns>A tuple containing positions, normals and indices for the triangulation.</returns>
405
- </member>
406
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Triangulate(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Collections.Generic.IEnumerable{System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D}},System.Windows.Media.Media3D.Vector3D,GeometryViewer.Model.Geometry.GeometricOrientation)">
407
- <summary>
408
- Triangulates a list of boundary vertices and holes
409
- </summary>
410
- <param name="boundary">The boundary</param>
411
- <param name="holes">List of holes</param>
412
- <param name="normal">The face normal</param>
413
- <param name="orientation">Orientation of the face (winding order)</param>
414
- <returns>A tuple containing position, normal and indices for the triangulation.</returns>
415
- </member>
416
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.TriangulateBoundary(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Windows.Media.Media3D.Vector3D,GeometryViewer.Model.Geometry.GeometricOrientation)">
417
- <summary>
418
- Triangulates a face, leaving away all holes
419
- </summary>
420
- <param name="boundary">Boundary vertex positions</param>
421
- <param name="normal">The face normal</param>
422
- <param name="orientation">Orientation of the face (winding order)</param>
423
- <returns>A tuple containing position, normal and indices for the triangulation.</returns>
424
- </member>
425
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.TriangulateBoundary(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.GeometricOrientation)">
426
- <summary>
427
- Triangulates a face, leaving away all holes
428
- </summary>
429
- <param name="face">The face</param>
430
- <param name="orientation">Orientation of the face</param>
431
- <returns>A tuple containing position, normal and indices for the triangulation.</returns>
432
- </member>
433
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.TriangulateBoundary(GeometryViewer.Model.Geometry.PFace)">
434
- <summary>
435
- Triangulates a face, leaving away all holes
436
- </summary>
437
- <param name="face">The face</param>
438
- <returns>A tuple containing position, normal and indices for the triangulation.</returns>
439
- </member>
440
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.FaceToXZMapping(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.GeometricOrientation)">
441
- <summary>
442
- Returns a matrix that maps the face into the XZ plane
443
- </summary>
444
- <param name="face">The face which should be mapped</param>
445
- <param name="orientation">Defines which side of the Face will point upwards</param>
446
- <returns>A rotation matrix</returns>
447
- </member>
448
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.FaceToXYMapping(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.GeometricOrientation)">
449
- <summary>
450
- Returns a matrix that maps the face into the XY plane
451
- </summary>
452
- <param name="face">The face which should be mapped</param>
453
- <param name="orientation">Defines which side of the Face will point upwards</param>
454
- <returns>A rotation matrix</returns>
455
- </member>
456
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.XYSize(GeometryViewer.Model.Geometry.Face)">
457
- <summary>
458
- Determines the size of the face in it's embedding plane
459
- This function maps the face in the XY plane and then calculates the size there.
460
- </summary>
461
- <param name="face">The face</param>
462
- <returns>The size</returns>
463
- </member>
464
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Center(GeometryViewer.Model.Geometry.Face)">
465
- <summary>
466
- Calculates the center of the face (center means geometric average)
467
- </summary>
468
- <param name="face">The face</param>
469
- <returns>The center</returns>
470
- </member>
471
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.ContainedGeometry(GeometryViewer.Model.Geometry.Face,System.Collections.Generic.List{GeometryViewer.Model.Geometry.BaseGeometry}@)">
472
- <summary>
473
- Returns all the geometry contained in this edge (faces + edge + vertices)
474
- </summary>
475
- <param name="f">The face</param>
476
- <param name="geometries">The resulting geometry list</param>
477
- </member>
478
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Contains(GeometryViewer.Model.Geometry.Face,System.Windows.Media.Media3D.Point3D,System.Double,System.Double)">
479
- <summary>
480
- Checks whether a face contains a point
481
- </summary>
482
- <param name="f">The face</param>
483
- <param name="v">The point</param>
484
- <param name="tolerance">Tolerance towards the boundary</param>
485
- <param name="zTolerance">Tolerance to the plane spanned by the face</param>
486
- <returns>Contained when point is inside polygon, None otherwise</returns>
487
- </member>
488
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Contains2D(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.Edge,System.Double,System.Double)">
489
- <summary>
490
- Checks whether a face contains or intersects an edge
491
- </summary>
492
- <param name="f">The face</param>
493
- <param name="e">The edge</param>
494
- <param name="tolerance">Tolerance towards the boundary</param>
495
- <param name="zTolerance">Tolerance to the plane spanned by the face</param>
496
- <returns>Contained when the edge is fully contained in the polygon, Intersecting when the edge intersects the polygon boundary, None otherwise</returns>
497
- </member>
498
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Contains2D(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.Face,System.Double,System.Double)">
499
- <summary>
500
- Checks whether a face contains or intersects another face
501
- </summary>
502
- <param name="fouter">The container face</param>
503
- <param name="f">The containing face</param>
504
- <param name="tolerance">Tolerance towards the boundary</param>
505
- <param name="zTolerance">Tolerance to the plane spanned by the face</param>
506
- <returns>Contained when the face is fully contained in the polygon, Intersecting when the face intersects the polygon, None otherwise</returns>
507
- </member>
508
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.HessianPlane(GeometryViewer.Model.Geometry.Face)">
509
- <summary>
510
- Calculates the hessian form of the plane spanned by a face
511
- </summary>
512
- <param name="f">The face</param>
513
- <returns>The hessian form</returns>
514
- </member>
515
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.IsSamePlane(System.ValueTuple{System.Windows.Media.Media3D.Vector3D,System.Double},System.ValueTuple{System.Windows.Media.Media3D.Vector3D,System.Double},System.Double,System.Double)">
516
- <summary>
517
- Tests whether two hessian forms are similar
518
- </summary>
519
- <param name="plane1">First plane</param>
520
- <param name="plane2">Second plane</param>
521
- <param name="angleTolerance">Tolerance (angular)</param>
522
- <param name="distanceTolerance">Tolerance (distance)</param>
523
- <returns></returns>
524
- </member>
525
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Area(GeometryViewer.Model.Geometry.Face)">
526
- <summary>
527
- Calculates the area of a face (Area of the boundary minus area of holes)
528
- The method produces wrong results when holes are not fully contained in the face or when holes overlap
529
- </summary>
530
- <param name="f">The face</param>
531
- <returns>The area of the face</returns>
532
- </member>
533
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.AreaMinMax(GeometryViewer.Model.Geometry.Face)">
534
- <summary>
535
- Returns the minimum and maximum area of the offset surfaces as well as the area of the reference surface
536
- </summary>
537
- <param name="f">The face</param>
538
- <returns>The area of the reference surface (area), the minimum area of the offset surfaces (offsetAreaMin)
539
- and maximum area or the offset surfaces (offsetAreaMax)</returns>
540
- </member>
541
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.AreaInnerOuter(GeometryViewer.Model.Geometry.Face)">
542
- <summary>
543
- Calculates the area of the face, the area of the inner offset surface and the area of the outer offset surface
544
- </summary>
545
- <param name="f">The face</param>
546
- <returns>area: Area of the reference geometry, innerArea: Area of the inner offset surface, outerArea: Area of the outer offset surface</returns>
547
- </member>
548
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Size(GeometryViewer.Model.Geometry.Face)">
549
- <summary>
550
- Returns a size estimate for the face. For floor/ceiling faces the direction of the used axis can vary
551
- </summary>
552
- <param name="f"></param>
553
- <returns></returns>
554
- </member>
555
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.HeightMinMax(GeometryViewer.Model.Geometry.Face)">
556
- <summary>
557
- Returns the minimum and maximum Y value of all vertices in a face
558
- </summary>
559
- <param name="f">The Face</param>
560
- <returns>Minimum and maximum Y value of all vertices</returns>
561
- </member>
562
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.IsFloorOrCeiling(GeometryViewer.Model.Geometry.Face)">
563
- <summary>
564
- Returns whether this surface is a floor or ceiling polygon
565
- </summary>
566
- <param name="f">The face</param>
567
- <returns>True when this face belongs to floor or ceiling.</returns>
568
- </member>
569
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.IsFloor(GeometryViewer.Model.Geometry.PFace)">
570
- <summary>
571
- Returns whether this surface is a floor polygon (Slope smaller than MaxAngleForFloor, normal pointing upwards)
572
- </summary>
573
- <param name="f">The face</param>
574
- <returns>True when this face belongs to the floor.</returns>
575
- </member>
576
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.IsFloor(System.Windows.Media.Media3D.Vector3D)">
577
- <summary>
578
- Returns whether a surface with this normal is a floor polygon (Slope smaller than MaxAngleForFloor, normal pointing upwards)
579
- </summary>
580
- <param name="normal">The face normal</param>
581
- <returns>True when this face belongs to the floor.</returns>
582
- </member>
583
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.IsCeiling(GeometryViewer.Model.Geometry.PFace)">
584
- <summary>
585
- Returns whether this surface is a ceiling polygon (Slope smaller than MaxAngleForCeiling, normal pointing downwards)
586
- </summary>
587
- <param name="f">The face</param>
588
- <returns>True when this face belongs to the ceiling.</returns>
589
- </member>
590
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.IsCeiling(System.Windows.Media.Media3D.Vector3D)">
591
- <summary>
592
- Returns whether a surface with this normal is a ceiling polygon (Slope smaller than MaxAngleForCeiling, normal pointing downwards)
593
- </summary>
594
- <param name="normal">The face normal</param>
595
- <returns>True when this face belongs to the ceiling.</returns>
596
- </member>
597
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.IsClosedHull(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Face})">
598
- <summary>
599
- Tests whether the faces form a closed hull (not taking openings into account)
600
- </summary>
601
- <param name="faces">A list of faces to test</param>
602
- <returns>True when the faces form a closed hull</returns>
603
- </member>
604
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.FindCommonVolume(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Face},GeometryViewer.Model.Geometry.GeometryModelData)">
605
- <summary>
606
- Tries to find a volume which contains all faces
607
- </summary>
608
- <param name="faces">The list of faces</param>
609
- <param name="model">The model to search in</param>
610
- <returns>A volume that contains all faces, or null when no such volume exists</returns>
611
- </member>
612
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Halfspace(GeometryViewer.Model.Geometry.Face,System.Collections.Generic.IEnumerable{System.Windows.Media.Media3D.Point3D},System.Double)">
613
- <summary>
614
- Determines whether a set of points lies completely on one side of the plane
615
- </summary>
616
- <param name="face">The face that defines the plane</param>
617
- <param name="points">The list of points to test</param>
618
- <param name="tolerance">Points in this distance to the plane are excluded from test</param>
619
- <returns>Forward or Backward when the points are completely on one side, Undefined when the are located on both sides</returns>
620
- </member>
621
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.Perimeter(GeometryViewer.Model.Geometry.Face)">
622
- <summary>
623
- Calculates the perimeter of the face. Sums the parimeter of the bounding and all holes.
624
- DOES NOT HANDLE DUPLICATES EDGES (E.G. WHEN TWO HOLES INTERSECT OR WHEN A HOLE INTERSECTS THE BOUNDARY)
625
- </summary>
626
- <param name="f">The face</param>
627
- <returns>The perimeter lenth</returns>
628
- </member>
629
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.SplitFace(GeometryViewer.Model.Geometry.Face)">
630
- <summary>
631
- Splits a face such that all openenings can be handles as adjacent faces.
632
- When no openings are present, nothing happens
633
- </summary>
634
- <param name="f">The face to split</param>
635
- </member>
636
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.OrientationIncline(GeometryViewer.Model.Geometry.PFace,System.Double)">
637
- <summary>
638
- Returns the incline (angle to up vector) and the orientation (angle to north=[0,0,1]) of a face in radians
639
- </summary>
640
- <param name="pface">The face</param>
641
- <param name="tolerance">Tolerance for calculations</param>
642
- <returns>
643
- Incline: Between -PI/2 and PI/2. 0 for vertical walls, -PI/2 for horizontal floors, PI/2 for horizontal ceilings
644
- Orientation: Angle in the xz-plane of the face normal to the north direction [0,0,1]. 0 when the face is horizontal (|incline| == 90).
645
- </returns>
646
- </member>
647
- <member name="M:GeometryViewer.Algorithms.Geometric.FaceAlgorithms.OrientationIncline(System.Windows.Media.Media3D.Vector3D,System.Double)">
648
- <summary>
649
- Returns the incline (angle to up vector) and the orientation (angle to north=[0,0,1]) of a face normal in radians
650
- </summary>
651
- <param name="normal">The face normal</param>
652
- <param name="tolerance">Tolerance for calculations</param>
653
- <returns>
654
- Incline: Between -PI/2 and PI/2. 0 for vertical walls, -PI/2 for horizontal floors, PI/2 for horizontal ceilings
655
- Orientation: Angle in the xz-plane of the face normal to the north direction [0,0,1]. 0 when the face is horizontal (|incline| == 90).
656
- </returns>
657
- </member>
658
- <member name="T:GeometryViewer.Algorithms.Geometric.GeometryAlgorithms">
659
- <summary>
660
- Provides general algorithms for geometries (intersections, closest points, ...)
661
- </summary>
662
- </member>
663
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryAlgorithms.LineLineDistance(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D)">
664
- <summary>
665
- Calculates the shortest distance between two lines (rays)
666
- </summary>
667
- <param name="l0Origin">Point on the first line</param>
668
- <param name="l0Direction">Direction of the first line</param>
669
- <param name="l1Origin">Point on the second line</param>
670
- <param name="l1Direction">Direction of the second line</param>
671
- <returns>The shortest distance between the two lines. </returns>
672
- </member>
673
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryAlgorithms.LineSegmentDistance(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D)">
674
- <summary>
675
- Calculates the shortest distance between a line and a line segment
676
- </summary>
677
- <param name="segmentP0">Start point of the segment</param>
678
- <param name="segmentP1">End point of the segment</param>
679
- <param name="rayOrigin">Point on the line</param>
680
- <param name="rayDirection">Direction of the line</param>
681
- <returns>The shortest distance between a line and a segment</returns>
682
- </member>
683
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryAlgorithms.LineSegmentClosesPoint(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D)">
684
- <summary>
685
- Calculates the points with the minimum distance between a line and a segment
686
- </summary>
687
- <param name="segmentP0">Start point of the segment</param>
688
- <param name="segmentP1">End point of the segment</param>
689
- <param name="rayOrigin">Point on the line</param>
690
- <param name="rayDirection">Direction of the line</param>
691
- <returns>segmentPoint: Point on the segment, rayPoint: Point on the line</returns>
692
- </member>
693
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryAlgorithms.LineLineClosestPoint(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D)">
694
- <summary>
695
- Calculates the points with the minimum distance between two lines
696
- </summary>
697
- <param name="l0Origin">Point on the first line</param>
698
- <param name="l0Direction">Direction of the first line</param>
699
- <param name="l1Origin">Point on the second line</param>
700
- <param name="l1Direction">Direction of the second line</param>
701
- <returns>l0Point: Point on the first line, l0Param: line parameter of l1Point, l1Param: Same for second line</returns>
702
- </member>
703
- <member name="T:GeometryViewer.Algorithms.Geometric.ModelInconsistentException">
704
- <summary>
705
- Exception when GeometryModel is inconsistent
706
- </summary>
707
- </member>
708
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelInconsistentException.#ctor(System.String)">
709
- <summary>
710
- Constructor
711
- </summary>
712
- <param name="msg">Exception message</param>
713
- </member>
714
- <member name="T:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms">
715
- <summary>
716
- Provides algorithms that operate on the whole GeometryModel
717
- </summary>
718
- </member>
719
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.SetAllVisibility(GeometryViewer.Model.Geometry.GeometryModelData,System.Boolean)">
720
- <summary>
721
- Sets the visibility of all contained elements
722
- </summary>
723
- <param name="model">The model</param>
724
- <param name="isVisible">The new visibility value</param>
725
- </member>
726
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.GetAllAffectedGeometries(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry})">
727
- <summary>
728
- Returns all geometries that are either a parent or a child of the initialGeometry
729
- </summary>
730
- <param name="initialGeometry">The initial geometry</param>
731
- <returns>A list of all geometries that are affected by change to the initial geometry</returns>
732
- </member>
733
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.GetAllAffectedGeometries(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Vertex})">
734
- <summary>
735
- Returns all geometries that are either a parent or a child of the initialGeometry
736
- </summary>
737
- <param name="initialGeometry">The initial geometry</param>
738
- <returns>A list of all geometries that are affected by change to the initial geometry</returns>
739
- </member>
740
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.GetAllContainingGeometries(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry})">
741
- <summary>
742
- Gets a list of all geometries that depend on the initialGeometry
743
- </summary>
744
- <param name="initialGeometry">The initial geometry</param>
745
- <returns>A list of all "parent" geometries (geometries that depend on the initial geometry)</returns>
746
- </member>
747
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.GetAllVisibleGeometries(GeometryViewer.Model.Geometry.GeometryModelData)">
748
- <summary>
749
- Returns a list of all visible geometries from a model (only Vertices, Edges, Faces and Volumes)
750
- </summary>
751
- <param name="model">The geometry model</param>
752
- <returns>A list of all visible geometries from a model (only Vertices, Edges, Faces and Volumes)</returns>
753
- </member>
754
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.Boundary(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.GeometryModelData},System.Boolean)">
755
- <summary>
756
- Calculates a 3D axis aligned bound box around the models
757
- </summary>
758
- <param name="models">List of geometry models that should be contained in the bounding box</param>
759
- <param name="includeInvisible">Set to true when currently invisible geometry should be included</param>
760
- <returns></returns>
761
- </member>
762
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.Boundary(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry},System.Boolean)">
763
- <summary>
764
- Calculates a 3D axis aligned bound box around some geometry objects
765
- </summary>
766
- <param name="geometry">List of geometry objects that should be contained in the bounding box</param>
767
- <param name="includeInvisible">Set to true when currently invisible geometry should be included</param>
768
- <returns></returns>
769
- </member>
770
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.CheckConsistency(GeometryViewer.Model.Geometry.GeometryModelData)">
771
- <summary>
772
- Checks if the model is in a consistent state. Tests whether all sub-geometries are also part of the model.
773
- Throws a ModelInconsistentException when not in a consistent state.
774
- </summary>
775
- <param name="model">The model to check</param>
776
- </member>
777
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.UpdateGeometryModelWithExistingIds(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.Geometry.GeometryModelData)">
778
- <summary>
779
- Computes the union of 2 geometry models to sustain existing IDs and adds everything else from newGeometryModel
780
- (returns union(ogm, ngm) + diff(ngm, union(ogm, ngm)))
781
- </summary>
782
- <param name="oldGeometryModel">Old model which gets updated with new geometry from newGeometryModel</param>
783
- <param name="newGeometryModel">GeometryModel with new changes which are copied to oldGeometryModel</param>
784
- <param name="outGeometryModel">The GeometryModel to which the data is added</param>
785
- </member>
786
- <member name="M:GeometryViewer.Algorithms.Geometric.GeometryModelAlgorithms.CopyContent(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.Geometry.GeometryModelData,System.Boolean)">
787
- <summary>
788
- Creates a deep copy of the from model in the to model
789
- </summary>
790
- <param name="from">The source model</param>
791
- <param name="to">The target model</param>
792
- <param name="preserveIds">When set to True, the ids are kept. Only works when the ids are not used in the to model.</param>
793
- </member>
794
- <member name="T:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms">
795
- <summary>
796
- Provides algorithms for working with GeoReferences
797
- </summary>
798
- </member>
799
- <member name="T:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.UTMCoord">
800
- <summary>
801
- Class that stores a single coordinate in UTM format
802
- </summary>
803
- </member>
804
- <member name="F:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.UTMCoord.Zone">
805
- <summary>
806
- Zone, must be in [1, 60]
807
- </summary>
808
- </member>
809
- <member name="F:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.UTMCoord.NorthernHemisphere">
810
- <summary>
811
- Flag whether point is on northern hemisphere
812
- </summary>
813
- </member>
814
- <member name="F:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.UTMCoord.Easting">
815
- <summary>
816
- Easting
817
- </summary>
818
- </member>
819
- <member name="F:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.UTMCoord.Northing">
820
- <summary>
821
- Northing
822
- </summary>
823
- </member>
824
- <member name="F:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.UTMCoord.Height">
825
- <summary>
826
- Height in meter
827
- </summary>
828
- </member>
829
- <member name="T:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint">
830
- <summary>
831
- Class for representing a georeferenced point in 3D
832
- </summary>
833
- </member>
834
- <member name="P:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint.OS">
835
- <summary>
836
- Point in object space
837
- </summary>
838
- </member>
839
- <member name="P:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint.WGS">
840
- <summary>
841
- Point in WGS84 space (long/lat/height)
842
- </summary>
843
- </member>
844
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint.#ctor(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D)">
845
- <summary>
846
- Initializes a new instance of the class GeoRefPoint
847
- </summary>
848
- <param name="OS">Position in object space</param>
849
- <param name="WGS">Position in WGS84 space (long/lat/height)</param>
850
- </member>
851
- <member name="T:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefTransform">
852
- <summary>
853
- Holds all parameters necessary to interpolate the WGS84 coordinates for an unreferenced point in object space
854
- </summary>
855
- </member>
856
- <member name="P:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefTransform.RefOrigin">
857
- <summary>
858
- Origin of coordinate system used to interpolate and transform
859
- </summary>
860
- </member>
861
- <member name="P:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefTransform.RefP1">
862
- <summary>
863
- First point (in tangent direction) of coordinate system used to interpolate and transform
864
- </summary>
865
- </member>
866
- <member name="P:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefTransform.RefP2">
867
- <summary>
868
- Second point (in bitangent direction) of coordinate system used to interpolate and transform
869
- </summary>
870
- </member>
871
- <member name="P:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefTransform.Azimuth1">
872
- <summary>
873
- Azimuth of direction between origin and P1
874
- </summary>
875
- </member>
876
- <member name="P:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefTransform.Azimuth2">
877
- <summary>
878
- Azimuth of direction between origin and P2
879
- </summary>
880
- </member>
881
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefTransform.#ctor(GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint,GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint,GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint)">
882
- <summary>
883
- Initializes a new instance of class GeoRefTransform and computes intrinsic parameters
884
- </summary>
885
- <param name="origin">Origin of the coordinate system</param>
886
- <param name="P1">First point (along tangent) of the coordinate system</param>
887
- <param name="P2">Second point (along bitangent) of the coordinate system</param>
888
- </member>
889
- <member name="T:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.InvalidGeoReferencingException">
890
- <summary>
891
- Exception that is thrown when the georeferencing of an object is invalid, i.e. if ValidatieGeoReferences(..) returns false
892
- </summary>
893
- </member>
894
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.InvalidGeoReferencingException.#ctor">
895
- <summary>
896
- Creates a new instance of this class
897
- </summary>
898
- </member>
899
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.FindBestGeoReferences(System.Collections.Generic.List{GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint},System.Windows.Media.Media3D.Point3D)">
900
- <summary>
901
- This searches for the best georeferences to form a 2D coordinate system (3 points) used for interpolation.
902
- Criteria are: axis are close to orthogonal, points span a wide distance, area covered by triangle is maximal
903
- </summary>
904
- <param name="geoReferences">List of georeferences to search</param>
905
- <param name="pOS">Point in object space to find transformation for</param>
906
- <returns>Transformation used for interpolation of WGS84 coordinates</returns>
907
- </member>
908
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.ValidateGeoReferences(System.Collections.Generic.List{GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint})">
909
- <summary>
910
- Validates list of georeferenced points.
911
- Criteria are: at least 3, not all points collinear in object and WGS space
912
- (also implicitly considers distance between points => should not be too close together)
913
- </summary>
914
- <param name="geoReferences">List of georeferenced points</param>
915
- <returns>true, if given georeferences are suitable for interpolation of WGS84 coordinates, i.e. building can be placed in world space</returns>
916
- </member>
917
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoReferenceMesh(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Collections.Generic.List{GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint})">
918
- <summary>
919
- Transforms given list of points into the WGS84 reference system based on a set of valid georeferenced points (use ValidateGeoReferences first).
920
- WGS84 coordinates for non-georeferenced points are interpolated/extrapolated non-linearly - see EstimateWGSNonLinear.
921
- Throws an InvalidGeoReferencingException if geoReferences are invalid
922
- </summary>
923
- <param name="positions">List of points to geo-reference.</param>
924
- <param name="geoReferences">List of known georeferences</param>
925
- <returns>Transformed list of points in Cartesian WGS84 space. Transformed list of points in WGS84 space (longitude/latitude/height).</returns>
926
- </member>
927
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.EstimateWGSNonLinear(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Collections.Generic.List{GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.GeoRefPoint})">
928
- <summary>
929
- Given a set of georeferences and a set of points, each point gets assigned a WGS84 coordinate.
930
- Points which are already referenced keep their respective georeference.
931
- Points directly above or below other points are garantueed to have the same long/lat coords.
932
- Other points are interpolated/extrapolated in a non-linear fashion given as:
933
- A 2D coordinate system (3 points) meeting certain criteria (see FindBestGeoReferences) is computed for each non-georeferenced point.
934
- The 2D coordinate system is used to calculate angles between its axes and the current point relative to the
935
- referenced origin in object space. This angle is used to interpolate linearly between the azimuth of the 2
936
- chosen directions. Eventually, the interpolated azimuth in combination with the distance in object space (in meter) is used
937
- to obtain the new WGS84 coordinates using Vincenty's direct formulae.
938
- </summary>
939
- <param name="positions">List of positions to assign WGS84 coordinates to</param>
940
- <param name="geoReferences">List of known georeferenced points</param>
941
- <returns>Georeferenced points (WGS84) in same order as in given point list. </returns>
942
- </member>
943
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.WGS84ToCart(System.Windows.Media.Media3D.Point3D)">
944
- <summary>
945
- Transforms a point with WGS coordinates into the cartesian coordinate system of the WGS reference ellipsoid.
946
- https://gssc.esa.int/navipedia/index.php/Ellipsoidal_and_Cartesian_Coordinates_Conversion
947
- https://en.wikipedia.org/wiki/World_Geodetic_System
948
- </summary>
949
- <param name="p">A point consisting of longitude (x), latitude (y) and height relative to surface (z)</param>
950
- <returns>The point in the cartesian coordinate system of the WGS reference ellipsoid.</returns>
951
- </member>
952
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.CartToWGS84(System.Windows.Media.Media3D.Point3D,System.Double)">
953
- <summary>
954
- Transforms a point with cartesian coordinates into the WGS coordinate system.
955
- https://gssc.esa.int/navipedia/index.php/Ellipsoidal_and_Cartesian_Coordinates_Conversion
956
- https://en.wikipedia.org/wiki/World_Geodetic_System
957
- </summary>
958
- <param name="point">A point in the catesian space with [0,0,0] being the earths center.</param>
959
- <param name="precision">The precision of the calculation.</param>
960
- <returns>The point in the WGS coordinate system.</returns>
961
- </member>
962
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.TangentFrame(System.Windows.Media.Media3D.Point3D)">
963
- <summary>
964
- Computes the tangent frame on the WGS84 ellipsoid in Cartesian coordinates for a given positions in WGS coordinates
965
- </summary>
966
- <param name="p">WGS coordinates of point</param>
967
- <returns>Tangent frame (tangent, bitangent, normal) for given point</returns>
968
- </member>
969
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.VincentyDirect(System.Windows.Media.Media3D.Point3D,System.Double,System.Double,System.Double,System.Int32)">
970
- <summary>
971
- Vincenty's direct formula to walk along a given amount in a given direction to obtain a new point lying on the WGS reference ellipsoid.
972
- https://en.wikipedia.org/wiki/Vincenty%27s_formulae
973
- </summary>
974
- <param name="p">Start point with longitude (x), latitude (y) and height in m (z)</param>
975
- <param name="azimuth">Direction to walk into given as an angle in degrees relative to the north pole [0,360)</param>
976
- <param name="distance">Distance in meters to walk</param>
977
- <param name="tolerance">Tolerance for the iterative algorithm. Default is 1e-12.</param>
978
- <param name="maxIterations">Max iterations used as fallback if tolerance cannot be reached to prevent infinite loops.</param>
979
- <returns>A point (longitude/latitude) which has a geodesic distance to the start point equal to the given input distance and it's final bearing (azimuth).
980
- Note, that this point has the same height as the input point.</returns>
981
- </member>
982
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.VincentyIndirect(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Double)">
983
- <summary>
984
- Vincenty's indirect formula to compute the geodesic distance and azimuth between two given WGS84 coordinate pairs.
985
- https://en.wikipedia.org/wiki/Vincenty%27s_formulae
986
- </summary>
987
- <param name="source">Start point with longitude (x), latitude (y) and height in m (z)</param>
988
- <param name="dest">End point with with longitude (x), latitude (y) and height in m (z)</param>
989
- <param name="tolerance">Tolerance for the iterative algorithm. Default is 1e-12.</param>
990
- <returns>Geodesic distance between the two given points as well as it's final bearing (azimuth in [0, 360)).</returns>
991
- </member>
992
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.ConvertUTMToWGS84(GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.UTMCoord)">
993
- <summary>
994
- Converts UTM coordinates to WGS84 coordinates. Height is simply copied from UTM to WGS84.
995
- https://www.movable-type.co.uk/scripts/latlong-utm-mgrs.html
996
- Transverse Mercator with an accuracy of a few nanometers, Karney 2011
997
- </summary>
998
- <param name="utm">UTM coordinates</param>
999
- <returns>WGS84 coordinates</returns>
1000
- </member>
1001
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.CreateAlignedWGSGrid(System.Windows.Media.Media3D.Point3D,System.Double,System.Double,System.Double,System.Double,System.Boolean)">
1002
- <summary>
1003
- Creates a grid that is algined along the longitude(x)/latitude(y) axes.
1004
- The grid is centered around midPoint and spans the area [widthInM, heightInM] with grid lines inserted every spacingX/spacingY meters.
1005
- If spacing does not fit an integer times into any dimension, the resulting grid is cropped to floor(dim/spacing) in the respective dimension.
1006
- </summary>
1007
- <param name="midPoint">Center point in WGS coordinates</param>
1008
- <param name="widthInM">Total width of the grid in meters</param>
1009
- <param name="heightInM">Total height </param>
1010
- <param name="spacingX"></param>
1011
- <param name="spacingY"></param>
1012
- <param name="toCartesian">if true, WGS coordinates are converted into Cartesian coordinates</param>
1013
- <returns></returns>
1014
- </member>
1015
- <member name="M:GeometryViewer.Algorithms.Geometric.GeoReferenceAlgorithms.Atanh(System.Double)">
1016
- <summary>
1017
- Computes the arctangent hyperbolicus using its logarithm form.
1018
- </summary>
1019
- <param name="X">Parameter</param>
1020
- <returns>atanh(x)</returns>
1021
- </member>
1022
- <member name="T:GeometryViewer.Algorithms.Geometric.LayerAlgorithms">
1023
- <summary>
1024
- Provides methods for working with layers
1025
- </summary>
1026
- </member>
1027
- <member name="M:GeometryViewer.Algorithms.Geometric.LayerAlgorithms.DeleteLayerAndContent(GeometryViewer.Model.Geometry.Layer)">
1028
- <summary>
1029
- Deletes the layer and it's content
1030
- </summary>
1031
- <param name="layer">The layer to delete</param>
1032
- <returns>A list of undo items for this operation</returns>
1033
- </member>
1034
- <member name="T:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms">
1035
- <summary>
1036
- Provides algorithms to clean up a mesh
1037
- </summary>
1038
- </member>
1039
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveDuplicateVertices(GeometryViewer.Model.Geometry.GeometryModelData,System.Double,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1040
- <summary>
1041
- Removes duplicate vertices by merging vertices which are closer than a given tolerance.
1042
- </summary>
1043
- <param name="model">The mode to clean up</param>
1044
- <param name="tolerance">The distance below which Vertices are merged</param>
1045
- <param name="vertexGrid">Speedup structure containing all vertices</param>
1046
- <param name="edgeGrid">Speedup structure containing all edges</param>
1047
- <param name="backgroundInfo">The background algorithm info for this task</param>
1048
- </member>
1049
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveDuplicateEdges(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1050
- <summary>
1051
- Removes duplicate edges by merging edges together
1052
- </summary>
1053
- <param name="model">The model</param>
1054
- <param name="edgeGrid">Speedup structure containing all edges</param>
1055
- <param name="backgroundInfo">The background algorithm info for this task</param>
1056
- </member>
1057
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveDuplicateFaces(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1058
- <summary>
1059
- Removes faces with similar edgeloops
1060
- </summary>
1061
- <param name="model">The model to check</param>
1062
- <param name="faceGrid">Speedup structure containing all faces</param>
1063
- <param name="backgroundInfo">The background algorithm info for this task</param>
1064
- </member>
1065
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveDuplicateHoles(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1066
- <summary>
1067
- Removes duplicate holes
1068
- </summary>
1069
- <param name="model">The GeometryModel</param>
1070
- <param name="backgroundInfo">The background algorithm info for this task</param>
1071
- </member>
1072
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveDuplicateHoleLoops(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1073
- <summary>
1074
- Removes holesloops which have a similar loop in a face boundary (happens when copying hole faces into existing holes)
1075
- </summary>
1076
- <param name="model">The GeometryModel</param>
1077
- <param name="backgroundInfo">The background algorithm info for this task</param>
1078
- </member>
1079
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveDuplicateVolumes(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1080
- <summary>
1081
- Removes duplicate volumes from a model.
1082
- Duplicate volumes are volumes that have the exact same set of faces.
1083
- </summary>
1084
- <param name="model">The geometry model</param>
1085
- <param name="backgroundInfo">A background worker info. May be Null when no background worker exists</param>
1086
- <param name="volumeGrid">The grid used to handle volumes</param>
1087
- </member>
1088
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveDegeneratedFaces(GeometryViewer.Model.Geometry.GeometryModelData,System.Double,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1089
- <summary>
1090
- Removes faces with 0 size
1091
- </summary>
1092
- <param name="model">The model in which the faces should be removed</param>
1093
- <param name="areaTolerance">Minimum area below which faces are considered degenerated</param>
1094
- <param name="faceGrid">Speedup structure containing all faces</param>
1095
- <param name="backgroundInfo">The background algorithm info for this task</param>
1096
- </member>
1097
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.SplitEdgeEdgeIntersections(GeometryViewer.Model.Geometry.GeometryModelData,System.Double,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1098
- <summary>
1099
- Handles Edge-Edge intersection (in one point) and overlapping edges
1100
- </summary>
1101
- <param name="model">The model</param>
1102
- <param name="tolerance">Tolerance for the calculation</param>
1103
- <param name="edgeGrid">Speedup structure containing all edges</param>
1104
- <param name="backgroundInfo">The background algorithm info for this task</param>
1105
- </member>
1106
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.SplitEdgeVertexIntersections(GeometryViewer.Model.Geometry.GeometryModelData,System.Double,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1107
- <summary>
1108
- Handles vertices that are placed on an edge
1109
- </summary>
1110
- <param name="model">The model</param>
1111
- <param name="tolerance">The calculation tolerance</param>
1112
- <param name="vertexGrid">Speedup structure containing all vertices</param>
1113
- <param name="edgeGrid">Speedup structure containing all edges</param>
1114
- <param name="backgroundInfo">The background algorithm info for this task</param>
1115
- </member>
1116
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.SplitFaces(GeometryViewer.Model.Geometry.GeometryModelData,System.Double,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1117
- <summary>
1118
- Splits overlapping faces
1119
- </summary>
1120
- <param name="model">The model</param>
1121
- <param name="tolerance">The calculation tolerance</param>
1122
- <param name="vertexGrid">Speedup structure containing all vertices</param>
1123
- <param name="faceGrid">Speedup structure containing all faces</param>
1124
- <param name="backgroundInfo">The background algorithm info for this task</param>
1125
- </member>
1126
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.SplitContainedFaces(GeometryViewer.Model.Geometry.GeometryModelData,System.Double,GeometryViewer.Model.SpatialStructures.AABBGrid@,GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo)">
1127
- <summary>
1128
- Adds faces that are completely contained in another faces as opening
1129
- </summary>
1130
- <param name="model">The model</param>
1131
- <param name="tolerance">The calculation tolerance</param>
1132
- <param name="faceGrid">Speedup structure containing all faces</param>
1133
- <param name="backgroundInfo">The background algorithm info for this task</param>
1134
- </member>
1135
- <member name="M:GeometryViewer.Algorithms.Geometric.ModelCleanupAlgorithms.RemoveErrorLayerIfEmpty(GeometryViewer.Model.Geometry.GeometryModelData)">
1136
- <summary>
1137
- Removes the error layer when there are no elements on it
1138
- </summary>
1139
- <param name="model">The model from which the error layer should be removed</param>
1140
- </member>
1141
- <member name="T:GeometryViewer.Algorithms.Geometric.PolylineAlgorithms">
1142
- <summary>
1143
- Provides algorithms for working with polylines
1144
- </summary>
1145
- </member>
1146
- <member name="M:GeometryViewer.Algorithms.Geometric.PolylineAlgorithms.Order(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.PEdge})">
1147
- <summary>
1148
- Tries to return an ordered list of edges
1149
- </summary>
1150
- <param name="edges">The input (unsorted) edges</param>
1151
- <returns>A bool indicating whether the edge list forms a polyline and a list of edges ordered along the polyline</returns>
1152
- </member>
1153
- <member name="M:GeometryViewer.Algorithms.Geometric.PolylineAlgorithms.GetStartEnd(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge})">
1154
- <summary>
1155
- Returns the start and the end of a polyline described by a set of edges. Sets isConnected to False when the edges do not form polyline
1156
- or describe a closed loop
1157
- </summary>
1158
- <param name="edges">The edges</param>
1159
- <returns>
1160
- isConnected == True when the edges form a single polyline, otherwise False
1161
- startVertex, endVertex the start and end of the polyline. Only valid when isConnected equals True
1162
- </returns>
1163
- </member>
1164
- <member name="T:GeometryViewer.Algorithms.Geometric.Triangulation">
1165
- <summary>
1166
- Provides methods to triangulate a polygon (with holes)
1167
- </summary>
1168
- <remarks>There is a updated version present in the old geometry viewer project which has to be ported</remarks>
1169
- </member>
1170
- <member name="M:GeometryViewer.Algorithms.Geometric.Triangulation.PolygonComplexFill(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Collections.Generic.List{System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D}},System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D}@,System.Collections.Generic.List{System.Int32}@,System.Boolean)">
1171
- <summary>
1172
- Segments a polygon in the XZ plane into triangles
1173
- </summary>
1174
- <param name="polygon">A list of points describing the boundary of the polygon</param>
1175
- <param name="holes">A list containing holes</param>
1176
- <param name="positions">Returns the positions of the triangulated polygon</param>
1177
- <param name="indices">Returns the indices of the triangulation</param>
1178
- <param name="reverse">When set to true all Point3D list are read back-to-front</param>
1179
- </member>
1180
- <member name="M:GeometryViewer.Algorithms.Geometric.Triangulation.DecomposeInSimplePolygons(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Collections.Generic.List{System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D}})">
1181
- <summary>
1182
- Returns a list of polygons that cover the polygon but have no holes.
1183
- </summary>
1184
- <param name="polygon">The original polygon</param>
1185
- <param name="holes">A list of hole polygons</param>
1186
- <returns></returns>
1187
- </member>
1188
- <member name="T:GeometryViewer.Algorithms.Geometric.HoleCycleDetector">
1189
- <summary>
1190
- For detecting cycles in the connecting lines between a polygon and the holes contained in it.
1191
- </summary>
1192
- </member>
1193
- <member name="F:GeometryViewer.Algorithms.Geometric.HoleCycleDetector.INVALID_INDEX">
1194
- <summary>
1195
- A reserved integer to indicate invalid indices.
1196
- </summary>
1197
- </member>
1198
- <member name="P:GeometryViewer.Algorithms.Geometric.HoleCycleDetector.AllNodes">
1199
- <summary>
1200
- A look-up table for all nodes - i.e. the ones representing holes and the one representing the polygon.
1201
- </summary>
1202
- </member>
1203
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleDetector.#ctor(System.Int32,System.Boolean)">
1204
- <summary>
1205
- Initializes the hole cycle detector and its root node.
1206
- </summary>
1207
- <param name="nr_of_holes">the number of holes in the polygon</param>
1208
- <param name="verbose">if true, generate debug console output</param>
1209
- </member>
1210
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleDetector.AddConnectingLine(System.ValueTuple{System.Int32,System.Int32,System.Int32,System.Int32})">
1211
- <summary>
1212
- Adds a connecting line w/o performing any tests.
1213
- </summary>
1214
- <param name="connecting_line">the connecting line</param>
1215
- </member>
1216
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleDetector.RemoveConnectingLine(System.ValueTuple{System.Int32,System.Int32,System.Int32,System.Int32})">
1217
- <summary>
1218
- Removes a connecting line.
1219
- </summary>
1220
- <param name="connecting_line">the connecting line</param>
1221
- </member>
1222
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleDetector.GetAllHolesConnectedToOnlyOneOtherHoleInclIndirection">
1223
- <summary>
1224
- Gets all holes that have to pass through a bottleneck of only one other hole in order to reach the outer polygon.
1225
- </summary>
1226
- <returns>true if such holes were found; in addition - a list of holes needing additional connections</returns>
1227
- </member>
1228
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleDetector.FindFirstCommonElement(System.Collections.Generic.IEnumerable{System.Collections.Generic.List{System.Int32}},System.Int32,System.Int32)">
1229
- <summary>
1230
- Gets the common element in the given paths. Excluded from those are the index -1, indicating the outer poygon, and the given excluded index.
1231
- </summary>
1232
- <param name="paths">all paths to check</param>
1233
- <param name="excluded">the index to exclude, generally the index of the hole itself that occupies the start of each path</param>
1234
- <param name="invalid_element">the value to return in case no common element was found</param>
1235
- <returns>the furst common element, or the ibvalid element if there was no common element</returns>
1236
- </member>
1237
- <member name="T:GeometryViewer.Algorithms.Geometric.HoleCycleNode">
1238
- <summary>
1239
- Represents a connected hole in the context of the search for connecting lines between
1240
- an outer polygon and the holes contained in it.
1241
- </summary>
1242
- </member>
1243
- <member name="P:GeometryViewer.Algorithms.Geometric.HoleCycleNode.Index">
1244
- <summary>
1245
- Representing the hole
1246
- </summary>
1247
- </member>
1248
- <member name="P:GeometryViewer.Algorithms.Geometric.HoleCycleNode.Connected2Nnodes">
1249
- <summary>
1250
- Representing the nodes reachable via the respective connecting lines.
1251
- </summary>
1252
- </member>
1253
- <member name="P:GeometryViewer.Algorithms.Geometric.HoleCycleNode.Nodes">
1254
- <summary>
1255
- Represent the unique nodes this one is conected to, and the number of times this node is connected to them.
1256
- </summary>
1257
- </member>
1258
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleNode.#ctor(System.Int32,System.Boolean)">
1259
- <summary>
1260
- Initializes a node with a specific index.
1261
- </summary>
1262
- <param name="index">the hole index, -1 indicates the outer polygon</param>
1263
- <param name="verbose">if true, print the debug output to the console</param>
1264
- </member>
1265
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleNode.Connect(System.ValueTuple{System.Int32,System.Int32,System.Int32,System.Int32},GeometryViewer.Algorithms.Geometric.HoleCycleNode)">
1266
- <summary>
1267
- Adds a connnection to another node.
1268
- </summary>
1269
- <param name="connection">the connecting line</param>
1270
- <param name="node">the node</param>
1271
- </member>
1272
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleNode.Disconnect(System.ValueTuple{System.Int32,System.Int32,System.Int32,System.Int32},GeometryViewer.Algorithms.Geometric.HoleCycleNode)">
1273
- <summary>
1274
- Removes an existing connection to a node.
1275
- </summary>
1276
- <param name="connection">the connecting line</param>
1277
- <param name="node">the node</param>
1278
- </member>
1279
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleNode.TraverseAndTest(System.Collections.Generic.List{System.ValueTuple{System.Int32,System.Int32,System.Int32,System.Int32}},System.Collections.Generic.List{System.ValueTuple{System.Int32,System.Int32,System.Int32}},System.String)">
1280
- <summary>
1281
- Searches for a cycle containing only holes and docking only at one point in any of the holes.
1282
- NOT IN USE !!!
1283
- </summary>
1284
- <param name="used_connections">the connecting lines used in the evaluation</param>
1285
- <param name="used_stops">the used points on the holes</param>
1286
- <param name="debug">the indent for the debug output</param>
1287
- <returns>the found cycles</returns>
1288
- </member>
1289
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleNode.BFSwCutoff(System.Int32)">
1290
- <summary>
1291
- Breadth-First search for all paths starting at this node and ending at the outer polygon or at this node again
1292
- with a cut-off after reaching the outer polygon a given number of times.
1293
- </summary>
1294
- <param name="after_reaching_the_outside_n_times">the number of times to reach the outer polygon</param>
1295
- <returns>each found path separately</returns>
1296
- </member>
1297
- <member name="M:GeometryViewer.Algorithms.Geometric.HoleCycleNode.ToString">
1298
- <inheritdoc/>
1299
- </member>
1300
- <member name="T:GeometryViewer.Algorithms.Geometric.VertexAlgorithms">
1301
- <summary>
1302
- Provides functions which operate on single points or vertices
1303
- </summary>
1304
- </member>
1305
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.FromMathematicalCoordinateSystem(System.Double,System.Double,System.Double)">
1306
- <summary>
1307
- Converts a point from a mathematically correct coordinate system (z = up) to a coordinate system used in computer graphics (y = up).
1308
- i.e. it performs a 90° rotation around the x-axis
1309
- </summary>
1310
- <param name="x">x coordinate</param>
1311
- <param name="y">y coordinate</param>
1312
- <param name="z">z coordinate</param>
1313
- <returns>Point in computer graphics coordinate system (y = up)</returns>
1314
- </member>
1315
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.FromMathematicalCoordinateSystem(System.Windows.Media.Media3D.Point3D)">
1316
- <summary>
1317
- Converts a point from a mathematically correct coordinate system (z = up) to a coordinate system used in computer graphics (y = up).
1318
- i.e. it performs a 90° rotation around the
1319
- </summary>
1320
- <param name="p">Point in mathematical coordinate system (z = up)</param>
1321
- <returns>Point in computer graphics coordinate system (y = up)</returns>
1322
- </member>
1323
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.FromMathematicalCoordinateSystem(GeometryViewer.Model.Geometry.Vertex)">
1324
- <summary>
1325
- Converts a point from a mathematically correct coordinate system (z = up) to a coordinate system used in computer graphics (y = up).
1326
- i.e. it performs a 90° rotation around the
1327
- </summary>
1328
- <param name="v">Vertex in mathematical coordinate system (z = up)</param>
1329
- <returns>Point in computer graphics coordinate system (y = up)</returns>
1330
- </member>
1331
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.ToMathematicalCoordinateSystem(System.Windows.Media.Media3D.Point3D)">
1332
- <summary>
1333
- Converts a point from rendering coordinate system (y = up) to a mathematically correct coordinate system (z = up).
1334
- </summary>
1335
- <param name="p">Vertex in rendering system (y = up)</param>
1336
- <returns>Point in mathematically correct coordinate system (z = up)</returns>
1337
- </member>
1338
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.IsCollinear(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Double)">
1339
- <summary>
1340
- Checks if a given set of points is collinear i.e. lies on the same line.
1341
- </summary>
1342
- <param name="positions">Set of positions</param>
1343
- <param name="threshold">Threshold to detect collinearity (maximum distance of a point from the shared line, max 1), default 1e-10</param>
1344
- <returns>true, if points lie on the same line</returns>
1345
- </member>
1346
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.IsCollinear(System.Collections.Generic.List{GeometryViewer.Model.Geometry.Vertex},System.Double)">
1347
- <summary>
1348
- Checks if a given set of points is collinear i.e. lies on the same line.
1349
- </summary>
1350
- <param name="vertices">Set of vertices</param>
1351
- <param name="threshold">Threshold to detect collinearity, default 1e-10</param>
1352
- <returns>true, if points lie on the same line</returns>
1353
- </member>
1354
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.IsEqual(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Double)">
1355
- <summary>
1356
- Checks if all coordinates in 2 given points are equal within a small threshold.
1357
- </summary>
1358
- <param name="p1">First point</param>
1359
- <param name="p2">Second point</param>
1360
- <param name="threshold">Maximum allowed difference of coordinates</param>
1361
- <returns>true, if points are equal</returns>
1362
- </member>
1363
- <member name="M:GeometryViewer.Algorithms.Geometric.VertexAlgorithms.BoundingBox(System.Collections.Generic.IEnumerable{System.Windows.Media.Media3D.Point3D})">
1364
- <summary>
1365
- Calculates the minimum and maximum (axis aligned bounding box) of a set of points along each axis
1366
- </summary>
1367
- <param name="points">The list of points</param>
1368
- <returns>The minimum and maximum along each axis</returns>
1369
- </member>
1370
- <member name="T:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms">
1371
- <summary>
1372
- Provides algorithms operation on Volume instances
1373
- </summary>
1374
- </member>
1375
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.FindConsistentOrientation(GeometryViewer.Model.Geometry.Volume)">
1376
- <summary>
1377
- Finds a consistent orientation by adjusting PFace.Orientation
1378
- </summary>
1379
- <param name="volume">The volume to operate on</param>
1380
- <returns>True when a consistent volume was found, False when no consistent volume is found</returns>
1381
- </member>
1382
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.FindUnclosedEdges(GeometryViewer.Model.Geometry.Volume)">
1383
- <summary>
1384
- Returns all edges where a volume is not closed properly (either because there is only one adjacent face,
1385
- or because there are more than two adjacent faces)
1386
- </summary>
1387
- <param name="volume">The volume for which edges are checked</param>
1388
- <returns>All edges where the volume is not closed</returns>
1389
- </member>
1390
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.Center(GeometryViewer.Model.Geometry.Volume)">
1391
- <summary>
1392
- Calculates the center (3D average) of a volume
1393
- </summary>
1394
- <param name="v">The volume</param>
1395
- <returns>The center</returns>
1396
- </member>
1397
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.ContainedGeometry(GeometryViewer.Model.Geometry.Volume,System.Collections.Generic.List{GeometryViewer.Model.Geometry.BaseGeometry}@)">
1398
- <summary>
1399
- Returns all the geometry contained in this edge (volume + faces + edge + vertices)
1400
- </summary>
1401
- <param name="v">The volume</param>
1402
- <param name="geometries">The resulting geometry list</param>
1403
- </member>
1404
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.MergeVolumes(GeometryViewer.Model.Geometry.Volume,GeometryViewer.Model.Geometry.Volume)">
1405
- <summary>
1406
- Merges two volumes that share a common surface. (Second volume gets deleted)
1407
- </summary>
1408
- <param name="v1">First volume</param>
1409
- <param name="v2">Second volume</param>
1410
- </member>
1411
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.RemoveFacesFromVolume(GeometryViewer.Model.Geometry.Volume,System.Collections.Generic.List{GeometryViewer.Model.Geometry.Face})">
1412
- <summary>
1413
- Removes faces from a volume. The volume might become inconsistent afterwards
1414
- </summary>
1415
- <param name="v">The volume where the faces should be removed</param>
1416
- <param name="faces">The faces to remove</param>
1417
- </member>
1418
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.AddFacesToVolume(GeometryViewer.Model.Geometry.Volume,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Face})">
1419
- <summary>
1420
- Adds faces from a volume. The volume might become inconsistent afterwards
1421
- </summary>
1422
- <param name="v">The volume where the faces should be added</param>
1423
- <param name="faces">The faces to add</param>
1424
- </member>
1425
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.Volume(GeometryViewer.Model.Geometry.Volume)">
1426
- <summary>
1427
- Calculates the volume of a volume
1428
- </summary>
1429
- <param name="vol">The volume to calculate the volume from</param>
1430
- <returns>The volume of the volume</returns>
1431
- </member>
1432
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.SignedVolume(System.Collections.Generic.List{System.ValueTuple{GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.GeometricOrientation}})">
1433
- <summary>
1434
- Computes the signed volume of a list of faces
1435
- </summary>
1436
- <param name="faces">List of faces. Must not be closed.</param>
1437
- <returns>Signed volume from face list</returns>
1438
- </member>
1439
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.VolumeBruttoNetto(GeometryViewer.Model.Geometry.Volume)">
1440
- <summary>
1441
- Returns the brutto and the netto volume
1442
- </summary>
1443
- <param name="vol">The volume</param>
1444
- <returns>The brutto and netto volume as given by the offset surfaces</returns>
1445
- </member>
1446
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.Height(GeometryViewer.Model.Geometry.Volume)">
1447
- <summary>
1448
- Returns the minimum and maximum height of a volume
1449
- </summary>
1450
- <param name="vol">The volume</param>
1451
- <returns>The minimum and maximum height differnce between floor and ceiling</returns>
1452
- </member>
1453
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.AreaBruttoNetto(GeometryViewer.Model.Geometry.Volume)">
1454
- <summary>
1455
- Calculates the area of the floor for the reference geometry, as well as for net and gross offsets.
1456
- AREABRUTTO IS ALWAYS double.NaN as it is still unclear how to calculate it.
1457
- </summary>
1458
- <param name="volume">The volume</param>
1459
- <returns>
1460
- areaReference: Area of the reference geometry of the floor,
1461
- areaBrutto: Always double.NaN
1462
- areaNetto: Net area (inner area) of the floor
1463
- </returns>
1464
- </member>
1465
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.Elevation(GeometryViewer.Model.Geometry.Volume)">
1466
- <summary>
1467
- Calculates absolute elevations for upper floor surfaces (Fussbodenoberkante) and lowest ceiling surface (Deckenunterkante)
1468
- </summary>
1469
- <param name="volume">The volume</param>
1470
- <returns>
1471
- floor: Highest point on the floor
1472
- ceiling: Lowest point on the ceiling
1473
- </returns>
1474
- </member>
1475
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.ElevationReference(GeometryViewer.Model.Geometry.Volume)">
1476
- <summary>
1477
- Calculates absolute elevations of the reference geometry
1478
- </summary>
1479
- <param name="volume">The volume</param>
1480
- <returns>
1481
- floor: Average height of the floor reference geometry
1482
- ceiling: Average height of the ceiling reference geometry
1483
- </returns>
1484
- </member>
1485
- <member name="M:GeometryViewer.Algorithms.Geometric.VolumeAlgorithms.FloorPerimeter(GeometryViewer.Model.Geometry.Volume)">
1486
- <summary>
1487
- Calculates the perimeter of the floor.
1488
- Sums up the perimeter sizes of all floor faces.
1489
- DOES NOT HANDLE DUPLICATE EDGES (E.G. WHEN TWO FLOOR POLYGONS INTERSECT)
1490
- </summary>
1491
- <param name="volume">The floor</param>
1492
- <returns>The perimeter length of the floor.</returns>
1493
- </member>
1494
- <member name="T:GeometryViewer.Algorithms.Importing.AssimpGeometryImporter">
1495
- <summary>
1496
- An Importer for generic meshes unsing the Assimp Library.
1497
- </summary>
1498
- </member>
1499
- <member name="P:GeometryViewer.Algorithms.Importing.AssimpGeometryImporter.Instance">
1500
- <summary>
1501
- Provides an Instance to this class.
1502
- </summary>
1503
- </member>
1504
- <member name="M:GeometryViewer.Algorithms.Importing.AssimpGeometryImporter.Import(System.String)">
1505
- <inheritdoc/>
1506
- </member>
1507
- <member name="T:GeometryViewer.Algorithms.Importing.GeometryImporterCache">
1508
- <summary>
1509
- A class used to cache the results of geometry import operations.
1510
- </summary>
1511
- </member>
1512
- <member name="M:GeometryViewer.Algorithms.Importing.GeometryImporterCache.#ctor">
1513
- <summary>
1514
- Creates a new GeometryImporterCache instance.
1515
- </summary>
1516
- </member>
1517
- <member name="M:GeometryViewer.Algorithms.Importing.GeometryImporterCache.TryGetCachedImportedGeometry(System.IO.FileInfo)">
1518
- <summary>
1519
- Tries to retrieve the cached value import result of the provided file.
1520
- Return null if there is no cached version or if the file changed.
1521
- </summary>
1522
- <param name="file">The file to retrieve the results for.</param>
1523
- <returns>The cached import result or null if there is no cache entry or if the entry is dirty and needs reimporting.</returns>
1524
- </member>
1525
- <member name="M:GeometryViewer.Algorithms.Importing.GeometryImporterCache.CacheImportedGeometry(System.IO.FileInfo,GeometryViewer.Algorithms.Importing.GeometryImporterResult)">
1526
- <summary>
1527
- Adds the import result of a specified file to the cache.
1528
- If the entry is already present it is overridden.
1529
- </summary>
1530
- <param name="file">The file to create the entry for.</param>
1531
- <param name="geometry">The import result of the file.</param>
1532
- </member>
1533
- <member name="T:GeometryViewer.Algorithms.Importing.GeometryImporterCache.CacheItem">
1534
- <summary>
1535
- Cache entry data model.
1536
- </summary>
1537
- </member>
1538
- <member name="T:GeometryViewer.Algorithms.Importing.GeometryImporterResult">
1539
- <summary>
1540
- Result of an GeometryImporter Import operation.
1541
- </summary>
1542
- </member>
1543
- <member name="P:GeometryViewer.Algorithms.Importing.GeometryImporterResult.Vertices">
1544
- <summary>
1545
- The vertices of the imported model.
1546
- </summary>
1547
- </member>
1548
- <member name="P:GeometryViewer.Algorithms.Importing.GeometryImporterResult.Normals">
1549
- <summary>
1550
- The normals of the imported model.
1551
- </summary>
1552
- </member>
1553
- <member name="P:GeometryViewer.Algorithms.Importing.GeometryImporterResult.Indices">
1554
- <summary>
1555
- The indices of the imported model.
1556
- </summary>
1557
- </member>
1558
- <member name="M:GeometryViewer.Algorithms.Importing.GeometryImporterResult.#ctor">
1559
- <summary>
1560
- Creates a new GeometryImporterResult with empty vertex/normal/index lists.
1561
- </summary>
1562
- </member>
1563
- <member name="T:GeometryViewer.Algorithms.Importing.GeometryImporterException">
1564
- <summary>
1565
- Gets thrown if an error happens while importing a geometry file.
1566
- </summary>
1567
- </member>
1568
- <member name="M:GeometryViewer.Algorithms.Importing.GeometryImporterException.#ctor">
1569
- <summary>
1570
- Creates an instance of this Exception with a default message.
1571
- </summary>
1572
- </member>
1573
- <member name="M:GeometryViewer.Algorithms.Importing.GeometryImporterException.#ctor(System.String)">
1574
- <summary>
1575
- Creates an instance of this Exception with the provided message.
1576
- <paramref name="message">The message of the exception</paramref>
1577
- </summary>
1578
- </member>
1579
- <member name="M:GeometryViewer.Algorithms.Importing.GeometryImporterException.#ctor(System.String,System.Exception)">
1580
- <summary>
1581
- Creates an instance of this Exception with the provided message and inner exception.
1582
- <paramref name="message">The message of the exception</paramref>
1583
- <paramref name="innerException">The inner exception</paramref>
1584
- </summary>
1585
- </member>
1586
- <member name="T:GeometryViewer.Algorithms.Importing.IGeometryImporter">
1587
- <summary>
1588
- Interface for a geometry importer.
1589
- </summary>
1590
- </member>
1591
- <member name="M:GeometryViewer.Algorithms.Importing.IGeometryImporter.Import(System.String)">
1592
- <summary>
1593
- Loads and parses the the model file at the given path and returns its contents.
1594
- Throws a FileNotFoundException if the file could not be found.
1595
- Throws a GeometryImporterException if an error occurred while loading the file.
1596
- </summary>
1597
- <param name="path">Path to the model file.</param>
1598
- <returns>A GeometryImporterResult containing the parsed model informations.</returns>
1599
- </member>
1600
- <member name="T:GeometryViewer.Algorithms.Generation.DummyOffsetSurfaceGenerator">
1601
- <summary>
1602
- Very fast offset surface generation. Just offsets the face into the required direction.
1603
- Does not close corners/edges to adjacent faces
1604
- </summary>
1605
- </member>
1606
- <member name="M:GeometryViewer.Algorithms.Generation.DummyOffsetSurfaceGenerator.Update(GeometryViewer.Model.Geometry.GeometryModelData)">
1607
- <summary>
1608
- Updates the offset mesh (on the full mesh)
1609
- </summary>
1610
- <param name="model">The geometry model to update</param>
1611
- </member>
1612
- <member name="M:GeometryViewer.Algorithms.Generation.DummyOffsetSurfaceGenerator.Update(GeometryViewer.Model.Geometry.GeometryModelData,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry})">
1613
- <summary>
1614
- Performs an partial update to the offset mesh
1615
- </summary>
1616
- <param name="model">The geometry model</param>
1617
- <param name="invalidatedGeometry">The geometry that should be updated (only Faces in this list are considered)</param>
1618
- <returns>A list of faces that have been modified</returns>
1619
- </member>
1620
- <member name="T:GeometryViewer.Algorithms.Generation.ImprovedOffsetSurfaceGenerator">
1621
- <summary>
1622
- Improved offset generator
1623
- Uses a heuristic based solve on each vertex
1624
- </summary>
1625
-
1626
- -- Details --
1627
-
1628
- --- Exterior Faces ---
1629
- For each exterior face (0 or 1 PFace) run around boundary vertices.
1630
- For each vertex find all adjacent faces. Calculate orientation and if there is a shared edge between the current face and the adjacent one
1631
- This gives a number of directions and offsets
1632
- Try to find three linear independed directions
1633
- - Case 1: Only one direction -> return that direction
1634
- - Case 2: Two directions -> add a third direction perpendicular to the first two with offset 0
1635
- - Case 3: Three directions -> solve equation system
1636
- - Test all directions/offsets against that solution
1637
-
1638
- Special cases:
1639
- A: Two parallel faces with different offset
1640
- - Solution: Remove faces parallel to the current face from search space (happens anyway because they are not lin.indep.)
1641
- B: Four directions with conflicting offsets
1642
- - Solution: If no solution to the equation system exists, remove all faces without shared edge, try to solve again
1643
-
1644
- Revisions:
1645
- Rev2: Try to only take one face per adjacent pedge (hopefully excludes wrong offsets in T-junctions
1646
- </member>
1647
- <member name="M:GeometryViewer.Algorithms.Generation.ImprovedOffsetSurfaceGenerator.Update(GeometryViewer.Model.Geometry.GeometryModelData)">
1648
- <summary>
1649
- Updates the offset mesh
1650
- </summary>
1651
- <param name="model">The model</param>
1652
- </member>
1653
- <member name="M:GeometryViewer.Algorithms.Generation.ImprovedOffsetSurfaceGenerator.Update(GeometryViewer.Model.Geometry.GeometryModelData,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry})">
1654
- <summary>
1655
- Performs a partial update on the offset mesh
1656
- </summary>
1657
- <param name="model">The offset model</param>
1658
- <param name="invalidatedGeometry">The invalidated geometry (only Faces are taken into account)</param>
1659
- <returns>A list of all modified faces</returns>
1660
- </member>
1661
- <member name="T:GeometryViewer.Algorithms.Generation.OffsetAlgorithm">
1662
- <summary>
1663
- Enumeration with different algorithms for offset surface generation
1664
- </summary>
1665
- </member>
1666
- <member name="F:GeometryViewer.Algorithms.Generation.OffsetAlgorithm.Full">
1667
- <summary>
1668
- Uses the best available algorithm
1669
- </summary>
1670
- </member>
1671
- <member name="F:GeometryViewer.Algorithms.Generation.OffsetAlgorithm.Fast">
1672
- <summary>
1673
- Uses a algorithm that is as fast as possible
1674
- </summary>
1675
- </member>
1676
- <member name="F:GeometryViewer.Algorithms.Generation.OffsetAlgorithm.Disabled">
1677
- <summary>
1678
- Do not perform any offset calculations
1679
- </summary>
1680
- </member>
1681
- <member name="T:GeometryViewer.Algorithms.Generation.OffsetSurfaceGenerator">
1682
- <summary>
1683
- Generates offset surfaces and handles switching between different algorithms
1684
- </summary>
1685
- </member>
1686
- <member name="P:GeometryViewer.Algorithms.Generation.OffsetSurfaceGenerator.Algorithm">
1687
- <summary>
1688
- The algorithm used for updates
1689
- </summary>
1690
- </member>
1691
- <member name="M:GeometryViewer.Algorithms.Generation.OffsetSurfaceGenerator.#ctor(GeometryViewer.Model.Geometry.GeometryModelData)">
1692
- <summary>
1693
- Initializes a new instance of the OffsetSurfaceGenerator class
1694
- </summary>
1695
- <param name="model">The geometry model</param>
1696
- </member>
1697
- <member name="M:GeometryViewer.Algorithms.Generation.OffsetSurfaceGenerator.Update(System.Boolean)">
1698
- <summary>
1699
- Performs a complete offset model recalculation
1700
- </summary>
1701
- <param name="calculateSurfaces">True for normal recalcuation, False to prevent calculations</param>
1702
- </member>
1703
- <member name="M:GeometryViewer.Algorithms.Generation.OffsetSurfaceGenerator.Update(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry},System.Boolean)">
1704
- <summary>
1705
- Performs a partial offset surface recalculation
1706
- </summary>
1707
- <param name="invalidatedGeometry">List of geoemtry that has to be recalculated</param>
1708
- <param name="calculateSurfaces">True for normal recalcuation, False to prevent calculations</param>
1709
- <returns></returns>
1710
- </member>
1711
- <member name="T:GeometryViewer.Algorithms.Generation.ProxyShapeGenerator">
1712
- <summary>
1713
- Algorithms for creating predefined proxy shapes
1714
- </summary>
1715
- </member>
1716
- <member name="M:GeometryViewer.Algorithms.Generation.ProxyShapeGenerator.UpdateCube(GeometryViewer.Model.Geometry.ProxyGeometry,System.Windows.Media.Media3D.Point3D)">
1717
- <summary>
1718
- Updates the geoemtry data of a proxy geometry to a cube
1719
- </summary>
1720
- <param name="proxy">The proxy geometry that should be updated.</param>
1721
- <param name="size">Size of the cube geometry (NOT: size of the proxy. This size is used to calculate vertex coordinates)</param>
1722
- <returns>A proxygeometry containing a cube</returns>
1723
- </member>
1724
- <member name="M:GeometryViewer.Algorithms.Generation.ProxyShapeGenerator.GenerateCube(GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Vertex,System.Windows.Media.Media3D.Point3D)">
1725
- <summary>
1726
- Generates a proxy geometry cube
1727
- </summary>
1728
- <param name="layer">Layer on which the cube is placed</param>
1729
- <param name="baseVertex">Vertex to which the cube should be attached</param>
1730
- <param name="size">Size of the cube geometry (NOT: size of the proxy. This size is used to calculate vertex coordinates)</param>
1731
- <returns>A proxygeometry containing a cube</returns>
1732
- </member>
1733
- <member name="M:GeometryViewer.Algorithms.Generation.ProxyShapeGenerator.LoadModel(GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Vertex,System.String,System.Collections.Generic.Dictionary{System.String,GeometryViewer.Algorithms.Importing.GeometryImporterResult})">
1734
- <summary>
1735
- Loads any 3D scene file that is supported by the Assimp library and returns it as a proxy geometry.
1736
- All scene meshes will be combined into a single mesh.
1737
- </summary>
1738
- <param name="layer">Layer on which the model is placed</param>
1739
- <param name="baseVertex">Vertex to which the model should be attached</param>
1740
- <param name="path">The path to the model file.</param>
1741
- <param name="cache">A cache for the geometry data. Before the geometry is imported from file the cache is checked if it already contains the data.</param>
1742
- <returns>A proxygeometry containing the imported model.</returns>
1743
- </member>
1744
- <member name="M:GeometryViewer.Algorithms.Generation.ProxyShapeGenerator.LoadModelsCombined(GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Vertex,System.Collections.Generic.IEnumerable{System.IO.FileInfo},GeometryViewer.IO.IGeometryModelStore)">
1745
- <summary>
1746
- Loads a list of meshes and combines them into a single proxy geometry.
1747
- </summary>
1748
- <param name="layer">Layer on which the model is placed</param>
1749
- <param name="baseVertex">Vertex to which the model should be attached</param>
1750
- <param name="paths">A List of file paths to the meshes that should be combined.</param>
1751
- <param name="modelStore">A IGeometryModelStore used to cache the imported results. Before the geometry is imported from file the cache is checked if it already contains the data.</param>
1752
- <returns>A proxygeometry containing the imported models.</returns>
1753
- </member>
1754
- <member name="M:GeometryViewer.Algorithms.Generation.ProxyShapeGenerator.UpdateProxyGeometryCombined(GeometryViewer.Model.Geometry.ProxyGeometry,System.Collections.Generic.IEnumerable{System.IO.FileInfo},GeometryViewer.IO.IGeometryModelStore)">
1755
- <summary>
1756
- Updates the geoemtry data of a proxy with the combined meshes of the provided mesh list.
1757
- </summary>
1758
- <param name="proxy">The proxy geometry that should be updated.</param>
1759
- <param name="paths">A List of file paths to the meshes that should be combined.</param>
1760
- <param name="modelStore">ModelStore used as cache for the geometry data. Before the geometry is imported from file the cache is checked if it already contains the data.</param>
1761
- </member>
1762
- <member name="T:GeometryViewer.Algorithms.Generation.ShapeGenerator">
1763
- <summary>
1764
- Provides methods for generating shape geometries
1765
- </summary>
1766
- </member>
1767
- <member name="M:GeometryViewer.Algorithms.Generation.ShapeGenerator.GenerateCube(GeometryViewer.Model.Geometry.Layer,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D)">
1768
- <summary>
1769
- Generates a cube volume
1770
- </summary>
1771
- <param name="layer">The layer in which the cube should be placed</param>
1772
- <param name="position">Position of the center of the cube</param>
1773
- <param name="size">Length of the sides of the cube</param>
1774
- <returns>A volume containing edges and vertices that for a cube</returns>
1775
- </member>
1776
- <member name="M:GeometryViewer.Algorithms.Generation.ShapeGenerator.GenerateXZRectangle(GeometryViewer.Model.Geometry.Layer,System.Windows.Media.Media3D.Point3D,System.Windows.Size)">
1777
- <summary>
1778
- Generates a new rectangle in the XZ-plane
1779
- </summary>
1780
- <param name="layer">Layer on which the object should be placed</param>
1781
- <param name="position">Position of one corner</param>
1782
- <param name="size">Size of the rectangle (width along x-axis, height along z-axis)</param>
1783
- <returns></returns>
1784
- </member>
1785
- <member name="T:GeometryViewer.IO.ILoaderGeometryViewerInstance">
1786
- <summary>
1787
- Interface used by the SimGeoIO to communicate with the ILoaderGeometryExchange
1788
- </summary>
1789
- </member>
1790
- <member name="P:GeometryViewer.IO.ILoaderGeometryViewerInstance.LoaderGeometryExchange">
1791
- <summary>
1792
- The ILoaderGeometryExchange of this instance
1793
- </summary>
1794
- </member>
1795
- <member name="T:GeometryViewer.IO.GeometryModelEventArgs">
1796
- <summary>
1797
- EventArgs for the GeometryModelAdded and GeometryModelRemoved event
1798
- </summary>
1799
- </member>
1800
- <member name="P:GeometryViewer.IO.GeometryModelEventArgs.Model">
1801
- <summary>
1802
- The GeometryModel which was added/removed
1803
- </summary>
1804
- </member>
1805
- <member name="M:GeometryViewer.IO.GeometryModelEventArgs.#ctor(GeometryViewer.Model.GeometryModel)">
1806
- <summary>
1807
- Initializes a new instance of the GeometryModelEventArgs class
1808
- </summary>
1809
- <param name="model">The affected model</param>
1810
- </member>
1811
- <member name="T:GeometryViewer.IO.IGeometryModelStore">
1812
- <summary>
1813
- Interface for a class that manages geometry models.
1814
- Implementations have to make sure that only one GeometryModel exists for a given File
1815
- </summary>
1816
- </member>
1817
- <member name="P:GeometryViewer.IO.IGeometryModelStore.Models">
1818
- <summary>
1819
- A list of all Models in this store
1820
- </summary>
1821
- </member>
1822
- <member name="E:GeometryViewer.IO.IGeometryModelStore.GeometryModelAdded">
1823
- <summary>
1824
- Invoked when a GeometryModel has been added to the store
1825
- </summary>
1826
- </member>
1827
- <member name="E:GeometryViewer.IO.IGeometryModelStore.GeometryModelRemoved">
1828
- <summary>
1829
- Invoked when a GeometryModel has been removed from the store
1830
- </summary>
1831
- </member>
1832
- <member name="M:GeometryViewer.IO.IGeometryModelStore.TryGetGeometryModel(System.Guid,GeometryViewer.Model.GeometryModel@,System.Boolean)">
1833
- <summary>
1834
- Tries to find a GeometryModel with a given id
1835
- </summary>
1836
- <param name="id">The id to search for</param>
1837
- <param name="model">Returns the model when one exists</param>
1838
- <param name="isOwning">
1839
- When set to true, the reference counter for this model is increased by one.
1840
- A model requested with isOwning == true has to be freed by calling RemoveGeometryModel
1841
- </param>
1842
- <returns>True when a model with this id exists, otherwise False</returns>
1843
- </member>
1844
- <member name="M:GeometryViewer.IO.IGeometryModelStore.TryGetGeometryModel(System.IO.FileInfo,GeometryViewer.Model.GeometryModel@,System.Boolean)">
1845
- <summary>
1846
- Tries to find a GeometryModel from a given file
1847
- </summary>
1848
- <param name="file">The file to search for</param>
1849
- <param name="model">Returns the model when one exists</param>
1850
- <param name="isOwning">
1851
- When set to true, the reference counter for this model is increased by one.
1852
- A model requested with isOwning == true has to be freed by calling RemoveGeometryModel
1853
- </param>
1854
- <returns>True when a model with this file exists, otherwise False</returns>
1855
- </member>
1856
- <member name="M:GeometryViewer.IO.IGeometryModelStore.AddGeometryModel(GeometryViewer.Model.GeometryModel)">
1857
- <summary>
1858
- Registers a new GeometryModel to the store
1859
- </summary>
1860
- <param name="model">The new model</param>
1861
- </member>
1862
- <member name="M:GeometryViewer.IO.IGeometryModelStore.RemoveGeometryModel(GeometryViewer.Model.GeometryModel)">
1863
- <summary>
1864
- Removes a GeometryModel from the store. Only frees the model when this has been the last reference to the model.
1865
- </summary>
1866
- <param name="model"></param>
1867
- <returns></returns>
1868
- </member>
1869
- <member name="M:GeometryViewer.IO.IGeometryModelStore.FileRenamed(System.IO.FileInfo,System.IO.FileInfo)">
1870
- <summary>
1871
- Notifies the store that a file has been renamed
1872
- </summary>
1873
- <param name="oldFile">The old file</param>
1874
- <param name="newFile">The new/renamed file</param>
1875
- </member>
1876
- <member name="M:GeometryViewer.IO.IGeometryModelStore.TryGetCachedImportedGeometry(System.IO.FileInfo)">
1877
- <summary>
1878
- Tries to get the imported geometry data from the cache.
1879
- </summary>
1880
- <param name="file">The file that should be checked if it is present in the cache.</param>
1881
- <returns>The GeometryImporterResult of the specified file from the cache or null if it was not found.</returns>
1882
- </member>
1883
- <member name="M:GeometryViewer.IO.IGeometryModelStore.CacheImportedGeometry(System.IO.FileInfo,GeometryViewer.Algorithms.Importing.GeometryImporterResult)">
1884
- <summary>
1885
- Adds or updates an entry in the imported geometry cache.
1886
- </summary>
1887
- <param name="file">File that was imported.</param>
1888
- <param name="geometry">The GeometryImporterResult of the imported geometry.</param>
1889
- </member>
1890
- <member name="M:GeometryViewer.IO.IGeometryModelStore.OnImporterWarning(System.Collections.Generic.IEnumerable{System.String})">
1891
- <summary>
1892
- Used to signal Warnings that occurred while importing geometry.
1893
- </summary>
1894
- <param name="messages">A list of messages that should be reported.</param>
1895
- </member>
1896
- <member name="T:GeometryViewer.IO.SimGeoIO">
1897
- <summary>
1898
- Provides methods for accessing simgeo format files. Currently only the Plaintext version is supported
1899
- </summary>
1900
- </member>
1901
- <member name="P:GeometryViewer.IO.SimGeoIO.SimGeoVersion">
1902
- <summary>
1903
- The current version of the SimGeo Format
1904
- </summary>
1905
- </member>
1906
- <member name="T:GeometryViewer.IO.SimGeoIO.WriteMode">
1907
- <summary>
1908
- Describes which format should be written
1909
- </summary>
1910
- </member>
1911
- <member name="F:GeometryViewer.IO.SimGeoIO.WriteMode.Plaintext">
1912
- <summary>
1913
- Plaintext format
1914
- </summary>
1915
- </member>
1916
- <member name="M:GeometryViewer.IO.SimGeoIO.Save(GeometryViewer.Model.GeometryModel,System.IO.FileInfo,GeometryViewer.IO.SimGeoIO.WriteMode)">
1917
- <summary>
1918
- Stores the model to a file
1919
- </summary>
1920
- <param name="model">The model to store</param>
1921
- <param name="path">FileInfo of the target file. The file gets overridden without conformation!!</param>
1922
- <param name="mode">Format in which the file should be written</param>
1923
- </member>
1924
- <member name="M:GeometryViewer.IO.SimGeoIO.Load(System.IO.FileInfo,GeometryViewer.IO.ILoaderGeometryViewerInstance,GeometryViewer.IO.IGeometryModelStore,GeometryViewer.Algorithms.Generation.OffsetAlgorithm)">
1925
- <summary>
1926
- Reads a model from a file
1927
- </summary>
1928
- <param name="geometryFile">The file</param>
1929
- <param name="instance">The instance which requested the loading</param>
1930
- <param name="modelStore">The model store in which the GeometryModels should be loaded</param>
1931
- <param name="offsetAlg">Defines how offset surfaces should be generated after loading</param>
1932
- <returns>The geometry model</returns>
1933
- </member>
1934
- <member name="M:GeometryViewer.IO.SimGeoIO.GetEncoding(System.String)">
1935
- <summary>
1936
- Determines a text file's encoding by analyzing its byte order mark (BOM).
1937
- Defaults to ASCII when detection of the text file's endianness fails.
1938
- From https://stackoverflow.com/questions/3825390/effective-way-to-find-any-files-encoding
1939
- </summary>
1940
- <param name="filename">The text file to analyze.</param>
1941
- <returns>The detected encoding.</returns>
1942
- </member>
1943
- <member name="T:GeometryViewer.AppSettings">
1944
- <summary>
1945
- Stores application wide settings
1946
- </summary>
1947
- </member>
1948
- <member name="P:GeometryViewer.AppSettings.Instance">
1949
- <summary>
1950
- Returns the singleton instance
1951
- </summary>
1952
- </member>
1953
- <member name="M:GeometryViewer.AppSettings.#cctor">
1954
- <summary>
1955
- Initializes the singleton and other static resources
1956
- </summary>
1957
- </member>
1958
- <member name="P:GeometryViewer.AppSettings.Tolerance">
1959
- <summary>
1960
- Gets or sets the general calculation tolerance
1961
- </summary>
1962
- </member>
1963
- <member name="P:GeometryViewer.AppSettings.UserSettingsDirectory">
1964
- <summary>
1965
- Returns the path where user settings should be stored
1966
- </summary>
1967
- </member>
1968
- <member name="P:GeometryViewer.AppSettings.LayoutFile">
1969
- <summary>
1970
- Returns the path to the window layout file
1971
- </summary>
1972
- </member>
1973
- <member name="P:GeometryViewer.AppSettings.Encoding">
1974
- <summary>
1975
- Returns the encoding for all files
1976
- </summary>
1977
- </member>
1978
- <member name="P:GeometryViewer.AppSettings.PluginDirectory">
1979
- <summary>
1980
- Returns the path to the plugin directory
1981
- </summary>
1982
- </member>
1983
- <member name="P:GeometryViewer.AppSettings.CalculateOffsetSurfaces">
1984
- <summary>
1985
- Specifies whether offset surfaces should be calculated
1986
- </summary>
1987
- </member>
1988
- <member name="P:GeometryViewer.AppSettings.OffsetSurfaceRecalcDelay">
1989
- <summary>
1990
- Stores the delay for offset surface full mode recalculations during fast mode.
1991
- In milliseconds
1992
- </summary>
1993
- </member>
1994
- <member name="P:GeometryViewer.AppSettings.ResetLayout">
1995
- <summary>
1996
- When set to true, the next layout storing will delete the file instead
1997
- </summary>
1998
- </member>
1999
- <member name="P:GeometryViewer.AppSettings.ResetSettings">
2000
- <summary>
2001
- When set to true, the next settings storing will delete the file instead
2002
- </summary>
2003
- </member>
2004
- <member name="M:GeometryViewer.AppSettings.#ctor">
2005
- <summary>
2006
- Initializes a new instance of the AppSettings class
2007
- </summary>
2008
- </member>
2009
- <member name="T:GeometryViewer.Model.CommunicationTransfer.ILoaderGeometryExchange">
2010
- <summary>
2011
- Interface for managing the information exchange btw. components and geometry and resource file management.
2012
- </summary>
2013
- </member>
2014
- <member name="M:GeometryViewer.Model.CommunicationTransfer.ILoaderGeometryExchange.ResourceFileExists(System.IO.FileInfo)">
2015
- <summary>
2016
- Checks if the resource file with the given path already exists.
2017
- </summary>
2018
- <param name="file">The file with file extension, *not* the path</param>
2019
- <returns>true, if the resource file was found on record</returns>
2020
- </member>
2021
- <member name="M:GeometryViewer.Model.CommunicationTransfer.ILoaderGeometryExchange.IsValidResourcePath(System.IO.FileInfo,System.Boolean)">
2022
- <summary>
2023
- Checks if the file can be added as a resource file.
2024
- </summary>
2025
- <param name="fi">the info about the file</param>
2026
- <param name="isContained">if true, the file is contained in the project's working directory</param>
2027
- <returns>true, if the file can be used as a resource, false otherwise</returns>
2028
- </member>
2029
- <member name="M:GeometryViewer.Model.CommunicationTransfer.ILoaderGeometryExchange.AddResourceFile(System.IO.FileInfo)">
2030
- <summary>
2031
- Adds the file name to the list of resources.
2032
- </summary>
2033
- <param name="fileName">the name of the file to add</param>
2034
- </member>
2035
- <member name="M:GeometryViewer.Model.CommunicationTransfer.ILoaderGeometryExchange.GetResourceFileIndex(System.IO.FileInfo)">
2036
- <summary>
2037
- Returns the index of the given file in the resource manager.
2038
- </summary>
2039
- <param name="fi">the info about the file</param>
2040
- <returns>Either the index or -1</returns>
2041
- </member>
2042
- <member name="M:GeometryViewer.Model.CommunicationTransfer.ILoaderGeometryExchange.GetFileFromResourceIndex(System.Int32)">
2043
- <summary>
2044
- Returns the FileInfo for a given resource index
2045
- </summary>
2046
- <param name="resourceIndex"></param>
2047
- <returns></returns>
2048
- </member>
2049
- <member name="T:GeometryViewer.Model.DerivedColor">
2050
- <summary>
2051
- Stores a color that can be derived from a parent object
2052
- </summary>
2053
- </member>
2054
- <member name="P:GeometryViewer.Model.DerivedColor.Color">
2055
- <summary>
2056
- Returns the color (either local or derived)
2057
- </summary>
2058
- </member>
2059
- <member name="P:GeometryViewer.Model.DerivedColor.LocalColor">
2060
- <summary>
2061
- Returns the local color
2062
- </summary>
2063
- </member>
2064
- <member name="P:GeometryViewer.Model.DerivedColor.ParentColor">
2065
- <summary>
2066
- Returns the parent color
2067
- </summary>
2068
- </member>
2069
- <member name="P:GeometryViewer.Model.DerivedColor.Parent">
2070
- <summary>
2071
- Returns the parent object (or null when no parent is set)
2072
- </summary>
2073
- </member>
2074
- <member name="P:GeometryViewer.Model.DerivedColor.PropertyName">
2075
- <summary>
2076
- Returns the name of the parent object's property (or null when no parent is set)
2077
- </summary>
2078
- </member>
2079
- <member name="P:GeometryViewer.Model.DerivedColor.IsFromParent">
2080
- <summary>
2081
- Returns whether the local color or the parent color should be used
2082
- </summary>
2083
- </member>
2084
- <member name="M:GeometryViewer.Model.DerivedColor.#ctor(System.Windows.Media.Color)">
2085
- <summary>
2086
- Initializes a new instance of the DerivedColor class
2087
- </summary>
2088
- <remarks>Using this constructor it is impossible to derive colors later</remarks>
2089
- <param name="color">A color</param>
2090
- </member>
2091
- <member name="M:GeometryViewer.Model.DerivedColor.#ctor(System.Windows.Media.Color,System.Object,System.String)">
2092
- <summary>
2093
- Initializes a new instance of the DerivedColor class
2094
- </summary>
2095
- <param name="color">A color</param>
2096
- <param name="parent">The parent object</param>
2097
- <param name="property">The name of the parent color property (of type DerivedColor)</param>
2098
- </member>
2099
- <member name="M:GeometryViewer.Model.DerivedColor.#ctor(GeometryViewer.Model.DerivedColor)">
2100
- <summary>
2101
- Initializes a new instance of the DerivedColor class
2102
- </summary>
2103
- <remarks>Using this constructor it is impossible to derive colors later</remarks>
2104
- <param name="source">Another DerivedColor to copy the data from</param>
2105
- </member>
2106
- <member name="E:GeometryViewer.Model.DerivedColor.PropertyChanged">
2107
- <inheritdoc />
2108
- </member>
2109
- <member name="T:GeometryViewer.Model.GeometryModelReplacedEventArgs">
2110
- <summary>
2111
- EventArgs for the Replaced event
2112
- </summary>
2113
- </member>
2114
- <member name="P:GeometryViewer.Model.GeometryModelReplacedEventArgs.OldGeometry">
2115
- <summary>
2116
- The old geometry data
2117
- </summary>
2118
- </member>
2119
- <member name="P:GeometryViewer.Model.GeometryModelReplacedEventArgs.NewGeometry">
2120
- <summary>
2121
- The new geometry data
2122
- </summary>
2123
- </member>
2124
- <member name="M:GeometryViewer.Model.GeometryModelReplacedEventArgs.#ctor(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.Geometry.GeometryModelData)">
2125
- <summary>
2126
- Initializes a new instance of the GeometryModelReplacedEventArgs class
2127
- </summary>
2128
- <param name="oldGeometry">The old geometry data</param>
2129
- <param name="newGeometry">The new geometry data</param>
2130
- </member>
2131
- <member name="T:GeometryViewer.Model.GeometryModel">
2132
- <summary>
2133
- Contains data for the geometry of a SIMULTAN geometry file
2134
- </summary>
2135
- </member>
2136
- <member name="P:GeometryViewer.Model.GeometryModel.Name">
2137
- <summary>
2138
- Returns the display name
2139
- </summary>
2140
- </member>
2141
- <member name="P:GeometryViewer.Model.GeometryModel.Id">
2142
- <summary>
2143
- A unique number that identifies the model. Usually supplied per project from the ComponentManager
2144
- </summary>
2145
- </member>
2146
- <member name="P:GeometryViewer.Model.GeometryModel.Geometry">
2147
- <summary>
2148
- The geometry of this model. Invokes the Replaced event when changed
2149
- </summary>
2150
- </member>
2151
- <member name="P:GeometryViewer.Model.GeometryModel.Permissions">
2152
- <summary>
2153
- Gets or sets the permissions that are applicable to this model
2154
- </summary>
2155
- </member>
2156
- <member name="P:GeometryViewer.Model.GeometryModel.File">
2157
- <summary>
2158
- Stores the geometry file for this model
2159
- </summary>
2160
- </member>
2161
- <member name="P:GeometryViewer.Model.GeometryModel.LinkedModels">
2162
- <summary>
2163
- A list of all models that are linked to this model
2164
- </summary>
2165
- </member>
2166
- <member name="E:GeometryViewer.Model.GeometryModel.Replaced">
2167
- <summary>
2168
- Invoked when the Geometry of this model has changed
2169
- </summary>
2170
- </member>
2171
- <member name="E:GeometryViewer.Model.GeometryModel.PropertyChanged">
2172
- <summary>
2173
- The PropertyChanged EventHandler
2174
- </summary>
2175
- </member>
2176
- <member name="M:GeometryViewer.Model.GeometryModel.#ctor(System.Guid,System.String,System.IO.FileInfo,GeometryViewer.Model.OperationPermission,GeometryViewer.Model.Geometry.GeometryModelData)">
2177
- <summary>
2178
- Initializes a new instance of the GeometryModel class
2179
- </summary>
2180
- <param name="id">Unique id of this GeometryModel (used to handle GeometryReferences between models)</param>
2181
- <param name="name">The display name</param>
2182
- <param name="file">The geometry file to use</param>
2183
- <param name="permissions">The permissions for this model</param>
2184
- <param name="geometry">The geometry for this model</param>
2185
- </member>
2186
- <member name="T:GeometryViewer.Model.Geometry.BaseEdgeContainer">
2187
- <summary>
2188
- Base class for all edge containing geometries (Polyline, EdgeLoop)
2189
- </summary>
2190
- </member>
2191
- <member name="P:GeometryViewer.Model.Geometry.BaseEdgeContainer.Edges">
2192
- <summary>
2193
- Stores a list of edges in this container
2194
- </summary>
2195
- </member>
2196
- <member name="M:GeometryViewer.Model.Geometry.BaseEdgeContainer.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,System.String)">
2197
- <summary>
2198
- Initializes a new instance of the BaseEdgeContainer class
2199
- </summary>
2200
- <param name="id">The unique identifier for this object</param>
2201
- <param name="layer">The layer this object is placed on</param>
2202
- <param name="name">The name of the geometry</param>
2203
- </member>
2204
- <member name="P:GeometryViewer.Model.Geometry.BaseEdgeContainer.Faces">
2205
- <summary>
2206
- Returns a list of all faces that use this Container
2207
- </summary>
2208
- </member>
2209
- <member name="T:GeometryViewer.Model.Geometry.BaseGeometry">
2210
- <summary>
2211
- Base class for all geometric objects
2212
- </summary>
2213
- </member>
2214
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.IsActuallyVisible">
2215
- <summary>
2216
- Gets or sets if this Geometry is visible including visibility of parent objects (Layer, GeometryModel)
2217
- </summary>
2218
- </member>
2219
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.IsVisible">
2220
- <summary>
2221
- Gets or sets if this Geometry is visible
2222
- </summary>
2223
- </member>
2224
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.Id">
2225
- <summary>
2226
- Returns a unique identifier for this object
2227
- </summary>
2228
- </member>
2229
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.ModelGeometry">
2230
- <summary>
2231
- Returns the model this geometry object belongs to
2232
- </summary>
2233
- </member>
2234
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.Layer">
2235
- <summary>
2236
- Gets or sets the layer on which this geometry object is placed
2237
- </summary>
2238
- </member>
2239
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.Name">
2240
- <summary>
2241
- Gets or sets the display name of this object
2242
- </summary>
2243
- <remarks>The name is NOT unique</remarks>
2244
- </member>
2245
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.Color">
2246
- <summary>
2247
- Color of the object
2248
- </summary>
2249
- </member>
2250
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.GeometryHasChanged">
2251
- <summary>
2252
- Determines if the geometry was changed during a batch operation
2253
- </summary>
2254
- </member>
2255
- <member name="P:GeometryViewer.Model.Geometry.BaseGeometry.Parent">
2256
- <summary>
2257
- Stores a reference to the parent geometry
2258
- </summary>
2259
- </member>
2260
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,System.String)">
2261
- <summary>
2262
- Initializes a new instance of the BaseGeometry class
2263
- </summary>
2264
- <param name="id">Unique identifier for this object</param>
2265
- <param name="layer">The layer for this object</param>
2266
- <param name="name">The display name</param>
2267
- </member>
2268
- <member name="T:GeometryViewer.Model.Geometry.BaseGeometry.GeometryEventHandler">
2269
- <summary>
2270
- Handler for the GeometryChanged event.
2271
- </summary>
2272
- <param name="sender">Object which emitted the event</param>
2273
- </member>
2274
- <member name="E:GeometryViewer.Model.Geometry.BaseGeometry.GeometryChanged">
2275
- <summary>
2276
- Emitted when geometric properties of this object have changed
2277
- </summary>
2278
- </member>
2279
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.NotifyGeometryChanged">
2280
- <summary>
2281
- Emits the GeometryChanged event when called outside a batch operation. Otherwise notifies the geometry to send the event after the batch operation
2282
- </summary>
2283
- </member>
2284
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.OnGeometryChanged(System.Boolean)">
2285
- <summary>
2286
- Calls the GeometryChanged event when NotifyGeometryChanged has marked this geometry during a batch operation
2287
- This event is not sent when either notifyGeometryChanged is False or when a TopologyChanged will be emitted instead
2288
- </summary>
2289
- <param name="notifyGeometryChanged">Defines whether the event should be send</param>
2290
- </member>
2291
- <member name="E:GeometryViewer.Model.Geometry.BaseGeometry.TopologyChanged">
2292
- <summary>
2293
- Emitted when the topology of this element or of one of its subelements has changed (e.g. when a edge uses different vertices now)
2294
- </summary>
2295
- </member>
2296
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.NotifyTopologyChanged">
2297
- <summary>
2298
- Emits the TopologyChanged event when called outside a batch operation. Otherwise notifies the geometry to send the event after the batch operation
2299
- </summary>
2300
- </member>
2301
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.OnTopologyChanged">
2302
- <summary>
2303
- Calls the TopologyChanged event when NotifyTopologyChanged has marked this geometry during a batch operation
2304
- </summary>
2305
- </member>
2306
- <member name="E:GeometryViewer.Model.Geometry.BaseGeometry.PropertyChanged">
2307
- <inheritdoc />
2308
- </member>
2309
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.OnPropertyChanged(System.String)">
2310
- <summary>
2311
- Emits the PropertyChanged event
2312
- </summary>
2313
- <param name="prop">The name of the property</param>
2314
- </member>
2315
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.MakeConsistent(System.Boolean,System.Boolean)">
2316
- <summary>
2317
- Ensures the the geometry is consistent. Called after batch operations
2318
- </summary>
2319
- </member>
2320
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.RemoveFromModel">
2321
- <summary>
2322
- Removes the Geometry from the model
2323
- </summary>
2324
- </member>
2325
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.AddToModel">
2326
- <summary>
2327
- Adds the Geometry to the model (inverse of RemoveFromModel)
2328
- </summary>
2329
- </member>
2330
- <member name="M:GeometryViewer.Model.Geometry.BaseGeometry.AssignToLayerColor(GeometryViewer.Model.Geometry.Layer)">
2331
- <summary>
2332
- Called during Layer reassignment to handle colors. The default implementation transers the color parent to the layer.
2333
- </summary>
2334
- <param name="layer">The new layer</param>
2335
- </member>
2336
- <member name="T:GeometryViewer.Model.Geometry.GeometryReference">
2337
- <summary>
2338
- Stores a reference to a (potentially unloaded) geometry. This class stores the GeometryModel.Id and the BaseGeometry.Id.
2339
- When loaded, Target points to the actual BaseGeometry. Name is cached and available even if the corresponding GeometryModel
2340
- is not loaded.
2341
- </summary>
2342
- </member>
2343
- <member name="P:GeometryViewer.Model.Geometry.GeometryReference.GeometryID">
2344
- <summary>
2345
- The BaseGeometry.Id of the target
2346
- </summary>
2347
- </member>
2348
- <member name="P:GeometryViewer.Model.Geometry.GeometryReference.ModelID">
2349
- <summary>
2350
- The GeometryModel.Id of the target
2351
- </summary>
2352
- </member>
2353
- <member name="P:GeometryViewer.Model.Geometry.GeometryReference.Name">
2354
- <summary>
2355
- The name. Returns Target.Name when Target != null. Otherwise a cached name
2356
- </summary>
2357
- </member>
2358
- <member name="P:GeometryViewer.Model.Geometry.GeometryReference.Target">
2359
- <summary>
2360
- Returns the target BaseGeometry if loaded, or Null
2361
- </summary>
2362
- </member>
2363
- <member name="P:GeometryViewer.Model.Geometry.GeometryReference.IsLoaded">
2364
- <summary>
2365
- Returns true when the Geometry is loaded.
2366
- </summary>
2367
- </member>
2368
- <member name="P:GeometryViewer.Model.Geometry.GeometryReference.ModelStore">
2369
- <summary>
2370
- Stores a list of all GeometryModels in the application
2371
- </summary>
2372
- </member>
2373
- <member name="E:GeometryViewer.Model.Geometry.GeometryReference.PropertyChanged">
2374
- <inheritdoc />
2375
- </member>
2376
- <member name="M:GeometryViewer.Model.Geometry.GeometryReference.#ctor(GeometryViewer.Model.Geometry.BaseGeometry,GeometryViewer.IO.IGeometryModelStore)">
2377
- <summary>
2378
- Initializes a new instance of the GeometryReference class
2379
- </summary>
2380
- <param name="target">The target geometry</param>
2381
- <param name="modelStore">The modelstore in which this geometry exists or may exist in future</param>
2382
- </member>
2383
- <member name="M:GeometryViewer.Model.Geometry.GeometryReference.#ctor(System.Guid,System.UInt64,System.String,GeometryViewer.Model.Geometry.BaseGeometry,GeometryViewer.IO.IGeometryModelStore)">
2384
- <summary>
2385
- Initializes a new instance of the GeometryReference class
2386
- </summary>
2387
- <param name="modelId">Id of the target GeometryModel</param>
2388
- <param name="geometryId">Id of the target BaseGeometry</param>
2389
- <param name="cachedName">The cached name (only used when cachedGeometry is null and the model isn't loaded)</param>
2390
- <param name="cachedGeometry">The target geometry (may be null)</param>
2391
- <param name="modelStore">The modelstore in which this geometry exists or may exist in future</param>
2392
- </member>
2393
- <member name="T:GeometryViewer.Model.Geometry.GeoReference">
2394
- <summary>
2395
- Stores the combination of a vertex and a Geo-Reference location
2396
- </summary>
2397
- </member>
2398
- <member name="P:GeometryViewer.Model.Geometry.GeoReference.Vertex">
2399
- <summary>
2400
- The vertex
2401
- </summary>
2402
- </member>
2403
- <member name="P:GeometryViewer.Model.Geometry.GeoReference.ReferencePoint">
2404
- <summary>
2405
- The geo location, x = long (degrees), y = lat (degrees), z = height (meter)
2406
- </summary>
2407
- </member>
2408
- <member name="M:GeometryViewer.Model.Geometry.GeoReference.#ctor(GeometryViewer.Model.Geometry.Vertex,System.Windows.Media.Media3D.Point3D)">
2409
- <summary>
2410
- Initializes a new instance of the GeoReference class
2411
- </summary>
2412
- <param name="vertex">The vertex</param>
2413
- <param name="reference">The reference location</param>
2414
- </member>
2415
- <member name="E:GeometryViewer.Model.Geometry.GeoReference.PropertyChanged">
2416
- <inheritdoc />
2417
- </member>
2418
- <member name="T:GeometryViewer.Model.Geometry.PEdge">
2419
- <summary>
2420
- Stores the relation between an edge and it's EdgeContainer (EdgeLoop/Polyline)
2421
- </summary>
2422
- </member>
2423
- <member name="P:GeometryViewer.Model.Geometry.PEdge.Parent">
2424
- <summary>
2425
- The container (EdgeLoop or Polyline)
2426
- </summary>
2427
- </member>
2428
- <member name="P:GeometryViewer.Model.Geometry.PEdge.StartVertex">
2429
- <summary>
2430
- Returns the start vertex
2431
- </summary>
2432
- </member>
2433
- <member name="P:GeometryViewer.Model.Geometry.PEdge.Edge">
2434
- <summary>
2435
- Returns the represented edge
2436
- </summary>
2437
- </member>
2438
- <member name="P:GeometryViewer.Model.Geometry.PEdge.Orientation">
2439
- <summary>
2440
- Returns the orientation to the original Edge (Forward means Vertex[0] to Vertex[1])
2441
- </summary>
2442
- </member>
2443
- <member name="P:GeometryViewer.Model.Geometry.PEdge.Next">
2444
- <summary>
2445
- The next pedge in the container (might be null)
2446
- </summary>
2447
- </member>
2448
- <member name="P:GeometryViewer.Model.Geometry.PEdge.Prev">
2449
- <summary>
2450
- The previouse pedge in the container (might be null)
2451
- </summary>
2452
- </member>
2453
- <member name="M:GeometryViewer.Model.Geometry.PEdge.#ctor(GeometryViewer.Model.Geometry.Edge,GeometryViewer.Model.Geometry.GeometricOrientation,GeometryViewer.Model.Geometry.BaseEdgeContainer)">
2454
- <summary>
2455
- Initializes a new instance of the PEdge class
2456
- </summary>
2457
- <param name="edge">The edge</param>
2458
- <param name="orientation">Orientation of the edge. Forward means from Vertices[0] to Vertices[1]</param>
2459
- <param name="parent">The container</param>
2460
- </member>
2461
- <member name="M:GeometryViewer.Model.Geometry.PEdge.MakeConsistent">
2462
- <inheritdoc />
2463
- </member>
2464
- <member name="T:GeometryViewer.Model.Geometry.Edge">
2465
- <summary>
2466
- Represents an edge
2467
- </summary>
2468
- </member>
2469
- <member name="P:GeometryViewer.Model.Geometry.Edge.Vertices">
2470
- <summary>
2471
- Returns the vertices defining this edge.
2472
- </summary>
2473
- <remarks>Has to contain exactly two vertices</remarks>
2474
- </member>
2475
- <member name="P:GeometryViewer.Model.Geometry.Edge.PEdges">
2476
- <summary>
2477
- Returns all pedges attached to this egde
2478
- </summary>
2479
- </member>
2480
- <member name="M:GeometryViewer.Model.Geometry.Edge.#ctor(GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Vertex})">
2481
- <summary>
2482
- Initializes a new instance of the Edge class
2483
- </summary>
2484
- <param name="layer">The layer this object is placed on</param>
2485
- <param name="vertices">The vertices defining this edge</param>
2486
- </member>
2487
- <member name="M:GeometryViewer.Model.Geometry.Edge.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Vertex})">
2488
- <summary>
2489
- Initializes a new instance of the Edge class
2490
- </summary>
2491
- <param name="id">The unique identifier for this object</param>
2492
- <param name="layer">The layer this object is placed on</param>
2493
- <param name="vertices">The vertices defining this edge</param>
2494
- </member>
2495
- <member name="M:GeometryViewer.Model.Geometry.Edge.MakeConsistent(System.Boolean,System.Boolean)">
2496
- <inheritdoc />
2497
- </member>
2498
- <member name="M:GeometryViewer.Model.Geometry.Edge.RemoveFromModel">
2499
- <inheritdoc/>
2500
- </member>
2501
- <member name="M:GeometryViewer.Model.Geometry.Edge.AddToModel">
2502
- <inheritdoc/>
2503
- </member>
2504
- <member name="T:GeometryViewer.Model.Geometry.EdgeLoop">
2505
- <summary>
2506
- Represents a closed edge loop
2507
- </summary>
2508
- </member>
2509
- <member name="P:GeometryViewer.Model.Geometry.EdgeLoop.Edges">
2510
- <summary>
2511
- Returns the PEdges in the EdgeLoop
2512
- </summary>
2513
- </member>
2514
- <member name="P:GeometryViewer.Model.Geometry.EdgeLoop.Faces">
2515
- <summary>
2516
- Gets or sets the Face this Loop is associated with
2517
- </summary>
2518
- </member>
2519
- <member name="M:GeometryViewer.Model.Geometry.EdgeLoop.#ctor(GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge})">
2520
- <summary>
2521
- Initializes a new instance of the EdgeLoop class
2522
- </summary>
2523
- <param name="layer">The layer this object is placed on</param>
2524
- <param name="edges">A list of edges in this loop</param>
2525
- </member>
2526
- <member name="M:GeometryViewer.Model.Geometry.EdgeLoop.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge})">
2527
- <summary>
2528
- Initializes a new instance of the EdgeLoop class
2529
- </summary>
2530
- <param name="layer">The layer this object is placed on</param>
2531
- <param name="edges">A list of edges in this loop</param>
2532
- <param name="id">The unique identifier for this object</param>
2533
- </member>
2534
- <member name="M:GeometryViewer.Model.Geometry.EdgeLoop.MakeConsistent(System.Boolean,System.Boolean)">
2535
- <inheritdoc />
2536
- </member>
2537
- <member name="M:GeometryViewer.Model.Geometry.EdgeLoop.RemoveFromModel">
2538
- <inheritdoc/>
2539
- </member>
2540
- <member name="M:GeometryViewer.Model.Geometry.EdgeLoop.AddToModel">
2541
- <inheritdoc/>
2542
- </member>
2543
- <member name="T:GeometryViewer.Model.Geometry.Face">
2544
- <summary>
2545
- Represents a planar surface
2546
- </summary>
2547
- </member>
2548
- <member name="P:GeometryViewer.Model.Geometry.Face.Boundary">
2549
- <summary>
2550
- Returns the boundary of the polygon
2551
- </summary>
2552
- </member>
2553
- <member name="P:GeometryViewer.Model.Geometry.Face.Holes">
2554
- <summary>
2555
- Returns a list of holes in the polygon
2556
- </summary>
2557
- </member>
2558
- <member name="P:GeometryViewer.Model.Geometry.Face.Orientation">
2559
- <summary>
2560
- Stores the orientation of the face. Forward means CCW, Backward means CW
2561
- </summary>
2562
- </member>
2563
- <member name="P:GeometryViewer.Model.Geometry.Face.Normal">
2564
- <summary>
2565
- Returns the face normal
2566
- </summary>
2567
- </member>
2568
- <member name="P:GeometryViewer.Model.Geometry.Face.PFaces">
2569
- <summary>
2570
- Returns all PFaces associated with this Face
2571
- </summary>
2572
- </member>
2573
- <member name="M:GeometryViewer.Model.Geometry.Face.#ctor(GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.EdgeLoop,GeometryViewer.Model.Geometry.GeometricOrientation,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.EdgeLoop})">
2574
- <summary>
2575
- Initializes a new instance of the Face class
2576
- </summary>
2577
- <param name="layer">The layer this object is placed on</param>
2578
- <param name="boundary">The boundary loop</param>
2579
- <param name="orientation">Orientation of the face</param>
2580
- <param name="holes">A list of hole loops</param>
2581
- </member>
2582
- <member name="M:GeometryViewer.Model.Geometry.Face.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.EdgeLoop,GeometryViewer.Model.Geometry.GeometricOrientation,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.EdgeLoop})">
2583
- <summary>
2584
- Initializes a new instance of the Face class
2585
- </summary>
2586
- <param name="id">The unique identifier for this object</param>
2587
- <param name="layer">The layer this object is placed on</param>
2588
- <param name="boundary">The boundary loop</param>
2589
- <param name="orientation">Orientation of the face</param>
2590
- <param name="holes">A list of hole loops</param>
2591
- </member>
2592
- <member name="M:GeometryViewer.Model.Geometry.Face.MakeConsistent(System.Boolean,System.Boolean)">
2593
- <inheritdoc />
2594
- </member>
2595
- <member name="M:GeometryViewer.Model.Geometry.Face.RemoveFromModel">
2596
- <inheritdoc/>
2597
- </member>
2598
- <member name="M:GeometryViewer.Model.Geometry.Face.AddToModel">
2599
- <inheritdoc/>
2600
- </member>
2601
- <member name="T:GeometryViewer.Model.Geometry.GeometricOrientation">
2602
- <summary>
2603
- Describes an Orientation
2604
- </summary>
2605
- </member>
2606
- <member name="F:GeometryViewer.Model.Geometry.GeometricOrientation.Forward">
2607
- <summary>
2608
- Orientated Forward
2609
- </summary>
2610
- </member>
2611
- <member name="F:GeometryViewer.Model.Geometry.GeometricOrientation.Backward">
2612
- <summary>
2613
- Orientated Backward
2614
- </summary>
2615
- </member>
2616
- <member name="F:GeometryViewer.Model.Geometry.GeometricOrientation.Undefined">
2617
- <summary>
2618
- Undefined Orientation
2619
- </summary>
2620
- </member>
2621
- <member name="T:GeometryViewer.Model.Geometry.GeometryModelData">
2622
- <summary>
2623
- Represents the geometry of a GeometryModel
2624
- </summary>
2625
-
2626
- There are several events relevant for working with GeometryModels:
2627
- - GeometryChanged
2628
- BaseGeometry::GeometryChanged is emitted whenever the underlying geometry has changed. This event is delayed during
2629
- batch operations and invoked during EndBatchOperation for all modified geometries
2630
- GeometryModel::GeometryChanged is invoke for each invocation of BaseGeometry::GeometryChanged. This event is delayed during
2631
- batch operations and is invoked *once* during EndBatchOperation when at least one geometry has changed.
2632
-
2633
- - GeometryAdded/GeometryRemoved
2634
- Emitted when one of the ObservableCollections has changed. This events is delayed during batch operations and is
2635
- invoked during EndBatchOperation once for all added/removed geometries.
2636
-
2637
- - TopologyChanged
2638
- Similar to GeometryAdded/GeometryRemoved. Invoked when one of the underlying geometry lists has changed. This event
2639
- is delayed during batch operations and issued *once* when any geometry has been added or removed.
2640
-
2641
- - BatchOperationFinished is invoked once when the batch operation has ended, no matter if anything was modified.
2642
- </member>
2643
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Model">
2644
- <summary>
2645
- Stores the mode this geometry is related to.
2646
- Can either be the current model or the last one this geometry was attached to
2647
- </summary>
2648
- </member>
2649
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.OffsetQuery">
2650
- <summary>
2651
- The offset query object for this model
2652
- </summary>
2653
- </member>
2654
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Vertices">
2655
- <summary>
2656
- Returns a list of all Vertex instances
2657
- </summary>
2658
- </member>
2659
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Edges">
2660
- <summary>
2661
- Returns a list of all Edge instances
2662
- </summary>
2663
- </member>
2664
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.EdgeLoops">
2665
- <summary>
2666
- Returns a list of all EdgeLoop instances
2667
- </summary>
2668
- </member>
2669
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Polylines">
2670
- <summary>
2671
- Returns a list of lal polyline instances
2672
- </summary>
2673
- </member>
2674
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Faces">
2675
- <summary>
2676
- Returns a list of all Faces instances
2677
- </summary>
2678
- </member>
2679
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Volumes">
2680
- <summary>
2681
- Returns a list of all Volumes instances
2682
- </summary>
2683
- </member>
2684
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Layers">
2685
- <summary>
2686
- Returns a list of all top level Layer
2687
- </summary>
2688
- </member>
2689
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.ProxyGeometries">
2690
- <summary>
2691
- Returns a list of proxy geometries
2692
- </summary>
2693
- </member>
2694
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.GeoReferences">
2695
- <summary>
2696
- Stores a list of georeferenced vertices
2697
- </summary>
2698
- </member>
2699
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.Geometries">
2700
- <summary>
2701
- Returns an IEnumerable with all geometries in the model.
2702
- </summary>
2703
- </member>
2704
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.HandleConsistency">
2705
- <summary>
2706
- Returns whether consistency handling is enabled or not.
2707
- </summary>
2708
- </member>
2709
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.IsVisible">
2710
- <summary>
2711
- Gets or sets if this Geometry is visible
2712
- </summary>
2713
- </member>
2714
- <member name="P:GeometryViewer.Model.Geometry.GeometryModelData.OffsetModel">
2715
- <summary>
2716
- Stores the offset surface model
2717
- </summary>
2718
- </member>
2719
- <member name="T:GeometryViewer.Model.Geometry.GeometryModelData.BaseGeometryEventHandler">
2720
- <summary>
2721
- Delegate for geometry add and remove events
2722
- </summary>
2723
- <param name="sender">Sending GeometryModel</param>
2724
- <param name="geometry">The added/removed geometry</param>
2725
- </member>
2726
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.GeometryAdded">
2727
- <summary>
2728
- Called whenever a BaseGeometry is added
2729
- </summary>
2730
- </member>
2731
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.GeometryRemoved">
2732
- <summary>
2733
- Called whenever a BaseGeometry is deleted
2734
- </summary>
2735
- </member>
2736
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.BatchOperationFinished">
2737
- <summary>
2738
- Invoked when a batch operation has finished
2739
- </summary>
2740
- </member>
2741
- <member name="T:GeometryViewer.Model.Geometry.GeometryModelData.OperationFinishedEventHandler">
2742
- <summary>
2743
- EventHandler for the OperationFinished event
2744
- </summary>
2745
- <param name="sender">The sending model</param>
2746
- <param name="affectedGeometries">List of geometries that were affected by the operation</param>
2747
- </member>
2748
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.OperationFinished">
2749
- <summary>
2750
- Emitted whenever a user-control operation has finished (e.g., Move, Extrude, Draw, ...)
2751
- </summary>
2752
- </member>
2753
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.OnOperationFinished(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry})">
2754
- <summary>
2755
- Issues a OperationFinished event
2756
- </summary>
2757
- <param name="affectedGeometries">List of geometries that were affected by the operation</param>
2758
- </member>
2759
- <member name="T:GeometryViewer.Model.Geometry.GeometryModelData.TopologyChangedEventHandler">
2760
- <summary>
2761
- Handler for the TopologyChanged event.
2762
- </summary>
2763
- <param name="sender">Object which emitted the event</param>
2764
- <param name="geometries">A list of all geometries that were affected. Note that this list might contain already deleted/removed geometry</param>
2765
- </member>
2766
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.TopologyChanged">
2767
- <summary>
2768
- Emitted when objects were added or removed during a batch operation
2769
- </summary>
2770
- </member>
2771
- <member name="T:GeometryViewer.Model.Geometry.GeometryModelData.GeometryChangedEventHandler">
2772
- <summary>
2773
- Handler for the GeometryChanged event.
2774
- </summary>
2775
- <param name="sender">Object which emitted the event</param>
2776
- <param name="geometries">List of BaseGeometries where the underlying geometry has changed</param>
2777
- </member>
2778
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.GeometryChanged">
2779
- <summary>
2780
- Emitted when a geometric property of this model or of one of the submodels has changed
2781
- </summary>
2782
- </member>
2783
- <member name="T:GeometryViewer.Model.Geometry.GeometryModelData.GeoReferencesChangedEventHandler">
2784
- <summary>
2785
- EventHandler for changed GeoReferences.
2786
- </summary>
2787
- <param name="sender">The sender of the event.</param>
2788
- <param name="geoReferences">The GeoReferences that got changed.</param>
2789
- </member>
2790
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.GeoReferencesChanged">
2791
- <summary>
2792
- The event for when GeoReferences change.
2793
- </summary>
2794
- </member>
2795
- <member name="E:GeometryViewer.Model.Geometry.GeometryModelData.PropertyChanged">
2796
- <inheritdoc />
2797
- </member>
2798
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.#ctor(GeometryViewer.Model.OffsetSurface.IOffsetQueryable)">
2799
- <summary>
2800
- Initializes a new instance of the GeometryModelData class
2801
- </summary>
2802
- <param name="offsetQuery">The query object for offset surface offsets</param>
2803
- </member>
2804
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.GetFreeId(System.Boolean)">
2805
- <summary>
2806
- Returns the next free unique id
2807
- </summary>
2808
- <returns>A free id</returns>
2809
- </member>
2810
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.GetMaxUsedId">
2811
- <summary>
2812
- Returns the maximum used unique id
2813
- </summary>
2814
- <returns>Maximum used unique id</returns>
2815
- </member>
2816
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.RegisterId(System.UInt64)">
2817
- <summary>
2818
- Registes an id as used.
2819
- </summary>
2820
- <param name="id">The id</param>
2821
- </member>
2822
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.FreeId(System.UInt64)">
2823
- <summary>
2824
- Frees an id.
2825
- </summary>
2826
- <param name="id">The id</param>
2827
- </member>
2828
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.StartBatchOperation">
2829
- <summary>
2830
- Starts a batch edit operation. During this operation no consistency checks are performed. Note that list might be outdated during the batch operation
2831
- </summary>
2832
- </member>
2833
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.EndBatchOperation">
2834
- <summary>
2835
- Ends a batch edit operation and ensures the model is in a consistent state.
2836
- Sends events that have been delayed during the batch operation.
2837
- </summary>
2838
- </member>
2839
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.MakeConsistent">
2840
- <summary>
2841
- Updates all derived data structure in a model
2842
- </summary>
2843
- </member>
2844
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.Clone">
2845
- <summary>
2846
- Creates a deep copy of the model and all geometries in the model
2847
- </summary>
2848
- <returns></returns>
2849
- </member>
2850
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.NotifyTopologyChanged(GeometryViewer.Model.Geometry.BaseGeometry)">
2851
- <summary>
2852
- Notifies the model that the topology has changed. Called by BaseGeomtries
2853
- </summary>
2854
- </member>
2855
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.ContainsGeometry(GeometryViewer.Model.Geometry.BaseGeometry)">
2856
- <summary>
2857
- Returns True when a BaseGeometry is contained in the Model
2858
- </summary>
2859
- <param name="geometry">The geometry</param>
2860
- <returns>True when the BaseGeometry is contained in the Model, otherwise False</returns>
2861
- </member>
2862
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.GeometryFromId(System.UInt64)">
2863
- <summary>
2864
- Returns the BaseGeometry with the given ID
2865
- </summary>
2866
- <param name="id">ID of the Geometry</param>
2867
- <returns>The BaseGeometry or null when the id doesn't exist</returns>
2868
- </member>
2869
- <member name="M:GeometryViewer.Model.Geometry.GeometryModelData.LayerFromId(System.UInt64)">
2870
- <summary>
2871
- Returns the layer with the given ID
2872
- </summary>
2873
- <param name="id">The id to search for</param>
2874
- <returns>The layer with this id, or null when no such layer exists</returns>
2875
- </member>
2876
- <member name="T:GeometryViewer.Model.Geometry.ActiveGeometryChangedEventArgs">
2877
- <summary>
2878
- Event args for the ActiveChanged event
2879
- </summary>
2880
- </member>
2881
- <member name="P:GeometryViewer.Model.Geometry.ActiveGeometryChangedEventArgs.OldValue">
2882
- <summary>
2883
- The old active geometry
2884
- </summary>
2885
- </member>
2886
- <member name="P:GeometryViewer.Model.Geometry.ActiveGeometryChangedEventArgs.NewValue">
2887
- <summary>
2888
- The new active geometry
2889
- </summary>
2890
- </member>
2891
- <member name="M:GeometryViewer.Model.Geometry.ActiveGeometryChangedEventArgs.#ctor(GeometryViewer.Model.Geometry.BaseGeometry,GeometryViewer.Model.Geometry.BaseGeometry)">
2892
- <summary>
2893
- Initializes a new instance of the ActiveGeometryChangedEventArgs class
2894
- </summary>
2895
- <param name="oldValue">The old active geometry</param>
2896
- <param name="newValue">The new active geometry</param>
2897
- </member>
2898
- <member name="T:GeometryViewer.Model.Geometry.GeometrySelectionModel">
2899
- <summary>
2900
- Provides methods to select geometries
2901
-
2902
- Usage Hints: If possible use the Select/Deselect methods with lists of objects.
2903
- Do not iterate over a geometry list and call Select on each element since this will issue a SelectionChanged Event per Select-call.
2904
- SelectionChanged is issued whenever a Select/Deselect operation has finished (once per operation).
2905
- </summary>
2906
- </member>
2907
- <member name="P:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectedGeometry">
2908
- <summary>
2909
- A list of all selected geometries
2910
- </summary>
2911
- </member>
2912
- <member name="P:GeometryViewer.Model.Geometry.GeometrySelectionModel.ActiveGeometry">
2913
- <summary>
2914
- Gets or sets the active geometry
2915
- </summary>
2916
- </member>
2917
- <member name="T:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedReason">
2918
- <summary>
2919
- Enumeration for reasons why the selection has changed
2920
- </summary>
2921
- </member>
2922
- <member name="F:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedReason.User">
2923
- <summary>
2924
- The user has changed the selection
2925
- </summary>
2926
- </member>
2927
- <member name="F:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedReason.UndoRedo">
2928
- <summary>
2929
- The selection has not really changed by the undo-operation has exchanged geometry
2930
- </summary>
2931
- </member>
2932
- <member name="T:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedEventArgs">
2933
- <summary>
2934
- Event args for the SelectionChanged event
2935
- </summary>
2936
- </member>
2937
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedEventArgs.#ctor(GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedReason,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry},System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry})">
2938
- <summary>
2939
- Initializes a new instance of the SelectionChangedEventArgs class
2940
- </summary>
2941
- <param name="reason">The reason for the selection change</param>
2942
- <param name="added">A list of all additionally selected objects (may be null)</param>
2943
- <param name="removed">A list of all deselected objects (may be null)</param>
2944
- </member>
2945
- <member name="P:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedEventArgs.Reason">
2946
- <summary>
2947
- The reason for the selection change
2948
- </summary>
2949
- </member>
2950
- <member name="P:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedEventArgs.Added">
2951
- <summary>
2952
- A list of all additionally selected objects (may be null)
2953
- </summary>
2954
- </member>
2955
- <member name="P:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedEventArgs.Removed">
2956
- <summary>
2957
- A list of all deselected objects (may be null)
2958
- </summary>
2959
- </member>
2960
- <member name="T:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChangedEventHandler">
2961
- <summary>
2962
- EventHandler for the SelectionChanged event
2963
- </summary>
2964
- <param name="sender">The sender</param>
2965
- <param name="args">The arguments for this event</param>
2966
- </member>
2967
- <member name="E:GeometryViewer.Model.Geometry.GeometrySelectionModel.SelectionChanged">
2968
- <summary>
2969
- Invoked whenever the selection changes
2970
- </summary>
2971
- </member>
2972
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.#ctor(System.Collections.ObjectModel.ObservableCollection{GeometryViewer.Model.GeometryModel})">
2973
- <summary>
2974
- Initializes a new instance of the GeometrySelectionModel class
2975
- </summary>
2976
- </member>
2977
- <member name="T:GeometryViewer.Model.Geometry.GeometrySelectionModel.ActiveGeometryChangedEventHandler">
2978
- <summary>
2979
- Event handler delegate for the ActiveChanged event
2980
- </summary>
2981
- <param name="sender">The sending object</param>
2982
- <param name="args">The event arguments</param>
2983
- </member>
2984
- <member name="E:GeometryViewer.Model.Geometry.GeometrySelectionModel.ActiveChanged">
2985
- <summary>
2986
- Invoked when the active geometry has changed
2987
- </summary>
2988
- </member>
2989
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.Select(GeometryViewer.Model.Geometry.BaseGeometry,System.Boolean)">
2990
- <summary>
2991
- Selects a BaseGeometry
2992
- </summary>
2993
- <param name="geometry">The geometry</param>
2994
- <param name="clearSelection">When true, the list of selected objects is cleared</param>
2995
- </member>
2996
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.Select(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry},System.Boolean)">
2997
- <summary>
2998
- Selects a number of geometries
2999
- </summary>
3000
- <param name="geometry">The geometries to select</param>
3001
- <param name="clearSelection">When set to true, the SelectionModel is cleared before selecting the new geometries</param>
3002
- </member>
3003
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.Select(GeometryViewer.Model.Geometry.GeometryModelData,System.Boolean)">
3004
- <summary>
3005
- Selects everything inside a GeometryModel
3006
- </summary>
3007
- <param name="model">The model</param>
3008
- <param name="clearSelection">When set to true, the selection is cleared</param>
3009
- </member>
3010
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.Deselect(GeometryViewer.Model.Geometry.BaseGeometry)">
3011
- <summary>
3012
- Unselects a Geometry
3013
- </summary>
3014
- <param name="geometry">The geometry</param>
3015
- </member>
3016
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.Deselect(GeometryViewer.Model.Geometry.GeometryModelData)">
3017
- <summary>
3018
- Deselects everything inside a GeometryModel
3019
- </summary>
3020
- <param name="model">The model</param>
3021
- </member>
3022
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.Deselect(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.BaseGeometry})">
3023
- <summary>
3024
- Deselects all elements from a list
3025
- </summary>
3026
- <param name="geometry">List of geometries to deselect</param>
3027
- </member>
3028
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.ToggleSelection(GeometryViewer.Model.Geometry.BaseGeometry)">
3029
- <summary>
3030
- Toggles the selection state for a Geometry
3031
- </summary>
3032
- <param name="geometry">The geometry</param>
3033
- </member>
3034
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.IsSelected(GeometryViewer.Model.Geometry.BaseGeometry)">
3035
- <summary>
3036
- Determines whether a geometry is selected or not
3037
- </summary>
3038
- <param name="geometry">The geometry</param>
3039
- <returns>True when the BaseGeometry is selected, otherwise False</returns>
3040
- </member>
3041
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.IsSelected(GeometryViewer.Model.Geometry.GeometryModelData)">
3042
- <summary>
3043
- Determines whether a GeometryModel is selected
3044
- </summary>
3045
- <param name="model">The model</param>
3046
- <returns>True when everything inside the model is selected, False otherwise</returns>
3047
- </member>
3048
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.Clear">
3049
- <summary>
3050
- Clears the selection list
3051
- </summary>
3052
- </member>
3053
- <member name="M:GeometryViewer.Model.Geometry.GeometrySelectionModel.MakeConsistent">
3054
- <summary>
3055
- Ensures that the SelectionModel only contains valid geometry
3056
- </summary>
3057
- </member>
3058
- <member name="T:GeometryViewer.Model.Geometry.Layer">
3059
- <summary>
3060
- Represents a layer
3061
- </summary>
3062
- </member>
3063
- <member name="P:GeometryViewer.Model.Geometry.Layer.Name">
3064
- <summary>
3065
- Gets or sets the Name of the Layer
3066
- </summary>
3067
- </member>
3068
- <member name="P:GeometryViewer.Model.Geometry.Layer.Color">
3069
- <summary>
3070
- Gets or sets the color of the Layer
3071
- </summary>
3072
- </member>
3073
- <member name="P:GeometryViewer.Model.Geometry.Layer.Model">
3074
- <summary>
3075
- Returns the GeometryModel this Layer belongs to
3076
- </summary>
3077
- </member>
3078
- <member name="P:GeometryViewer.Model.Geometry.Layer.Elements">
3079
- <summary>
3080
- Returns a list of all geometric elements in this layer
3081
- </summary>
3082
- </member>
3083
- <member name="P:GeometryViewer.Model.Geometry.Layer.Layers">
3084
- <summary>
3085
- Returns a list of sublayer
3086
- </summary>
3087
- </member>
3088
- <member name="P:GeometryViewer.Model.Geometry.Layer.Parent">
3089
- <summary>
3090
- Stores the parent layer. Automatically set when adding the layer as a child
3091
- </summary>
3092
- </member>
3093
- <member name="P:GeometryViewer.Model.Geometry.Layer.IsActuallyVisible">
3094
- <summary>
3095
- Gets or sets if this Layer is visible including visibility of parent objects (parent Layer, GeometryModel)
3096
- </summary>
3097
- </member>
3098
- <member name="P:GeometryViewer.Model.Geometry.Layer.IsVisible">
3099
- <summary>
3100
- Gets or sets if this Layer is visible
3101
- </summary>
3102
- </member>
3103
- <member name="P:GeometryViewer.Model.Geometry.Layer.Id">
3104
- <summary>
3105
- Unique ID of this layer
3106
- </summary>
3107
- </member>
3108
- <member name="E:GeometryViewer.Model.Geometry.Layer.PropertyChanged">
3109
- <inheritdoc />
3110
- </member>
3111
- <member name="M:GeometryViewer.Model.Geometry.Layer.#ctor(GeometryViewer.Model.Geometry.GeometryModelData,System.String)">
3112
- <summary>
3113
- Initializes a new instance of the Layer class
3114
- </summary>
3115
- <param name="model">The GeometryModel this layer belongs to</param>
3116
- <param name="name">The display name</param>
3117
- </member>
3118
- <member name="M:GeometryViewer.Model.Geometry.Layer.#ctor(System.UInt64,GeometryViewer.Model.Geometry.GeometryModelData,System.String)">
3119
- <summary>
3120
- Initializes a new instance of the Layer class
3121
- </summary>
3122
- <param name="id">Unique Id for the layer</param>
3123
- <param name="model">The GeometryModel this layer belongs to</param>
3124
- <param name="name">The display name</param>
3125
- </member>
3126
- <member name="M:GeometryViewer.Model.Geometry.Layer.FindInHierarchy(System.String)">
3127
- <summary>
3128
- Searches for a layer with given name in the whole hierarchy with this layer as root.
3129
- </summary>
3130
- <param name="layerName">Layer name to search for</param>
3131
- <returns>Returns layer if found or null otherwise</returns>
3132
- </member>
3133
- <member name="M:GeometryViewer.Model.Geometry.Layer.Clone(GeometryViewer.Model.Geometry.GeometryModelData)">
3134
- <summary>
3135
- Clones a layer and all sublayers and copies them into given target GeometryModel.
3136
- </summary>
3137
- <param name="target">Target GeometryModel</param>
3138
- <returns>Cloned layer</returns>
3139
- </member>
3140
- <member name="M:GeometryViewer.Model.Geometry.Layer.Clone(GeometryViewer.Model.Geometry.GeometryModelData,System.Collections.Generic.Dictionary{GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Layer})">
3141
- <summary>
3142
- Clones a layer and all sublayers and copies them into given target GeometryModel. Additionally, a mapping between old and new layers is maintained.
3143
- </summary>
3144
- <param name="target">Target GeometryModel</param>
3145
- <param name="mapping">Mapping that contains old layers as keys and new (cloned) layers as values</param>
3146
- <returns>Cloned layer</returns>
3147
- </member>
3148
- <member name="T:GeometryViewer.Model.Geometry.PFace">
3149
- <summary>
3150
- Stores a oriented association of a Face with a Volume
3151
- </summary>
3152
- </member>
3153
- <member name="P:GeometryViewer.Model.Geometry.PFace.Face">
3154
- <summary>
3155
- Returns the Face
3156
- </summary>
3157
- </member>
3158
- <member name="P:GeometryViewer.Model.Geometry.PFace.Volume">
3159
- <summary>
3160
- Returns the Volume
3161
- </summary>
3162
- </member>
3163
- <member name="P:GeometryViewer.Model.Geometry.PFace.Orientation">
3164
- <summary>
3165
- Returns the orientation relative to the Face
3166
- </summary>
3167
- </member>
3168
- <member name="M:GeometryViewer.Model.Geometry.PFace.#ctor(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.Volume,GeometryViewer.Model.Geometry.GeometricOrientation)">
3169
- <summary>
3170
- Initializes a new instance of the PFace class
3171
- </summary>
3172
- <param name="face">The Face</param>
3173
- <param name="volume">The Volume</param>
3174
- <param name="orientation">The orientation relative to the Face (Forward means same Normal)</param>
3175
- </member>
3176
- <member name="M:GeometryViewer.Model.Geometry.PFace.MakeConsistent">
3177
- <inheritdoc />
3178
- </member>
3179
- <member name="T:GeometryViewer.Model.Geometry.Polyline">
3180
- <summary>
3181
- Represents a polyline (consisting of multiple connected edges).
3182
- A polyline may not be closed. For closed loops have a look at the EdgeLoop class
3183
- </summary>
3184
- </member>
3185
- <member name="P:GeometryViewer.Model.Geometry.Polyline.Edges">
3186
- <inheritdoc/>
3187
- </member>
3188
- <member name="P:GeometryViewer.Model.Geometry.Polyline.Faces">
3189
- <inheritdoc />
3190
- </member>
3191
- <member name="M:GeometryViewer.Model.Geometry.Polyline.#ctor(GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge})">
3192
- <summary>
3193
- Initializes a new Polyline class
3194
- </summary>
3195
- <param name="layer">The layer on which the polyline is created</param>
3196
- <param name="edges">A list of edges for this polyline. The edges have to form a single path without branches.
3197
- The order is not important.
3198
- </param>
3199
- </member>
3200
- <member name="M:GeometryViewer.Model.Geometry.Polyline.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Edge})">
3201
- <summary>
3202
- Initializes a new Polyline class
3203
- </summary>
3204
- <param name="id">The unique id for this polyline</param>
3205
- <param name="layer">The layer on which the polyline is created</param>
3206
- <param name="edges">A list of edges for this polyline. The edges have to form a single path without branches.
3207
- The order is not important.
3208
- </param>
3209
- </member>
3210
- <member name="M:GeometryViewer.Model.Geometry.Polyline.AddToModel">
3211
- <inheritdoc/>
3212
- </member>
3213
- <member name="M:GeometryViewer.Model.Geometry.Polyline.RemoveFromModel">
3214
- <inheritdoc/>
3215
- </member>
3216
- <member name="M:GeometryViewer.Model.Geometry.Polyline.MakeConsistent(System.Boolean,System.Boolean)">
3217
- <inheritdoc/>
3218
- </member>
3219
- <member name="T:GeometryViewer.Model.Geometry.ProxyGeometry">
3220
- <summary>
3221
- Displays a arbitrary triangle mesh that is attached to a vertex.
3222
- The proxy acts similar to the vertex during selection and all other operations
3223
- </summary>
3224
- </member>
3225
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.Vertex">
3226
- <summary>
3227
- The vertex to which the proxy geometry is attached
3228
- </summary>
3229
- </member>
3230
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.Positions">
3231
- <summary>
3232
- A list of triangles vertices
3233
- </summary>
3234
- </member>
3235
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.Normals">
3236
- <summary>
3237
- A list of vertex normals
3238
- </summary>
3239
- </member>
3240
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.Indices">
3241
- <summary>
3242
- Index list for the triangle mesh (always three indices form a face)
3243
- </summary>
3244
- </member>
3245
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.Size">
3246
- <summary>
3247
- Gets or sets the size (scaling) of the proxy geometry
3248
- </summary>
3249
- </member>
3250
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.Rotation">
3251
- <summary>
3252
- Gets or sets the local rotation of the proxy geometry
3253
- </summary>
3254
- </member>
3255
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.EulerAngles">
3256
- <summary>
3257
- Euler angles of rotation
3258
- </summary>
3259
- </member>
3260
- <member name="P:GeometryViewer.Model.Geometry.ProxyGeometry.Transformation">
3261
- <summary>
3262
- Returns the full model matrix. Includes Size and the vertex position.
3263
- </summary>
3264
- </member>
3265
- <member name="M:GeometryViewer.Model.Geometry.ProxyGeometry.#ctor(GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Vertex)">
3266
- <summary>
3267
- Initializes a new instance of the ProxyGeometry class
3268
- </summary>
3269
- <param name="layer">The layer on which the proxy geometry should exist</param>
3270
- <param name="vertex">The vertex to which the proxy is attached</param>
3271
- </member>
3272
- <member name="M:GeometryViewer.Model.Geometry.ProxyGeometry.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Vertex,System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Collections.Generic.List{System.Windows.Media.Media3D.Vector3D},System.Collections.Generic.List{System.Int32})">
3273
- <summary>
3274
- Initializes a new instance of the ProxyGeometry class
3275
- </summary>
3276
- <param name="id">The unique id of this geometry</param>
3277
- <param name="layer">The layer on which the proxy geometry should exist</param>
3278
- <param name="vertex">The vertex to which the proxy is attached</param>
3279
- <param name="positions">List of vertex positions, default null</param>
3280
- <param name="normals">List of vertex normals, default null</param>
3281
- <param name="indices">List of indices, default null</param>
3282
- </member>
3283
- <member name="M:GeometryViewer.Model.Geometry.ProxyGeometry.AddToModel">
3284
- <inheritdoc/>
3285
- </member>
3286
- <member name="M:GeometryViewer.Model.Geometry.ProxyGeometry.MakeConsistent(System.Boolean,System.Boolean)">
3287
- <inheritdoc/>
3288
- </member>
3289
- <member name="M:GeometryViewer.Model.Geometry.ProxyGeometry.RemoveFromModel">
3290
- <inheritdoc/>
3291
- </member>
3292
- <member name="M:GeometryViewer.Model.Geometry.ProxyGeometry.AssignToLayerColor(GeometryViewer.Model.Geometry.Layer)">
3293
- <inheritdoc />
3294
- </member>
3295
- <member name="T:GeometryViewer.Model.Geometry.Vertex">
3296
- <summary>
3297
- Represents a point in 3D space
3298
- </summary>
3299
- </member>
3300
- <member name="P:GeometryViewer.Model.Geometry.Vertex.Position">
3301
- <summary>
3302
- Gets or sets the position
3303
- </summary>
3304
- </member>
3305
- <member name="P:GeometryViewer.Model.Geometry.Vertex.Edges">
3306
- <summary>
3307
- Returns all edges the vertex is part of
3308
- </summary>
3309
- </member>
3310
- <member name="P:GeometryViewer.Model.Geometry.Vertex.ProxyGeometries">
3311
- <summary>
3312
- Stores a list of proxy geometries that are attached to this vertex
3313
- </summary>
3314
- </member>
3315
- <member name="M:GeometryViewer.Model.Geometry.Vertex.#ctor(GeometryViewer.Model.Geometry.Layer,System.Windows.Media.Media3D.Point3D)">
3316
- <summary>
3317
- Initializes a new instance of the Vertex class
3318
- </summary>
3319
- <param name="layer">The layer this object is placed on</param>
3320
- <param name="position">The position of the vertex</param>
3321
- </member>
3322
- <member name="M:GeometryViewer.Model.Geometry.Vertex.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,System.Windows.Media.Media3D.Point3D)">
3323
- <summary>
3324
- Initializes a new instance of the Vertex class
3325
- </summary>
3326
- <param name="id">The unique identifier for this object</param>
3327
- <param name="layer">The layer this object is placed on</param>
3328
- <param name="position">The position of the vertex</param>
3329
- </member>
3330
- <member name="M:GeometryViewer.Model.Geometry.Vertex.MakeConsistent(System.Boolean,System.Boolean)">
3331
- <inheritdoc />
3332
- </member>
3333
- <member name="M:GeometryViewer.Model.Geometry.Vertex.RemoveFromModel">
3334
- <inheritdoc/>
3335
- </member>
3336
- <member name="M:GeometryViewer.Model.Geometry.Vertex.AddToModel">
3337
- <inheritdoc/>
3338
- </member>
3339
- <member name="M:GeometryViewer.Model.Geometry.Vertex.Clone">
3340
- <summary>
3341
- Creates a deep copy of the vertex
3342
- </summary>
3343
- <returns></returns>
3344
- </member>
3345
- <member name="M:GeometryViewer.Model.Geometry.Vertex.Clone(GeometryViewer.Model.Geometry.Layer)">
3346
- <summary>
3347
- Creates a deep copy of the vertex on a specific layer
3348
- </summary>
3349
- <param name="layer">The target layer</param>
3350
- <returns>The new vertex</returns>
3351
- </member>
3352
- <member name="T:GeometryViewer.Model.Geometry.Volume">
3353
- <summary>
3354
- Represents a volume
3355
- </summary>
3356
- </member>
3357
- <member name="P:GeometryViewer.Model.Geometry.Volume.Faces">
3358
- <summary>
3359
- Returns a list of all boundary PFaces
3360
- </summary>
3361
- </member>
3362
- <member name="P:GeometryViewer.Model.Geometry.Volume.IsConsistentOriented">
3363
- <summary>
3364
- Stores whether the faces describe a closed and consistently oriented volume. If False, several methods might
3365
- return wrong values (e.g. Volume calculation returns NaN).
3366
- </summary>
3367
- </member>
3368
- <member name="M:GeometryViewer.Model.Geometry.Volume.#ctor(GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Face})">
3369
- <summary>
3370
- Initializes a new instance of the Volume class
3371
- </summary>
3372
- <param name="layer">The layer this object is placed on</param>
3373
- <param name="faces">A list of boundary faces</param>
3374
- </member>
3375
- <member name="M:GeometryViewer.Model.Geometry.Volume.#ctor(System.UInt64,GeometryViewer.Model.Geometry.Layer,System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Face})">
3376
- <summary>
3377
- Initializes a new instance of the Volume class
3378
- </summary>
3379
- <param name="id">The unique identifier for this object</param>
3380
- <param name="layer">The layer this object is placed on</param>
3381
- <param name="faces">A list of boundary faces</param>
3382
- </member>
3383
- <member name="M:GeometryViewer.Model.Geometry.Volume.MakeConsistent(System.Boolean,System.Boolean)">
3384
- <inheritdoc />
3385
- </member>
3386
- <member name="M:GeometryViewer.Model.Geometry.Volume.RemoveFromModel">
3387
- <inheritdoc/>
3388
- </member>
3389
- <member name="M:GeometryViewer.Model.Geometry.Volume.AddToModel">
3390
- <inheritdoc/>
3391
- </member>
3392
- <member name="M:GeometryViewer.Model.Geometry.Volume.AddFace(GeometryViewer.Model.Geometry.Face)">
3393
- <summary>
3394
- Adds a face to the volume
3395
- </summary>
3396
- <param name="face">The face to add</param>
3397
- </member>
3398
- <member name="T:GeometryViewer.Model.OffsetSurface.GeometryInvalidatedEventHandler">
3399
- <summary>
3400
- Event handler delegate for the GeometryInvalidated event.
3401
- </summary>
3402
- <param name="sender">the sending object</param>
3403
- <param name="affected_geometry">the geometry affected by the change</param>
3404
- </member>
3405
- <member name="T:GeometryViewer.Model.OffsetSurface.IOffsetQueryable">
3406
- <summary>
3407
- Interface for a class that provides offset surface thicknesses
3408
- </summary>
3409
- </member>
3410
- <member name="M:GeometryViewer.Model.OffsetSurface.IOffsetQueryable.GetFaceOffset(GeometryViewer.Model.Geometry.Face)">
3411
- <summary>
3412
- Gets the outer and inner offsets of the given face according to
3413
- the associated component representing a wall construction. If there is no
3414
- such component, both offsets are 0.0.
3415
- </summary>
3416
- <param name="_face">the face whose offsets we are looking for</param>
3417
- <returns>a tuple of doubles: the outer and inner offsets</returns>
3418
- </member>
3419
- <member name="E:GeometryViewer.Model.OffsetSurface.IOffsetQueryable.GeometryInvalidated">
3420
- <summary>
3421
- Invoked when a change in the source of one or more connectors causes
3422
- the target geometry to become invalid (e.g., size change for placed components, or wall construction thickness).
3423
- </summary>
3424
- </member>
3425
- <member name="T:GeometryViewer.Model.OffsetSurface.OffsetFace">
3426
- <summary>
3427
- Stores data for one face in an offset surface mesh
3428
- </summary>
3429
- </member>
3430
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetFace.Face">
3431
- <summary>
3432
- The associated face
3433
- </summary>
3434
- </member>
3435
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetFace.Offset">
3436
- <summary>
3437
- The office that was used for this offset face
3438
- </summary>
3439
- </member>
3440
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetFace.Openings">
3441
- <summary>
3442
- Stores initial opening loops. The key is the <see cref="T:GeometryViewer.Model.Geometry.EdgeLoop"/> which represents the opening in the reference face.
3443
- </summary>
3444
- </member>
3445
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetFace.Boundary">
3446
- <summary>
3447
- Stores the final boundary polygon
3448
- </summary>
3449
- </member>
3450
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetFace.AdditionalEdges">
3451
- <summary>
3452
- Stores additional edges for this face (e.g., side-closing edges, edges of openings, ...)
3453
- </summary>
3454
- </member>
3455
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetFace.AdditionalQuads">
3456
- <summary>
3457
- Stores a list of additional quads.
3458
- </summary>
3459
- </member>
3460
- <member name="M:GeometryViewer.Model.OffsetSurface.OffsetFace.#ctor(GeometryViewer.Model.Geometry.Face)">
3461
- <summary>
3462
- Initializes a new instance of the OffsetFace class
3463
- </summary>
3464
- <param name="face">The face which is associated with this offset face</param>
3465
- </member>
3466
- <member name="T:GeometryViewer.Model.OffsetSurface.OffsetModel">
3467
- <summary>
3468
- Stores information about offset faces
3469
- </summary>
3470
- </member>
3471
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetModel.Model">
3472
- <summary>
3473
- Stores the GeometryModel this model belongs to
3474
- </summary>
3475
- </member>
3476
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetModel.HandleGeometryInvalidated">
3477
- <summary>
3478
- Determines whether offset surfaces should be updated when the GeometryChanged event is invoked.
3479
- Use this to disable offset generation during multi-step operations
3480
- </summary>
3481
- </member>
3482
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetModel.OffsetQuery">
3483
- <summary>
3484
- Stores the offset query object
3485
- </summary>
3486
- </member>
3487
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetModel.Faces">
3488
- <summary>
3489
- Stores the offset faces (always inner and outer surface for each face)
3490
- </summary>
3491
- </member>
3492
- <member name="T:GeometryViewer.Model.OffsetSurface.OffsetModel.OffsetChangedEventHandler">
3493
- <summary>
3494
- EventHandler for the OffsetSurfaceChanged event
3495
- </summary>
3496
- <param name="sender">The sender</param>
3497
- <param name="modifiedFaces">An enumerable containg all modified faces</param>
3498
- </member>
3499
- <member name="E:GeometryViewer.Model.OffsetSurface.OffsetModel.OffsetSurfaceChanged">
3500
- <summary>
3501
- Invoked when the offset surface has changed
3502
- </summary>
3503
- </member>
3504
- <member name="P:GeometryViewer.Model.OffsetSurface.OffsetModel.Generator">
3505
- <summary>
3506
- Stores the generator used to generate offset surfaces
3507
- </summary>
3508
- </member>
3509
- <member name="M:GeometryViewer.Model.OffsetSurface.OffsetModel.OnOffsetSurfaceChanged(System.Collections.Generic.IEnumerable{GeometryViewer.Model.Geometry.Face})">
3510
- <summary>
3511
- Invokes the OffsetSurfaceChanged event
3512
- </summary>
3513
- <param name="faces">All modified faces</param>
3514
- </member>
3515
- <member name="M:GeometryViewer.Model.OffsetSurface.OffsetModel.#ctor(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.OffsetSurface.IOffsetQueryable)">
3516
- <summary>
3517
- Initializes a new instance of the OffsetModel class
3518
- </summary>
3519
- <param name="model">The geometrymodel</param>
3520
- <param name="offsetQuery">Object to query offsets</param>
3521
- </member>
3522
- <member name="T:GeometryViewer.Model.GeometryOperationPermissions">
3523
- <summary>
3524
- Flags for permission on BaseGeometries
3525
- </summary>
3526
- </member>
3527
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.None">
3528
- <summary>
3529
- No interaction with the model is allowed
3530
- </summary>
3531
- </member>
3532
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.Select">
3533
- <summary>
3534
- The user can select geometry
3535
- </summary>
3536
- </member>
3537
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.Move">
3538
- <summary>
3539
- The user can move geometry (grab, scale, rotate)
3540
- </summary>
3541
- </member>
3542
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.Delete">
3543
- <summary>
3544
- The user can delete geometry
3545
- </summary>
3546
- </member>
3547
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.Create">
3548
- <summary>
3549
- The user can create new geometry (covers extrude and polyline drawing)
3550
- </summary>
3551
- </member>
3552
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.Split">
3553
- <summary>
3554
- The user can split existing edges
3555
- </summary>
3556
- </member>
3557
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.Unsplit">
3558
- <summary>
3559
- The user can remove points from EdgeLoops and Polylines
3560
- </summary>
3561
- </member>
3562
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.ModifyLayer">
3563
- <summary>
3564
- The user can move geometry to a new layer
3565
- </summary>
3566
- </member>
3567
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.ModifyName">
3568
- <summary>
3569
- The user can change the name of a Geometry
3570
- </summary>
3571
- </member>
3572
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.ModifyColor">
3573
- <summary>
3574
- The user can modify the color of a Geometry
3575
- </summary>
3576
- </member>
3577
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.ModifyParent">
3578
- <summary>
3579
- The user can set/unset the parent of a BaseGeometry
3580
- </summary>
3581
- </member>
3582
- <member name="F:GeometryViewer.Model.GeometryOperationPermissions.All">
3583
- <summary>
3584
- The user can do everything
3585
- </summary>
3586
- </member>
3587
- <member name="T:GeometryViewer.Model.LayerOperationPermissions">
3588
- <summary>
3589
- Flags for permissions on layer
3590
- </summary>
3591
- </member>
3592
- <member name="F:GeometryViewer.Model.LayerOperationPermissions.None">
3593
- <summary>
3594
- No interaction with the model is allowed
3595
- </summary>
3596
- </member>
3597
- <member name="F:GeometryViewer.Model.LayerOperationPermissions.Create">
3598
- <summary>
3599
- The user can create new layer
3600
- </summary>
3601
- </member>
3602
- <member name="F:GeometryViewer.Model.LayerOperationPermissions.Delete">
3603
- <summary>
3604
- The user can delete layer
3605
- </summary>
3606
- </member>
3607
- <member name="F:GeometryViewer.Model.LayerOperationPermissions.ModifyColor">
3608
- <summary>
3609
- The user can modify the color of a layer
3610
- </summary>
3611
- </member>
3612
- <member name="F:GeometryViewer.Model.LayerOperationPermissions.ModifyTopolgy">
3613
- <summary>
3614
- The user can modify the layer structure (move layer to other parent)
3615
- </summary>
3616
- </member>
3617
- <member name="F:GeometryViewer.Model.LayerOperationPermissions.ModifyName">
3618
- <summary>
3619
- The user can modify layer names
3620
- </summary>
3621
- </member>
3622
- <member name="F:GeometryViewer.Model.LayerOperationPermissions.All">
3623
- <summary>
3624
- The user can do everything
3625
- </summary>
3626
- </member>
3627
- <member name="T:GeometryViewer.Model.GeometryModelOperationPermissions">
3628
- <summary>
3629
- Flags for permissions on GeometryModels and linked Models
3630
- </summary>
3631
- </member>
3632
- <member name="F:GeometryViewer.Model.GeometryModelOperationPermissions.None">
3633
- <summary>
3634
- No interaction with the model is allowed
3635
- </summary>
3636
- </member>
3637
- <member name="F:GeometryViewer.Model.GeometryModelOperationPermissions.RemoveLinked">
3638
- <summary>
3639
- The user can remove linked models
3640
- </summary>
3641
- </member>
3642
- <member name="F:GeometryViewer.Model.GeometryModelOperationPermissions.AddLinked">
3643
- <summary>
3644
- The user can link additional models to this model (also includes linking networks)
3645
- </summary>
3646
- </member>
3647
- <member name="F:GeometryViewer.Model.GeometryModelOperationPermissions.All">
3648
- <summary>
3649
- The user can do everything
3650
- </summary>
3651
- </member>
3652
- <member name="T:GeometryViewer.Model.OperationPermission">
3653
- <summary>
3654
- Stores the permissions for a GeometryModel
3655
- </summary>
3656
- </member>
3657
- <member name="P:GeometryViewer.Model.OperationPermission.None">
3658
- <summary>
3659
- Returns a permission set that allows the user to do nothing
3660
- </summary>
3661
- </member>
3662
- <member name="P:GeometryViewer.Model.OperationPermission.DefaultWallModelPermissions">
3663
- <summary>
3664
- Returns the default permission set for wall models (everything allowed)
3665
- </summary>
3666
- </member>
3667
- <member name="P:GeometryViewer.Model.OperationPermission.DefaultNetworkPermissions">
3668
- <summary>
3669
- Returns the default permission set for Network models
3670
- </summary>
3671
- </member>
3672
- <member name="P:GeometryViewer.Model.OperationPermission.All">
3673
- <summary>
3674
- Returns a permission set that allows everything
3675
- </summary>
3676
- </member>
3677
- <member name="P:GeometryViewer.Model.OperationPermission.GeometryPermissions">
3678
- <summary>
3679
- Stores the permissions for BaseGeometries
3680
- </summary>
3681
- </member>
3682
- <member name="P:GeometryViewer.Model.OperationPermission.LayerPermissions">
3683
- <summary>
3684
- Stores the permissions for layer
3685
- </summary>
3686
- </member>
3687
- <member name="P:GeometryViewer.Model.OperationPermission.ModelPermissions">
3688
- <summary>
3689
- Stores the permission for GeometryModels (and linked models)
3690
- </summary>
3691
- </member>
3692
- <member name="M:GeometryViewer.Model.OperationPermission.#ctor(GeometryViewer.Model.GeometryModelOperationPermissions,GeometryViewer.Model.GeometryOperationPermissions,GeometryViewer.Model.LayerOperationPermissions)">
3693
- <summary>
3694
- Initializes a new instance of the OperationPermission class
3695
- </summary>
3696
- <param name="modelPermissions">The GeometryModel permissions</param>
3697
- <param name="geometryPermissions">The BaseGeometry permissions</param>
3698
- <param name="layerPermissions">The Layer permissions</param>
3699
- </member>
3700
- <member name="T:GeometryViewer.Model.SpatialStructures.AABB">
3701
- <summary>
3702
- Stores an axis-aligned bounding box
3703
- </summary>
3704
- </member>
3705
- <member name="P:GeometryViewer.Model.SpatialStructures.AABB.Min">
3706
- <summary>
3707
- The minimum along each axis
3708
- </summary>
3709
- </member>
3710
- <member name="P:GeometryViewer.Model.SpatialStructures.AABB.Max">
3711
- <summary>
3712
- The maximum along each axis
3713
- </summary>
3714
- </member>
3715
- <member name="P:GeometryViewer.Model.SpatialStructures.AABB.Content">
3716
- <summary>
3717
- The BaseGeometry this box belongs to
3718
- </summary>
3719
- </member>
3720
- <member name="M:GeometryViewer.Model.SpatialStructures.AABB.#ctor(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,GeometryViewer.Model.Geometry.BaseGeometry)">
3721
- <summary>
3722
- Initializes a new instance of the AABB class
3723
- </summary>
3724
- <param name="min">The minimum position</param>
3725
- <param name="max">The maximum position</param>
3726
- <param name="content">The geometry this aabb contains</param>
3727
- </member>
3728
- <member name="M:GeometryViewer.Model.SpatialStructures.AABB.#ctor(GeometryViewer.Model.Geometry.Face)">
3729
- <summary>
3730
- Initializes a new instance of the AABB class
3731
- </summary>
3732
- <param name="face">The face for which the AABB should be calculated</param>
3733
- </member>
3734
- <member name="M:GeometryViewer.Model.SpatialStructures.AABB.#ctor(GeometryViewer.Model.Geometry.Vertex)">
3735
- <summary>
3736
- Initializes a new instance of the AABB class
3737
- </summary>
3738
- <param name="vertex">The vertex for which the AABB should be calculated</param>
3739
- </member>
3740
- <member name="M:GeometryViewer.Model.SpatialStructures.AABB.#ctor(GeometryViewer.Model.Geometry.Edge)">
3741
- <summary>
3742
- Initializes a new instance of the AABB class
3743
- </summary>
3744
- <param name="edge">The edge for which the AABB should be calculated</param>
3745
- </member>
3746
- <member name="M:GeometryViewer.Model.SpatialStructures.AABB.#ctor(GeometryViewer.Model.Geometry.Volume)">
3747
- <summary>
3748
- Initializes a new instance of the AABB class
3749
- </summary>
3750
- <param name="volume">The volume for which the AABB should be calculated</param>
3751
- </member>
3752
- <member name="M:GeometryViewer.Model.SpatialStructures.AABB.Merge(System.Collections.Generic.IEnumerable{GeometryViewer.Model.SpatialStructures.AABB})">
3753
- <summary>
3754
- Calculates the aabb which contains all item AABBs
3755
- </summary>
3756
- <param name="items">A list of AABBs which should be contained in the result</param>
3757
- <returns>The minimum and maximum of all boxes</returns>
3758
- </member>
3759
- <member name="T:GeometryViewer.Model.SpatialStructures.AABBGrid">
3760
- <summary>
3761
- Stores AABBs in a grid structure
3762
- </summary>
3763
- </member>
3764
- <member name="P:GeometryViewer.Model.SpatialStructures.AABBGrid.Cells">
3765
- <summary>
3766
- The cells of the grid. May be null when no AABBs are present
3767
- </summary>
3768
- </member>
3769
- <member name="P:GeometryViewer.Model.SpatialStructures.AABBGrid.ActualCellSize">
3770
- <summary>
3771
- The size of each cell in the grid. Might defer from the desired size due to equalization reasons
3772
- </summary>
3773
- </member>
3774
- <member name="P:GeometryViewer.Model.SpatialStructures.AABBGrid.Min">
3775
- <summary>
3776
- Minimum position of the grid
3777
- </summary>
3778
- </member>
3779
- <member name="P:GeometryViewer.Model.SpatialStructures.AABBGrid.Max">
3780
- <summary>
3781
- Maximum position in the grid
3782
- </summary>
3783
- </member>
3784
- <member name="M:GeometryViewer.Model.SpatialStructures.AABBGrid.#ctor(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D)">
3785
- <summary>
3786
- Initializes a new instance of the AABBGrid class
3787
- </summary>
3788
- <param name="min">Minimum position of the grid</param>
3789
- <param name="max">Maximum position of the grid</param>
3790
- <param name="cellSize">The desired cell size</param>
3791
- </member>
3792
- <member name="M:GeometryViewer.Model.SpatialStructures.AABBGrid.ForEachCell(GeometryViewer.Model.SpatialStructures.AABB,System.Action{SIMULTAN.Util.IntIndex3D})">
3793
- <summary>
3794
- Iterates over each cell a AABB touches and executes an action with this index
3795
- </summary>
3796
- <param name="item">The aabb</param>
3797
- <param name="action">The action</param>
3798
- </member>
3799
- <member name="M:GeometryViewer.Model.SpatialStructures.AABBGrid.ForCell(System.Windows.Media.Media3D.Point3D,System.Action{SIMULTAN.Util.IntIndex3D})">
3800
- <summary>
3801
- Executes an action for the cell the position is in
3802
- </summary>
3803
- <param name="position">The position</param>
3804
- <param name="action">The action</param>
3805
- </member>
3806
- <member name="M:GeometryViewer.Model.SpatialStructures.AABBGrid.Add(GeometryViewer.Model.SpatialStructures.AABB)">
3807
- <summary>
3808
- Adds an AABB to the grid
3809
- </summary>
3810
- <param name="item"></param>
3811
- </member>
3812
- <member name="M:GeometryViewer.Model.SpatialStructures.AABBGrid.AddRange(System.Collections.Generic.IEnumerable{GeometryViewer.Model.SpatialStructures.AABB})">
3813
- <summary>
3814
- Adds a number of AABBs to the grid
3815
- </summary>
3816
- <param name="items"></param>
3817
- </member>
3818
- <member name="M:GeometryViewer.Model.SpatialStructures.AABBGrid.Remove(GeometryViewer.Model.SpatialStructures.AABB)">
3819
- <summary>
3820
- Removes an AABB from the grid
3821
- </summary>
3822
- <param name="item"></param>
3823
- </member>
3824
- <member name="P:GeometryViewer.Model.SpatialStructures.AABBGrid.Item(SIMULTAN.Util.IntIndex3D)">
3825
- <summary>
3826
- Returns a list of all AABB which could contain a given point.
3827
- </summary>
3828
- <param name="index"></param>
3829
- <returns></returns>
3830
- </member>
3831
- <member name="T:GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo">
3832
- <summary>
3833
- Provides information about the ongoing background operation
3834
- </summary>
3835
- </member>
3836
- <member name="P:GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo.CancellationPending">
3837
- <summary>
3838
- True when the user wants to cancel the operation. In this case the algorithm should stop as soon as possible
3839
- </summary>
3840
- </member>
3841
- <member name="P:GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo.Cancel">
3842
- <summary>
3843
- Stores whether this operation was canceled. Set this to true while responding to CancellationPending
3844
- </summary>
3845
- </member>
3846
- <member name="M:GeometryViewer.Util.BackgroundWork.IBackgroundAlgorithmInfo.ReportProgress(System.Int32)">
3847
- <summary>
3848
- Notifies the main thread about progress
3849
- </summary>
3850
- <param name="percent">Progress in Percent (0-100)</param>
3851
- </member>
3852
- <member name="T:GeometryViewer.Util.BackgroundWork.BackgroundAlgorithmInfo">
3853
- <summary>
3854
- Info for a background worker called from inside the DoWork event
3855
- Implementation of the IBackgroundAlgorithmInfo interface
3856
- </summary>
3857
- </member>
3858
- <member name="P:GeometryViewer.Util.BackgroundWork.BackgroundAlgorithmInfo.CancellationPending">
3859
- <inheritdoc/>
3860
- </member>
3861
- <member name="P:GeometryViewer.Util.BackgroundWork.BackgroundAlgorithmInfo.Cancel">
3862
- <inheritdoc/>
3863
- </member>
3864
- <member name="M:GeometryViewer.Util.BackgroundWork.BackgroundAlgorithmInfo.#ctor(System.ComponentModel.BackgroundWorker,System.ComponentModel.DoWorkEventArgs,System.Double,System.Double,System.String)">
3865
- <summary>
3866
- Initializes a new instance of the BackgroundAlgorithmInfo class
3867
- </summary>
3868
- <param name="worker">The worker whos executing the operation</param>
3869
- <param name="args">The EventArgs from the background workers DoWork event</param>
3870
- <param name="percentStart">Start progress for this part of the algorithm (0-100)</param>
3871
- <param name="percentEnd">Final progress for this part of the algorithm</param>
3872
- <param name="userText">The text displayed while this algorithm is working</param>
3873
- </member>
3874
- <member name="M:GeometryViewer.Util.BackgroundWork.BackgroundAlgorithmInfo.ReportProgress(System.Int32)">
3875
- <inheritdoc/>
3876
- </member>
3877
- <member name="T:GeometryViewer.Util.BackgroundWork.EmptyBackgroundAlgorithmInfo">
3878
- <summary>
3879
- Dummy implementation that does nothing
3880
- </summary>
3881
- </member>
3882
- <member name="P:GeometryViewer.Util.BackgroundWork.EmptyBackgroundAlgorithmInfo.CancellationPending">
3883
- <inheritdoc/>
3884
- </member>
3885
- <member name="P:GeometryViewer.Util.BackgroundWork.EmptyBackgroundAlgorithmInfo.Cancel">
3886
- <inheritdoc/>
3887
- </member>
3888
- <member name="M:GeometryViewer.Util.BackgroundWork.EmptyBackgroundAlgorithmInfo.ReportProgress(System.Int32)">
3889
- <inheritdoc/>
3890
- </member>
3891
- <member name="T:GeometryViewer.Util.BackgroundWork.BackgroundUserState">
3892
- <summary>
3893
- Stores additional data for the progress of background worker
3894
- </summary>
3895
- </member>
3896
- <member name="P:GeometryViewer.Util.BackgroundWork.BackgroundUserState.Text">
3897
- <summary>
3898
- Usertext displayed next to the title in the ui. Use this to describe which part of your algorithm is currently running.
3899
- </summary>
3900
- </member>
3901
- <member name="M:GeometryViewer.Util.BackgroundWork.BackgroundUserState.#ctor(System.String)">
3902
- <summary>
3903
- Initializes a new instance of the BackgroundUserState class
3904
- </summary>
3905
- <param name="text">The text</param>
3906
- </member>
3907
- <member name="T:GeometryViewer.Util.ClipPlane">
3908
- <summary>
3909
- Describes a plane in Hessian normal form (ax + by + cz + d = 0) to clip against
3910
- </summary>
3911
- </member>
3912
- <member name="P:GeometryViewer.Util.ClipPlane.Normal">
3913
- <summary>
3914
- Normal of the plane (a, b, c)
3915
- </summary>
3916
- </member>
3917
- <member name="P:GeometryViewer.Util.ClipPlane.Distance">
3918
- <summary>
3919
- Distance of the plane (d) from the origin (along the plane normal)
3920
- </summary>
3921
- </member>
3922
- <member name="M:GeometryViewer.Util.ClipPlane.#ctor(System.Windows.Media.Media3D.Vector3D,System.Double)">
3923
- <summary>
3924
- Initializes a new instance of the ClipPlane class from a given normal and distance
3925
- </summary>
3926
- <param name="normal">Normal of the plane</param>
3927
- <param name="distance">Distance from the origin along the normal</param>
3928
- </member>
3929
- <member name="M:GeometryViewer.Util.ClipPlane.#ctor(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Vector3D)">
3930
- <summary>
3931
- Initializes a new instance of the ClipPlane class from a given normal and point on the plane
3932
- </summary>
3933
- <param name="pointOnPlane">Point on the plane</param>
3934
- <param name="normal">Normal of the plane</param>
3935
- </member>
3936
- <member name="M:GeometryViewer.Util.ClipPlane.#ctor(GeometryViewer.Util.ClipPlane)">
3937
- <summary>
3938
- Copies the parameters of another clip plane
3939
- </summary>
3940
- <param name="plane">ClipPlane to copy</param>
3941
- </member>
3942
- <member name="M:GeometryViewer.Util.ClipPlane.IsInside(System.Windows.Media.Media3D.Point3D)">
3943
- <summary>
3944
- Checks whether the given point lies inside (i.e. behind the plane according to its normal)
3945
- Point on the plane are considered as inside
3946
- </summary>
3947
- <param name="p">Point to test</param>
3948
- <returns>Returns true, if the point lies inside (behind the plane)</returns>
3949
- </member>
3950
- <member name="M:GeometryViewer.Util.ClipPlane.IntersectLine(System.Windows.Media.Media3D.Point3D,System.Windows.Media.Media3D.Point3D)">
3951
- <summary>
3952
- Intersects the line given as (p1- p0) with this clip plane
3953
- </summary>
3954
- <param name="p0">Start point of the line</param>
3955
- <param name="p1">End point of the line</param>
3956
- <returns>
3957
- The intersection point and the distance t between start point and intersection point
3958
- If t is negative, the intersection point was not found
3959
- </returns>
3960
- </member>
3961
- <member name="T:GeometryViewer.Util.Frustum">
3962
- <summary>
3963
- Describes a 3D frustum enclosed by a list of clip planes
3964
- </summary>
3965
- </member>
3966
- <member name="P:GeometryViewer.Util.Frustum.Planes">
3967
- <summary>
3968
- Clip planes defining the inside of the frustum as the intersection of inside half spaces
3969
- </summary>
3970
- </member>
3971
- <member name="M:GeometryViewer.Util.Frustum.#ctor(System.Collections.Generic.List{GeometryViewer.Util.ClipPlane})">
3972
- <summary>
3973
- Initializes a new instance of this class with a set of clip planes
3974
- </summary>
3975
- <param name="clipPlanes"></param>
3976
- </member>
3977
- <member name="M:GeometryViewer.Util.Frustum.IsPointInside(System.Windows.Media.Media3D.Point3D)">
3978
- <summary>
3979
- Checks whether a given point is contained in the frustum (i.e. the inside volume defined by the clip planes)
3980
- </summary>
3981
- <param name="p">Point to check</param>
3982
- <returns>True, if point is contained in the frustum volume</returns>
3983
- </member>
3984
- <member name="M:GeometryViewer.Util.Frustum.IsNgonInside(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D},System.Boolean)">
3985
- <summary>
3986
- Tests if a polygon is entirely contained in the frustum.
3987
- The polygon is clipped against the frustum first before testing.
3988
- </summary>
3989
- <param name="ngon">Polygon to test</param>
3990
- <param name="allowPartially">If true, at least 1 vertex of the polygon has to remain in the frustum after clipping</param>
3991
- <returns>True, if the polygon is inside the frustum</returns>
3992
- </member>
3993
- <member name="M:GeometryViewer.Util.Frustum.Clip(System.Collections.Generic.List{System.Windows.Media.Media3D.Point3D})">
3994
- <summary>
3995
- Clips the given polygon against all clip planes (performs Sutherland-Hodgman clipping)
3996
- </summary>
3997
- <param name="ngon">List of polygon vertices</param>
3998
- <returns>List of vertices resulting after clipping</returns>
3999
- </member>
4000
- <member name="T:GeometryViewer.Util.Matrix3DExtensions">
4001
- <summary>
4002
- Provides extension methods for the Matrix3D class
4003
- </summary>
4004
- </member>
4005
- <member name="T:GeometryViewer.Util.QuaternionExtensions">
4006
- <summary>
4007
- Common extensions or static methods for quaternions
4008
- </summary>
4009
- </member>
4010
- <member name="M:GeometryViewer.Util.QuaternionExtensions.CreateFromYawPitchRoll(System.Double,System.Double,System.Double)">
4011
- <summary>
4012
- Creates a quaternion from Euler angles (in deg)
4013
- https://en.wikipedia.org/wiki/Conversion_between_quaternions_and_Euler_angles
4014
- </summary>
4015
- <param name="yaw">Rotation around z-axis</param>
4016
- <param name="pitch">Rotation around y-axis</param>
4017
- <param name="roll">Rotation around x-axis</param>
4018
- <returns>Quaternion from Euler angles</returns>
4019
- </member>
4020
- <member name="M:GeometryViewer.Util.QuaternionExtensions.CreateFromYawPitchRoll(System.Windows.Media.Media3D.Vector3D)">
4021
- <summary>
4022
- Creates a quaternion from Euler angles (in deg), where x is roll, y is pitch and z is yaw
4023
- </summary>
4024
- <param name="eulerAngles">Euler angles (in deg)</param>
4025
- <returns>Quaternion from Euler angles</returns>
4026
- </member>
4027
- <member name="M:GeometryViewer.Util.QuaternionExtensions.ToEulerAngles(System.Windows.Media.Media3D.Quaternion)">
4028
- <summary>
4029
- Converts this quaternion to Euler angles (in deg)
4030
- https://en.wikipedia.org/wiki/Conversion_between_quaternions_and_Euler_angles
4031
- </summary>
4032
- <param name="q"></param>
4033
- <returns></returns>
4034
- </member>
4035
- <member name="T:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem">
4036
- <summary>
4037
- A group undo item that handles it's children in a batch-operation
4038
- </summary>
4039
- </member>
4040
- <member name="P:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem.Items">
4041
- <summary>
4042
- Returns a list of contained undo items. Do not change this after registering to the undo manager
4043
- </summary>
4044
- </member>
4045
- <member name="P:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem.Model">
4046
- <summary>
4047
- Stores the GeometryModel this undoitem operates on
4048
- </summary>
4049
- </member>
4050
- <member name="M:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem.#ctor(GeometryViewer.Model.Geometry.GeometryModelData)">
4051
- <summary>
4052
- Initializes a new instance of the GroupUndoItem class
4053
- </summary>
4054
- </member>
4055
- <member name="M:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem.#ctor(GeometryViewer.Model.Geometry.GeometryModelData,System.Collections.Generic.List{SIMULTAN.Util.UndoRedo.IUndoItem})">
4056
- <summary>
4057
- Initializes a new instance of the GroupUndoItem class
4058
- </summary>
4059
- <param name="model">The model in which the batch operation is started</param>
4060
- <param name="items">The list of IUndoItems</param>
4061
- </member>
4062
- <member name="M:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem.Execute">
4063
- <inheritdoc/>
4064
- </member>
4065
- <member name="M:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem.Redo">
4066
- <inheritdoc/>
4067
- </member>
4068
- <member name="M:GeometryViewer.Util.UndoRedo.BatchOperationGroupUndoItem.Undo">
4069
- <inheritdoc/>
4070
- </member>
4071
- <member name="T:GeometryViewer.Util.UndoRedo.CommunicationUndoItem">
4072
- <summary>
4073
- Undo item that shows/hides communication messages
4074
- </summary>
4075
- </member>
4076
- <member name="M:GeometryViewer.Util.UndoRedo.CommunicationUndoItem.#ctor(GeometryViewer.Util.Communication.CommunicationMessage)">
4077
- <summary>
4078
- Initializes a new instance of the CommunicationUndoItem class
4079
- </summary>
4080
- <param name="message">The message that should be hidden or shown. Make sure to display the message in first place.</param>
4081
- </member>
4082
- <member name="M:GeometryViewer.Util.UndoRedo.CommunicationUndoItem.Execute">
4083
- <inheritdoc/>
4084
- </member>
4085
- <member name="M:GeometryViewer.Util.UndoRedo.CommunicationUndoItem.Redo">
4086
- <inheritdoc/>
4087
- </member>
4088
- <member name="M:GeometryViewer.Util.UndoRedo.CommunicationUndoItem.Undo">
4089
- <inheritdoc/>
4090
- </member>
4091
- <member name="T:GeometryViewer.Util.UndoRedo.GeometryAddUndoItem">
4092
- <summary>
4093
- UndoItem for undoing addition of geometries (for example, during connect or extrude)
4094
- The geoemtries have to be attached to the model already. They are NOT touched by Execute.
4095
- </summary>
4096
- </member>
4097
- <member name="P:GeometryViewer.Util.UndoRedo.GeometryAddUndoItem.CreatedGeometry">
4098
- <summary>
4099
- Returns the created geometry that is undone/redone by this item
4100
- </summary>
4101
- </member>
4102
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryAddUndoItem.#ctor(System.Collections.Generic.List{GeometryViewer.Model.Geometry.BaseGeometry},GeometryViewer.Model.Geometry.GeometryModelData)">
4103
- <summary>
4104
- Initializes a new instance of the GeometryAddUndoItem class
4105
- </summary>
4106
- <param name="createdGeometry">The geomtries created by this instance. The geoemtries have to be attached to the model.</param>
4107
- <param name="model">The model on which add and remove should operate</param>
4108
- </member>
4109
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryAddUndoItem.Execute">
4110
- <inheritdoc/>
4111
- </member>
4112
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryAddUndoItem.Redo">
4113
- <inheritdoc/>
4114
- </member>
4115
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryAddUndoItem.Undo">
4116
- <inheritdoc/>
4117
- </member>
4118
- <member name="T:GeometryViewer.Util.UndoRedo.GeometryRemoveUndoItem">
4119
- <summary>
4120
- Removes previousely generated geometry.
4121
- </summary>
4122
- </member>
4123
- <member name="P:GeometryViewer.Util.UndoRedo.GeometryRemoveUndoItem.DeletedGeometry">
4124
- <summary>
4125
- Returns the list of deleted geometries
4126
- </summary>
4127
- </member>
4128
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryRemoveUndoItem.#ctor(System.Collections.Generic.List{GeometryViewer.Model.Geometry.BaseGeometry},GeometryViewer.Model.Geometry.GeometryModelData)">
4129
- <summary>
4130
- Initializes a new instance of the GeometryRemoveUndoItem class
4131
- </summary>
4132
- <param name="deletedGeometry">The geomtries deleted by this instance. The geoemtries have to be removed from the model before attaching them here.</param>
4133
- <param name="model">The model on which add and remove should operate</param>
4134
- </member>
4135
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryRemoveUndoItem.Execute">
4136
- <inheritdoc/>
4137
- </member>
4138
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryRemoveUndoItem.Redo">
4139
- <inheritdoc/>
4140
- </member>
4141
- <member name="M:GeometryViewer.Util.UndoRedo.GeometryRemoveUndoItem.Undo">
4142
- <inheritdoc/>
4143
- </member>
4144
- <member name="T:GeometryViewer.Util.UndoRedo.HoleRemoveUndoItem">
4145
- <summary>
4146
- Undo Item for removing a hole from a face
4147
- </summary>
4148
- </member>
4149
- <member name="M:GeometryViewer.Util.UndoRedo.HoleRemoveUndoItem.#ctor(GeometryViewer.Model.Geometry.Face,GeometryViewer.Model.Geometry.EdgeLoop)">
4150
- <summary>
4151
- Initializes a new instance of the HoleRemoveUndoItem class. The hole has to be removed before creating the undo model
4152
- </summary>
4153
- <param name="face">The face from which the hole was removed</param>
4154
- <param name="hole">The removed hole</param>
4155
- </member>
4156
- <member name="M:GeometryViewer.Util.UndoRedo.HoleRemoveUndoItem.Execute">
4157
- <inheritdoc/>
4158
- </member>
4159
- <member name="M:GeometryViewer.Util.UndoRedo.HoleRemoveUndoItem.Redo">
4160
- <inheritdoc/>
4161
- </member>
4162
- <member name="M:GeometryViewer.Util.UndoRedo.HoleRemoveUndoItem.Undo">
4163
- <inheritdoc/>
4164
- </member>
4165
- <member name="T:GeometryViewer.Util.UndoRedo.LayerReorderUndoItem">
4166
- <summary>
4167
- UndoItem for moving a layer to a new parent
4168
- </summary>
4169
- </member>
4170
- <member name="P:GeometryViewer.Util.UndoRedo.LayerReorderUndoItem.OldPos">
4171
- <summary>
4172
- The Old Position of the UndoItem. Used to correct sorting when multiple of these are
4173
- used in a GroupItem.
4174
- </summary>
4175
- </member>
4176
- <member name="M:GeometryViewer.Util.UndoRedo.LayerReorderUndoItem.#ctor(GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Layer,System.Int32,GeometryViewer.Model.Geometry.Layer,System.Int32)">
4177
- <summary>
4178
- Initializes a new instance of the LayerReorderUndoItem class. The class handles reordering layers.
4179
- If used in a GroupUndoItem, soft descending by the OldPos property for correct undo.
4180
- </summary>
4181
- <param name="layer">The layer</param>
4182
- <param name="oldParent">The old parent (can be null when directly attached to a GeometryModel)</param>
4183
- <param name="oldPos">The old position (index) of the item in the original list.</param>
4184
- <param name="newParent">The new parent (can be null when directly attached to a GeometryModel)</param>
4185
- <param name="newPos">The new position (index) of the layer. Inserts at this index.</param>
4186
- </member>
4187
- <member name="M:GeometryViewer.Util.UndoRedo.LayerReorderUndoItem.Execute">
4188
- <inheritdoc/>
4189
- </member>
4190
- <member name="M:GeometryViewer.Util.UndoRedo.LayerReorderUndoItem.Redo">
4191
- <inheritdoc/>
4192
- </member>
4193
- <member name="M:GeometryViewer.Util.UndoRedo.LayerReorderUndoItem.Undo">
4194
- <inheritdoc/>
4195
- </member>
4196
- <member name="T:GeometryViewer.Util.UndoRedo.LayerMoveUndoItem">
4197
- <summary>
4198
- UndoItem for moving a layer to a new parent
4199
- </summary>
4200
- </member>
4201
- <member name="M:GeometryViewer.Util.UndoRedo.LayerMoveUndoItem.#ctor(GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Layer,GeometryViewer.Model.Geometry.Layer)">
4202
- <summary>
4203
- Initializes a new instance of the LayerMoveUndoItem class. The class handles the initial move
4204
- </summary>
4205
- <param name="layer">The layer</param>
4206
- <param name="oldParent">The old parent (can be null when directly attached to a GeometryModel)</param>
4207
- <param name="newParent">The new parent (can be null when directly attached to a GeometryModel)</param>
4208
- </member>
4209
- <member name="M:GeometryViewer.Util.UndoRedo.LayerMoveUndoItem.Execute">
4210
- <inheritdoc/>
4211
- </member>
4212
- <member name="M:GeometryViewer.Util.UndoRedo.LayerMoveUndoItem.Redo">
4213
- <inheritdoc/>
4214
- </member>
4215
- <member name="M:GeometryViewer.Util.UndoRedo.LayerMoveUndoItem.Undo">
4216
- <inheritdoc/>
4217
- </member>
4218
- <member name="T:GeometryViewer.Util.UndoRedo.ModelCompleteStateUndoItem">
4219
- <summary>
4220
- Undos a model operation by replacing the geometry in the model with an old state.
4221
- </summary>
4222
- Usage: Clone the model before the operation, perform the operation and pass the old state to the undo item
4223
- </member>
4224
- <member name="M:GeometryViewer.Util.UndoRedo.ModelCompleteStateUndoItem.#ctor(GeometryViewer.Model.Geometry.GeometryModelData,GeometryViewer.Model.GeometryModel)">
4225
- <summary>
4226
- Initializes a new instance of the ModelCompleteStateUndoItem class
4227
- </summary>
4228
- <param name="newGeometry">The new geometry data</param>
4229
- <param name="targetModel">An old geometry data</param>
4230
- </member>
4231
- <member name="M:GeometryViewer.Util.UndoRedo.ModelCompleteStateUndoItem.Execute">
4232
- <inheritdoc/>
4233
- </member>
4234
- <member name="M:GeometryViewer.Util.UndoRedo.ModelCompleteStateUndoItem.Redo">
4235
- <inheritdoc/>
4236
- </member>
4237
- <member name="M:GeometryViewer.Util.UndoRedo.ModelCompleteStateUndoItem.Undo">
4238
- <inheritdoc/>
4239
- </member>
4240
- <member name="T:GeometryViewer.Util.Communication.CommunicationAction">
4241
- <summary>
4242
- Stores a user-clickable action for a CommunicationMessage
4243
- </summary>
4244
- </member>
4245
- <member name="P:GeometryViewer.Util.Communication.CommunicationAction.Text">
4246
- <summary>
4247
- Stores the display text of this Option
4248
- </summary>
4249
- </member>
4250
- <member name="P:GeometryViewer.Util.Communication.CommunicationAction.Command">
4251
- <summary>
4252
- Stores the command that is called when the user selects this option
4253
- </summary>
4254
- </member>
4255
- <member name="P:GeometryViewer.Util.Communication.CommunicationAction.Message">
4256
- <summary>
4257
- Gets or sets the Message this option belongs to (set automatically by the CommunicationMessage class)
4258
- </summary>
4259
- </member>
4260
- <member name="P:GeometryViewer.Util.Communication.CommunicationAction.IsSelected">
4261
- <summary>
4262
- Gets or sets whether this is the selected option
4263
- </summary>
4264
- </member>
4265
- <member name="E:GeometryViewer.Util.Communication.CommunicationAction.PropertyChanged">
4266
- <inheritdoc/>
4267
- </member>
4268
- <member name="M:GeometryViewer.Util.Communication.CommunicationAction.#ctor(System.String,System.Action,System.Boolean)">
4269
- <summary>
4270
- Initializes a new instance of the CommunicationAction class
4271
- </summary>
4272
- <param name="text">The display text</param>
4273
- <param name="action">An action that is executed when the user selects this action</param>
4274
- <param name="isSelected">True when the option is selected, False otherwiseo</param>
4275
- </member>
4276
- <member name="M:GeometryViewer.Util.Communication.CommunicationAction.#ctor(System.String,System.Action{GeometryViewer.Util.Communication.CommunicationAction},System.Boolean)">
4277
- <summary>
4278
- Initializes a new instance of the CommunicationAction class
4279
- </summary>
4280
- <param name="text">The display text</param>
4281
- <param name="action">A list of action that are executed when the user selects this action</param>
4282
- <param name="isSelected">True when the option is selected, False otherwiseo</param>
4283
- </member>
4284
- <member name="T:GeometryViewer.Util.Communication.CommunicationMessage">
4285
- <summary>
4286
- Stores a message that is sent to the user
4287
- </summary>
4288
- </member>
4289
- <member name="P:GeometryViewer.Util.Communication.CommunicationMessage.Text">
4290
- <summary>
4291
- Returns the display text
4292
- </summary>
4293
- </member>
4294
- <member name="P:GeometryViewer.Util.Communication.CommunicationMessage.MessageType">
4295
- <summary>
4296
- Returns the type of the message (determines only color at the moment)
4297
- </summary>
4298
- </member>
4299
- <member name="P:GeometryViewer.Util.Communication.CommunicationMessage.Actions">
4300
- <summary>
4301
- Stores a list of actions (can be empty)
4302
- </summary>
4303
- </member>
4304
- <member name="P:GeometryViewer.Util.Communication.CommunicationMessage.VisibilityDuration">
4305
- <summary>
4306
- Stores how long the message will be visible to the user
4307
- </summary>
4308
- </member>
4309
- <member name="M:GeometryViewer.Util.Communication.CommunicationMessage.#ctor(System.String,GeometryViewer.Util.Communication.MessageType,System.Nullable{System.TimeSpan},System.Collections.Generic.IEnumerable{GeometryViewer.Util.Communication.CommunicationAction})">
4310
- <summary>
4311
- Initializes a new instance of the CommunicationMessage class
4312
- </summary>
4313
- <param name="text">Display text</param>
4314
- <param name="type">Type of the message</param>
4315
- <param name="visibilityDuration">Time the message is displayed</param>
4316
- <param name="actions">List of actions that the user can choose from</param>
4317
- </member>
4318
- <member name="T:GeometryViewer.Util.Communication.MessageType">
4319
- <summary>
4320
- Type of messages
4321
- </summary>
4322
- </member>
4323
- <member name="F:GeometryViewer.Util.Communication.MessageType.Success">
4324
- <summary>
4325
- A success message
4326
- </summary>
4327
- </member>
4328
- <member name="F:GeometryViewer.Util.Communication.MessageType.Message">
4329
- <summary>
4330
- A normal message
4331
- </summary>
4332
- </member>
4333
- <member name="F:GeometryViewer.Util.Communication.MessageType.Warning">
4334
- <summary>
4335
- A warning
4336
- </summary>
4337
- </member>
4338
- <member name="F:GeometryViewer.Util.Communication.MessageType.Error">
4339
- <summary>
4340
- A error
4341
- </summary>
4342
- </member>
4343
- <member name="T:GeometryViewer.Util.Communication.CommunicationProvider">
4344
- <summary>
4345
- Provides methods to communication with the user
4346
- This class is a Singleton
4347
- </summary>
4348
- </member>
4349
- <member name="P:GeometryViewer.Util.Communication.CommunicationProvider.Instance">
4350
- <summary>
4351
- Returns the current instance
4352
- </summary>
4353
- </member>
4354
- <member name="F:GeometryViewer.Util.Communication.CommunicationProvider.dispatcher">
4355
- <summary>
4356
- Dispatcher for displaying/modifying communication messages
4357
- </summary>
4358
- </member>
4359
- <member name="P:GeometryViewer.Util.Communication.CommunicationProvider.Messages">
4360
- <summary>
4361
- Returns a collection containing all messages
4362
- </summary>
4363
- </member>
4364
- <member name="M:GeometryViewer.Util.Communication.CommunicationProvider.ShowMessage(System.String,GeometryViewer.Util.Communication.MessageType)">
4365
- <summary>
4366
- Shows a message to the user
4367
- </summary>
4368
- <param name="message">The message text</param>
4369
- <param name="type">Type of message</param>
4370
- </member>
4371
- <member name="M:GeometryViewer.Util.Communication.CommunicationProvider.ShowMessage(System.String,GeometryViewer.Util.Communication.MessageType,System.Collections.Generic.IEnumerable{GeometryViewer.Util.Communication.CommunicationAction})">
4372
- <summary>
4373
- Shows a message to the user
4374
- </summary>
4375
- <param name="message">The message text</param>
4376
- <param name="type">Type of message</param>
4377
- <param name="actions">List of actions the user can choose from</param>
4378
- </member>
4379
- <member name="M:GeometryViewer.Util.Communication.CommunicationProvider.ShowMessage(GeometryViewer.Util.Communication.CommunicationMessage)">
4380
- <summary>
4381
- Shows a message to the user
4382
- </summary>
4383
- <param name="message">The communication massage that should be displayed</param>
4384
- </member>
4385
- <member name="M:GeometryViewer.Util.Communication.CommunicationProvider.HideMessage(GeometryViewer.Util.Communication.CommunicationMessage)">
4386
- <summary>
4387
- Hides a message
4388
- </summary>
4389
- <param name="message">The message that should be hidden</param>
4390
- </member>
4391
- <member name="T:GeometryViewer.Util.PointVectorExtensions">
4392
- <summary>
4393
- Usefull extensions for the Point3D class
4394
- </summary>
4395
- </member>
4396
- <member name="M:GeometryViewer.Util.PointVectorExtensions.Multiply(System.Windows.Media.Media3D.Point3D,System.Double)">
4397
- <summary>
4398
- Multiplies the point with a scalar value
4399
- </summary>
4400
- <param name="p">The point</param>
4401
- <param name="d">The scalar</param>
4402
- <returns>The multiplied point</returns>
4403
- </member>
4404
- <member name="M:GeometryViewer.Util.PointVectorExtensions.Divide(System.Windows.Media.Media3D.Point3D,System.Double)">
4405
- <summary>
4406
- Divides the point by a scalar value
4407
- </summary>
4408
- <param name="p">The point</param>
4409
- <param name="d">The scalar</param>
4410
- <returns>The divided point</returns>
4411
- </member>
4412
- <member name="M:GeometryViewer.Util.PointVectorExtensions.XY(System.Windows.Media.Media3D.Point3D)">
4413
- <summary>
4414
- Returns a point containing only the X and Y coordinate
4415
- </summary>
4416
- <param name="p">Original point</param>
4417
- <returns>A point containing only X and Y coordinate</returns>
4418
- </member>
4419
- <member name="M:GeometryViewer.Util.PointVectorExtensions.XY(System.Windows.Media.Media3D.Vector3D)">
4420
- <summary>
4421
- Returns a vector containing only the X and Y coordinate
4422
- </summary>
4423
- <param name="v">Original vector</param>
4424
- <returns>A vector containing only X and Y coordinate</returns>
4425
- </member>
4426
- <member name="M:GeometryViewer.Util.PointVectorExtensions.Get(System.Windows.Media.Media3D.Vector3D,System.Int32)">
4427
- <summary>
4428
- Returns a specific dimension of a Vector3D
4429
- </summary>
4430
- <param name="v">The Vector3D</param>
4431
- <param name="idx">Index of the dimension: X: 0, Y: 1, Z: 2</param>
4432
- <returns></returns>
4433
- </member>
4434
- <member name="M:GeometryViewer.Util.PointVectorExtensions.Get(System.Windows.Media.Media3D.Point3D,System.Int32)">
4435
- <summary>
4436
- Returns a specific dimension of a Point3D
4437
- </summary>
4438
- <param name="v">The Point3D</param>
4439
- <param name="idx">Index of the dimension: X: 0, Y: 1, Z: 2</param>
4440
- <returns></returns>
4441
- </member>
4442
- </members>
4443
- </doc>