Decompiled source of Tunnel Safehouse v1.1.2
Tunnel_Safehouse.dll
Decompiled a year ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.Collections; using System.Collections.Generic; using System.ComponentModel; using System.Diagnostics; using System.Globalization; using System.IO; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Security; using System.Security.Permissions; using System.Text; using System.Text.RegularExpressions; using System.Threading; using Atlas; using BepInEx; using BepInEx.Logging; using FistVR; using Sabresaurus.SabreCSG.ShapeEditor; using Sabresaurus.SabreCSG.ShapeEditor.Decomposition; using Sodalite.Api; using Sodalite.Utilities; using Technie.PhysicsCreator.QHull; using UnityEditor; using UnityEditor.Callbacks; using UnityEditor.SceneManagement; using UnityEditorInternal; using UnityEngine; using UnityEngine.AI; using UnityEngine.Audio; using UnityEngine.Events; using UnityEngine.Rendering; using UnityEngine.SceneManagement; using UnityEngine.Serialization; using UnityEngine.UI; [assembly: Debuggable(DebuggableAttribute.DebuggingModes.DisableOptimizations | DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: SecurityPermission(SecurityAction.RequestMinimum, SkipVerification = true)] [assembly: AssemblyVersion("0.0.0.0")] [module: UnverifiableCode] namespace Sabresaurus.SabreCSG { public abstract class CompoundBrush : BrushBase { [SerializeField] protected Bounds localBounds = new Bounds(Vector3.zero, new Vector3(2f, 2f, 2f)); protected List<PrimitiveBrush> generatedBrushes = new List<PrimitiveBrush>(); private CSGModelBase parentCsgModel; public abstract int BrushCount { get; } public override string BeautifulBrushName => ((object)this).GetType().Name; public CSGModelBase GetCSGModel() { if ((Object)(object)parentCsgModel == (Object)null) { CSGModelBase[] componentsInParent = ((Component)((Component)this).transform).GetComponentsInParent<CSGModelBase>(true); if (componentsInParent.Length > 0) { parentCsgModel = componentsInParent[0]; } } return parentCsgModel; } protected virtual void Start() { generatedBrushes = new List<PrimitiveBrush>(((Component)this).GetComponentsInChildren<PrimitiveBrush>()); for (int i = 0; i < generatedBrushes.Count; i++) { generatedBrushes[i].SetBrushController(this); } } public override void Invalidate(bool polygonsChanged) { base.Invalidate(polygonsChanged); generatedBrushes.RemoveAll((PrimitiveBrush item) => (Object)(object)item == (Object)null); if (generatedBrushes.Count > BrushCount) { for (int i = BrushCount; i < generatedBrushes.Count; i++) { if ((Object)(object)generatedBrushes[i] != (Object)null) { Object.DestroyImmediate((Object)(object)((Component)generatedBrushes[i]).gameObject); } } generatedBrushes.RemoveRange(BrushCount, generatedBrushes.Count - BrushCount); } else if (generatedBrushes.Count < BrushCount) { while (generatedBrushes.Count < BrushCount) { PrimitiveBrush primitiveBrush = CreateBrush(); ((Component)primitiveBrush).transform.SetParent(((Component)this).transform, false); primitiveBrush.SetBrushController(this); generatedBrushes.Add(primitiveBrush); } } } public override Bounds GetBounds() { //IL_0002: Unknown result type (might be due to invalid IL or missing references) //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_000d: Unknown result type (might be due to invalid IL or missing references) return localBounds; } public override void SetBounds(Bounds newBounds) { //IL_0007: Unknown result type (might be due to invalid IL or missing references) //IL_0019: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) ((Bounds)(ref localBounds)).center = Vector3.zero; ((Bounds)(ref localBounds)).extents = ((Bounds)(ref newBounds)).extents; ((Component)this).transform.Translate(((Bounds)(ref newBounds)).center); } public override Bounds GetBoundsTransformed() { //IL_0016: Unknown result type (might be due to invalid IL or missing references) //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_0022: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Unknown result type (might be due to invalid IL or missing references) //IL_00ac: Unknown result type (might be due to invalid IL or missing references) //IL_00b1: Unknown result type (might be due to invalid IL or missing references) //IL_00ce: Unknown result type (might be due to invalid IL or missing references) //IL_00e7: Unknown result type (might be due to invalid IL or missing references) //IL_00e9: Unknown result type (might be due to invalid IL or missing references) //IL_0075: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Unknown result type (might be due to invalid IL or missing references) //IL_0077: Unknown result type (might be due to invalid IL or missing references) //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_0083: Unknown result type (might be due to invalid IL or missing references) //IL_0084: Unknown result type (might be due to invalid IL or missing references) //IL_0089: Unknown result type (might be due to invalid IL or missing references) //IL_0091: Unknown result type (might be due to invalid IL or missing references) //IL_0092: Unknown result type (might be due to invalid IL or missing references) //IL_00f0: Unknown result type (might be due to invalid IL or missing references) Vector3[] array = (Vector3[])(object)new Vector3[8]; for (int i = 0; i < 8; i++) { Vector3 center = ((Bounds)(ref localBounds)).center; Vector3 extents = ((Bounds)(ref localBounds)).extents; if (i % 2 == 0) { extents.x = 0f - extents.x; } if (i % 4 < 2) { extents.y = 0f - extents.y; } if (i % 8 < 4) { extents.z = 0f - extents.z; } center += extents; center = ((Component)this).transform.TransformPoint(center); array[i] = center; } Bounds result = default(Bounds); ((Bounds)(ref result))..ctor(array[0], Vector3.zero); for (int j = 1; j < 8; j++) { ((Bounds)(ref result)).Encapsulate(array[j]); } return result; } public override Bounds GetBoundsLocalTo(Transform otherTransform) { //IL_0016: Unknown result type (might be due to invalid IL or missing references) //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_0022: Unknown result type (might be due to invalid IL or missing references) //IL_0027: Unknown result type (might be due to invalid IL or missing references) //IL_00b2: Unknown result type (might be due to invalid IL or missing references) //IL_00b7: Unknown result type (might be due to invalid IL or missing references) //IL_00d4: Unknown result type (might be due to invalid IL or missing references) //IL_00ed: Unknown result type (might be due to invalid IL or missing references) //IL_00ef: Unknown result type (might be due to invalid IL or missing references) //IL_0075: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Unknown result type (might be due to invalid IL or missing references) //IL_0077: Unknown result type (might be due to invalid IL or missing references) //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_0084: Unknown result type (might be due to invalid IL or missing references) //IL_0085: Unknown result type (might be due to invalid IL or missing references) //IL_008a: Unknown result type (might be due to invalid IL or missing references) //IL_008f: Unknown result type (might be due to invalid IL or missing references) //IL_0097: Unknown result type (might be due to invalid IL or missing references) //IL_0098: Unknown result type (might be due to invalid IL or missing references) //IL_00f6: Unknown result type (might be due to invalid IL or missing references) Vector3[] array = (Vector3[])(object)new Vector3[8]; for (int i = 0; i < 8; i++) { Vector3 center = ((Bounds)(ref localBounds)).center; Vector3 extents = ((Bounds)(ref localBounds)).extents; if (i % 2 == 0) { extents.x = 0f - extents.x; } if (i % 4 < 2) { extents.y = 0f - extents.y; } if (i % 8 < 4) { extents.z = 0f - extents.z; } center += extents; center = otherTransform.InverseTransformPoint(((Component)this).transform.TransformPoint(center)); array[i] = center; } Bounds result = default(Bounds); ((Bounds)(ref result))..ctor(array[0], Vector3.zero); for (int j = 1; j < 8; j++) { ((Bounds)(ref result)).Encapsulate(array[j]); } return result; } public Polygon[] GetPolygons() { List<Polygon> list = new List<Polygon>(); Brush[] componentsInChildren = ((Component)this).GetComponentsInChildren<Brush>(); foreach (Brush brush in componentsInChildren) { list.AddRange(GenerateTransformedPolygons(((Component)brush).transform, brush.GetPolygons())); } return list.ToArray(); } private Polygon[] GenerateTransformedPolygons(Transform t, Polygon[] polygons) { //IL_0009: Unknown result type (might be due to invalid IL or missing references) //IL_000e: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_0015: Unknown result type (might be due to invalid IL or missing references) //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_001c: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Unknown result type (might be due to invalid IL or missing references) //IL_004d: Unknown result type (might be due to invalid IL or missing references) //IL_004e: Unknown result type (might be due to invalid IL or missing references) //IL_0053: Unknown result type (might be due to invalid IL or missing references) //IL_0058: Unknown result type (might be due to invalid IL or missing references) //IL_0059: Unknown result type (might be due to invalid IL or missing references) //IL_005e: Unknown result type (might be due to invalid IL or missing references) //IL_006f: Unknown result type (might be due to invalid IL or missing references) //IL_007c: Unknown result type (might be due to invalid IL or missing references) //IL_0081: Unknown result type (might be due to invalid IL or missing references) //IL_0086: Unknown result type (might be due to invalid IL or missing references) Polygon[] array = polygons.DeepCopy(); Vector3 localPosition = t.localPosition; Quaternion localRotation = t.localRotation; Vector3 lossyScale = t.lossyScale; for (int i = 0; i < array.Length; i++) { for (int j = 0; j < array[i].Vertices.Length; j++) { array[i].Vertices[j].Position = localRotation * array[i].Vertices[j].Position.Multiply(lossyScale) + localPosition; array[i].Vertices[j].Normal = localRotation * array[i].Vertices[j].Normal; } array[i].CalculatePlane(); } return array; } public virtual PrimitiveBrush CreateBrush() { //IL_0008: Unknown result type (might be due to invalid IL or missing references) //IL_000d: Unknown result type (might be due to invalid IL or missing references) //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_001a: Unknown result type (might be due to invalid IL or missing references) return GetCSGModel().CreateBrush(PrimitiveBrushType.Cube, Vector3.zero, Vector3.one).GetComponent<PrimitiveBrush>(); } public override void OnUndoRedoPerformed() { generatedBrushes = new List<PrimitiveBrush>(((Component)this).GetComponentsInChildren<PrimitiveBrush>()); for (int i = 0; i < generatedBrushes.Count; i++) { generatedBrushes[i].SetBrushController(this); } Invalidate(polygonsChanged: true); } public static List<Type> FindAllInAssembly() { List<Type> list = new List<Type>(); Assembly[] assemblies = AppDomain.CurrentDomain.GetAssemblies(); Assembly[] array = assemblies; foreach (Assembly assembly in array) { if (!assembly.FullName.StartsWith("Assembly-CSharp")) { continue; } Type[] types = assembly.GetTypes(); for (int j = 0; j < types.Length; j++) { if (!types[j].IsAbstract && types[j].IsSubclassOf(typeof(CompoundBrush)) && (object)types[j] != typeof(StairBrush) && (object)types[j] != typeof(CurvedStairBrush) && (object)types[j] != typeof(ShapeEditorBrush)) { list.Add(types[j]); } } } return list; } } [ExecuteInEditMode] public class CurvedStairBrush : CompoundBrush { [SerializeField] private float innerRadius = 1f; [SerializeField] private float stepHeight = 0.0625f; [SerializeField] private float stepWidth = 1f; [SerializeField] private float angleOfCurve = 90f; [SerializeField] private int numSteps = 4; [SerializeField] private float addToFirstStep = 0f; [SerializeField] private bool counterClockwise = false; [SerializeField] private bool fillToBottom = true; [SerializeField] private bool curvedWall = false; [SerializeField] private bool slopedFloor = false; [SerializeField] private bool slopedCeiling = false; private Vector3 m_LastKnownExtents; private Vector3 m_LastKnownPosition; public float InnerRadius { get { return innerRadius; } set { innerRadius = value; } } public float StepHeight { get { return stepHeight; } set { stepHeight = value; } } public float StepWidth { get { return stepWidth; } set { stepWidth = value; } } public float AngleOfCurve { get { return angleOfCurve; } set { angleOfCurve = value; } } public int NumberOfSteps { get { return numSteps; } set { numSteps = value; } } public float AddToFirstStep { get { return addToFirstStep; } set { addToFirstStep = value; } } public bool CounterClockwise { get { return counterClockwise; } set { counterClockwise = value; } } public bool FillToBottom { get { return fillToBottom; } set { fillToBottom = value; } } public bool CurvedWall { get { return curvedWall; } set { curvedWall = value; } } public bool SlopedFloor { get { return slopedFloor; } set { slopedFloor = value; } } public bool SlopedCeiling { get { return slopedCeiling; } set { slopedCeiling = value; } } public override string BeautifulBrushName => "Curved Stairs Brush"; public override int BrushCount => numSteps; protected override void Awake() { //IL_000e: Unknown result type (might be due to invalid IL or missing references) //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Unknown result type (might be due to invalid IL or missing references) base.Awake(); m_LastKnownExtents = ((Bounds)(ref localBounds)).extents; m_LastKnownPosition = ((Component)this).transform.localPosition; } public override void UpdateVisibility() { } public override void Invalidate(bool polygonsChanged) { //IL_0009: Unknown result type (might be due to invalid IL or missing references) //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_00ef: Unknown result type (might be due to invalid IL or missing references) //IL_00f7: Unknown result type (might be due to invalid IL or missing references) //IL_00ff: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) //IL_003b: Unknown result type (might be due to invalid IL or missing references) //IL_0040: Unknown result type (might be due to invalid IL or missing references) //IL_008a: Unknown result type (might be due to invalid IL or missing references) //IL_008f: Unknown result type (might be due to invalid IL or missing references) //IL_006e: Unknown result type (might be due to invalid IL or missing references) //IL_0073: Unknown result type (might be due to invalid IL or missing references) //IL_00d0: Unknown result type (might be due to invalid IL or missing references) //IL_00d5: Unknown result type (might be due to invalid IL or missing references) //IL_0173: Unknown result type (might be due to invalid IL or missing references) //IL_0177: Unknown result type (might be due to invalid IL or missing references) //IL_017c: Unknown result type (might be due to invalid IL or missing references) //IL_0181: Unknown result type (might be due to invalid IL or missing references) //IL_0183: Unknown result type (might be due to invalid IL or missing references) //IL_0188: Unknown result type (might be due to invalid IL or missing references) //IL_01a3: Unknown result type (might be due to invalid IL or missing references) //IL_01fc: Unknown result type (might be due to invalid IL or missing references) //IL_0268: Unknown result type (might be due to invalid IL or missing references) //IL_026c: Unknown result type (might be due to invalid IL or missing references) //IL_0271: Unknown result type (might be due to invalid IL or missing references) //IL_0276: Unknown result type (might be due to invalid IL or missing references) //IL_0278: Unknown result type (might be due to invalid IL or missing references) //IL_027d: Unknown result type (might be due to invalid IL or missing references) //IL_0298: Unknown result type (might be due to invalid IL or missing references) //IL_033b: Unknown result type (might be due to invalid IL or missing references) //IL_033f: Unknown result type (might be due to invalid IL or missing references) //IL_0344: Unknown result type (might be due to invalid IL or missing references) //IL_0349: Unknown result type (might be due to invalid IL or missing references) //IL_034b: Unknown result type (might be due to invalid IL or missing references) //IL_0350: Unknown result type (might be due to invalid IL or missing references) //IL_036f: Unknown result type (might be due to invalid IL or missing references) //IL_02f1: Unknown result type (might be due to invalid IL or missing references) //IL_03b4: Unknown result type (might be due to invalid IL or missing references) //IL_03b8: Unknown result type (might be due to invalid IL or missing references) //IL_03bd: Unknown result type (might be due to invalid IL or missing references) //IL_03c2: Unknown result type (might be due to invalid IL or missing references) //IL_03c4: Unknown result type (might be due to invalid IL or missing references) //IL_03c9: Unknown result type (might be due to invalid IL or missing references) //IL_03e8: Unknown result type (might be due to invalid IL or missing references) //IL_047d: Unknown result type (might be due to invalid IL or missing references) //IL_0e3e: Unknown result type (might be due to invalid IL or missing references) //IL_0e40: Unknown result type (might be due to invalid IL or missing references) //IL_0e4c: Unknown result type (might be due to invalid IL or missing references) //IL_0e51: Unknown result type (might be due to invalid IL or missing references) //IL_0e5d: Unknown result type (might be due to invalid IL or missing references) //IL_0e62: Unknown result type (might be due to invalid IL or missing references) //IL_059d: Unknown result type (might be due to invalid IL or missing references) //IL_05a2: Unknown result type (might be due to invalid IL or missing references) //IL_05b6: Unknown result type (might be due to invalid IL or missing references) //IL_05bb: Unknown result type (might be due to invalid IL or missing references) //IL_05cf: Unknown result type (might be due to invalid IL or missing references) //IL_05d4: Unknown result type (might be due to invalid IL or missing references) //IL_05e8: Unknown result type (might be due to invalid IL or missing references) //IL_05ed: Unknown result type (might be due to invalid IL or missing references) //IL_0530: Unknown result type (might be due to invalid IL or missing references) //IL_0535: Unknown result type (might be due to invalid IL or missing references) //IL_0549: Unknown result type (might be due to invalid IL or missing references) //IL_054e: Unknown result type (might be due to invalid IL or missing references) //IL_0562: Unknown result type (might be due to invalid IL or missing references) //IL_0567: Unknown result type (might be due to invalid IL or missing references) //IL_057d: Unknown result type (might be due to invalid IL or missing references) //IL_0582: Unknown result type (might be due to invalid IL or missing references) //IL_0690: Unknown result type (might be due to invalid IL or missing references) //IL_0695: Unknown result type (might be due to invalid IL or missing references) //IL_06a9: Unknown result type (might be due to invalid IL or missing references) //IL_06be: Unknown result type (might be due to invalid IL or missing references) //IL_06c3: Unknown result type (might be due to invalid IL or missing references) //IL_06c8: Unknown result type (might be due to invalid IL or missing references) //IL_06dc: Unknown result type (might be due to invalid IL or missing references) //IL_06f1: Unknown result type (might be due to invalid IL or missing references) //IL_06f6: Unknown result type (might be due to invalid IL or missing references) //IL_06fb: Unknown result type (might be due to invalid IL or missing references) //IL_070f: Unknown result type (might be due to invalid IL or missing references) //IL_0714: Unknown result type (might be due to invalid IL or missing references) //IL_062d: Unknown result type (might be due to invalid IL or missing references) //IL_0632: Unknown result type (might be due to invalid IL or missing references) //IL_0642: Unknown result type (might be due to invalid IL or missing references) //IL_0647: Unknown result type (might be due to invalid IL or missing references) //IL_0657: Unknown result type (might be due to invalid IL or missing references) //IL_065c: Unknown result type (might be due to invalid IL or missing references) //IL_0670: Unknown result type (might be due to invalid IL or missing references) //IL_0675: Unknown result type (might be due to invalid IL or missing references) //IL_072c: Unknown result type (might be due to invalid IL or missing references) //IL_0741: Unknown result type (might be due to invalid IL or missing references) //IL_0746: Unknown result type (might be due to invalid IL or missing references) //IL_074b: Unknown result type (might be due to invalid IL or missing references) //IL_0756: Unknown result type (might be due to invalid IL or missing references) //IL_076b: Unknown result type (might be due to invalid IL or missing references) //IL_0770: Unknown result type (might be due to invalid IL or missing references) //IL_0775: Unknown result type (might be due to invalid IL or missing references) //IL_081a: Unknown result type (might be due to invalid IL or missing references) //IL_082f: Unknown result type (might be due to invalid IL or missing references) //IL_0834: Unknown result type (might be due to invalid IL or missing references) //IL_0839: Unknown result type (might be due to invalid IL or missing references) //IL_084d: Unknown result type (might be due to invalid IL or missing references) //IL_0852: Unknown result type (might be due to invalid IL or missing references) //IL_0866: Unknown result type (might be due to invalid IL or missing references) //IL_086b: Unknown result type (might be due to invalid IL or missing references) //IL_087f: Unknown result type (might be due to invalid IL or missing references) //IL_0894: Unknown result type (might be due to invalid IL or missing references) //IL_0899: Unknown result type (might be due to invalid IL or missing references) //IL_089e: Unknown result type (might be due to invalid IL or missing references) //IL_07b3: Unknown result type (might be due to invalid IL or missing references) //IL_07b8: Unknown result type (might be due to invalid IL or missing references) //IL_07cc: Unknown result type (might be due to invalid IL or missing references) //IL_07d1: Unknown result type (might be due to invalid IL or missing references) //IL_07e5: Unknown result type (might be due to invalid IL or missing references) //IL_07ea: Unknown result type (might be due to invalid IL or missing references) //IL_07fa: Unknown result type (might be due to invalid IL or missing references) //IL_07ff: Unknown result type (might be due to invalid IL or missing references) //IL_08c1: Unknown result type (might be due to invalid IL or missing references) //IL_08c6: Unknown result type (might be due to invalid IL or missing references) //IL_08e7: Unknown result type (might be due to invalid IL or missing references) //IL_0902: Unknown result type (might be due to invalid IL or missing references) //IL_0907: Unknown result type (might be due to invalid IL or missing references) //IL_090c: Unknown result type (might be due to invalid IL or missing references) //IL_09b1: Unknown result type (might be due to invalid IL or missing references) //IL_09b6: Unknown result type (might be due to invalid IL or missing references) //IL_09ca: Unknown result type (might be due to invalid IL or missing references) //IL_09df: Unknown result type (might be due to invalid IL or missing references) //IL_09e4: Unknown result type (might be due to invalid IL or missing references) //IL_09e9: Unknown result type (might be due to invalid IL or missing references) //IL_09fd: Unknown result type (might be due to invalid IL or missing references) //IL_0a12: Unknown result type (might be due to invalid IL or missing references) //IL_0a17: Unknown result type (might be due to invalid IL or missing references) //IL_0a1c: Unknown result type (might be due to invalid IL or missing references) //IL_0a30: Unknown result type (might be due to invalid IL or missing references) //IL_0a35: Unknown result type (might be due to invalid IL or missing references) //IL_094c: Unknown result type (might be due to invalid IL or missing references) //IL_0951: Unknown result type (might be due to invalid IL or missing references) //IL_0963: Unknown result type (might be due to invalid IL or missing references) //IL_0968: Unknown result type (might be due to invalid IL or missing references) //IL_0978: Unknown result type (might be due to invalid IL or missing references) //IL_097d: Unknown result type (might be due to invalid IL or missing references) //IL_0991: Unknown result type (might be due to invalid IL or missing references) //IL_0996: Unknown result type (might be due to invalid IL or missing references) //IL_0a58: Unknown result type (might be due to invalid IL or missing references) //IL_0a5d: Unknown result type (might be due to invalid IL or missing references) //IL_0a7e: Unknown result type (might be due to invalid IL or missing references) //IL_0a99: Unknown result type (might be due to invalid IL or missing references) //IL_0a9e: Unknown result type (might be due to invalid IL or missing references) //IL_0aa3: Unknown result type (might be due to invalid IL or missing references) //IL_0b42: Unknown result type (might be due to invalid IL or missing references) //IL_0b57: Unknown result type (might be due to invalid IL or missing references) //IL_0b5c: Unknown result type (might be due to invalid IL or missing references) //IL_0b61: Unknown result type (might be due to invalid IL or missing references) //IL_0b75: Unknown result type (might be due to invalid IL or missing references) //IL_0b8a: Unknown result type (might be due to invalid IL or missing references) //IL_0b8f: Unknown result type (might be due to invalid IL or missing references) //IL_0b94: Unknown result type (might be due to invalid IL or missing references) //IL_0ba8: Unknown result type (might be due to invalid IL or missing references) //IL_0bbd: Unknown result type (might be due to invalid IL or missing references) //IL_0bc2: Unknown result type (might be due to invalid IL or missing references) //IL_0bc7: Unknown result type (might be due to invalid IL or missing references) //IL_0bdb: Unknown result type (might be due to invalid IL or missing references) //IL_0bf0: Unknown result type (might be due to invalid IL or missing references) //IL_0bf5: Unknown result type (might be due to invalid IL or missing references) //IL_0bfa: Unknown result type (might be due to invalid IL or missing references) //IL_0adf: Unknown result type (might be due to invalid IL or missing references) //IL_0ae4: Unknown result type (might be due to invalid IL or missing references) //IL_0af6: Unknown result type (might be due to invalid IL or missing references) //IL_0afb: Unknown result type (might be due to invalid IL or missing references) //IL_0b0d: Unknown result type (might be due to invalid IL or missing references) //IL_0b12: Unknown result type (might be due to invalid IL or missing references) //IL_0b22: Unknown result type (might be due to invalid IL or missing references) //IL_0b27: Unknown result type (might be due to invalid IL or missing references) //IL_0c1b: Unknown result type (might be due to invalid IL or missing references) //IL_0c36: Unknown result type (might be due to invalid IL or missing references) //IL_0c3b: Unknown result type (might be due to invalid IL or missing references) //IL_0c40: Unknown result type (might be due to invalid IL or missing references) //IL_0c54: Unknown result type (might be due to invalid IL or missing references) //IL_0c6f: Unknown result type (might be due to invalid IL or missing references) //IL_0c74: Unknown result type (might be due to invalid IL or missing references) //IL_0c79: Unknown result type (might be due to invalid IL or missing references) //IL_0d20: Unknown result type (might be due to invalid IL or missing references) //IL_0d35: Unknown result type (might be due to invalid IL or missing references) //IL_0d3a: Unknown result type (might be due to invalid IL or missing references) //IL_0d3f: Unknown result type (might be due to invalid IL or missing references) //IL_0d53: Unknown result type (might be due to invalid IL or missing references) //IL_0d58: Unknown result type (might be due to invalid IL or missing references) //IL_0d6c: Unknown result type (might be due to invalid IL or missing references) //IL_0d71: Unknown result type (might be due to invalid IL or missing references) //IL_0d85: Unknown result type (might be due to invalid IL or missing references) //IL_0d9a: Unknown result type (might be due to invalid IL or missing references) //IL_0d9f: Unknown result type (might be due to invalid IL or missing references) //IL_0da4: Unknown result type (might be due to invalid IL or missing references) //IL_0cb7: Unknown result type (might be due to invalid IL or missing references) //IL_0cbc: Unknown result type (might be due to invalid IL or missing references) //IL_0cd0: Unknown result type (might be due to invalid IL or missing references) //IL_0cd5: Unknown result type (might be due to invalid IL or missing references) //IL_0ce9: Unknown result type (might be due to invalid IL or missing references) //IL_0cee: Unknown result type (might be due to invalid IL or missing references) //IL_0d00: Unknown result type (might be due to invalid IL or missing references) //IL_0d05: Unknown result type (might be due to invalid IL or missing references) //IL_0e23: Unknown result type (might be due to invalid IL or missing references) //IL_0dc7: Unknown result type (might be due to invalid IL or missing references) //IL_0dcc: Unknown result type (might be due to invalid IL or missing references) //IL_0de2: Unknown result type (might be due to invalid IL or missing references) //IL_0de7: Unknown result type (might be due to invalid IL or missing references) base.Invalidate(polygonsChanged); if (m_LastKnownExtents != ((Bounds)(ref localBounds)).extents) { ((Component)this).transform.localPosition = m_LastKnownPosition; if (((Bounds)(ref localBounds)).extents.y > m_LastKnownExtents.y) { numSteps++; m_LastKnownExtents = ((Bounds)(ref localBounds)).extents; Invalidate(polygonsChanged: true); return; } if (((Bounds)(ref localBounds)).extents.y < m_LastKnownExtents.y) { numSteps--; if (numSteps < 1) { numSteps = 1; } m_LastKnownExtents = ((Bounds)(ref localBounds)).extents; Invalidate(polygonsChanged: true); return; } } List<Vector3> list = new List<Vector3>(); Vector3 val = default(Vector3); Vector3 val2 = default(Vector3); Vector3 val3 = default(Vector3); val.z = angleOfCurve / (float)numSteps; if (counterClockwise) { val.z *= -1f; } int count = list.Count; val2.x = innerRadius; for (int i = 0; i < numSteps + 1; i++) { float num = ((i != 0) ? 0f : addToFirstStep); val3 = Quaternion.Euler(val * (float)i) * val2; list.Add(new Vector3(val3.x, val2.z - num, val3.y)); if (curvedWall) { val2.z = stepHeight * (float)numSteps; } else { val2.z += stepHeight; } list.Add(new Vector3(val3.x, val2.z, val3.y)); } int count2 = list.Count; val2.x = innerRadius + stepWidth; val2.z = 0f; for (int j = 0; j < numSteps + 1; j++) { float num = ((j != 0) ? 0f : addToFirstStep); val3 = Quaternion.Euler(val * (float)j) * val2; list.Add(new Vector3(val3.x, val2.z - num, val3.y)); if (curvedWall) { val2.z = stepHeight * (float)numSteps; } else { val2.z += stepHeight; } list.Add(new Vector3(val3.x, val2.z, val3.y)); } int count3 = list.Count; val2.x = innerRadius; val2.z = 0f; for (int k = 0; k < numSteps + 1; k++) { val3 = Quaternion.Euler(val * (float)k) * val2; list.Add(new Vector3(val3.x, val2.z - addToFirstStep, val3.y)); } int count4 = list.Count; val2.x = innerRadius + stepWidth; for (int l = 0; l < numSteps + 1; l++) { val3 = Quaternion.Euler(val * (float)l) * val2; list.Add(new Vector3(val3.x, val2.z - addToFirstStep, val3.y)); } int num2 = 0; int num3 = 1; int num4 = 2; int num5 = 3; if (counterClockwise) { num2 = 2; num3 = 1; num4 = 0; num5 = 3; } if (curvedWall) { slopedFloor = false; slopedCeiling = false; } if (fillToBottom) { slopedCeiling = false; } if (slopedFloor || slopedCeiling) { base.IsNoCSG = true; } Bounds val4 = default(Bounds); int brushCount = BrushCount; for (int m = 0; m < brushCount; m++) { generatedBrushes[m].Mode = base.Mode; generatedBrushes[m].IsNoCSG = base.IsNoCSG; generatedBrushes[m].IsVisible = base.IsVisible; generatedBrushes[m].HasCollision = base.HasCollision; Polygon[] polygons = generatedBrushes[m].GetPolygons(); Vertex[] vertices = polygons[5].Vertices; if (slopedFloor) { vertices[num2].Position = list[count2 + m * 2 + 2 + 1]; vertices[num3].Position = list[count2 + m * 2 + 1]; vertices[num4].Position = list[count + m * 2 + 1]; vertices[num5].Position = list[count + m * 2 + 2 + 1]; } else { vertices[num2].Position = list[count2 + m * 2 + 2]; vertices[num3].Position = list[count2 + m * 2 + 1]; vertices[num4].Position = list[count + m * 2 + 1]; vertices[num5].Position = list[count + m * 2 + 2]; } GenerateNormals(polygons[5]); GenerateUvCoordinates(polygons[5]); vertices = polygons[3].Vertices; if (fillToBottom) { vertices[num2].Position = list[count2 + m * 2 + 1]; vertices[num3].Position = list[count4 + m]; vertices[num4].Position = list[count3 + m]; vertices[num5].Position = list[count + m * 2 + 1]; } else { vertices[num2].Position = list[count2 + m * 2 + 1]; vertices[num3].Position = list[count2 + m * 2 + 1] - new Vector3(0f, stepHeight, 0f); vertices[num4].Position = list[count + m * 2 + 1] - new Vector3(0f, stepHeight, 0f); vertices[num5].Position = list[count + m * 2 + 1]; } if (slopedCeiling) { Vertex obj = vertices[num3]; obj.Position -= new Vector3(0f, stepHeight, 0f); Vertex obj2 = vertices[num4]; obj2.Position -= new Vector3(0f, stepHeight, 0f); } GenerateNormals(polygons[3]); GenerateUvCoordinates(polygons[3]); vertices = polygons[1].Vertices; if (fillToBottom) { vertices[num2].Position = list[count3 + m + 1]; vertices[num3].Position = list[count + m * 2 + 2]; vertices[num4].Position = list[count + m * 2 + 1]; vertices[num5].Position = list[count3 + m]; } else { vertices[num2].Position = list[count + m * 2 + 2] - new Vector3(0f, stepHeight, 0f); vertices[num3].Position = list[count + m * 2 + 2]; vertices[num4].Position = list[count + m * 2 + 1]; vertices[num5].Position = list[count + m * 2 + 1] - new Vector3(0f, stepHeight, 0f); } if (slopedFloor) { vertices[num3].Position = list[count + m * 2 + 2 + 1]; } if (slopedCeiling) { vertices[num5].Position = list[count + m * 2 + 1] - new Vector3(0f, stepHeight * 2f, 0f); } GenerateNormals(polygons[1]); GenerateUvCoordinates(polygons[1]); vertices = polygons[2].Vertices; if (fillToBottom) { vertices[num2].Position = list[count2 + m * 2 + 2]; vertices[num3].Position = list[count4 + m + 1]; vertices[num4].Position = list[count4 + m]; vertices[num5].Position = list[count2 + m * 2 + 1]; } else { vertices[num2].Position = list[count2 + m * 2 + 2]; vertices[num3].Position = list[count2 + m * 2 + 2] - new Vector3(0f, stepHeight, 0f); vertices[num4].Position = list[count2 + m * 2 + 1] - new Vector3(0f, stepHeight, 0f); vertices[num5].Position = list[count2 + m * 2 + 1]; } if (slopedFloor) { vertices[num2].Position = list[count2 + m * 2 + 2 + 1]; } if (slopedCeiling) { vertices[num4].Position = list[count2 + m * 2 + 1] - new Vector3(0f, stepHeight * 2f, 0f); } GenerateNormals(polygons[2]); GenerateUvCoordinates(polygons[2]); vertices = polygons[4].Vertices; if (fillToBottom) { vertices[num2].Position = list[count4 + m]; vertices[num3].Position = list[count4 + m + 1]; vertices[num4].Position = list[count3 + m + 1]; vertices[num5].Position = list[count3 + m]; } else { vertices[num2].Position = list[count2 + m * 2 + 1] - new Vector3(0f, stepHeight, 0f); vertices[num3].Position = list[count2 + m * 2 + 2] - new Vector3(0f, stepHeight, 0f); vertices[num4].Position = list[count + m * 2 + 2] - new Vector3(0f, stepHeight, 0f); vertices[num5].Position = list[count + m * 2 + 1] - new Vector3(0f, stepHeight, 0f); } if (slopedCeiling) { vertices[num2].Position = list[count2 + m * 2 + 1] - new Vector3(0f, stepHeight * 2f, 0f); vertices[num5].Position = list[count + m * 2 + 1] - new Vector3(0f, stepHeight * 2f, 0f); } GenerateNormals(polygons[4]); GenerateUvCoordinates(polygons[4]); vertices = polygons[0].Vertices; if (fillToBottom) { vertices[num2].Position = list[count4 + m + 1]; vertices[num3].Position = list[count2 + m * 2 + 2]; vertices[num4].Position = list[count + m * 2 + 2]; vertices[num5].Position = list[count3 + m + 1]; } else { vertices[num2].Position = list[count2 + m * 2 + 2] - new Vector3(0f, stepHeight, 0f); vertices[num3].Position = list[count2 + m * 2 + 2]; vertices[num4].Position = list[count + m * 2 + 2]; vertices[num5].Position = list[count + m * 2 + 2] - new Vector3(0f, stepHeight, 0f); } if (slopedFloor) { vertices[num3].Position = list[count2 + m * 2 + 2 + 1]; vertices[num4].Position = list[count + m * 2 + 2 + 1]; } GenerateNormals(polygons[0]); GenerateUvCoordinates(polygons[0]); generatedBrushes[m].Invalidate(polygonsChanged: true); ((Bounds)(ref val4)).Encapsulate(generatedBrushes[m].GetBounds()); } localBounds = val4; m_LastKnownExtents = ((Bounds)(ref localBounds)).extents; m_LastKnownPosition = ((Component)this).transform.localPosition; UpdateGeneratedHierarchyName(); } private void GenerateUvCoordinates(Polygon polygon) { //IL_0017: Unknown result type (might be due to invalid IL or missing references) //IL_001c: Unknown result type (might be due to invalid IL or missing references) //IL_0021: Unknown result type (might be due to invalid IL or missing references) Vertex[] vertices = polygon.Vertices; foreach (Vertex vertex in vertices) { vertex.UV = GeometryHelper.GetUVForPosition(polygon, vertex.Position); } } private void GenerateNormals(Polygon polygon) { //IL_000b: Unknown result type (might be due to invalid IL or missing references) //IL_0018: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_0045: Unknown result type (might be due to invalid IL or missing references) //IL_004a: Unknown result type (might be due to invalid IL or missing references) Plane val = default(Plane); ((Plane)(ref val))..ctor(polygon.Vertices[1].Position, polygon.Vertices[2].Position, polygon.Vertices[3].Position); Vertex[] vertices = polygon.Vertices; foreach (Vertex vertex in vertices) { vertex.Normal = ((Plane)(ref val)).normal; } } } [ExecuteInEditMode] public class HollowBoxBrush : CompoundBrush { [SerializeField] private float wallThickness = 0.25f; public float WallThickness { get { return wallThickness; } set { wallThickness = value; } } public override string BeautifulBrushName => "Hollow Box Brush"; public override int BrushCount => (!IsBrushXYZTooSmall) ? 1 : 2; public bool IsBrushXYZTooSmall => ((Bounds)(ref localBounds)).size.x > wallThickness * 2f && ((Bounds)(ref localBounds)).size.z > wallThickness * 2f && ((Bounds)(ref localBounds)).size.y > wallThickness * 2f; public override void UpdateVisibility() { } public override void Invalidate(bool polygonsChanged) { //IL_0170: Unknown result type (might be due to invalid IL or missing references) //IL_00ad: Unknown result type (might be due to invalid IL or missing references) //IL_00db: Unknown result type (might be due to invalid IL or missing references) //IL_0104: Unknown result type (might be due to invalid IL or missing references) //IL_0109: Unknown result type (might be due to invalid IL or missing references) base.Invalidate(polygonsChanged); for (int i = 0; i < BrushCount; i++) { generatedBrushes[i].Mode = base.Mode; generatedBrushes[i].IsNoCSG = base.IsNoCSG; generatedBrushes[i].IsVisible = base.IsVisible; generatedBrushes[i].HasCollision = base.HasCollision; } if (IsBrushXYZTooSmall) { generatedBrushes[0].Mode = CSGMode.Add; BrushUtility.Resize(generatedBrushes[0], ((Bounds)(ref localBounds)).size); generatedBrushes[1].Mode = CSGMode.Subtract; BrushUtility.Resize(generatedBrushes[1], ((Bounds)(ref localBounds)).size - new Vector3(wallThickness * 2f, wallThickness * 2f, wallThickness * 2f)); for (int j = 0; j < BrushCount; j++) { generatedBrushes[j].SetPolygons(GeneratePolys(j)); generatedBrushes[j].Invalidate(polygonsChanged: true); } } else { BrushUtility.Resize(generatedBrushes[0], ((Bounds)(ref localBounds)).size); } } private Polygon[] GeneratePolys(int index) { Polygon[] polygons = generatedBrushes[index].GetPolygons(); for (int i = 0; i < 6; i++) { polygons[i].ResetVertexNormals(); polygons[i].GenerateUvCoordinates(); } return polygons; } } } namespace Sabresaurus.SabreCSG.ShapeEditor { public static class Bezier { public static Vector3 GetPoint(Vector3 p0, Vector3 p1, Vector3 p2, Vector3 p3, float t) { //IL_0018: Unknown result type (might be due to invalid IL or missing references) //IL_0019: Unknown result type (might be due to invalid IL or missing references) //IL_002a: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) //IL_0030: Unknown result type (might be due to invalid IL or missing references) //IL_0042: Unknown result type (might be due to invalid IL or missing references) //IL_0043: Unknown result type (might be due to invalid IL or missing references) //IL_0048: Unknown result type (might be due to invalid IL or missing references) //IL_0055: Unknown result type (might be due to invalid IL or missing references) //IL_0056: Unknown result type (might be due to invalid IL or missing references) //IL_005b: Unknown result type (might be due to invalid IL or missing references) //IL_0060: Unknown result type (might be due to invalid IL or missing references) //IL_0066: Unknown result type (might be due to invalid IL or missing references) t = Mathf.Clamp01(t); float num = 1f - t; return num * num * num * p0 + 3f * num * num * t * p1 + 3f * num * t * t * p2 + t * t * t * p3; } public static Vector3 GetPoint(Vector3 p0, Vector3 p1, Vector3 p2, float t) { //IL_0014: Unknown result type (might be due to invalid IL or missing references) //IL_0015: Unknown result type (might be due to invalid IL or missing references) //IL_0023: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Unknown result type (might be due to invalid IL or missing references) //IL_0029: Unknown result type (might be due to invalid IL or missing references) //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_0032: Unknown result type (might be due to invalid IL or missing references) //IL_0037: Unknown result type (might be due to invalid IL or missing references) //IL_003c: Unknown result type (might be due to invalid IL or missing references) //IL_0042: Unknown result type (might be due to invalid IL or missing references) t = Mathf.Clamp01(t); float num = 1f - t; return num * num * p0 + 2f * num * t * p1 + t * t * p2; } } } namespace Sabresaurus.SabreCSG.ShapeEditor.Decomposition { public static class BayazitDecomposer { private static class MathUtils { public static float Area(Vector2 a, Vector2 b, Vector2 c) { return Area(ref a, ref b, ref c); } public static float Area(ref Vector2 a, ref Vector2 b, ref Vector2 c) { return a.x * (b.y - c.y) + b.x * (c.y - a.y) + c.x * (a.y - b.y); } public static bool FloatEquals(float value1, float value2) { return Math.Abs(value1 - value2) <= SettingsEpsilon; } public static bool Collinear(ref Vector2 a, ref Vector2 b, ref Vector2 c) { return Collinear(ref a, ref b, ref c, 0f); } public static bool Collinear(ref Vector2 a, ref Vector2 b, ref Vector2 c, float tolerance) { return FloatInRange(Area(ref a, ref b, ref c), 0f - tolerance, tolerance); } public static bool FloatInRange(float value, float min, float max) { return value >= min && value <= max; } public static int NextIndex(Vector2[] vertices, int index) { return (index + 1 <= vertices.Length - 1) ? (index + 1) : 0; } public static int PreviousIndex(Vector2[] vertices, int index) { return (index - 1 >= 0) ? (index - 1) : (vertices.Length - 1); } } private static class LineTools { public static Vector2 LineIntersect(Vector2 p1, Vector2 p2, Vector2 q1, Vector2 q2) { //IL_0001: Unknown result type (might be due to invalid IL or missing references) //IL_0006: Unknown result type (might be due to invalid IL or missing references) //IL_00b8: Unknown result type (might be due to invalid IL or missing references) //IL_00b9: Unknown result type (might be due to invalid IL or missing references) //IL_00c0: Unknown result type (might be due to invalid IL or missing references) Vector2 zero = Vector2.zero; float num = p2.y - p1.y; float num2 = p1.x - p2.x; float num3 = num * p1.x + num2 * p1.y; float num4 = q2.y - q1.y; float num5 = q1.x - q2.x; float num6 = num4 * q1.x + num5 * q1.y; float num7 = num * num5 - num4 * num2; if (!MathUtils.FloatEquals(num7, 0f)) { zero.x = (num5 * num3 - num2 * num6) / num7; zero.y = (num * num6 - num4 * num3) / num7; } return zero; } public static bool LineIntersect(Vector2 point1, Vector2 point2, Vector2 point3, Vector2 point4, out Vector2 intersectionPoint) { return LineIntersect(ref point1, ref point2, ref point3, ref point4, firstIsSegment: true, secondIsSegment: true, out intersectionPoint); } public static bool LineIntersect(Vector2 point1, Vector2 point2, Vector2 point3, Vector2 point4, bool firstIsSegment, bool secondIsSegment, out Vector2 intersectionPoint) { return LineIntersect(ref point1, ref point2, ref point3, ref point4, firstIsSegment, secondIsSegment, out intersectionPoint); } public static bool LineIntersect(ref Vector2 point1, ref Vector2 point2, ref Vector2 point3, ref Vector2 point4, bool firstIsSegment, bool secondIsSegment, out Vector2 point) { //IL_0003: Unknown result type (might be due to invalid IL or missing references) point = default(Vector2); float num = point4.y - point3.y; float num2 = point2.x - point1.x; float num3 = point4.x - point3.x; float num4 = point2.y - point1.y; float num5 = num * num2 - num3 * num4; if (!(num5 >= 0f - SettingsEpsilon) || !(num5 <= SettingsEpsilon)) { float num6 = point1.y - point3.y; float num7 = point1.x - point3.x; float num8 = 1f / num5; float num9 = num3 * num6 - num * num7; num9 *= num8; if (!firstIsSegment || (num9 >= 0f && num9 <= 1f)) { float num10 = num2 * num6 - num4 * num7; num10 *= num8; if ((!secondIsSegment || (num10 >= 0f && num10 <= 1f)) && (num9 != 0f || num10 != 0f)) { point.x = point1.x + num9 * num2; point.y = point1.y + num9 * num4; return true; } } } return false; } } private static class SimplifyTools { public static Vector2[] CollinearSimplify(Vector2[] vertices, float collinearityTolerance) { //IL_0037: Unknown result type (might be due to invalid IL or missing references) //IL_003c: Unknown result type (might be due to invalid IL or missing references) //IL_0045: Unknown result type (might be due to invalid IL or missing references) //IL_004a: Unknown result type (might be due to invalid IL or missing references) //IL_0054: Unknown result type (might be due to invalid IL or missing references) //IL_0059: Unknown result type (might be due to invalid IL or missing references) //IL_0072: Unknown result type (might be due to invalid IL or missing references) if (vertices.Length < 3) { return vertices; } List<Vector2> list = new List<Vector2>(); for (int i = 0; i < vertices.Length; i++) { int num = MathUtils.PreviousIndex(vertices, i); int num2 = MathUtils.NextIndex(vertices, i); Vector2 a = vertices[num]; Vector2 b = vertices[i]; Vector2 c = vertices[num2]; if (!MathUtils.Collinear(ref a, ref b, ref c, collinearityTolerance)) { list.Add(b); } } return list.ToArray(); } } public static float SettingsEpsilon = 0.0001f; public static int MaxPolygonVertices = 1024; private static Vector2 At(int i, Vector2[] vertices) { //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0025: Unknown result type (might be due to invalid IL or missing references) //IL_002b: Unknown result type (might be due to invalid IL or missing references) int num = vertices.Length; return vertices[(i >= 0) ? (i % num) : (num - -i % num)]; } private static Vector2[] Copy(int i, int j, Vector2[] vertices) { //IL_0023: Unknown result type (might be due to invalid IL or missing references) List<Vector2> list = new List<Vector2>(); while (j < i) { j += vertices.Length; } while (i <= j) { list.Add(At(i, vertices)); i++; } return list.ToArray(); } public static List<Vector2[]> ConvexPartition(Vector2[] vertices) { //IL_0009: Unknown result type (might be due to invalid IL or missing references) //IL_0011: Unknown result type (might be due to invalid IL or missing references) //IL_004a: Unknown result type (might be due to invalid IL or missing references) //IL_0052: Unknown result type (might be due to invalid IL or missing references) //IL_005a: Unknown result type (might be due to invalid IL or missing references) //IL_0104: Unknown result type (might be due to invalid IL or missing references) //IL_010c: Unknown result type (might be due to invalid IL or missing references) //IL_0116: Unknown result type (might be due to invalid IL or missing references) //IL_006e: Unknown result type (might be due to invalid IL or missing references) //IL_0076: Unknown result type (might be due to invalid IL or missing references) //IL_0080: Unknown result type (might be due to invalid IL or missing references) //IL_01da: Unknown result type (might be due to invalid IL or missing references) //IL_01dc: Unknown result type (might be due to invalid IL or missing references) //IL_01de: Unknown result type (might be due to invalid IL or missing references) //IL_01e8: Unknown result type (might be due to invalid IL or missing references) //IL_01ed: Unknown result type (might be due to invalid IL or missing references) //IL_0202: Unknown result type (might be due to invalid IL or missing references) //IL_021c: Unknown result type (might be due to invalid IL or missing references) //IL_012a: Unknown result type (might be due to invalid IL or missing references) //IL_0132: Unknown result type (might be due to invalid IL or missing references) //IL_013a: Unknown result type (might be due to invalid IL or missing references) //IL_0095: Unknown result type (might be due to invalid IL or missing references) //IL_009d: Unknown result type (might be due to invalid IL or missing references) //IL_00a5: Unknown result type (might be due to invalid IL or missing references) //IL_00af: Unknown result type (might be due to invalid IL or missing references) //IL_00b4: Unknown result type (might be due to invalid IL or missing references) //IL_00b9: Unknown result type (might be due to invalid IL or missing references) //IL_00c0: Unknown result type (might be due to invalid IL or missing references) //IL_00c8: Unknown result type (might be due to invalid IL or missing references) //IL_00cd: Unknown result type (might be due to invalid IL or missing references) //IL_014f: Unknown result type (might be due to invalid IL or missing references) //IL_0157: Unknown result type (might be due to invalid IL or missing references) //IL_015f: Unknown result type (might be due to invalid IL or missing references) //IL_0169: Unknown result type (might be due to invalid IL or missing references) //IL_016e: Unknown result type (might be due to invalid IL or missing references) //IL_0173: Unknown result type (might be due to invalid IL or missing references) //IL_017a: Unknown result type (might be due to invalid IL or missing references) //IL_0182: Unknown result type (might be due to invalid IL or missing references) //IL_0187: Unknown result type (might be due to invalid IL or missing references) //IL_00dd: Unknown result type (might be due to invalid IL or missing references) //IL_00e2: Unknown result type (might be due to invalid IL or missing references) //IL_0197: Unknown result type (might be due to invalid IL or missing references) //IL_019c: Unknown result type (might be due to invalid IL or missing references) //IL_00f4: Unknown result type (might be due to invalid IL or missing references) //IL_00f6: Unknown result type (might be due to invalid IL or missing references) //IL_01b2: Unknown result type (might be due to invalid IL or missing references) //IL_01b4: Unknown result type (might be due to invalid IL or missing references) //IL_0272: Unknown result type (might be due to invalid IL or missing references) //IL_027a: Unknown result type (might be due to invalid IL or missing references) //IL_02a1: Unknown result type (might be due to invalid IL or missing references) //IL_02a9: Unknown result type (might be due to invalid IL or missing references) //IL_02b1: Unknown result type (might be due to invalid IL or missing references) //IL_02c5: Unknown result type (might be due to invalid IL or missing references) //IL_02cd: Unknown result type (might be due to invalid IL or missing references) //IL_02d5: Unknown result type (might be due to invalid IL or missing references) List<Vector2[]> list = new List<Vector2[]>(); Vector2 val = default(Vector2); Vector2 val2 = default(Vector2); int num = 0; int i = 0; for (int j = 0; j < vertices.Length; j++) { if (!Reflex(j, vertices)) { continue; } float num2; float num3 = (num2 = float.MaxValue); for (int k = 0; k < vertices.Length; k++) { Vector2 val3; if (Left(At(j - 1, vertices), At(j, vertices), At(k, vertices)) && RightOn(At(j - 1, vertices), At(j, vertices), At(k - 1, vertices))) { val3 = LineTools.LineIntersect(At(j - 1, vertices), At(j, vertices), At(k, vertices), At(k - 1, vertices)); if (Right(At(j + 1, vertices), At(j, vertices), val3)) { float num4 = SquareDist(At(j, vertices), val3); if (num4 < num3) { num3 = num4; val = val3; num = k; } } } if (!Left(At(j + 1, vertices), At(j, vertices), At(k + 1, vertices)) || !RightOn(At(j + 1, vertices), At(j, vertices), At(k, vertices))) { continue; } val3 = LineTools.LineIntersect(At(j + 1, vertices), At(j, vertices), At(k, vertices), At(k + 1, vertices)); if (Left(At(j - 1, vertices), At(j, vertices), val3)) { float num4 = SquareDist(At(j, vertices), val3); if (num4 < num2) { num2 = num4; i = k; val2 = val3; } } } List<Vector2> list2; List<Vector2> list3; if (num == (i + 1) % vertices.Length) { Vector2 item = (val + val2) / 2f; list2 = Copy(j, i, vertices).ToList(); list2.Add(item); list3 = Copy(num, j, vertices).ToList(); list3.Add(item); } else { double num5 = 0.0; double num6 = num; for (; i < num; i += vertices.Length) { } for (int l = num; l <= i; l++) { if (CanSee(j, l, vertices)) { double num7 = 1f / (SquareDist(At(j, vertices), At(l, vertices)) + 1f); num7 = ((!Reflex(l, vertices)) ? (num7 + 1.0) : ((!RightOn(At(l - 1, vertices), At(l, vertices), At(j, vertices)) || !LeftOn(At(l + 1, vertices), At(l, vertices), At(j, vertices))) ? (num7 + 2.0) : (num7 + 3.0))); if (num7 > num5) { num6 = l; num5 = num7; } } } list2 = Copy(j, (int)num6, vertices).ToList(); list3 = Copy((int)num6, j, vertices).ToList(); } list.AddRange(ConvexPartition(list2.ToArray())); list.AddRange(ConvexPartition(list3.ToArray())); return list; } if (vertices.Length > MaxPolygonVertices) { List<Vector2> list2 = Copy(0, vertices.Length / 2, vertices).ToList(); List<Vector2> list3 = Copy(vertices.Length / 2, 0, vertices).ToList(); list.AddRange(ConvexPartition(list2.ToArray())); list.AddRange(ConvexPartition(list3.ToArray())); } else { list.Add(vertices); } for (int m = 0; m < list.Count; m++) { list[m] = SimplifyTools.CollinearSimplify(list[m], 0f); } for (int num8 = list.Count - 1; num8 >= 0; num8--) { if (list[num8].Length == 0) { list.RemoveAt(num8); } } return list; } private static bool CanSee(int i, int j, Vector2[] vertices) { //IL_0060: Unknown result type (might be due to invalid IL or missing references) //IL_0069: Unknown result type (might be due to invalid IL or missing references) //IL_0070: Unknown result type (might be due to invalid IL or missing references) //IL_0010: Unknown result type (might be due to invalid IL or missing references) //IL_0019: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_0081: Unknown result type (might be due to invalid IL or missing references) //IL_008a: Unknown result type (might be due to invalid IL or missing references) //IL_0091: Unknown result type (might be due to invalid IL or missing references) //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_003a: Unknown result type (might be due to invalid IL or missing references) //IL_0041: Unknown result type (might be due to invalid IL or missing references) //IL_0107: Unknown result type (might be due to invalid IL or missing references) //IL_0110: Unknown result type (might be due to invalid IL or missing references) //IL_0117: Unknown result type (might be due to invalid IL or missing references) //IL_00b7: Unknown result type (might be due to invalid IL or missing references) //IL_00c0: Unknown result type (might be due to invalid IL or missing references) //IL_00c7: Unknown result type (might be due to invalid IL or missing references) //IL_0128: Unknown result type (might be due to invalid IL or missing references) //IL_0131: Unknown result type (might be due to invalid IL or missing references) //IL_0138: Unknown result type (might be due to invalid IL or missing references) //IL_00d8: Unknown result type (might be due to invalid IL or missing references) //IL_00e1: Unknown result type (might be due to invalid IL or missing references) //IL_00e8: Unknown result type (might be due to invalid IL or missing references) //IL_0187: Unknown result type (might be due to invalid IL or missing references) //IL_018e: Unknown result type (might be due to invalid IL or missing references) //IL_0195: Unknown result type (might be due to invalid IL or missing references) //IL_019e: Unknown result type (might be due to invalid IL or missing references) if (Reflex(i, vertices)) { if (LeftOn(At(i, vertices), At(i - 1, vertices), At(j, vertices)) && RightOn(At(i, vertices), At(i + 1, vertices), At(j, vertices))) { return false; } } else if (RightOn(At(i, vertices), At(i + 1, vertices), At(j, vertices)) || LeftOn(At(i, vertices), At(i - 1, vertices), At(j, vertices))) { return false; } if (Reflex(j, vertices)) { if (LeftOn(At(j, vertices), At(j - 1, vertices), At(i, vertices)) && RightOn(At(j, vertices), At(j + 1, vertices), At(i, vertices))) { return false; } } else if (RightOn(At(j, vertices), At(j + 1, vertices), At(i, vertices)) || LeftOn(At(j, vertices), At(j - 1, vertices), At(i, vertices))) { return false; } for (int k = 0; k < vertices.Length; k++) { if ((k + 1) % vertices.Length != i && k != i && (k + 1) % vertices.Length != j && k != j && LineTools.LineIntersect(At(i, vertices), At(j, vertices), At(k, vertices), At(k + 1, vertices), out var _)) { return false; } } return true; } private static bool Reflex(int i, Vector2[] vertices) { return Right(i, vertices); } private static bool Right(int i, Vector2[] vertices) { //IL_0005: Unknown result type (might be due to invalid IL or missing references) //IL_000c: Unknown result type (might be due to invalid IL or missing references) //IL_0015: Unknown result type (might be due to invalid IL or missing references) return Right(At(i - 1, vertices), At(i, vertices), At(i + 1, vertices)); } private static bool Left(Vector2 a, Vector2 b, Vector2 c) { return MathUtils.Area(ref a, ref b, ref c) > 0f; } private static bool LeftOn(Vector2 a, Vector2 b, Vector2 c) { return MathUtils.Area(ref a, ref b, ref c) >= 0f; } private static bool Right(Vector2 a, Vector2 b, Vector2 c) { return MathUtils.Area(ref a, ref b, ref c) < 0f; } private static bool RightOn(Vector2 a, Vector2 b, Vector2 c) { return MathUtils.Area(ref a, ref b, ref c) <= 0f; } private static float SquareDist(Vector2 a, Vector2 b) { float num = b.x - a.x; float num2 = b.y - a.y; return num * num + num2 * num2; } } public static class SeidelDecomposer { public static List<Vector2[]> ConvexPartition(Vector2[] vertices, float sheer) { //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_00ae: Unknown result type (might be due to invalid IL or missing references) List<Point> list = new List<Point>(vertices.Length); for (int i = 0; i < vertices.Length; i++) { Vector2 val = vertices[i]; list.Add(new Point(val.x, val.y)); } Triangulator triangulator = new Triangulator(list, sheer); List<Vector2[]> list2 = new List<Vector2[]>(); foreach (List<Point> triangle in triangulator.Triangles) { List<Vector2> list3 = new List<Vector2>(triangle.Count); foreach (Point item in triangle) { list3.Add(new Vector2(item.X, item.Y)); } list2.Add(list3.ToArray()); } return list2; } public static List<Vector2[]> ConvexPartitionTrapezoid(Vector2[] vertices, float sheer) { //IL_001b: Unknown result type (might be due to invalid IL or missing references) //IL_0020: Unknown result type (might be due to invalid IL or missing references) //IL_00b0: Unknown result type (might be due to invalid IL or missing references) List<Point> list = new List<Point>(vertices.Length); for (int i = 0; i < vertices.Length; i++) { Vector2 val = vertices[i]; list.Add(new Point(val.x, val.y)); } Triangulator triangulator = new Triangulator(list, sheer); List<Vector2[]> list2 = new List<Vector2[]>(); foreach (Trapezoid trapezoid in triangulator.Trapezoids) { List<Vector2> list3 = new List<Vector2>(); List<Point> list4 = trapezoid.Vertices(); foreach (Point item in list4) { list3.Add(new Vector2(item.X, item.Y)); } list2.Add(list3.ToArray()); } return list2; } } internal class MonotoneMountain { private const float PiSlop = 3.1f; public List<List<Point>> Triangles; private HashSet<Point> _convexPoints; private Point _head; private List<Point> _monoPoly; private bool _positive; private int _size; private Point _tail; public MonotoneMountain() { _size = 0; _tail = null; _head = null; _positive = false; _convexPoints = new HashSet<Point>(); _monoPoly = new List<Point>(); Triangles = new List<List<Point>>(); } public void Add(Point point) { if (_size == 0) { _head = point; _size = 1; } else if (_size == 1) { _tail = point; _tail.Prev = _head; _head.Next = _tail; _size = 2; } else { _tail.Next = point; point.Prev = _tail; _tail = point; _size++; } } public void Remove(Point point) { Point next = point.Next; Point prev = point.Prev; point.Prev.Next = next; point.Next.Prev = prev; _size--; } public void Process() { _positive = AngleSign(); GenMonoPoly(); Point next = _head.Next; while (next.Neq(_tail)) { float num = Angle(next); if (num >= 3.1f || num <= -3.1f || (double)num == 0.0) { Remove(next); } else if (IsConvex(next)) { _convexPoints.Add(next); } next = next.Next; } Triangulate(); } private void Triangulate() { while (_convexPoints.Count != 0) { IEnumerator<Point> enumerator = _convexPoints.GetEnumerator(); enumerator.MoveNext(); Point current = enumerator.Current; _convexPoints.Remove(current); Point prev = current.Prev; Point item = current; Point next = current.Next; List<Point> list = new List<Point>(3); list.Add(prev); list.Add(item); list.Add(next); Triangles.Add(list); Remove(current); if (Valid(prev)) { _convexPoints.Add(prev); } if (Valid(next)) { _convexPoints.Add(next); } } Debug.Assert(_size <= 3, "Triangulation bug, please report"); } private bool Valid(Point p) { return p.Neq(_head) && p.Neq(_tail) && IsConvex(p); } private void GenMonoPoly() { for (Point point = _head; point != null; point = point.Next) { _monoPoly.Add(point); } } private float Angle(Point p) { Point point = p.Next - p; Point p2 = p.Prev - p; return (float)Math.Atan2(point.Cross(p2), point.Dot(p2)); } private bool AngleSign() { Point point = _head.Next - _head; Point p = _tail - _head; return Math.Atan2(point.Cross(p), point.Dot(p)) >= 0.0; } private bool IsConvex(Point p) { if (_positive != Angle(p) >= 0f) { return false; } return true; } } internal abstract class Node { protected Node LeftChild; public List<Node> ParentList; protected Node RightChild; protected Node(Node left, Node right) { ParentList = new List<Node>(); LeftChild = left; RightChild = right; left?.ParentList.Add(this); right?.ParentList.Add(this); } public abstract Sink Locate(Edge s); public void Replace(Node node) { foreach (Node parent in node.ParentList) { if (parent.LeftChild == node) { parent.LeftChild = this; } else { parent.RightChild = this; } } ParentList.AddRange(node.ParentList); } } internal class QueryGraph { private Node _head; public QueryGraph(Node head) { _head = head; } private Trapezoid Locate(Edge edge) { return _head.Locate(edge).Trapezoid; } public List<Trapezoid> FollowEdge(Edge edge) { List<Trapezoid> list = new List<Trapezoid>(); list.Add(Locate(edge)); for (int i = 0; edge.Q.X > list[i].RightPoint.X; i++) { if (edge.IsAbove(list[i].RightPoint)) { list.Add(list[i].UpperRight); } else { list.Add(list[i].LowerRight); } } return list; } private void Replace(Sink sink, Node node) { if (sink.ParentList.Count == 0) { _head = node; } else { node.Replace(sink); } } public void Case1(Sink sink, Edge edge, Trapezoid[] tList) { YNode lChild = new YNode(edge, Sink.Isink(tList[1]), Sink.Isink(tList[2])); XNode rChild = new XNode(edge.Q, lChild, Sink.Isink(tList[3])); XNode node = new XNode(edge.P, Sink.Isink(tList[0]), rChild); Replace(sink, node); } public void Case2(Sink sink, Edge edge, Trapezoid[] tList) { YNode rChild = new YNode(edge, Sink.Isink(tList[1]), Sink.Isink(tList[2])); XNode node = new XNode(edge.P, Sink.Isink(tList[0]), rChild); Replace(sink, node); } public void Case3(Sink sink, Edge edge, Trapezoid[] tList) { YNode node = new YNode(edge, Sink.Isink(tList[0]), Sink.Isink(tList[1])); Replace(sink, node); } public void Case4(Sink sink, Edge edge, Trapezoid[] tList) { YNode lChild = new YNode(edge, Sink.Isink(tList[0]), Sink.Isink(tList[1])); XNode node = new XNode(edge.Q, lChild, Sink.Isink(tList[2])); Replace(sink, node); } } internal class Sink : Node { public Trapezoid Trapezoid; private Sink(Trapezoid trapezoid) : base(null, null) { Trapezoid = trapezoid; trapezoid.Sink = this; } public static Sink Isink(Trapezoid trapezoid) { if (trapezoid.Sink == null) { return new Sink(trapezoid); } return trapezoid.Sink; } public override Sink Locate(Edge edge) { return this; } } internal class TrapezoidalMap { public HashSet<Trapezoid> Map; private Edge _bCross; private Edge _cross; private float _margin; public TrapezoidalMap() { Map = new HashSet<Trapezoid>(); _margin = 50f; _bCross = null; _cross = null; } public void Clear() { _bCross = null; _cross = null; } public Trapezoid[] Case1(Trapezoid t, Edge e) { Trapezoid[] array = new Trapezoid[4] { new Trapezoid(t.LeftPoint, e.P, t.Top, t.Bottom), new Trapezoid(e.P, e.Q, t.Top, e), new Trapezoid(e.P, e.Q, e, t.Bottom), new Trapezoid(e.Q, t.RightPoint, t.Top, t.Bottom) }; array[0].UpdateLeft(t.UpperLeft, t.LowerLeft); array[1].UpdateLeftRight(array[0], null, array[3], null); array[2].UpdateLeftRight(null, array[0], null, array[3]); array[3].UpdateRight(t.UpperRight, t.LowerRight); return array; } public Trapezoid[] Case2(Trapezoid t, Edge e) { Point rightPoint = ((e.Q.X != t.RightPoint.X) ? t.RightPoint : e.Q); Trapezoid[] array = new Trapezoid[3] { new Trapezoid(t.LeftPoint, e.P, t.Top, t.Bottom), new Trapezoid(e.P, rightPoint, t.Top, e), new Trapezoid(e.P, rightPoint, e, t.Bottom) }; array[0].UpdateLeft(t.UpperLeft, t.LowerLeft); array[1].UpdateLeftRight(array[0], null, t.UpperRight, null); array[2].UpdateLeftRight(null, array[0], null, t.LowerRight); _bCross = t.Bottom; _cross = t.Top; e.Above = array[1]; e.Below = array[2]; return array; } public Trapezoid[] Case3(Trapezoid t, Edge e) { Point leftPoint = ((e.P.X != t.LeftPoint.X) ? t.LeftPoint : e.P); Point rightPoint = ((e.Q.X != t.RightPoint.X) ? t.RightPoint : e.Q); Trapezoid[] array = new Trapezoid[2]; if (_cross == t.Top) { array[0] = t.UpperLeft; array[0].UpdateRight(t.UpperRight, null); array[0].RightPoint = rightPoint; } else { array[0] = new Trapezoid(leftPoint, rightPoint, t.Top, e); array[0].UpdateLeftRight(t.UpperLeft, e.Above, t.UpperRight, null); } if (_bCross == t.Bottom) { array[1] = t.LowerLeft; array[1].UpdateRight(null, t.LowerRight); array[1].RightPoint = rightPoint; } else { array[1] = new Trapezoid(leftPoint, rightPoint, e, t.Bottom); array[1].UpdateLeftRight(e.Below, t.LowerLeft, null, t.LowerRight); } _bCross = t.Bottom; _cross = t.Top; e.Above = array[0]; e.Below = array[1]; return array; } public Trapezoid[] Case4(Trapezoid t, Edge e) { Point leftPoint = ((e.P.X != t.LeftPoint.X) ? t.LeftPoint : e.P); Trapezoid[] array = new Trapezoid[3]; if (_cross == t.Top) { array[0] = t.UpperLeft; array[0].RightPoint = e.Q; } else { array[0] = new Trapezoid(leftPoint, e.Q, t.Top, e); array[0].UpdateLeft(t.UpperLeft, e.Above); } if (_bCross == t.Bottom) { array[1] = t.LowerLeft; array[1].RightPoint = e.Q; } else { array[1] = new Trapezoid(leftPoint, e.Q, e, t.Bottom); array[1].UpdateLeft(e.Below, t.LowerLeft); } array[2] = new Trapezoid(e.Q, t.RightPoint, t.Top, t.Bottom); array[2].UpdateLeftRight(array[0], array[1], t.UpperRight, t.LowerRight); return array; } public Trapezoid BoundingBox(List<Edge> edges) { Point point = edges[0].P + _margin; Point point2 = edges[0].Q - _margin; foreach (Edge edge3 in edges) { if (edge3.P.X > point.X) { point = new Point(edge3.P.X + _margin, point.Y); } if (edge3.P.Y > point.Y) { point = new Point(point.X, edge3.P.Y + _margin); } if (edge3.Q.X > point.X) { point = new Point(edge3.Q.X + _margin, point.Y); } if (edge3.Q.Y > point.Y) { point = new Point(point.X, edge3.Q.Y + _margin); } if (edge3.P.X < point2.X) { point2 = new Point(edge3.P.X - _margin, point2.Y); } if (edge3.P.Y < point2.Y) { point2 = new Point(point2.X, edge3.P.Y - _margin); } if (edge3.Q.X < point2.X) { point2 = new Point(edge3.Q.X - _margin, point2.Y); } if (edge3.Q.Y < point2.Y) { point2 = new Point(point2.X, edge3.Q.Y - _margin); } } Edge edge = new Edge(new Point(point2.X, point.Y), new Point(point.X, point.Y)); Edge edge2 = new Edge(new Point(point2.X, point2.Y), new Point(point.X, point2.Y)); Point p = edge2.P; Point q = edge.Q; return new Trapezoid(p, q, edge, edge2); } } internal class Point { public Point Next; public Point Prev; public float X; public float Y; public Point(float x, float y) { X = x; Y = y; Next = null; Prev = null; } public static Point operator -(Point p1, Point p2) { return new Point(p1.X - p2.X, p1.Y - p2.Y); } public static Point operator +(Point p1, Point p2) { return new Point(p1.X + p2.X, p1.Y + p2.Y); } public static Point operator -(Point p1, float f) { return new Point(p1.X - f, p1.Y - f); } public static Point operator +(Point p1, float f) { return new Point(p1.X + f, p1.Y + f); } public float Cross(Point p) { return X * p.Y - Y * p.X; } public float Dot(Point p) { return X * p.X + Y * p.Y; } public bool Neq(Point p) { return p.X != X || p.Y != Y; } public float Orient2D(Point pb, Point pc) { float num = X - pc.X; float num2 = pb.X - pc.X; float num3 = Y - pc.Y; float num4 = pb.Y - pc.Y; return num * num4 - num3 * num2; } } internal class Edge { public Trapezoid Above; public float B; public Trapezoid Below; public HashSet<Point> MPoints; public Point P; public Point Q; public float Slope; public Edge(Point p, Point q) { P = p; Q = q; if (q.X - p.X != 0f) { Slope = (q.Y - p.Y) / (q.X - p.X); } else { Slope = 0f; } B = p.Y - p.X * Slope; Above = null; Below = null; MPoints = new HashSet<Point>(); MPoints.Add(p); MPoints.Add(q); } public bool IsAbove(Point point) { return P.Orient2D(Q, point) < 0f; } public bool IsBelow(Point point) { return P.Orient2D(Q, point) > 0f; } public void AddMpoint(Point point) { foreach (Point mPoint in MPoints) { if (!mPoint.Neq(point)) { return; } } MPoints.Add(point); } } internal class Trapezoid { public Edge Bottom; public bool Inside; public Point LeftPoint; public Trapezoid LowerLeft; public Trapezoid LowerRight; public Point RightPoint; public Sink Sink; public Edge Top; public Trapezoid UpperLeft; public Trapezoid UpperRight; public Trapezoid(Point leftPoint, Point rightPoint, Edge top, Edge bottom) { LeftPoint = leftPoint; RightPoint = rightPoint; Top = top; Bottom = bottom; UpperLeft = null; UpperRight = null; LowerLeft = null; LowerRight = null; Inside = true; Sink = null; } public void UpdateLeft(Trapezoid ul, Trapezoid ll) { UpperLeft = ul; if (ul != null) { ul.UpperRight = this; } LowerLeft = ll; if (ll != null) { ll.LowerRight = this; } } public void UpdateRight(Trapezoid ur, Trapezoid lr) { UpperRight = ur; if (ur != null) { ur.UpperLeft = this; } LowerRight = lr; if (lr != null) { lr.LowerLeft = this; } } public void UpdateLeftRight(Trapezoid ul, Trapezoid ll, Trapezoid ur, Trapezoid lr) { UpperLeft = ul; if (ul != null) { ul.UpperRight = this; } LowerLeft = ll; if (ll != null) { ll.LowerRight = this; } UpperRight = ur; if (ur != null) { ur.UpperLeft = this; } LowerRight = lr; if (lr != null) { lr.LowerLeft = this; } } public void TrimNeighbors() { if (Inside) { Inside = false; if (UpperLeft != null) { UpperLeft.TrimNeighbors(); } if (LowerLeft != null) { LowerLeft.TrimNeighbors(); } if (UpperRight != null) { UpperRight.TrimNeighbors(); } if (LowerRight != null) { LowerRight.TrimNeighbors(); } } } public bool Contains(Point point) { return point.X > LeftPoint.X && point.X < RightPoint.X && Top.IsAbove(point) && Bottom.IsBelow(point); } public List<Point> Vertices() { List<Point> list = new List<Point>(4); list.Add(LineIntersect(Top, LeftPoint.X)); list.Add(LineIntersect(Bottom, LeftPoint.X)); list.Add(LineIntersect(Bottom, RightPoint.X)); list.Add(LineIntersect(Top, RightPoint.X)); return list; } private Point LineIntersect(Edge edge, float x) { float y = edge.Slope * x + edge.B; return new Point(x, y); } public void AddPoints() { if (LeftPoint != Bottom.P) { Bottom.AddMpoint(LeftPoint); } if (RightPoint != Bottom.Q) { Bottom.AddMpoint(RightPoint); } if (LeftPoint != Top.P) { Top.AddMpoint(LeftPoint); } if (RightPoint != Top.Q) { Top.AddMpoint(RightPoint); } } } internal class XNode : Node { private Point _point; public XNode(Point point, Node lChild, Node rChild) : base(lChild, rChild) { _point = point; } public override Sink Locate(Edge edge) { if (edge.P.X >= _point.X) { return RightChild.Locate(edge); } return LeftChild.Locate(edge); } } internal class YNode : Node { private Edge _edge; public YNode(Edge edge, Node lChild, Node rChild) : base(lChild, rChild) { _edge = edge; } public override Sink Locate(Edge edge) { if (_edge.IsAbove(edge.P)) { return RightChild.Locate(edge); } if (_edge.IsBelow(edge.P)) { return LeftChild.Locate(edge); } if (edge.Slope < _edge.Slope) { return RightChild.Locate(edge); } return LeftChild.Locate(edge); } } internal class Triangulator { public List<Trapezoid> Trapezoids; public List<List<Point>> Triangles; private Trapezoid _boundingBox; private List<Edge> _edgeList; private QueryGraph _queryGraph; private float _sheer = 0.001f; private TrapezoidalMap _trapezoidalMap; private List<MonotoneMountain> _xMonoPoly; public Triangulator(List<Point> polyLine, float sheer) { _sheer = sheer; Triangles = new List<List<Point>>(); Trapezoids = new List<Trapezoid>(); _xMonoPoly = new List<MonotoneMountain>(); _edgeList = InitEdges(polyLine); _trapezoidalMap = new TrapezoidalMap(); _boundingBox = _trapezoidalMap.BoundingBox(_edgeList); _queryGraph = new QueryGraph(Sink.Isink(_boundingBox)); Process(); } private void Process() { foreach (Edge edge in _edgeList) { List<Trapezoid> list = _queryGraph.FollowEdge(edge); foreach (Trapezoid item2 in list) { _trapezoidalMap.Map.Remove(item2); bool flag = item2.Contains(edge.P); bool flag2 = item2.Contains(edge.Q); Trapezoid[] array; if (flag && flag2) { array = _trapezoidalMap.Case1(item2, edge); _queryGraph.Case1(item2.Sink, edge, array); } else if (flag && !flag2) { array = _trapezoidalMap.Case2(item2, edge); _queryGraph.Case2(item2.Sink, edge, array); } else if (!flag && !flag2) { array = _trapezoidalMap.Case3(item2, edge); _queryGraph.Case3(item2.Sink, edge, array); } else { array = _trapezoidalMap.Case4(item2, edge); _queryGraph.Case4(item2.Sink, edge, array); } Trapezoid[] array2 = array; foreach (Trapezoid item in array2) { _trapezoidalMap.Map.Add(item); } } _trapezoidalMap.Clear(); } foreach (Trapezoid item3 in _trapezoidalMap.Map) { MarkOutside(item3); } foreach (Trapezoid item4 in _trapezoidalMap.Map) { if (item4.Inside) { Trapezoids.Add(item4); item4.AddPoints(); } } CreateMountains(); } private void CreateMountains() { foreach (Edge edge in _edgeList) { if (edge.MPoints.Count <= 2) { continue; } MonotoneMountain monotoneMountain = new MonotoneMountain(); List<Point> list = new List<Point>(edge.MPoints); list.Sort((Point p1, Point p2) => p1.X.CompareTo(p2.X)); foreach (Point item in list) { monotoneMountain.Add(item); } monotoneMountain.Process(); foreach (List<Point> triangle in monotoneMountain.Triangles) { Triangles.Add(triangle); } _xMonoPoly.Add(monotoneMountain); } } private void MarkOutside(Trapezoid t) { if (t.Top == _boundingBox.Top || t.Bottom == _boundingBox.Bottom) { t.TrimNeighbors(); } } private List<Edge> InitEdges(List<Point> points) { List<Edge> list = new List<Edge>(); for (int i = 0; i < points.Count - 1; i++) { list.Add(new Edge(points[i], points[i + 1])); } list.Add(new Edge(points[0], points[points.Count - 1])); return OrderSegments(list); } private List<Edge> OrderSegments(List<Edge> edgeInput) { List<Edge> list = new List<Edge>(); foreach (Edge item in edgeInput) { Point point = ShearTransform(item.P); Point point2 = ShearTransform(item.Q); if (point.X > point2.X) { list.Add(new Edge(point2, point)); } else if (point.X < point2.X) { list.Add(new Edge(point, point2)); } } Shuffle(list); return list; } private static void Shuffle<T>(IList<T> list) { Random random = new Random(); int num = list.Count; while (num > 1) { num--; int index = random.Next(num + 1); T value = list[index]; list[index] = list[num]; list[num] = value; } } private Point ShearTransform(Point point) { return new Point(point.X + _sheer * point.Y, point.Y); } } } namespace Sabresaurus.SabreCSG.ShapeEditor { public interface ISelectable { Vector2Int position { get; set; } } [Serializable] public class Pivot : ISelectable { [SerializeField] private Vector2Int _position; public Vector2Int position { get { return _position; } set { _position = value; } } } [Serializable] public class Project { [SerializeField] public int version = 1; [SerializeField] public List<Shape> shapes = new List<Shape> { new Shape() }; [SerializeField] public Pivot globalPivot = new Pivot(); [SerializeField] public bool flipHorizontally = false; [SerializeField] public bool flipVertically = false; [SerializeField] public float extrudeDepth = 1f; [SerializeField] public float extrudeClipDepth = 0.5f; [SerializeField] public Vector2 extrudeScale = Vector2.one; [SerializeField] public int revolve360 = 8; [SerializeField] public int revolveSteps = 4; [SerializeField] public int revolveDistance = 1; [SerializeField] public int revolveRadius = 1; [SerializeField] public bool revolveDirection = true; [SerializeField] public bool revolveSpiralSloped = false; [SerializeField] public bool convexBrushes = true; public Project Clone() { return JsonUtility.FromJson<Project>(JsonUtility.ToJson((object)this)); } } [Serializable] public class Segment : ISelectable { [SerializeField] private Vector2Int _position; [SerializeField] public SegmentType type = SegmentType.Linear; [SerializeField] public Pivot bezierPivot1 = new Pivot(); [SerializeField] public Pivot bezierPivot2 = new Pivot(); [SerializeField] public int bezierDetail = 3; public Vector2Int position { get { return _position; } set { _position = value; } } public Segment(int x, int y) { position = new Vector2Int(x, y); } } public enum SegmentType { Linear, Bezier } [Serializable] public class Shape { [SerializeField] public List<Segment> segments = new List<Segment> { new Segment(-8, -8), new Segment(8, -8), new Segment(8, 8), new Segment(-8, 8) }; public Pivot pivot = new Pivot(); public void CalculatePivotPosition() { Vector2Int vector2Int = default(Vector2Int); foreach (Segment segment in segments) { vector2Int += segment.position; } pivot.position = new Vector2Int(vector2Int.x / segments.Count, vector2Int.y / segments.Count); } public Shape Clone() { return JsonUtility.FromJson<Shape>(JsonUtility.ToJson((object)this)); } } [ExecuteInEditMode] public class ShapeEditorBrush : CompoundBrush { public enum ExtrudeMode { CreatePolygon, RevolveShape, ExtrudeShape, ExtrudePoint, ExtrudeBevel } [SerializeField] private Project project = JsonUtility.FromJson<Project>("{\"version\":1,\"shapes\":[{\"segments\":[{\"_position\":{\"x\":-18,\"y\":-8},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-14,\"y\":-11},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-14,\"y\":-13},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-20,\"y\":-13},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-10,\"y\":-19},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-6,\"y\":-19},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-6,\"y\":-16},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-3,\"y\":-19},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":6,\"y\":-19},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":9,\"y\":-16},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":11,\"y\":-16},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":14,\"y\":-12},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":14,\"y\":-2},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":10,\"y\":-8},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":9,\"y\":-11},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":5,\"y\":-15},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-2,\"y\":-16},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-3,\"y\":-11},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":9,\"y\":-11},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":10,\"y\":-8},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":6,\"y\":-8},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-2,\"y\":-1},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-2,\"y\":3},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":5,\"y\":6},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":12,\"y\":6},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":10,\"y\":8},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-10,\"y\":8},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3},{\"_position\":{\"x\":-18,\"y\":0},\"type\":0,\"bezierPivot1\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierPivot2\":{\"_position\":{\"x\":-2,\"y\":-6}},\"bezierDetail\":3}],\"pivot\":{\"_position\":{\"x\":0,\"y\":-8}}}],\"globalPivot\":{\"_position\":{\"x\":0,\"y\":0}},\"flipHorizontally\":false,\"flipVertically\":false,\"extrudeDepth\":1.0,\"extrudeClipDepth\":0.5,\"extrudeScale\":{\"x\":1.0,\"y\":1.0},\"revolve360\":8,\"revolveSteps\":4,\"revolveDistance\":1,\"revolveRadius\":1,\"revolveDirection\":true}"); [SerializeField] private ExtrudeMode extrudeMode = ExtrudeMode.ExtrudeShape; [SerializeField] private int desiredBrushCount; [SerializeField] private bool isDirty = true; private Vector3 m_LastKnownExtents; private Vector3 m_LastKnownPosition; private List<Polygon> m_LastBuiltPolygons; public override string BeautifulBrushName => "2D Shape Editor Brush"; public override int BrushCount { get { if (!project.convexBrushes) { return 1; } if (!isDirty) { return desiredBrushCount; } if (m_LastBuiltPolygons == null) { m_LastBuiltPolygons = BuildConvexPolygons(); } return desiredBrushCount; } } protected override void Awake() { //IL_000e: Unknown result type (might be due to invalid IL or missing references) //IL_0013: Unknown result type (might be due to invalid IL or missing references) //IL_001f: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Unknown result type (might be due to invalid IL or missing references) base.Awake(); m_LastKnownExtents = ((Bounds)(ref localBounds)).extents; m_LastKnownPosition = ((Component)this).transform.localPosition; } public override void UpdateVisibility() { } public override void Invalidate(bool polygonsChanged) { //IL_0002: Unknown result type (might be due to invalid IL or missing references) //IL_000d: Unknown result type (might be due to invalid IL or missing references) //IL_0031: Unknown result type (might be due to invalid IL or missing references) //IL_0024: Unknown result type (might be due to invalid IL or missing references) //IL_0130: Unknown result type (might be due to invalid IL or missing references) //IL_0162: Unknown result type (might be due to invalid IL or missing references) //IL_0163: Unknown result type (might be due to invalid IL or missing references) //IL_016f: Unknown result type (might be due to invalid IL or missing references) //IL_0174: Unknown result type (might be due to invalid IL or missing references) //IL_0180: Unknown result type (might be due to invalid IL or missing references) //IL_0185: Unknown result type (might be due to invalid IL or missing references) //IL_0d3c: Unknown result type (might be due to invalid IL or missing references) //IL_0d3d: Unknown result type (might be due to invalid IL or missing references) //IL_0d49: Unknown result type (might be due to invalid IL or missing references) //IL_0d4e: Unknown result type (might be due to invalid IL or missing references) //IL_0d5a: Unknown result type (might be due to invalid IL or missing references) //IL_0d5f: Unknown result type (might be due to invalid IL or missing references) //IL_0d30: Unknown result type (might be due to invalid IL or missing references) //IL_0be4: Unknown result type (might be due to invalid IL or missing references) //IL_08fd: Unknown result type (might be due to invalid IL or missing references) //IL_0a15: Unknown result type (might be due to invalid IL or missing references) //IL_0472: Unknown result type (might be due to invalid IL or missing references) //IL_047a: Unknown result type (might be due to invalid IL or missing references) //IL_04d0: Unknown result type (might be due to invalid IL or missing references) //IL_04f1: Unknown result type (might be due to invalid IL or missing references) //IL_04f6: Unknown result type (might be due to invalid IL or missing references) //IL_04fb: Unknown result type (might be due to invalid IL or missing references) //IL_0500: Unknown result type (might be due to invalid IL or missing references) //IL_0594: Unknown result type (might be due to invalid IL or missing references) //IL_059c: Unknown result type (might be due to invalid IL or missing references) //IL_05f2: Unknown result type (might be due to invalid IL or missing references) //IL_0616: Unknown result type (might be due to invalid IL or missing references) //IL_061b: Unknown result type (might be due to invalid IL or missing references) //IL_0620: Unknown result type (might be due to invalid IL or missing references) //IL_0625: Unknown result type (might be due to invalid IL or missing references) //IL_068f: Unknown result type (might be due to invalid IL or missing references) //IL_0694: Unknown result type (might be due to invalid IL or missing references) //IL_0699: Unknown result type (might be due to invalid IL or missing references) //IL_06ad: Unknown result type (might be due to invalid IL or missing references) //IL_06b2: Unknown result type (might be due to invalid IL or missing references) //IL_06b7: Unknown result type (might be due to invalid IL or missing references) //IL_06cb: Unknown result type (might be due to invalid IL or missing references) //IL_06d0: Unknown result type (might be due to invalid IL or missing references) //IL_06d5: Unknown result type (might be due to invalid IL or missing references) //IL_06e9: Unknown result type (might be due to invalid IL or missing references) //IL_06ee: Unknown result type (might be due to invalid IL or missing references) //IL_06f3: Unknown result type (might be due to invalid IL or missing references) //IL_0721: Unknown result type (might be due to invalid IL or missing references) //IL_0726: Unknown result type (might be due to invalid IL or missing references) //IL_072a: Unknown result type (might be due to invalid IL or missing references) //IL_072f: Unknown result type (might be due to invalid IL or missing references) if (m_LastKnownExtents != ((Bounds)(ref localBounds)).extents) { ((Component)this).transform.localPosition = m_LastKnownPosition; } Bounds val = default(Bounds); if (extrudeMode == ExtrudeMode.CreatePolygon) { base.IsNoCSG = true; } if (extrudeMode == ExtrudeMode.RevolveShape && project.revolveSpiralSloped && project.globalPivot.position.y != 0) { base.IsNoCSG = true; } if (!project.convexBrushes) { base.IsNoCSG = true; } if (!isDirty) { for (int i = 0; i < ((!project.convexBrushes) ? 1 : desiredBrushCount); i++) { generatedBrushes[i].Mode = base.Mode; generatedBrushes[i].IsNoCSG = base.IsNoCSG; generatedBrushes[i].IsVisible = base.IsVisible; generatedBrushes[i].HasCollision = base.HasCollision; generatedBrushes[i].Invalidate(polygonsChanged: true); ((Bounds)(ref val)).Encapsulate(generatedBrushes[i].GetBounds()); } localBounds = val; m_LastKnownExtents = ((Bounds)(ref localBounds)).extents; m_LastKnownPosition = ((Component)this).transform.localPosition; return; } base.Invalidate(polygonsChanged); isDirty = false; if (m_LastBuiltPolygons == null) { m_LastBuiltPolygons = BuildConvexPolygons();