public override void BuildProcessing(MillingCommandGenerator generator) { switch (CalcMethod) { case CalcMethodType.Average: for (int i = 0; i < PointsX.Count; i++) { generator.GCommand(CommandNames.Fast, 0, x: PointsX[i] + 230, y: PointsY[i] - 100 - TechProcess.Tool.Thickness.GetValueOrDefault()); generator.ToolPosition.Point -= new Vector3d(0, 0, 1); generator.GCommand("", 0, z: Thickness.GetValueOrDefault() + TechProcess.ZSafety); generator.Command("M131"); generator.Command($"DBL THICK{i} = %TastL.ZLastra - %TastL.ZBanco", "Измерение"); generator.Command($"G0 Z(THICK{i}/1000 + 100)"); } var s = String.Join(" + ", Enumerable.Range(0, PointsX.Count).Select(p => $"THICK{p}")); generator.Command($"DBL THICK = ({s})/{PointsX.Count}/1000"); break; case CalcMethodType.Minimum: for (int i = 0; i < PointsX.Count; i++) { generator.GCommand(CommandNames.Fast, 0, x: PointsX[i] + 230, y: PointsY[i] - 100 - TechProcess.Tool.Thickness.GetValueOrDefault()); generator.ToolPosition.Point -= new Vector3d(0, 0, 1); generator.GCommand("", 0, z: Thickness.GetValueOrDefault() + TechProcess.ZSafety); generator.Command("M131"); generator.Command($"DBL THICK{i} = %TastL.ZLastra - %TastL.ZBanco", "Измерение"); generator.Command($"G0 Z(THICK{i}/1000 + 100)"); if (i != 0) { generator.Command($"IF (THICK{i} < THICK0) THEN"); generator.Command($" THICK0 = THICK{i}"); generator.Command("ENDIF"); } } generator.Command("DBL THICK = THICK0/1000"); break; case CalcMethodType.Сorners: var points = PointsX.Select((p, i) => new Point2d(p, PointsY[i])).OrderBy(p => p.X).ToList(); var corners = points.Take(2).OrderBy(p => p.Y).Concat(points.Skip(2).OrderByDescending(p => p.Y)).ToList(); for (int i = 0; i < corners.Count; i++) { generator.GCommand(CommandNames.Fast, 0, x: corners[i].X + 230, y: corners[i].Y - 100 - TechProcess.Tool.Thickness.GetValueOrDefault()); generator.ToolPosition.Point -= new Vector3d(0, 0, 1); generator.GCommand("", 0, z: Thickness.GetValueOrDefault() + TechProcess.ZSafety); generator.Command("M131"); generator.Command($"DBL THICK{i} = (%TastL.ZLastra - %TastL.ZBanco)/1000", "Измерение"); generator.Command($"G0 Z(THICK{i} + 100)"); } var l1 = corners[3].X - corners[0].X; var l2 = corners[1].Y - corners[0].Y; generator.Command($"DBL KK1=(THICK3 - THICK0) / {l1}"); generator.Command($"DBL KK2=(THICK2 - THICK1) / {l1}"); generator.Command("DBL THICK"); generator.ThickCommand = $"THICK = (({{0}}-{corners[0].X})*KK2+THICK1)*({{1}}-{corners[0].Y})/{l2} + (({{0}}-{corners[0].X})*KK1+THICK0)*(1-({{1}}-{corners[0].Y})/{l2})"; break; } generator.WithThick = true; }