Изменения документа Макрос для формирования карты высот
Редактировал(а) Edgar Allan Poe 2024/11/14 17:01
От версии 3.6
отредактировано abolgov
на 2022/06/10 15:08
на 2022/06/10 15:08
Изменить комментарий:
Renamed from xwiki:PUMPUBLIC.Описание M-кодов.Примеры макросов.Макрос для формирования карты высот.WebHome
Сводка
-
Свойства страницы (3 изменено, 0 добавлено, 0 удалено)
Подробности
- Свойства страницы
-
- Родительский документ
-
... ... @@ -1,1 +1,1 @@ 1 - xwiki:PUMPUBLIC.Руководство пользователя.Описание M-кодов.Примеры макросов.WebHome1 +Руководство пользователя.Описание M-кодов.Примеры макросов.WebHome - Автор документа
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki.a bolgov1 +XWiki.Knetyaga - Содержимое
-
... ... @@ -1,85 +1,87 @@ 1 -Для определённых задач (например, фрезеровки печатных плат) возник ает необходимость сканирования поверхности с последующей корректировкой неровностей по Z.Карта высот подготавливается с помощью макроса (пример ниже), и на основе этой карты высот модифицируется G-код. Сформировать G-код с готовыми координатами можно, например, в программе G-Code Ripper.1 +Для определённых задач (например, фрезеровки печатных плат) может возникнуть необходимость сканирования поверхности с последующей корректировкой неровностей по Z. 2 2 3 -{{code}} 3 +Карту высот на основе сканирования поверхности можно подготовить с помощью макроса (пример ниже) и затем, используя эту карту высот, модифицировать G-код. 4 + 5 +Сформировать G-код с готовыми координатами поможет, например, программа G-Code Ripper. 6 + 7 +{{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" 14 - 15 - PushCurrentDistanceMode() 16 - PushCurrentMotionMode() 17 - 18 - if (IsProbingPinConfigured()) then 19 - -- open the file 20 - file, msg = io.open(ProbeFilename, "w") 21 - 22 - if (file == nil) then 23 - DisplayMessage("Could not open probe output file ("..msg..")") 24 - Stop() 25 - return 26 - end 27 - 28 - ExecuteMDI("F "..Feed) 29 - ExecuteMDI("G90 G38.2 Z-100") 30 - 31 - -- set the current location to 0,0,0 32 - ExecuteMDI("G92 X0Y0Z0") 33 - ExecuteMDI("G0 Z"..SafeZ) 34 - 35 - local direction = 0 36 - for y = 0, YWidth, StepY do 37 - if (direction == 1) then 38 - direction = 0 39 - else 40 - direction = 1 41 - end 42 - 43 - for x = 0, XWidth, StepX do 44 - if (direction == 1) then 45 - ExecuteMDI("G0 X"..x.." Y"..y.." Z"..SafeZ) 46 - else 47 - ExecuteMDI("G0 X"..(XWidth - x).." Y"..y.." Z"..SafeZ) 48 - end 49 - 50 - ExecuteMDI("G38.2 Z"..ProbeZ) 51 - LogCurrentPos(TipHeight) 52 - ExecuteMDI("G0 Z"..SafeZ) 53 - end 54 - end 55 - 56 - if (direction == 1) then 57 - ExecuteMDI("G0 X"..XWidth.." Y"..YWidth.." Z"..SafeZ) 58 - else 59 - ExecuteMDI("G0 X".."0".." Y"..YWidth.." Z"..SafeZ) 60 - end 61 - 62 - local HighZ = 5 63 - ExecuteMDI("G0 Z"..HighZ) 64 - ExecuteMDI("G0 X0Y0") 65 - 66 - file:close() 67 - else 68 - DisplayMessage("Probe input is not configured") 69 - return 70 - end 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" 18 + 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 28 + 29 + if (file == nil) then 30 + DisplayMessage("Could not open probe output file ("..msg..")") 31 + Stop() 32 + return 33 + end 34 + 35 + ExecuteMDI("F "..Feed) 36 + ExecuteMDI("G90 G38.2 Z-100") 37 + 38 + ExecuteMDI("G92 X0Y0Z0") -- set the current location to 0,0,0 39 + ExecuteMDI("G0 Z"..SafeZ) 40 + 41 + local direction = 0 42 + for y = 0, YWidth, StepY do 43 + if (direction == 1) then 44 + direction = 0 45 + else 46 + direction = 1 47 + 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 55 + 56 + ExecuteMDI("G38.2 Z"..ProbeZ) 57 + LogCurrentPos(TipHeight) 58 + ExecuteMDI("G0 Z"..SafeZ) 59 + end 60 + 61 + end 62 + 63 + if (direction == 1) then 64 + ExecuteMDI("G0 X"..XWidth.." Y"..YWidth.." Z"..SafeZ) 65 + else 66 + ExecuteMDI("G0 X".."0".." Y"..YWidth.." Z"..SafeZ) 67 + end 68 + 69 + local HighZ = 5 70 + ExecuteMDI("G0 Z"..HighZ) 71 + ExecuteMDI("G0 X0Y0") 72 + 73 + file:close() 71 71 end 72 72 73 73 function LogCurrentPos(tipHeight) 74 - local CurrX = AxisGetPos(Axis.X) 75 - local CurrY = AxisGetPos(Axis.Y) 76 - local CurrZ = AxisGetPos(Axis.Z) 77 - 78 - local fmt = "%.5f" 79 - file:write(string.format(fmt, CurrX)..","..string.format(fmt, CurrY)..","..string.format(fmt, CurrZ - tipHeight), "\n") 77 + local CurrX = AxisGetPos(Axis.X) 78 + local CurrY = AxisGetPos(Axis.Y) 79 + local CurrZ = AxisGetPos(Axis.Z) 80 + 81 + local fmt = "%.5f" 82 + file:write(string.format(fmt, CurrX)..","..string.format(fmt, CurrY)..",".. 83 + string.format(fmt, CurrZ - tipHeight), "\n") 80 80 end 81 81 {{/code}} 82 82 83 - 84 - 85 -{{view-file att--filename="M155.pm" name="" height="250"/}} 87 +**[[Скачать макрос>>attach:M155.pm]]**