本文整理汇总了C#中Segment.GetSplitSegmentForVertecies方法的典型用法代码示例。如果您正苦于以下问题:C# Segment.GetSplitSegmentForVertecies方法的具体用法?C# Segment.GetSplitSegmentForVertecies怎么用?C# Segment.GetSplitSegmentForVertecies使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Segment
的用法示例。
在下文中一共展示了Segment.GetSplitSegmentForVertecies方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: MakeCloseSegmentsMergable
public void MakeCloseSegmentsMergable()
{
// check that we can cut up a single segment
{
List<Segment> segmentsControl = Segment.ConvertPathToSegments(new List<Point3>()
{
new Point3(0, 0),
new Point3(2500, 0),
new Point3(5000, 0),
}, false);
List<Point3> cuts = new List<Point3>()
{
new Point3(2500, 0),
new Point3(2500, 401),
};
Segment segmentToCut = new Segment()
{
Start = new Point3(0, 0),
End = new Point3(5000, 0),
};
List<Segment> segmentsTest = segmentToCut.GetSplitSegmentForVertecies(cuts, 400);
Assert.IsTrue(segmentsControl.Count == segmentsTest.Count);
for(int i=0; i<segmentsTest.Count; i++)
{
Assert.IsTrue(segmentsTest[i] == segmentsControl[i]);
}
}
// A path that needs to have points inserted to do the correct thing
{
// |\ /| |\ /|
// | \s___/ | | \____/ |
// |________| create points -> |_.____._|
int travelSpeed = 50;
int retractionMinimumDistance = 20;
GCodePlanner planner = new GCodePlanner(new GCodeExport(), travelSpeed, retractionMinimumDistance);
List<Point3> perimeter = new List<Point3>()
{
new Point3(5000, 50),
new Point3(0, 10000),
new Point3(0, 0),
new Point3(15000, 0),
new Point3(15000, 10000),
new Point3(10000, 50),
};
Assert.IsTrue(perimeter.Count == 6);
List<Point3> correctedPath = planner.MakeCloseSegmentsMergable(perimeter, 400 / 4);
Assert.IsTrue(correctedPath.Count == 8);
}
// Make sure we work correctly when splitting the closing segment.
{
// |\ /| |\ /|
// | \____/ | | \____/ |
// |_______s| create points -> |_.____._|
int travelSpeed = 50;
int retractionMinimumDistance = 20;
GCodePlanner planner = new GCodePlanner(new GCodeExport(), travelSpeed, retractionMinimumDistance);
List<Point3> perimeter = new List<Point3>()
{
new Point3(15000, 0),
new Point3(15000, 10000),
new Point3(10000, 50),
new Point3(5000, 50),
new Point3(0, 10000),
new Point3(0, 0),
};
Assert.IsTrue(perimeter.Count == 6);
List<Point3> correctedPath = planner.MakeCloseSegmentsMergable(perimeter, 400 / 4);
Assert.IsTrue(correctedPath.Count == 8);
}
}