com.wallstop-studios.unity-helpers 2.0.0-rc57 → 2.0.0-rc58

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (292) hide show
  1. package/.config/dotnet-tools.json +9 -9
  2. package/.editorconfig +184 -184
  3. package/.gitattributes +63 -63
  4. package/.github/workflows/npm-publish.yml +66 -66
  5. package/.pre-commit-config.yaml +21 -21
  6. package/Editor/AnimationCopier.cs +181 -181
  7. package/Editor/AnimationCopier.cs.meta +2 -2
  8. package/Editor/AnimationCreator.cs +253 -253
  9. package/Editor/AnimationCreator.cs.meta +11 -11
  10. package/Editor/AnimationEventEditor.cs +887 -887
  11. package/Editor/AnimatorControllerCopier.cs +162 -162
  12. package/Editor/AnimatorControllerCopier.cs.meta +2 -2
  13. package/Editor/CustomEditors/MatchColliderToSpriteEditor.cs +34 -34
  14. package/Editor/CustomEditors/MatchColliderToSpriteEditor.cs.meta +2 -2
  15. package/Editor/CustomEditors.meta +2 -2
  16. package/Editor/FitTextureSizeWizard.cs +147 -147
  17. package/Editor/FitTextureSizeWizard.cs.meta +2 -2
  18. package/Editor/PrefabCheckWizard.cs +170 -170
  19. package/Editor/PrefabCheckWizard.cs.meta +11 -11
  20. package/Editor/SpriteSettingsApplier.cs +272 -272
  21. package/Editor/SpriteSettingsApplier.cs.meta +2 -2
  22. package/Editor/StringInListeDrawer.cs +56 -56
  23. package/Editor/TextureResizerWizard.cs +181 -181
  24. package/Editor/TextureResizerWizard.cs.meta +2 -2
  25. package/Editor/TextureSettingsApplier.cs +178 -178
  26. package/Editor/TextureSettingsApplier.cs.meta +2 -2
  27. package/Editor/Utils/DxReadOnlyPropertyDrawer.cs +26 -26
  28. package/Editor/Utils/DxReadOnlyPropertyDrawer.cs.meta +11 -11
  29. package/Editor/Utils/EditorUtilities.cs +22 -22
  30. package/Editor/Utils/EditorUtilities.cs.meta +11 -11
  31. package/Editor/Utils.meta +8 -8
  32. package/Editor/WShowIfPropertyDrawer.cs +63 -63
  33. package/Editor/WallstopStudios.UnityHelpers.Editor.asmdef +17 -17
  34. package/Editor/WallstopStudios.UnityHelpers.Editor.asmdef.meta +7 -7
  35. package/LICENSE +21 -21
  36. package/LICENSE.md +6 -6
  37. package/LICENSE.meta +7 -7
  38. package/README.md +177 -177
  39. package/Runtime/Binaries/Microsoft.Bcl.AsyncInterfaces.dll.meta +33 -33
  40. package/Runtime/Binaries/Microsoft.Bcl.AsyncInterfaces.xml +223 -223
  41. package/Runtime/Binaries/Microsoft.Bcl.AsyncInterfaces.xml.meta +7 -7
  42. package/Runtime/Binaries/System.Text.Encodings.Web.dll.meta +33 -33
  43. package/Runtime/Binaries/System.Text.Encodings.Web.xml +935 -935
  44. package/Runtime/Binaries/System.Text.Encodings.Web.xml.meta +7 -7
  45. package/Runtime/Binaries/System.Text.Json.dll.meta +33 -33
  46. package/Runtime/Binaries/System.Text.Json.xml +4829 -4829
  47. package/Runtime/Binaries/System.Text.Json.xml.meta +7 -7
  48. package/Runtime/Binaries.meta +8 -8
  49. package/Runtime/Core/Attributes/AnimationEventAttribute.cs +131 -131
  50. package/Runtime/Core/Attributes/ChildComponentAttribute.cs +209 -209
  51. package/Runtime/Core/Attributes/DxReadOnlyAttribute.cs +6 -6
  52. package/Runtime/Core/Attributes/KSerializableAttribute.cs +19 -19
  53. package/Runtime/Core/Attributes/NotNullAttribute.cs +32 -32
  54. package/Runtime/Core/Attributes/ParentComponent.cs +185 -185
  55. package/Runtime/Core/Attributes/RelationalComponentExtensions.cs +14 -14
  56. package/Runtime/Core/Attributes/SiblingComponentAttribute.cs +117 -117
  57. package/Runtime/Core/Attributes/SiblingComponentAttribute.cs.meta +11 -11
  58. package/Runtime/Core/Attributes/ValidateAssignmentAttribute.cs +101 -101
  59. package/Runtime/Core/Attributes/ValidateAssignmentAttribute.cs.meta +11 -11
  60. package/Runtime/Core/Attributes/WShowIfAttribute.cs +16 -16
  61. package/Runtime/Core/Attributes.meta +8 -8
  62. package/Runtime/Core/DataStructure/Adapters/FastVector2Int.cs +92 -92
  63. package/Runtime/Core/DataStructure/Adapters/FastVector3Int.cs +185 -185
  64. package/Runtime/Core/DataStructure/Adapters/KGuid.cs +305 -305
  65. package/Runtime/Core/DataStructure/Adapters/KVector2.cs +80 -80
  66. package/Runtime/Core/DataStructure/Circle.cs +50 -50
  67. package/Runtime/Core/DataStructure/CyclicBuffer.cs +153 -153
  68. package/Runtime/Core/DataStructure/ISpatialTree.cs +60 -60
  69. package/Runtime/Core/DataStructure/ISpatialTree.cs.meta +11 -11
  70. package/Runtime/Core/DataStructure/KDTree.cs +292 -292
  71. package/Runtime/Core/DataStructure/KDTree.cs.meta +11 -11
  72. package/Runtime/Core/DataStructure/QuadTree.cs +287 -287
  73. package/Runtime/Core/DataStructure/RTree.cs +346 -346
  74. package/Runtime/Core/DataStructure/RTree.cs.meta +11 -11
  75. package/Runtime/Core/DataStructure/StringWrapper.cs +91 -91
  76. package/Runtime/Core/DataStructure/TimedCache.cs +66 -66
  77. package/Runtime/Core/Extension/AnimatorExtensions.cs +25 -25
  78. package/Runtime/Core/Extension/AsyncOperationExtensions.cs +110 -110
  79. package/Runtime/Core/Extension/CircleExtensions.cs +25 -25
  80. package/Runtime/Core/Extension/ColorExtensions.cs +629 -629
  81. package/Runtime/Core/Extension/DictionaryExtensions.cs +279 -279
  82. package/Runtime/Core/Extension/DirectionExtensions.cs +213 -213
  83. package/Runtime/Core/Extension/EnumExtensions.cs +37 -37
  84. package/Runtime/Core/Extension/EnumExtensions.cs.meta +2 -2
  85. package/Runtime/Core/Extension/HashSetExtensions.cs +12 -12
  86. package/Runtime/Core/Extension/IEnumerableExtensions.cs +122 -122
  87. package/Runtime/Core/Extension/IListExtensions.cs +106 -106
  88. package/Runtime/Core/Extension/LoggingExtensions.cs +258 -258
  89. package/Runtime/Core/Extension/RandomExtensions.cs +109 -109
  90. package/Runtime/Core/Extension/SerializedPropertyExtensions.cs +157 -157
  91. package/Runtime/Core/Extension/StringExtensions.cs +151 -151
  92. package/Runtime/Core/Extension/UnityExtensions.cs +1608 -1608
  93. package/Runtime/Core/Helper/ArrayConverter.cs +39 -39
  94. package/Runtime/Core/Helper/ArrayConverter.cs.meta +2 -2
  95. package/Runtime/Core/Helper/AssignUtilities.cs +14 -14
  96. package/Runtime/Core/Helper/AssignUtilities.cs.meta +11 -11
  97. package/Runtime/Core/Helper/Enumerables.cs +17 -17
  98. package/Runtime/Core/Helper/FormattingHelpers.cs +32 -32
  99. package/Runtime/Core/Helper/Geometry.cs +43 -43
  100. package/Runtime/Core/Helper/Helpers.cs +722 -722
  101. package/Runtime/Core/Helper/Helpers.cs.meta +11 -11
  102. package/Runtime/Core/Helper/IterationHelpers.cs +32 -32
  103. package/Runtime/Core/Helper/IterationHelpers.cs.meta +11 -11
  104. package/Runtime/Core/Helper/LifetimeHelpers.cs +13 -13
  105. package/Runtime/Core/Helper/Objects.cs +769 -769
  106. package/Runtime/Core/Helper/Partials/LogHelpers.cs +13 -13
  107. package/Runtime/Core/Helper/Partials/LogHelpers.cs.meta +2 -2
  108. package/Runtime/Core/Helper/Partials/MathHelpers.cs +30 -30
  109. package/Runtime/Core/Helper/Partials/MathHelpers.cs.meta +2 -2
  110. package/Runtime/Core/Helper/Partials/ObjectHelpers.cs +388 -388
  111. package/Runtime/Core/Helper/Partials/ObjectHelpers.cs.meta +2 -2
  112. package/Runtime/Core/Helper/Partials/TransformHelpers.cs +189 -189
  113. package/Runtime/Core/Helper/Partials/TransformHelpers.cs.meta +2 -2
  114. package/Runtime/Core/Helper/Partials.meta +2 -2
  115. package/Runtime/Core/Helper/ReflectionHelpers.cs +452 -452
  116. package/Runtime/Core/Helper/ReflectionHelpers.cs.meta +2 -2
  117. package/Runtime/Core/Helper/SceneHelper.cs +209 -213
  118. package/Runtime/Core/Helper/SpriteHelpers.cs +41 -41
  119. package/Runtime/Core/Helper/SpriteHelpers.cs.meta +11 -11
  120. package/Runtime/Core/Helper/StringInList.cs +31 -31
  121. package/Runtime/Core/Helper/StringInList.cs.meta +11 -11
  122. package/Runtime/Core/Helper/UnityMainThreadDispatcher.cs +82 -82
  123. package/Runtime/Core/Helper/WallMath.cs +166 -166
  124. package/Runtime/Core/Math/Line.cs +55 -55
  125. package/Runtime/Core/Math/Parabola.cs +47 -47
  126. package/Runtime/Core/Math/PointPolygonCheck.cs +36 -36
  127. package/Runtime/Core/Math/PointPolygonCheck.cs.meta +11 -11
  128. package/Runtime/Core/Math/Range.cs +92 -92
  129. package/Runtime/Core/Math/XXHash.cs +310 -310
  130. package/Runtime/Core/Math/XXHash.cs.meta +11 -11
  131. package/Runtime/Core/Model/Direction.cs +43 -43
  132. package/Runtime/Core/OneOf/FastOneOf.cs +152 -152
  133. package/Runtime/Core/OneOf/None.cs +4 -4
  134. package/Runtime/Core/Random/AbstractRandom.cs +585 -585
  135. package/Runtime/Core/Random/DotNetRandom.cs +54 -54
  136. package/Runtime/Core/Random/DotNetRandom.cs.meta +2 -2
  137. package/Runtime/Core/Random/IRandom.cs +161 -161
  138. package/Runtime/Core/Random/LinearCongruentialGenerator.cs +49 -49
  139. package/Runtime/Core/Random/NativePcgRandom.cs +97 -97
  140. package/Runtime/Core/Random/PRNG.cs +7 -7
  141. package/Runtime/Core/Random/PRNG.cs.meta +2 -2
  142. package/Runtime/Core/Random/PcgRandom.cs +149 -149
  143. package/Runtime/Core/Random/PerlinNoise.cs +369 -369
  144. package/Runtime/Core/Random/PerlinNoise.cs.meta +2 -2
  145. package/Runtime/Core/Random/RandomState.cs +131 -131
  146. package/Runtime/Core/Random/RandomUtilities.cs +26 -26
  147. package/Runtime/Core/Random/RandomUtilities.cs.meta +11 -11
  148. package/Runtime/Core/Random/RomuDuo.cs +116 -116
  149. package/Runtime/Core/Random/RomuDuo.cs.meta +2 -2
  150. package/Runtime/Core/Random/SplitMix64.cs +94 -94
  151. package/Runtime/Core/Random/SplitMix64.cs.meta +2 -2
  152. package/Runtime/Core/Random/SquirrelRandom.cs +84 -84
  153. package/Runtime/Core/Random/SystemRandom.cs +162 -162
  154. package/Runtime/Core/Random/ThreadLocalRandom.cs +12 -12
  155. package/Runtime/Core/Random/UnityRandom.cs +57 -57
  156. package/Runtime/Core/Random/UnityRandom.cs.meta +11 -11
  157. package/Runtime/Core/Random/WyRandom.cs +121 -121
  158. package/Runtime/Core/Random/WyRandom.cs.meta +2 -2
  159. package/Runtime/Core/Random/XorShiftRandom.cs +52 -52
  160. package/Runtime/Core/Random/XorShiftRandom.cs.meta +11 -11
  161. package/Runtime/Core/Random/XorShiroRandom.cs +119 -119
  162. package/Runtime/Core/Random/XorShiroRandom.cs.meta +2 -2
  163. package/Runtime/Core/Serialization/JsonConverters/ColorConverter.cs +88 -88
  164. package/Runtime/Core/Serialization/JsonConverters/GameObjectConverter.cs +37 -37
  165. package/Runtime/Core/Serialization/JsonConverters/Matrix4x4Converter.cs +218 -218
  166. package/Runtime/Core/Serialization/JsonConverters/TypeConverter.cs +28 -28
  167. package/Runtime/Core/Serialization/JsonConverters/Vector2Converter.cs +74 -74
  168. package/Runtime/Core/Serialization/JsonConverters/Vector3Converter.cs +81 -81
  169. package/Runtime/Core/Serialization/JsonConverters/Vector4Converter.cs +88 -88
  170. package/Runtime/Core/Serialization/Serializer.cs +195 -195
  171. package/Runtime/Core/Threading/SingleThreadedThreadPool.cs +113 -113
  172. package/Runtime/Protobuf-Net/System.Buffers.dll.meta +33 -33
  173. package/Runtime/Protobuf-Net/System.Collections.Immutable.dll.meta +33 -33
  174. package/Runtime/Protobuf-Net/System.Collections.Immutable.xml +5379 -5379
  175. package/Runtime/Protobuf-Net/System.Collections.Immutable.xml.meta +7 -7
  176. package/Runtime/Protobuf-Net/System.Numerics.Vectors.dll.meta +33 -33
  177. package/Runtime/Protobuf-Net/System.Runtime.CompilerServices.Unsafe.dll.meta +33 -33
  178. package/Runtime/Protobuf-Net/System.Runtime.CompilerServices.Unsafe.xml +290 -290
  179. package/Runtime/Protobuf-Net/System.Runtime.CompilerServices.Unsafe.xml.meta +7 -7
  180. package/Runtime/Protobuf-Net/protobuf-net.Core.dll.meta +33 -33
  181. package/Runtime/Protobuf-Net/protobuf-net.dll.meta +33 -33
  182. package/Runtime/UI/LayeredImage.cs +364 -364
  183. package/Runtime/UI/LayeredImage.cs.meta +2 -2
  184. package/Runtime/UI.meta +2 -2
  185. package/Runtime/Utils/AnimationEventEqualityComparer.cs +161 -161
  186. package/Runtime/Utils/AnimatorEnumStateMachine.cs +88 -88
  187. package/Runtime/Utils/Buffers.cs +33 -33
  188. package/Runtime/Utils/CenterPointOffset.cs +30 -30
  189. package/Runtime/Utils/CenterPointOffset.cs.meta +2 -2
  190. package/Runtime/Utils/CircleLineRenderer.cs +134 -134
  191. package/Runtime/Utils/CoroutineHandler.cs +4 -4
  192. package/Runtime/Utils/CoroutineHandler.cs.meta +2 -2
  193. package/Runtime/Utils/DeferredDisposalResult.cs +23 -23
  194. package/Runtime/Utils/MatchColliderToSprite.cs +94 -94
  195. package/Runtime/Utils/MatchColliderToSprite.cs.meta +2 -2
  196. package/Runtime/Utils/Oscillator.cs +27 -27
  197. package/Runtime/Utils/RuntimeSingleton.cs +69 -69
  198. package/Runtime/Utils/RuntimeSingleton.cs.meta +11 -11
  199. package/Runtime/Utils/SetTextureImportData.cs +69 -69
  200. package/Runtime/Utils/SpriteRendererMetadata.cs +374 -374
  201. package/Runtime/Utils/SpriteRendererMetadata.cs.meta +2 -2
  202. package/Runtime/Utils/SpriteRendererSyncer.cs +100 -100
  203. package/Runtime/Utils/SpriteRendererSyncer.cs.meta +2 -2
  204. package/Runtime/Utils/TextureScale.cs +179 -179
  205. package/Runtime/Utils/TextureScale.cs.meta +2 -2
  206. package/Runtime/WallstopStudios.UnityHelpers.asmdef +13 -13
  207. package/Tests/Runtime/Attributes/ChildComponentTests.cs +81 -81
  208. package/Tests/Runtime/Attributes/Components/ExpectChildSpriteRenderers.cs +28 -28
  209. package/Tests/Runtime/Attributes/Components/ExpectParentSpriteRenderers.cs +28 -28
  210. package/Tests/Runtime/Attributes/ParentComponentTests.cs +68 -68
  211. package/Tests/Runtime/Components/RelationalComponentTesterComplex.cs +34 -34
  212. package/Tests/Runtime/Components/RelationalComponentTesterComplex.cs.meta +2 -2
  213. package/Tests/Runtime/Components/RelationalComponentsTesterSimple.cs +40 -40
  214. package/Tests/Runtime/Components.meta +2 -2
  215. package/Tests/Runtime/DataStructures/BalancedKDTreeTests.cs +14 -14
  216. package/Tests/Runtime/DataStructures/BalancedKDTreeTests.cs.meta +11 -11
  217. package/Tests/Runtime/DataStructures/CyclicBufferTests.cs +324 -324
  218. package/Tests/Runtime/DataStructures/QuadTreeTests.cs +14 -14
  219. package/Tests/Runtime/DataStructures/QuadTreeTests.cs.meta +11 -11
  220. package/Tests/Runtime/DataStructures/SpatialTreeTests.cs +130 -130
  221. package/Tests/Runtime/DataStructures/SpatialTreeTests.cs.meta +11 -11
  222. package/Tests/Runtime/DataStructures/UnbalancedKDTreeTests.cs +14 -14
  223. package/Tests/Runtime/DataStructures/UnbalancedKDTreeTests.cs.meta +11 -11
  224. package/Tests/Runtime/DataStructures.meta +8 -8
  225. package/Tests/Runtime/Extensions/DictionaryExtensionTests.cs +439 -439
  226. package/Tests/Runtime/Extensions/DictionaryExtensionTests.cs.meta +2 -2
  227. package/Tests/Runtime/Extensions/EnumExtensionTests.cs +128 -128
  228. package/Tests/Runtime/Extensions/EnumExtensionTests.cs.meta +2 -2
  229. package/Tests/Runtime/Extensions/IListExtensionTests.cs +104 -104
  230. package/Tests/Runtime/Extensions/RandomExtensionTests.cs +27 -27
  231. package/Tests/Runtime/Extensions/RandomExtensionTests.cs.meta +2 -2
  232. package/Tests/Runtime/Extensions/StringExtensionTests.cs +31 -31
  233. package/Tests/Runtime/Extensions/StringExtensionTests.cs.meta +2 -2
  234. package/Tests/Runtime/Extensions.meta +2 -2
  235. package/Tests/Runtime/Helper/ArrayConverterTests.cs +19 -19
  236. package/Tests/Runtime/Helper/ArrayConverterTests.cs.meta +2 -2
  237. package/Tests/Runtime/Helper/FormattingHelperTests.cs +129 -129
  238. package/Tests/Runtime/Helper/FormattingHelperTests.cs.meta +2 -2
  239. package/Tests/Runtime/Helper/ObjectHelperTests.cs +402 -402
  240. package/Tests/Runtime/Helper/ObjectHelperTests.cs.meta +2 -2
  241. package/Tests/Runtime/Helper/ReflectionHelperTests.cs +536 -536
  242. package/Tests/Runtime/Helper/SceneHelperTests.cs +94 -94
  243. package/Tests/Runtime/Helper/WallMathTests.cs +233 -233
  244. package/Tests/Runtime/Helper/WallMathTests.cs.meta +2 -2
  245. package/Tests/Runtime/Helper.meta +2 -2
  246. package/Tests/Runtime/Performance/KDTreePerformanceTests.cs +14 -14
  247. package/Tests/Runtime/Performance/KDTreePerformanceTests.cs.meta +11 -11
  248. package/Tests/Runtime/Performance/QuadTreePerformanceTests.cs +14 -14
  249. package/Tests/Runtime/Performance/QuadTreePerformanceTests.cs.meta +11 -11
  250. package/Tests/Runtime/Performance/RandomPerformanceTests.cs +157 -157
  251. package/Tests/Runtime/Performance/RandomPerformanceTests.cs.meta +11 -11
  252. package/Tests/Runtime/Performance/RelationComponentPerformanceTests.cs +61 -61
  253. package/Tests/Runtime/Performance/RelationComponentPerformanceTests.cs.meta +2 -2
  254. package/Tests/Runtime/Performance/SpatialTreePerformanceTest.cs +154 -154
  255. package/Tests/Runtime/Performance/SpatialTreePerformanceTest.cs.meta +11 -11
  256. package/Tests/Runtime/Performance/UnbalancedKDTreeTests.cs +14 -14
  257. package/Tests/Runtime/Performance/UnbalancedKDTreeTests.cs.meta +11 -11
  258. package/Tests/Runtime/Performance.meta +8 -8
  259. package/Tests/Runtime/Random/DotNetRandomTests.cs +9 -9
  260. package/Tests/Runtime/Random/DotNetRandomTests.cs.meta +2 -2
  261. package/Tests/Runtime/Random/LinearCongruentialGeneratorTests.cs +12 -12
  262. package/Tests/Runtime/Random/PcgRandomTests.cs +9 -9
  263. package/Tests/Runtime/Random/PcgRandomTests.cs.meta +11 -11
  264. package/Tests/Runtime/Random/RandomTestBase.cs +787 -787
  265. package/Tests/Runtime/Random/RandomTestBase.cs.meta +11 -11
  266. package/Tests/Runtime/Random/RomuDuoRandomTests.cs +9 -9
  267. package/Tests/Runtime/Random/RomuDuoRandomTests.cs.meta +2 -2
  268. package/Tests/Runtime/Random/SplitMix64RandomTests.cs +9 -9
  269. package/Tests/Runtime/Random/SplitMix64RandomTests.cs.meta +2 -2
  270. package/Tests/Runtime/Random/SquirrelRandomTests.cs +14 -14
  271. package/Tests/Runtime/Random/SquirrelRandomTests.cs.meta +11 -11
  272. package/Tests/Runtime/Random/SystemRandomTests.cs +10 -10
  273. package/Tests/Runtime/Random/SystemRandomTests.cs.meta +11 -11
  274. package/Tests/Runtime/Random/UnityRandomTests.cs +9 -9
  275. package/Tests/Runtime/Random/UnityRandomTests.cs.meta +11 -11
  276. package/Tests/Runtime/Random/WyRandomTests.cs +9 -9
  277. package/Tests/Runtime/Random/WyRandomTests.cs.meta +2 -2
  278. package/Tests/Runtime/Random/XorShiftRandomTests.cs +9 -9
  279. package/Tests/Runtime/Random/XorShiftRandomTests.cs.meta +11 -11
  280. package/Tests/Runtime/Random/XorShiroRandomTests.cs +9 -9
  281. package/Tests/Runtime/Random/XorShiroRandomTests.cs.meta +2 -2
  282. package/Tests/Runtime/Random.meta +8 -8
  283. package/Tests/Runtime/Serialization/JsonSerializationTest.cs +156 -156
  284. package/Tests/Runtime/Serialization/JsonSerializationTest.cs.meta +2 -2
  285. package/Tests/Runtime/Serialization.meta +2 -2
  286. package/Tests/Runtime/Utils/SpriteRendererMetadataTests.cs +399 -399
  287. package/Tests/Runtime/Utils/SpriteRendererMetadataTests.cs.meta +2 -2
  288. package/Tests/Runtime/Utils.meta +2 -2
  289. package/Tests/Runtime/WallstopStudios.UnityHelpers.Tests.Runtime.asmdef +22 -22
  290. package/Tests/Runtime/WallstopStudios.UnityHelpers.Tests.Runtime.asmdef.meta +7 -7
  291. package/Tests/Runtime.meta +8 -8
  292. package/package.json +38 -38
@@ -1,292 +1,292 @@
1
- namespace UnityHelpers.Core.DataStructure
2
- {
3
- using System;
4
- using System.Collections.Generic;
5
- using System.Collections.Immutable;
6
- using System.Linq;
7
- using Extension;
8
- using UnityEngine;
9
- using Utils;
10
-
11
- [Serializable]
12
- public sealed class KDTree<T> : ISpatialTree<T>
13
- {
14
- public delegate float Axis<in V>(V element);
15
-
16
- [Serializable]
17
- public sealed class KDTreeNode<V>
18
- {
19
- public readonly Bounds boundary;
20
- public readonly KDTreeNode<V> left;
21
- public readonly KDTreeNode<V> right;
22
- public readonly V[] elements;
23
- public readonly bool isTerminal;
24
-
25
- public KDTreeNode(
26
- List<V> elements,
27
- Func<V, Vector2> elementTransformer,
28
- int bucketSize,
29
- bool isXAxis,
30
- bool balanced
31
- )
32
- {
33
- boundary = elements.Select(elementTransformer).GetBounds() ?? new Bounds();
34
- this.elements = elements.ToArray();
35
- isTerminal = elements.Count <= bucketSize;
36
- if (isTerminal)
37
- {
38
- return;
39
- }
40
-
41
- if (balanced)
42
- {
43
- Axis<V> axisFunction = isXAxis
44
- ? element => elementTransformer(element).x
45
- : element => elementTransformer(element).y;
46
-
47
- int Comparison(V lhs, V rhs)
48
- {
49
- return axisFunction(lhs).CompareTo(axisFunction(rhs));
50
- }
51
- elements.Sort(Comparison);
52
-
53
- int cutoff = elements.Count / 2;
54
- left = new KDTreeNode<V>(
55
- elements.Take(cutoff).ToList(),
56
- elementTransformer,
57
- bucketSize,
58
- !isXAxis,
59
- true
60
- );
61
- right = new KDTreeNode<V>(
62
- elements.Skip(cutoff).ToList(),
63
- elementTransformer,
64
- bucketSize,
65
- !isXAxis,
66
- true
67
- );
68
- }
69
- else
70
- {
71
- Vector2 cutoff = boundary.center;
72
- if (isXAxis)
73
- {
74
- left = new KDTreeNode<V>(
75
- elements
76
- .Where(element => elementTransformer(element).x <= cutoff.x)
77
- .ToList(),
78
- elementTransformer,
79
- bucketSize,
80
- false,
81
- false
82
- );
83
- right = new KDTreeNode<V>(
84
- elements
85
- .Where(element => cutoff.x < elementTransformer(element).x)
86
- .ToList(),
87
- elementTransformer,
88
- bucketSize,
89
- false,
90
- false
91
- );
92
- }
93
- else
94
- {
95
- left = new KDTreeNode<V>(
96
- elements
97
- .Where(element => elementTransformer(element).y <= cutoff.y)
98
- .ToList(),
99
- elementTransformer,
100
- bucketSize,
101
- true,
102
- false
103
- );
104
- right = new KDTreeNode<V>(
105
- elements
106
- .Where(element => cutoff.y < elementTransformer(element).y)
107
- .ToList(),
108
- elementTransformer,
109
- bucketSize,
110
- true,
111
- false
112
- );
113
- }
114
- }
115
- }
116
- }
117
-
118
- public const int DefaultBucketSize = 12;
119
-
120
- public readonly ImmutableArray<T> elements;
121
- public Bounds Boundary => _bounds;
122
- public Func<T, Vector2> ElementTransformer => _elementTransformer;
123
-
124
- private readonly Bounds _bounds;
125
- private readonly Func<T, Vector2> _elementTransformer;
126
- private readonly KDTreeNode<T> _head;
127
-
128
- public KDTree(
129
- IEnumerable<T> points,
130
- Func<T, Vector2> elementTransformer,
131
- int bucketSize = DefaultBucketSize,
132
- bool balanced = true
133
- )
134
- {
135
- _elementTransformer =
136
- elementTransformer ?? throw new ArgumentNullException(nameof(elementTransformer));
137
- elements =
138
- points?.ToImmutableArray() ?? throw new ArgumentNullException(nameof(points));
139
- _bounds = elements.Select(elementTransformer).GetBounds() ?? new Bounds();
140
- _head = new KDTreeNode<T>(
141
- elements.ToList(),
142
- elementTransformer,
143
- bucketSize: bucketSize,
144
- isXAxis: true,
145
- balanced: balanced
146
- );
147
- }
148
-
149
- public IEnumerable<T> GetElementsInBounds(Bounds bounds)
150
- {
151
- Stack<KDTreeNode<T>> buffer = Buffers<KDTreeNode<T>>.Stack;
152
- return GetElementsInBounds(bounds, buffer);
153
- }
154
-
155
- public IEnumerable<T> GetElementsInBounds(Bounds bounds, Stack<KDTreeNode<T>> nodeBuffer)
156
- {
157
- if (!bounds.FastIntersects2D(_bounds))
158
- {
159
- yield break;
160
- }
161
-
162
- Stack<KDTreeNode<T>> nodesToVisit = nodeBuffer ?? new Stack<KDTreeNode<T>>();
163
- nodesToVisit.Clear();
164
- nodesToVisit.Push(_head);
165
-
166
- while (nodesToVisit.TryPop(out KDTreeNode<T> currentNode))
167
- {
168
- if (currentNode.isTerminal)
169
- {
170
- foreach (T element in currentNode.elements)
171
- {
172
- if (bounds.FastContains2D(_elementTransformer(element)))
173
- {
174
- yield return element;
175
- }
176
- }
177
-
178
- continue;
179
- }
180
-
181
- if (bounds.Overlaps2D(currentNode.boundary))
182
- {
183
- foreach (T element in currentNode.elements)
184
- {
185
- yield return element;
186
- }
187
-
188
- continue;
189
- }
190
-
191
- KDTreeNode<T> leftNode = currentNode.left;
192
- if (0 < leftNode.elements.Length && bounds.FastIntersects2D(leftNode.boundary))
193
- {
194
- nodesToVisit.Push(leftNode);
195
- }
196
-
197
- KDTreeNode<T> rightNode = currentNode.right;
198
- if (0 < rightNode.elements.Length && bounds.FastIntersects2D(rightNode.boundary))
199
- {
200
- nodesToVisit.Push(rightNode);
201
- }
202
- }
203
- }
204
-
205
- public void GetApproximateNearestNeighbors(
206
- Vector2 position,
207
- int count,
208
- List<T> nearestNeighbors
209
- )
210
- {
211
- Stack<KDTreeNode<T>> nodeBuffer = Buffers<KDTreeNode<T>>.Stack;
212
- HashSet<T> nearestNeighborBuffer = Buffers<T>.HashSet;
213
- GetApproximateNearestNeighbors(
214
- position,
215
- count,
216
- nearestNeighbors,
217
- nodeBuffer,
218
- nearestNeighborBuffer
219
- );
220
- }
221
-
222
- // Heavily adapted http://homepage.divms.uiowa.edu/%7Ekvaradar/sp2012/daa/ann.pdf
223
- public void GetApproximateNearestNeighbors(
224
- Vector2 position,
225
- int count,
226
- List<T> nearestNeighbors,
227
- Stack<KDTreeNode<T>> nodeBuffer,
228
- HashSet<T> nearestNeighborBuffer
229
- )
230
- {
231
- nearestNeighbors.Clear();
232
-
233
- KDTreeNode<T> current = _head;
234
- Stack<KDTreeNode<T>> stack = nodeBuffer ?? new Stack<KDTreeNode<T>>();
235
- stack.Clear();
236
- stack.Push(_head);
237
- HashSet<T> nearestNeighborsSet = nearestNeighborBuffer ?? new HashSet<T>(count);
238
- nearestNeighborsSet.Clear();
239
-
240
- while (!current.isTerminal)
241
- {
242
- KDTreeNode<T> left = current.left;
243
- KDTreeNode<T> right = current.right;
244
- if (
245
- ((Vector2)left.boundary.center - position).sqrMagnitude
246
- < ((Vector2)right.boundary.center - position).sqrMagnitude
247
- )
248
- {
249
- stack.Push(left);
250
- current = left;
251
- if (left.elements.Length <= count)
252
- {
253
- break;
254
- }
255
- }
256
- else
257
- {
258
- stack.Push(right);
259
- current = right;
260
- if (right.elements.Length <= count)
261
- {
262
- break;
263
- }
264
- }
265
- }
266
-
267
- while (nearestNeighborsSet.Count < count && stack.TryPop(out KDTreeNode<T> selected))
268
- {
269
- foreach (T element in selected.elements)
270
- {
271
- _ = nearestNeighborsSet.Add(element);
272
- }
273
- }
274
-
275
- foreach (T element in nearestNeighborsSet)
276
- {
277
- nearestNeighbors.Add(element);
278
- }
279
- if (count < nearestNeighbors.Count)
280
- {
281
- Vector2 localPosition = position;
282
- nearestNeighbors.Sort(NearestComparison);
283
- nearestNeighbors.RemoveRange(count, nearestNeighbors.Count - count);
284
-
285
- int NearestComparison(T lhs, T rhs) =>
286
- (_elementTransformer(lhs) - localPosition).sqrMagnitude.CompareTo(
287
- (_elementTransformer(rhs) - localPosition).sqrMagnitude
288
- );
289
- }
290
- }
291
- }
292
- }
1
+ namespace UnityHelpers.Core.DataStructure
2
+ {
3
+ using System;
4
+ using System.Collections.Generic;
5
+ using System.Collections.Immutable;
6
+ using System.Linq;
7
+ using Extension;
8
+ using UnityEngine;
9
+ using Utils;
10
+
11
+ [Serializable]
12
+ public sealed class KDTree<T> : ISpatialTree<T>
13
+ {
14
+ public delegate float Axis<in V>(V element);
15
+
16
+ [Serializable]
17
+ public sealed class KDTreeNode<V>
18
+ {
19
+ public readonly Bounds boundary;
20
+ public readonly KDTreeNode<V> left;
21
+ public readonly KDTreeNode<V> right;
22
+ public readonly V[] elements;
23
+ public readonly bool isTerminal;
24
+
25
+ public KDTreeNode(
26
+ List<V> elements,
27
+ Func<V, Vector2> elementTransformer,
28
+ int bucketSize,
29
+ bool isXAxis,
30
+ bool balanced
31
+ )
32
+ {
33
+ boundary = elements.Select(elementTransformer).GetBounds() ?? new Bounds();
34
+ this.elements = elements.ToArray();
35
+ isTerminal = elements.Count <= bucketSize;
36
+ if (isTerminal)
37
+ {
38
+ return;
39
+ }
40
+
41
+ if (balanced)
42
+ {
43
+ Axis<V> axisFunction = isXAxis
44
+ ? element => elementTransformer(element).x
45
+ : element => elementTransformer(element).y;
46
+
47
+ int Comparison(V lhs, V rhs)
48
+ {
49
+ return axisFunction(lhs).CompareTo(axisFunction(rhs));
50
+ }
51
+ elements.Sort(Comparison);
52
+
53
+ int cutoff = elements.Count / 2;
54
+ left = new KDTreeNode<V>(
55
+ elements.Take(cutoff).ToList(),
56
+ elementTransformer,
57
+ bucketSize,
58
+ !isXAxis,
59
+ true
60
+ );
61
+ right = new KDTreeNode<V>(
62
+ elements.Skip(cutoff).ToList(),
63
+ elementTransformer,
64
+ bucketSize,
65
+ !isXAxis,
66
+ true
67
+ );
68
+ }
69
+ else
70
+ {
71
+ Vector2 cutoff = boundary.center;
72
+ if (isXAxis)
73
+ {
74
+ left = new KDTreeNode<V>(
75
+ elements
76
+ .Where(element => elementTransformer(element).x <= cutoff.x)
77
+ .ToList(),
78
+ elementTransformer,
79
+ bucketSize,
80
+ false,
81
+ false
82
+ );
83
+ right = new KDTreeNode<V>(
84
+ elements
85
+ .Where(element => cutoff.x < elementTransformer(element).x)
86
+ .ToList(),
87
+ elementTransformer,
88
+ bucketSize,
89
+ false,
90
+ false
91
+ );
92
+ }
93
+ else
94
+ {
95
+ left = new KDTreeNode<V>(
96
+ elements
97
+ .Where(element => elementTransformer(element).y <= cutoff.y)
98
+ .ToList(),
99
+ elementTransformer,
100
+ bucketSize,
101
+ true,
102
+ false
103
+ );
104
+ right = new KDTreeNode<V>(
105
+ elements
106
+ .Where(element => cutoff.y < elementTransformer(element).y)
107
+ .ToList(),
108
+ elementTransformer,
109
+ bucketSize,
110
+ true,
111
+ false
112
+ );
113
+ }
114
+ }
115
+ }
116
+ }
117
+
118
+ public const int DefaultBucketSize = 12;
119
+
120
+ public readonly ImmutableArray<T> elements;
121
+ public Bounds Boundary => _bounds;
122
+ public Func<T, Vector2> ElementTransformer => _elementTransformer;
123
+
124
+ private readonly Bounds _bounds;
125
+ private readonly Func<T, Vector2> _elementTransformer;
126
+ private readonly KDTreeNode<T> _head;
127
+
128
+ public KDTree(
129
+ IEnumerable<T> points,
130
+ Func<T, Vector2> elementTransformer,
131
+ int bucketSize = DefaultBucketSize,
132
+ bool balanced = true
133
+ )
134
+ {
135
+ _elementTransformer =
136
+ elementTransformer ?? throw new ArgumentNullException(nameof(elementTransformer));
137
+ elements =
138
+ points?.ToImmutableArray() ?? throw new ArgumentNullException(nameof(points));
139
+ _bounds = elements.Select(elementTransformer).GetBounds() ?? new Bounds();
140
+ _head = new KDTreeNode<T>(
141
+ elements.ToList(),
142
+ elementTransformer,
143
+ bucketSize: bucketSize,
144
+ isXAxis: true,
145
+ balanced: balanced
146
+ );
147
+ }
148
+
149
+ public IEnumerable<T> GetElementsInBounds(Bounds bounds)
150
+ {
151
+ Stack<KDTreeNode<T>> buffer = Buffers<KDTreeNode<T>>.Stack;
152
+ return GetElementsInBounds(bounds, buffer);
153
+ }
154
+
155
+ public IEnumerable<T> GetElementsInBounds(Bounds bounds, Stack<KDTreeNode<T>> nodeBuffer)
156
+ {
157
+ if (!bounds.FastIntersects2D(_bounds))
158
+ {
159
+ yield break;
160
+ }
161
+
162
+ Stack<KDTreeNode<T>> nodesToVisit = nodeBuffer ?? new Stack<KDTreeNode<T>>();
163
+ nodesToVisit.Clear();
164
+ nodesToVisit.Push(_head);
165
+
166
+ while (nodesToVisit.TryPop(out KDTreeNode<T> currentNode))
167
+ {
168
+ if (currentNode.isTerminal)
169
+ {
170
+ foreach (T element in currentNode.elements)
171
+ {
172
+ if (bounds.FastContains2D(_elementTransformer(element)))
173
+ {
174
+ yield return element;
175
+ }
176
+ }
177
+
178
+ continue;
179
+ }
180
+
181
+ if (bounds.Overlaps2D(currentNode.boundary))
182
+ {
183
+ foreach (T element in currentNode.elements)
184
+ {
185
+ yield return element;
186
+ }
187
+
188
+ continue;
189
+ }
190
+
191
+ KDTreeNode<T> leftNode = currentNode.left;
192
+ if (0 < leftNode.elements.Length && bounds.FastIntersects2D(leftNode.boundary))
193
+ {
194
+ nodesToVisit.Push(leftNode);
195
+ }
196
+
197
+ KDTreeNode<T> rightNode = currentNode.right;
198
+ if (0 < rightNode.elements.Length && bounds.FastIntersects2D(rightNode.boundary))
199
+ {
200
+ nodesToVisit.Push(rightNode);
201
+ }
202
+ }
203
+ }
204
+
205
+ public void GetApproximateNearestNeighbors(
206
+ Vector2 position,
207
+ int count,
208
+ List<T> nearestNeighbors
209
+ )
210
+ {
211
+ Stack<KDTreeNode<T>> nodeBuffer = Buffers<KDTreeNode<T>>.Stack;
212
+ HashSet<T> nearestNeighborBuffer = Buffers<T>.HashSet;
213
+ GetApproximateNearestNeighbors(
214
+ position,
215
+ count,
216
+ nearestNeighbors,
217
+ nodeBuffer,
218
+ nearestNeighborBuffer
219
+ );
220
+ }
221
+
222
+ // Heavily adapted http://homepage.divms.uiowa.edu/%7Ekvaradar/sp2012/daa/ann.pdf
223
+ public void GetApproximateNearestNeighbors(
224
+ Vector2 position,
225
+ int count,
226
+ List<T> nearestNeighbors,
227
+ Stack<KDTreeNode<T>> nodeBuffer,
228
+ HashSet<T> nearestNeighborBuffer
229
+ )
230
+ {
231
+ nearestNeighbors.Clear();
232
+
233
+ KDTreeNode<T> current = _head;
234
+ Stack<KDTreeNode<T>> stack = nodeBuffer ?? new Stack<KDTreeNode<T>>();
235
+ stack.Clear();
236
+ stack.Push(_head);
237
+ HashSet<T> nearestNeighborsSet = nearestNeighborBuffer ?? new HashSet<T>(count);
238
+ nearestNeighborsSet.Clear();
239
+
240
+ while (!current.isTerminal)
241
+ {
242
+ KDTreeNode<T> left = current.left;
243
+ KDTreeNode<T> right = current.right;
244
+ if (
245
+ ((Vector2)left.boundary.center - position).sqrMagnitude
246
+ < ((Vector2)right.boundary.center - position).sqrMagnitude
247
+ )
248
+ {
249
+ stack.Push(left);
250
+ current = left;
251
+ if (left.elements.Length <= count)
252
+ {
253
+ break;
254
+ }
255
+ }
256
+ else
257
+ {
258
+ stack.Push(right);
259
+ current = right;
260
+ if (right.elements.Length <= count)
261
+ {
262
+ break;
263
+ }
264
+ }
265
+ }
266
+
267
+ while (nearestNeighborsSet.Count < count && stack.TryPop(out KDTreeNode<T> selected))
268
+ {
269
+ foreach (T element in selected.elements)
270
+ {
271
+ _ = nearestNeighborsSet.Add(element);
272
+ }
273
+ }
274
+
275
+ foreach (T element in nearestNeighborsSet)
276
+ {
277
+ nearestNeighbors.Add(element);
278
+ }
279
+ if (count < nearestNeighbors.Count)
280
+ {
281
+ Vector2 localPosition = position;
282
+ nearestNeighbors.Sort(NearestComparison);
283
+ nearestNeighbors.RemoveRange(count, nearestNeighbors.Count - count);
284
+
285
+ int NearestComparison(T lhs, T rhs) =>
286
+ (_elementTransformer(lhs) - localPosition).sqrMagnitude.CompareTo(
287
+ (_elementTransformer(rhs) - localPosition).sqrMagnitude
288
+ );
289
+ }
290
+ }
291
+ }
292
+ }
@@ -1,11 +1,11 @@
1
- fileFormatVersion: 2
2
- guid: 2ebf309d2de45e944946aa5cccd9754a
3
- MonoImporter:
4
- externalObjects: {}
5
- serializedVersion: 2
6
- defaultReferences: []
7
- executionOrder: 0
8
- icon: {instanceID: 0}
9
- userData:
10
- assetBundleName:
11
- assetBundleVariant:
1
+ fileFormatVersion: 2
2
+ guid: 2ebf309d2de45e944946aa5cccd9754a
3
+ MonoImporter:
4
+ externalObjects: {}
5
+ serializedVersion: 2
6
+ defaultReferences: []
7
+ executionOrder: 0
8
+ icon: {instanceID: 0}
9
+ userData:
10
+ assetBundleName:
11
+ assetBundleVariant: