gpt4 book ai didi

c# - 使用 linq 查找锯齿状数组中最左边和最右边的点?

转载 作者:太空宇宙 更新时间:2023-11-03 21:24:38 26 4
gpt4 key购买 nike

我确定它在某处,但我找不到它。

我有一个标准

StrokeCollection strokes

集合中的每个笔划都由一个点数组组成。因此,这是锯齿状的点数组,Point[][]

我需要找到 StrokeCollection 中最左边和最右边的点。这是如何用 linq 完成的?

这基本上就是我正在尝试做的(没有成功):

var x = from stroke in strokes
from point in stroke
where min(point.x)
select point

如有任何帮助,我们将不胜感激。

编辑:显然直接使用墨水笔点存在一些问题,所以让

 Point[][] myStrokeCollection = new Point[strokes.Count][];
for (int i = 0; i < strokes.Count; i++)
{
// creating a one-dimensional array of StylusPoints for the i row of myStrokeCollection.
myStrokeCollection[i] = new Point[strokes[i].StylusPoints.Count];
for (int j = 0; j < strokes[i].StylusPoints.Count; j++)
{
myStrokeCollection[i][j] = new Point();
myStrokeCollection[i][j].X = strokes[i].StylusPoints[j].X;
myStrokeCollection[i][j].Y = strokes[i].StylusPoints[j].Y;
}
}

是否可以使用 linq(一次性通过?)为 myStrokeCollection 获得最左边的点 (x,y) 和最右边的点 (x,y)? (希望没有定义额外的类型)。

最佳答案

Here is what needs to be done

var leftMostVal = strokeCollection.Min(p => p.Point.Min(q => q.Min(r => r.X)));
var rightMostVal = strokeCollection.Max(p => p.Point.Max(q => q.Max(r => r.X)));

Here is fiddle https://dotnetfiddle.net/y5hZ7w

Or

public class StrokeCollection : List<Stroke>
{
}

public class Stroke : List<Point>
{
public Point[][] Points { get; set; }
}
class Program
{
static void Main(string[] args)
{
StrokeCollection lst = new StrokeCollection();


Random rnd1 = new Random(3);
Random rnd2 = new Random(13);


for (int i = 0; i < 10; i++)
{
int x = rnd1.Next(1, 5);
var s = new Stroke { Points = new Point[x][] };
foreach (var r in Enumerable.Range(0, x))
{
int y = rnd1.Next(1, 5);
s.Points[r] = new Point[y];

for (int j = 0; j < y; j++)
s.Points[r][j] = new Point(rnd2.Next(-50, 80), rnd2.Next(-20, 20));
}
lst.Add(s);
}

Point leftMostPoint = Point.Empty;
Point rightMostPoint = Point.Empty;

lst.ForEach(p1 =>
{
foreach (Point[] p2 in p1.Points)
{
foreach (var p3 in p2)
{
if (leftMostPoint == Point.Empty)
leftMostPoint = p3;

if (rightMostPoint == Point.Empty)
rightMostPoint = p3;

if (p3.X < leftMostPoint.X)
leftMostPoint = p3;

if (p3.X > rightMostPoint.X)
rightMostPoint = p3;
}
}
});

Console.WriteLine("Leftmost point " + leftMostPoint.ToString());
Console.WriteLine("Rightmost point " + rightMostPoint.ToString());
}
}

编辑:更新这是你最终需要的

    System.Windows.Ink.StrokeCollection strokeCollection; //Set it to whatever    resultant you want collection to set 

var l1 = strokeCollection.SelectMany(p => p.StylusPoints)
.GroupBy(p => p.X)
.OrderBy(p => p.Key)
.ToList();

StylusPoint leftPoint = l1.First().FirstOrDefault();
StylusPoint rightPoint = l1.Last().FirstOrDefault();

关于c# - 使用 linq 查找锯齿状数组中最左边和最右边的点?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27996711/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com