Редактировал(а) Edgar Allan Poe 2024/11/14 17:01

От версии 5.1
отредактировано writer
на 2023/01/26 13:53
Изменить комментарий: К данной версии нет комментариев
К версии 9.1
отредактировано Edgar Allan Poe
на 2024/11/14 17:01
Изменить комментарий: К данной версии нет комментариев

Сводка

Подробности

Свойства страницы
Автор документа
... ... @@ -1,1 +1,1 @@
1 -XWiki.Knetyaga
1 +XWiki.afirsov
Теги
... ... @@ -1,0 +1,1 @@
1 +macros|макросы|probing
Содержимое
... ... @@ -1,27 +1,35 @@
1 -Для определённых задач (например, фрезеровки печатных плат) возникает необходимость сканирования поверхности с последующей корректировкой неровностей по Z. Карта высот подготавливается с помощью макроса (пример ниже), и на основе этой карты высот модифицируется G-код. Сформировать G-код с готовыми координатами можно, например, в программе G-Code Ripper.
1 +Для определённых задач (например, фрезеровки печатных плат) может возникнуть необходимость сканирования поверхности с последующей корректировкой неровностей по Z.
2 2  
3 +Карту высот на основе сканирования поверхности можно подготовить с помощью макроса (пример ниже) и затем, используя эту карту высот, модифицировать G-код.
4 +
5 +Сформировать G-код с готовыми координатами поможет, например, программа G-Code Ripper.
6 +
3 3  {{code language="lua"}}
4 4  function m155()
5 - local XWidth = 70
6 - local YWidth = 50
7 - local SafeZ = 3
8 - local ProbeZ = -3
9 - local StepX = 15
10 - local StepY = 15
11 - local Feed = 50
12 - local TipHeight = 0
13 - local ProbeFilename = "C:\temp\probe.txt"
9 + local XWidth = 70
10 + local YWidth = 50
11 + local SafeZ = 3
12 + local ProbeZ = -3
13 + local StepX = 15
14 + local StepY = 15
15 + local Feed = 50
16 + local TipHeight = 0
17 + local ProbeFilename = "C:\\temp\\probe.txt"
14 14  
15 - PushCurrentDistanceMode()
16 - PushCurrentMotionMode()
17 -
18 - if (IsProbingPinConfigured()) then
19 - file, msg = io.open(ProbeFilename, "w") -- open the file
19 + PushCurrentDistanceMode()
20 + PushCurrentMotionMode()
21 +
22 + if (IsProbingPinConfigured()) then
23 + file, msg = io.open(ProbeFilename, "w") -- open the file
24 + else
25 + DisplayMessage("Probe input is not configured")
26 + return
27 + end
20 20  
21 21   if (file == nil) then
22 - DisplayMessage("Could not open probe output file ("..msg..")")
23 - Stop()
24 - return
30 + DisplayMessage("Could not open probe output file ("..msg..")")
31 + Stop()
32 + return
25 25   end
26 26  
27 27   ExecuteMDI("F "..Feed)
... ... @@ -32,29 +32,30 @@
32 32  
33 33   local direction = 0
34 34   for y = 0, YWidth, StepY do
35 - if (direction == 1) then
36 - direction = 0
37 - else
38 - direction = 1
39 - end
40 -
41 - for x = 0, XWidth, StepX do
42 42   if (direction == 1) then
43 - ExecuteMDI("G0 X"..x.." Y"..y.." Z"..SafeZ)
44 + direction = 0
44 44   else
45 - ExecuteMDI("G0 X"..(XWidth - x).." Y"..y.." Z"..SafeZ)
46 + direction = 1
46 46   end
48 +
49 + for x = 0, XWidth, StepX do
50 + if (direction == 1) then
51 + ExecuteMDI("G0 X"..x.." Y"..y.." Z"..SafeZ)
52 + else
53 + ExecuteMDI("G0 X"..(XWidth - x).." Y"..y.." Z"..SafeZ)
54 + end
47 47  
48 - ExecuteMDI("G38.2 Z"..ProbeZ)
49 - LogCurrentPos(TipHeight)
50 - ExecuteMDI("G0 Z"..SafeZ)
51 - end
56 + ExecuteMDI("G38.2 Z"..ProbeZ)
57 + LogCurrentPos(TipHeight)
58 + ExecuteMDI("G0 Z"..SafeZ)
59 + end
60 +
52 52   end
53 53  
54 54   if (direction == 1) then
55 - ExecuteMDI("G0 X"..XWidth.." Y"..YWidth.." Z"..SafeZ)
64 + ExecuteMDI("G0 X"..XWidth.." Y"..YWidth.." Z"..SafeZ)
56 56   else
57 - ExecuteMDI("G0 X".."0".." Y"..YWidth.." Z"..SafeZ)
66 + ExecuteMDI("G0 X".."0".." Y"..YWidth.." Z"..SafeZ)
58 58   end
59 59  
60 60   local HighZ = 5
... ... @@ -62,20 +62,17 @@
62 62   ExecuteMDI("G0 X0Y0")
63 63  
64 64   file:close()
65 - else
66 - DisplayMessage("Probe input is not configured")
67 - return
68 - end
69 69  end
70 70  
71 71  function LogCurrentPos(tipHeight)
72 - local CurrX = AxisGetPos(Axis.X)
73 - local CurrY = AxisGetPos(Axis.Y)
74 - local CurrZ = AxisGetPos(Axis.Z)
77 + local CurrX = AxisGetPos(Axis.X)
78 + local CurrY = AxisGetPos(Axis.Y)
79 + local CurrZ = AxisGetPos(Axis.Z)
75 75  
76 - local fmt = "%.5f"
77 - file:write(string.format(fmt, CurrX)..","..string.format(fmt, CurrY)..","..string.format(fmt, CurrZ - tipHeight), "\n")
81 + local fmt = "%.5f"
82 + file:write(string.format(fmt, CurrX)..","..string.format(fmt, CurrY)..","..
83 + string.format(fmt, CurrZ - tipHeight), "\n")
78 78  end
79 79  {{/code}}
80 80  
81 -[[Скачать макрос>>attach:M155.pm]]
87 +**[[Скачать макрос>>attach:M155.pm]]**