RemoveClosePointsNode.cs 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. using PixiEditor.ChangeableDocument.Changeables.Graph.Nodes.Shapes.Data;
  2. using PixiEditor.ChangeableDocument.Rendering;
  3. using PixiEditor.DrawingApi.Core;
  4. using PixiEditor.Numerics;
  5. using ShapeData = PixiEditor.ChangeableDocument.Changeables.Graph.Nodes.Shapes.Data.ShapeData;
  6. namespace PixiEditor.ChangeableDocument.Changeables.Graph.Nodes.Shapes;
  7. [NodeInfo("RemoveClosePoints", "REMOVE_CLOSE_POINTS", Category = "SHAPE")]
  8. public class RemoveClosePointsNode : ShapeNode<PointsData>
  9. {
  10. public InputProperty<PointsData> Input { get; }
  11. public InputProperty<double> MinDistance { get; }
  12. public InputProperty<int> Seed { get; }
  13. public RemoveClosePointsNode()
  14. {
  15. Input = CreateInput<PointsData>("Input", "POINTS", null);
  16. MinDistance = CreateInput("MinDistance", "MIN_DISTANCE", 0d);
  17. Seed = CreateInput("Seed", "SEED", 0);
  18. }
  19. protected override PointsData? GetShapeData(RenderingContext context)
  20. {
  21. var data = Input.Value;
  22. var distance = MinDistance.Value;
  23. if (distance == 0 || data == null || data.Points == null)
  24. {
  25. return null;
  26. }
  27. var availablePoints = data.Points.Distinct().ToList();
  28. List<VecD> newPoints = new List<VecD>();
  29. var minDistance = MinDistance.Value;
  30. var documentSize = context.DocumentSize;
  31. var random = new Random(Seed.Value);
  32. while (availablePoints.Count > 1)
  33. {
  34. var index = random.Next(availablePoints.Count);
  35. var point = availablePoints[index];
  36. newPoints.Add(point);
  37. availablePoints.RemoveAt(index);
  38. foreach (var remove in availablePoints.Where(InRange).ToList())
  39. {
  40. availablePoints.Remove(remove);
  41. }
  42. continue;
  43. bool InRange(VecD other) =>
  44. (other - point).Length <= minDistance;
  45. }
  46. if (availablePoints.Count == 1)
  47. {
  48. newPoints.Add(availablePoints[0]);
  49. }
  50. var finalData = new PointsData(newPoints);
  51. return finalData;
  52. }
  53. public override Node CreateCopy() => new RemoveClosePointsNode();
  54. }