Compare commits
96 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 7c7fa77608 | |||
| 5ad54c18f1 | |||
| 07b9a60a25 | |||
| 6f625c46ae | |||
| 33048785f9 | |||
| cad4045171 | |||
| b19415b030 | |||
| dd2e8f357a | |||
| 415eb4d32a | |||
| 752d307cde | |||
| 7b14c98461 | |||
| a0314f3222 | |||
| 6a60cd2b5e | |||
| 9df7f78665 | |||
| 6211c6d873 | |||
| 4b97a5b949 | |||
| eed869c997 | |||
| bb1ba2b66f | |||
| 462a173729 | |||
| 548a192315 | |||
| ac9fa89de1 | |||
| 4162dfd7b4 | |||
| da1c2c6424 | |||
| 328ef638e8 | |||
| f9caff1cc0 | |||
| e1c375aa5a | |||
| c718593585 | |||
| 29f1243c91 | |||
| ad44ff7c5a | |||
| bcaf1c56a4 | |||
| 000bd0091f | |||
| b0ebb4a871 | |||
| 3d6f9f2b85 | |||
| 898d065fe1 | |||
| 54d809508d | |||
| 1596869230 | |||
| 68caeb21b2 | |||
| eb955244b3 | |||
| 2215fc2240 | |||
| 78b722b236 | |||
| 4d342b56c2 | |||
| f12d8b56c8 | |||
| c7cbe66299 | |||
| baaf137cb4 | |||
| cfe7de8123 | |||
| f5c9890924 | |||
| cdef58712f | |||
| 94b02be20a | |||
| a15593303f | |||
| 011f049c43 | |||
| e214e5a766 | |||
| e4c696c498 | |||
| e37a2f8e85 | |||
| 5619072e46 | |||
| ff59ee3e5b | |||
| af03fe39d8 | |||
| 775d0c9329 | |||
| 6669803e53 | |||
| 2827ba9ac0 | |||
| 30368edd88 | |||
| b420905b7a | |||
| 36a867ef4a | |||
| 7cebcd4b0e | |||
| fa7f51d02e | |||
| eac6b2da77 | |||
| 995ed10a0a | |||
| 6c2e16a13e | |||
| 3cdb99f795 | |||
| 973eba6379 | |||
| c2163ebf3f | |||
| 3f9628121c | |||
| d97543fbf9 | |||
| 85bbeb8523 | |||
| 9f6dda3079 | |||
| f3b3704f3b | |||
| 1b67ca3559 | |||
| 86d4000455 | |||
| 3d5b7522bd | |||
| d343e36e77 | |||
| 87d2641ab1 | |||
| b610f1f5e1 | |||
| d83b571883 | |||
| a595fcdb98 | |||
| 43949d7f13 | |||
| 00700f3194 | |||
| 28686fe6b6 | |||
| 4a4a7d648b | |||
| 03c1768afe | |||
| ba9470ee88 | |||
| e629f1b12d | |||
| 451f3a2939 | |||
| bc3cf3b3a9 | |||
| 4225985a61 | |||
| fcd61efd53 | |||
| 01711d2925 | |||
| e015136592 |
+4
-4
@@ -16,14 +16,14 @@ variables:
|
||||
$FileList = Get-ChildItem("*.lua")
|
||||
ForEach ($File in $FileList) {
|
||||
$FileName = Split-Path $File -leaf
|
||||
lua54 -o bin\$FileName $FileName
|
||||
echo "lua54 -o bin\$FileName $FileName"
|
||||
lua54 -o bin\$FileName -s $FileName
|
||||
echo "lua54 -o bin\$FileName -s $FileName"
|
||||
}
|
||||
$FileList = Get-ChildItem("LuaLibs\*.lua")
|
||||
ForEach ($File in $FileList) {
|
||||
$FileName = Split-Path $File -leaf
|
||||
lua54 -o bin\LuaLibs\$FileName LuaLibs\$FileName
|
||||
echo "lua54 -o bin\LuaLibs\$FileName LuaLibs\$FileName"
|
||||
lua54 -o bin\LuaLibs\$FileName -s LuaLibs\$FileName
|
||||
echo "lua54 -o bin\LuaLibs\$FileName -s LuaLibs\$FileName"
|
||||
}
|
||||
|
||||
# helper copia SORGENTI verso cartella di rete R:\ dei SORGENTI
|
||||
|
||||
Vendored
+34
@@ -0,0 +1,34 @@
|
||||
{
|
||||
"Lua.diagnostics.globals": [
|
||||
"MATERIAL",
|
||||
"EgtGetFirstNameInGroup",
|
||||
"GDB_ID",
|
||||
"EgtGroup",
|
||||
"EgtSetLevel",
|
||||
"EgtSetName",
|
||||
"GDB_LV",
|
||||
"EgtGetCurrMachineDir",
|
||||
"EgtGetCurrMachineName",
|
||||
"EgtGetStringFromIni",
|
||||
"EgtGetFirstPart",
|
||||
"EgtGetInfo",
|
||||
"EgtGetNextPart",
|
||||
"EgtGetLastNameInGroup",
|
||||
"EgtRemoveInfo",
|
||||
"EgtGetFirstInGroup",
|
||||
"EgtGetName",
|
||||
"EgtCurveLength",
|
||||
"EgtGetNext",
|
||||
"EgtCurveArea",
|
||||
"EgtGetNextName",
|
||||
"EgtSetInfo",
|
||||
"floor",
|
||||
"pi",
|
||||
"pow",
|
||||
"EgtProcessEvents",
|
||||
"EgtEmptyGroup",
|
||||
"EgtOutLog",
|
||||
"EgtIf",
|
||||
"EgtProtectGlobal"
|
||||
]
|
||||
}
|
||||
+16
-14
@@ -1,19 +1,21 @@
|
||||
|
||||
REM Compilazione degli script 3dPrinting Egaltech 2023.01.11
|
||||
REM Compilazione degli script 3dPrinting Egaltech 2024.03.27
|
||||
REM Per togliere info di debug aggiungere flag -s prima del nome del file di input
|
||||
|
||||
REM Compilazione 32 e 64 bit
|
||||
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\AddManData.lua LuaLibs\AddManData.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcPaths.lua LuaLibs\CalcPaths.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcSlices.lua LuaLibs\CalcSlices.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcToolPath.lua LuaLibs\CalcToolPath.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunCalcSolids.lua LuaLibs\RunCalcSolids.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunGcodeGenerate.lua LuaLibs\RunGcodeGenerate.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunMachParamFromSWCalc.lua LuaLibs\RunMachParamFromSWCalc.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunSlicing.lua LuaLibs\RunSlicing.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\CalcMachParamFromSW.lua CalcMachParamFromSW.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\CalcSolids.lua CalcSolids.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\GcodeGenerate.lua GcodeGenerate.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\Slicing.lua Slicing.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\Version.lua Version.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\AddManData.lua -s LuaLibs\AddManData.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcPaths.lua -s LuaLibs\CalcPaths.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcSlices.lua -s LuaLibs\CalcSlices.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcToolPath.lua -s LuaLibs\CalcToolPath.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunCalcSolids.lua -s LuaLibs\RunCalcSolids.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunGcodeGenerate.lua -s LuaLibs\RunGcodeGenerate.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunMachParamFromSWCalc.lua -s LuaLibs\RunMachParamFromSWCalc.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunPrepareExport.lua -s LuaLibs\RunPrepareExport.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunSlicing.lua -s LuaLibs\RunSlicing.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\CalcMachParamFromSW.lua -s CalcMachParamFromSW.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\CalcSolids.lua -s CalcSolids.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\GcodeGenerate.lua -s GcodeGenerate.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\PrepareExport.lua -s PrepareExport.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\Slicing.lua -s Slicing.lua
|
||||
\EgtProg\Dll32\luac54 -o bin\Version.lua -s Version.lua
|
||||
|
||||
+96
-17
@@ -28,23 +28,30 @@ LINK_CRV = "Link"
|
||||
FRAME_PART = "FramePart"
|
||||
START_GEOM = "Start"
|
||||
TOT_SHELL_TRIM_SURF = "TotalShellSurfForTrim"
|
||||
SHELL_SURF = "ShellSurf"
|
||||
COARSE_TRIM_SURF = "CoarseTrimSurf"
|
||||
TRIM_SURF_LOOP = "TrimSurfLoop"
|
||||
SURF_LOOP = "SurfLoop"
|
||||
LOOP_GRP = "LoopGrp"
|
||||
DIR_ARROW = "Arrow"
|
||||
|
||||
MIN_LEN = 0.1
|
||||
MIN_AREA = 0.01
|
||||
MIN_RIBS_LEN = 2
|
||||
MIN_INFILL_LEN = 2
|
||||
|
||||
-- Parametri di lavorazione
|
||||
SEC_DEFAULT = "Default"
|
||||
KEY_PARAMS = "Params"
|
||||
KEY_CALC_SOLIDS = "CalcSolids"
|
||||
KEY_SPIRAL_VASE = "SpiralVase"
|
||||
KEY_SPIRAL_VASE_LEN = 'SpiralVaseLen'
|
||||
KEY_SPIRAL_VASE_INTERP_LEN = 'SpiralVaseInterpLen'
|
||||
KEY_SLICING_TYPE = "SlicingType"
|
||||
KEY_SLICING_DIR = "SlicingDir"
|
||||
KEY_SLICE_STEP = "StrandH"
|
||||
KEY_SHELLS_NBR = "StrandCount"
|
||||
KEY_STRAND = "StrandW"
|
||||
KEY_INNER_STRAND = "InnerStrandW"
|
||||
KEY_STRAND_OVERLAP = "StrandOverlap"
|
||||
KEY_OFFSET_SLICE = "Offset"
|
||||
KEY_SP_OFFSET_ON_SLICE = "StartPointOffsetOnSlice"
|
||||
@@ -55,10 +62,6 @@ KEY_TYPE = "Type"
|
||||
KEY_LINK_TYPE = "LinkType"
|
||||
KEY_LINK_PARAM = "LinkParam"
|
||||
KEY_LINK_ZUP = "LinkZup"
|
||||
KEY_FLOOR_NBR = "FloorCount"
|
||||
KEY_FLOOR_TYPE = "FloorType"
|
||||
KEY_CEIL_NBR = "CeilCount"
|
||||
KEY_CEIL_TYPE = "CeilType"
|
||||
KEY_SPEED = "Speed"
|
||||
KEY_FEED = "Feed"
|
||||
KEY_EXT_FEED = "ExtFeed"
|
||||
@@ -81,12 +84,37 @@ KEY_COASTING_FEED = "CoastingFeed"
|
||||
KEY_WIPE_LEN = "WipeLen"
|
||||
KEY_WIPE_DIR = "WipeDir"
|
||||
KEY_WIPE_FEEDPU = "WipeFeedPu"
|
||||
KEY_TOOL_DIAM = "ToolDiam"
|
||||
KEY_TOOL_DIAM = "ToolDiam"
|
||||
KEY_MAX_STRANDH_FACTOR = 'MaxStrandHFactor'
|
||||
KEY_MIN_STRANDH_FACTOR = 'MinStrandHFactor'
|
||||
|
||||
-- Solid Fill
|
||||
KEY_FLOOR_NBR = "FloorCount"
|
||||
KEY_FLOOR_TYPE = "FloorType"
|
||||
KEY_CEIL_NBR = "CeilCount"
|
||||
KEY_CEIL_TYPE = "CeilType"
|
||||
KEY_FILL_TYPE = "FillType"
|
||||
|
||||
-- Infill
|
||||
KEY_INFILL_STRAND = "InfillStrandW"
|
||||
KEY_INFILL_TYPE = "InfillType"
|
||||
KEY_INFILL_DENSITY = "InfillDensity"
|
||||
KEY_INFILL_LINK = "InfillLink"
|
||||
KEY_INFILL_OVERLAP = "InfillOverlap"
|
||||
KEY_INFILL_GRID_OVERLAP = "InfillGridOverlap"
|
||||
KEY_INFILL_DIR = "InfillDirection"
|
||||
KEY_INFILL_OFFSET_X = "InfillOffsetX"
|
||||
KEY_INFILL_OFFSET_Y = "InfillOffsetY"
|
||||
KEY_INFILL_COASTING = "InfillCoasting"
|
||||
KEY_INFILL_WIPE = "InfillWipe"
|
||||
KEY_INFILL_WIPE_DIR = "InfillWipeDir"
|
||||
|
||||
-- Ribs
|
||||
KEY_RIBS_STRAND = "RibsStrandW"
|
||||
KEY_RIBS_TYPE = "RibsType"
|
||||
KEY_LIMIT_UNBDD_RIBS = "LimitUnboundedRibsWithSolid"
|
||||
KEY_RIBS_OVERLAP = "RibsOverlap"
|
||||
KEY_RIBS_STRAND_OVERLAP = 'RibsStrandOverlap'
|
||||
KEY_RIBS_SHELLS_NBR = "RibsStrandCount"
|
||||
KEY_RIBS_LINK = "RibsLink"
|
||||
KEY_RIBS_INVERT_DIR = "RibsInvertDirection"
|
||||
@@ -114,6 +142,10 @@ KEY_RIBS_USER_LINK_CCW = "RibUserLinkCCW"
|
||||
KEY_RIBS_USER_LINK_ORDER = "RibUserLinkOrder"
|
||||
KEY_RIBS_USER_LINK_TOT = "RibsUserLinkParts"
|
||||
KEY_RIBS_INVERT_STRAND_ORDER = "RibsInvertStrandOrder"
|
||||
KEY_RIBS_MERGE_WITH_SHELLS = "RibsMergeWithShell"
|
||||
KEY_INVERT_RIBS_MERGED_SHELL_LINK = "InvertRibsMergedShellMainLink"
|
||||
KEY_RIBS_LEAD_FILLET = "RibsLeadFillet"
|
||||
KEY_RIBS_LINK_FILLET = "RibsLinkFillet"
|
||||
|
||||
-- Regioni con diverso numero di passate
|
||||
KEY_SHELL_NBR_DIFF = "ShellNbrDifference"
|
||||
@@ -125,12 +157,21 @@ KEY_EXTRA_SHELL_WIPE = "ExtraShellWipe"
|
||||
KEY_EXTRA_SHELL_WIPE_DIR = "ExtraShellWipeDir"
|
||||
|
||||
-- Solidi ausiliari
|
||||
KEY_AUX_SOLIDS_STRAND = "AuxSolidsStrandW"
|
||||
KEY_AUX_SOLIDS_SHELLS_NBR = "AuxSolidsStrandCount"
|
||||
KEY_AUX_SOLIDS_OVERLAP = "AuxSolidsOverlap"
|
||||
KEY_AUX_SOLIDS_INFILL = "AuxSolidsInfill"
|
||||
KEY_AUX_SOLIDS_PRINT_ORDER = "AuxSolidsStrandOrder"
|
||||
KEY_AUX_SOLIDS_OVERLAP = "AuxSolidsOverlap"
|
||||
KEY_AUX_SOLIDS_LINK_TYPE = "AuxSolidsLinkType"
|
||||
KEY_AUX_SOLIDS_SP_OFFSET = "AuxSolidsStartPointOffsetOnSlice"
|
||||
KEY_AUX_SOLIDS_LINK_PARAM = "AuxSolidsLinkParam"
|
||||
KEY_AUX_SOLIDS_SP_OFFSET = "AuxSolidsStartPointOffsetOnSlice"
|
||||
KEY_AUX_SOLIDS_LP_OFFSET = "AuxSolidsOffsetLeadPoint"
|
||||
KEY_AUX_SOLIDS_INFILL_LINK = "AuxSolidsInfillLink"
|
||||
KEY_AUX_SOLIDS_DENSITY = "AuxSolidsDensity"
|
||||
KEY_AUX_SOLIDS_DIR = "AuxSolidsDirection"
|
||||
KEY_AUX_SOLIDS_OFFSET_X = "AuxSolidsOffsetX"
|
||||
KEY_AUX_SOLIDS_OFFSET_Y = "AuxSolidsOffsetY"
|
||||
KEY_AUX_SOLIDS_GRID_OVERLAP = "AuxSolidsGridOverlap"
|
||||
KEY_AUX_SOLIDS_COASTING_LEN = "AuxSolidsCoastingLen"
|
||||
KEY_AUX_SOLIDS_WIPE_LEN = "AuxSolidsWipeLen"
|
||||
KEY_AUX_SOLIDS_WIPE_DIR = "AuxSolidsWipeDir"
|
||||
@@ -141,12 +182,17 @@ KEY_COEFF_X = "CoeffX"
|
||||
KEY_COEFF_Y = "CoeffY"
|
||||
KEY_SPEED_MIN = "SpeedMin"
|
||||
KEY_SPEED_MAX = "SpeedMax"
|
||||
KEY_FEED_MAX = 'FeedMax'
|
||||
KEY_LINEAR_APPROX = 'LinearApprox'
|
||||
KEY_LINEAR_TOL = 'LinearTol'
|
||||
|
||||
-- Altre chiavi
|
||||
KEY_MAX_H = "SlicingHeight"
|
||||
KEY_MAX_SLICES_NBR = "MaxSlicesNumber"
|
||||
KEY_SLICE_NBR = "SliceNbr"
|
||||
KEY_SLICE_Z = "SliceZ"
|
||||
KEY_SLICE_DIR = "SliceDir"
|
||||
KEY_SLICE_POS = "SlicePos"
|
||||
KEY_SLICE_DELTAZ = "DeltaZ"
|
||||
KEY_SLICE_REAL_Z = "SliceRealZ"
|
||||
KEY_ZIG_ZAG_INFILL = "ZigZagInfill"
|
||||
KEY_ZIG_ZAG_DIR = "ZigZagDir"
|
||||
KEY_INVERTED_CRV = "InvertedCrv"
|
||||
@@ -156,13 +202,28 @@ KEY_ASSOCIATED_CRVS = "AssociatedCrvs"
|
||||
KEY_ORIGINAL_SURF = "OriginalSurf"
|
||||
KEY_HAS_SOLIDS = "Solids"
|
||||
KEY_BOX_MIN_Z = "PartBoxMinZ"
|
||||
KEY_START_POINT = "StartPoint"
|
||||
KEY_ORIGINAL_START_POINT = "OriginalStartPoint"
|
||||
KEY_FIRST_SOLID_LAY = "FirstSolidLay"
|
||||
KEY_LAST_SOLID_LAY = "LastSolidLay"
|
||||
KEY_ASSOCIATED_TP_CRV = "AssociatedToolPathCrv"
|
||||
KEY_ASSOCIATED_P_CRV = "AssociatedPathCrv"
|
||||
KEY_INTERNAL_SRF_LOOP = "InternalSrfLoop"
|
||||
KEY_PREV_CRV = "PrevCrv"
|
||||
KEY_NEXT_CRVS = "NextCrvs"
|
||||
KEY_CRV_STRAND = "CurveStrand"
|
||||
KEY_LAYER_CNT = "LayerCnt"
|
||||
KEY_CRV_OFFSET = "CurveOffset"
|
||||
KEY_ORIG_REF = "Orig"
|
||||
KEY_WIPE_ON_CRV = "WipeOnCrv"
|
||||
KEY_FEED_COEFF = 'FeedCoeff'
|
||||
KEY_ENTITY_NAME = 'EntityName'
|
||||
|
||||
SLICING_TYPE = {
|
||||
SLICING_TYPE = {
|
||||
VERTICAL = 1,
|
||||
DEG45_X = 2,
|
||||
DEG45_Y = 3,
|
||||
HORIZONTAL = 4,
|
||||
MULTIPLANAR = 5,
|
||||
}
|
||||
|
||||
TYPE = {
|
||||
@@ -202,7 +263,7 @@ PRINT_DIRECTION = {
|
||||
LINK_TYPE = {
|
||||
NONE = 1,
|
||||
LINEAR = 2,
|
||||
BIARC = 3,
|
||||
BIARC = 3,
|
||||
}
|
||||
|
||||
LEAD_TYPE = {
|
||||
@@ -211,10 +272,21 @@ LEAD_TYPE = {
|
||||
ARC = 3,
|
||||
}
|
||||
|
||||
INFILL_TYPE = {
|
||||
NONE = 1,
|
||||
OFFSET = 2,
|
||||
ZIGZAG = 3,
|
||||
FILL_CATEGORY = {
|
||||
NONE = 0,
|
||||
SOLID_FILL = 16,
|
||||
INFILL = 32,
|
||||
}
|
||||
|
||||
FILL_TYPE = {
|
||||
NONE = 0,
|
||||
OFFSET = 16,
|
||||
ZIGZAG = 17,
|
||||
LINES = 32,
|
||||
GRID = 33,
|
||||
ZIG_ZAG_GRID = 34,
|
||||
HONEYCOMB = 35,
|
||||
HONEYCOMB_GRID = 36,
|
||||
}
|
||||
|
||||
RIB_TYPE = {
|
||||
@@ -234,10 +306,12 @@ LAY_RIBS = "Ribs"
|
||||
LAY_AUX_SOLIDS = "AuxSolids"
|
||||
LAY_SHELL_NBR = "ShellNumber"
|
||||
LAY_AUX = "Aux"
|
||||
SPINE_CURVE = "Spine"
|
||||
LAY_FRAME = "Frame"
|
||||
VIEWPARAMS = 'ViewParams'
|
||||
IMPORTED_SOLID = 'ImportedSolid'
|
||||
RESULT_READ_PROG = 'ResultReadProg'
|
||||
LAY_EXPORT = "ExportLayer"
|
||||
|
||||
KEY_PART_ON_TABLE = 'PartOnTable'
|
||||
KEY_RESULT = 'Result'
|
||||
@@ -293,9 +367,14 @@ SHELL_NBR_CRV = "ShellNbrRegion"
|
||||
SHELL_NBR_SURF = "ShellNbrSurf"
|
||||
|
||||
AUX_SOLIDS_GRP = "AuxSolids"
|
||||
AUX_SOLIDS_INFILL_GRP = "InfillAuxSolids"
|
||||
AUX_SOLIDS_CRV = "AuxSolid"
|
||||
AUX_SOLIDS_INFILL_CRV = "InfillAuxSolid"
|
||||
AUX_SOLIDS_SRF = "SrfAuxSolid"
|
||||
|
||||
INFILL_GRP = "Infill"
|
||||
INFILL_CRV = "InfillCrv"
|
||||
|
||||
---------------------------------------------------------------------
|
||||
-- parametri calcolo tempi, F ed S
|
||||
LAY_TFSCALC = "TFSCalc"
|
||||
|
||||
+2483
-827
File diff suppressed because it is too large
Load Diff
+1009
-351
File diff suppressed because it is too large
Load Diff
+2277
-608
File diff suppressed because it is too large
Load Diff
+746
-156
File diff suppressed because it is too large
Load Diff
@@ -36,7 +36,7 @@ function RunGcodeGenerate.Exec()
|
||||
|
||||
-- Recupero i layer da processare
|
||||
local vLayIds = EgtGetNameInGroup( nPartId, SLICE_LAYER.."*")
|
||||
if not vLayIds then
|
||||
if not vLayIds or #vLayIds == 0 then
|
||||
EgtOutBox( 'Error missing slices', 'GcodeGenerate')
|
||||
return
|
||||
end
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
-- RunMachParamFromSWCalc.lua by Egaltech s.r.l. 2022/12/28
|
||||
-- RunMachParamFromSWCalc.lua by Egaltech s.r.l. 2024/01/30
|
||||
-- Calcolo dei parametri di stampa
|
||||
|
||||
-- Tabella per definizione modulo
|
||||
@@ -53,6 +53,8 @@ function RunMachParamFromSWCalc.Exec()
|
||||
local sMachIni = EgtGetCurrMachineDir() .. '\\' .. EgtGetCurrMachineName() .. '.ini'
|
||||
local dSMin = tonumber( EgtGetStringFromIni( SEC_3DPRINTING, KEY_SPEED_MIN, 0, sMachIni))
|
||||
local dSMax = tonumber( EgtGetStringFromIni( SEC_3DPRINTING, KEY_SPEED_MAX, 50000, sMachIni))
|
||||
-- recupero Feed massima dalla macchina
|
||||
local dFLimit = tonumber( EgtGetStringFromIni( SEC_3DPRINTING, KEY_FEED_MAX, 10000, sMachIni))
|
||||
-- massa materiale utilizzato
|
||||
local dPrintMass = 0
|
||||
-- massimo indice di layer calcolato
|
||||
@@ -62,7 +64,7 @@ function RunMachParamFromSWCalc.Exec()
|
||||
while nPartId do
|
||||
if not EgtGetInfo( nPartId, KEY_PART_ON_TABLE, 'b') then
|
||||
nPartId = EgtGetNextPart( nPartId)
|
||||
goto continue
|
||||
goto continue
|
||||
end
|
||||
-- recupero i parametri di lavorazione del pezzo
|
||||
local dSliceStep = EgtGetInfo( nPartId, KEY_SLICE_STEP, 'd')
|
||||
@@ -77,6 +79,8 @@ function RunMachParamFromSWCalc.Exec()
|
||||
while nLayerId do
|
||||
-- rimuovo eventuale info precedente del tempo di attesa
|
||||
EgtRemoveInfo( nLayerId, KEY_WAITING_TIME)
|
||||
-- divido curve in base alla larghezza strand
|
||||
local LengthCrvList = {}
|
||||
-- calcolo lunghezza totale del layer
|
||||
local dTotLayerLength = 0
|
||||
local dTotLayerLengthForMass = 0
|
||||
@@ -84,14 +88,29 @@ function RunMachParamFromSWCalc.Exec()
|
||||
local nCrvId = EgtGetFirstNameInGroup( nLayerId, CONTOUR_GRP .. '*')
|
||||
while nCrvId do
|
||||
local nToolPathId = EgtGetFirstNameInGroup( nCrvId, TOOLPATH_GRP)
|
||||
-- sommo lunghezze percorsi
|
||||
-- recupero lunghezze percorsi
|
||||
local dTotCrvLength = 0
|
||||
local dTotCrvLengthForMass = 0
|
||||
nShellId = EgtGetFirstInGroup( nToolPathId)
|
||||
local nShellId = EgtGetFirstInGroup( nToolPathId)
|
||||
while nShellId do
|
||||
dTotCrvLength = dTotCrvLength + EgtCurveLength( nShellId)
|
||||
local dShellWidth = EgtGetInfo( nShellId, KEY_CRV_STRAND, "d")
|
||||
local dShellLength = EgtCurveLength( nShellId)
|
||||
local bFound = false
|
||||
for LengthIndex = 1, #LengthCrvList do
|
||||
if LengthCrvList[LengthIndex].Width == dShellWidth then
|
||||
table.insert( LengthCrvList[LengthIndex].IdList, nShellId)
|
||||
LengthCrvList[LengthIndex].Length = LengthCrvList[LengthIndex].Length + dShellLength
|
||||
bFound = true
|
||||
break
|
||||
end
|
||||
end
|
||||
if not bFound then
|
||||
table.insert( LengthCrvList, { Width = dShellWidth, IdList = { nShellId}, Length = dShellLength})
|
||||
end
|
||||
-- sommo per lunghezza totale
|
||||
dTotCrvLength = dTotCrvLength + dShellLength
|
||||
if EgtGetName( nShellId) ~= WIPE_CRV then
|
||||
dTotCrvLengthForMass = dTotCrvLengthForMass + EgtCurveLength( nShellId)
|
||||
dTotCrvLengthForMass = dTotCrvLengthForMass + dShellLength
|
||||
end
|
||||
nShellId = EgtGetNext( nShellId)
|
||||
end
|
||||
@@ -132,11 +151,17 @@ function RunMachParamFromSWCalc.Exec()
|
||||
table.insert( nOrigLayers, nLayerId)
|
||||
end
|
||||
EgtSetInfo( nLayerResultId, KEY_SLICEID, nOrigLayers)
|
||||
-- calcolo strand medio (media ponderata sulla lunghezza)
|
||||
local dStrandMean = 0
|
||||
for nMeanIndex = 1, #LengthCrvList do
|
||||
dStrandMean = dStrandMean + LengthCrvList[nMeanIndex].Width * LengthCrvList[nMeanIndex].Length
|
||||
end
|
||||
dStrandMean = dStrandMean / EgtIf( dTotLayerLength > 0.1, dTotLayerLength, 1)
|
||||
-- calcolo costante MF
|
||||
local dMF = 1
|
||||
local dSC = 1
|
||||
if dTotLayerArea > 1 then
|
||||
dMF = dTotLayerLength * dStrand / dTotLayerArea * 100
|
||||
dMF = dTotLayerLength * dStrandMean / dTotLayerArea * 100
|
||||
dSC = dStrandCount
|
||||
else
|
||||
dMF = 100
|
||||
@@ -151,12 +176,12 @@ function RunMachParamFromSWCalc.Exec()
|
||||
end
|
||||
end
|
||||
-- calcolo tempi stimati del layer
|
||||
local dTMin = ( MATERIAL.K_LAYERTIME / 100.0) * ( dMF + MATERIAL.AMin) / MATERIAL.BMin * pow( 0.25 * dStrand, MATERIAL.KW) * pow( dSliceStep, MATERIAL.KZ) * pow( dSC, MATERIAL.KN)
|
||||
local dTTrg = ( MATERIAL.K_LAYERTIME / 100.0) * ( dMF + MATERIAL.ATrg) / MATERIAL.BTrg * pow( 0.25 * dStrand, MATERIAL.KW) * pow( dSliceStep, MATERIAL.KZ) * pow( dSC, MATERIAL.KN)
|
||||
local dTMax = ( MATERIAL.K_LAYERTIME / 100.0) * ( dMF + MATERIAL.AMax) / MATERIAL.BMax * pow( 0.25 * dStrand, MATERIAL.KW) * pow( dSliceStep, MATERIAL.KZ) * pow( dSC, MATERIAL.KN)
|
||||
local dFMin = dTotLayerLength / dTMax * 60
|
||||
local dFTrg = dTotLayerLength / dTTrg * 60
|
||||
local dFMax = dTotLayerLength / dTMin * 60
|
||||
local dTMin = ( MATERIAL.K_LAYERTIME / 100.0) * ( dMF + MATERIAL.AMin) / MATERIAL.BMin * pow( 0.25 * dStrandMean, MATERIAL.KW) * pow( dSliceStep, MATERIAL.KZ) * pow( dSC, MATERIAL.KN)
|
||||
local dTTrg = ( MATERIAL.K_LAYERTIME / 100.0) * ( dMF + MATERIAL.ATrg) / MATERIAL.BTrg * pow( 0.25 * dStrandMean, MATERIAL.KW) * pow( dSliceStep, MATERIAL.KZ) * pow( dSC, MATERIAL.KN)
|
||||
local dTMax = ( MATERIAL.K_LAYERTIME / 100.0) * ( dMF + MATERIAL.AMax) / MATERIAL.BMax * pow( 0.25 * dStrandMean, MATERIAL.KW) * pow( dSliceStep, MATERIAL.KZ) * pow( dSC, MATERIAL.KN)
|
||||
local dFMin = dTotLayerLength / EgtIf( dTMax > 0.1, dTMax, 1) * 60
|
||||
local dFTrg = dTotLayerLength / EgtIf( dTTrg > 0.1, dTTrg, 1) * 60
|
||||
local dFMax = dTotLayerLength / EgtIf( dTMin > 0.1, dTMin, 1) * 60
|
||||
local dLayerTime = dTTrg
|
||||
if dLayerFeed == 0 then
|
||||
dLayerFeed = dFTrg
|
||||
@@ -164,8 +189,10 @@ function RunMachParamFromSWCalc.Exec()
|
||||
dLayerTime = dTotLayerLength / dLayerFeed * 60
|
||||
end
|
||||
dLayerWait = floor( dTMin + 0.5) - floor( dLayerTime + 0.5)
|
||||
-- sezione dello strand
|
||||
local dSect = max( ( dStrandMean - dSliceStep) * dSliceStep, 0) + pi * dSliceStep * dSliceStep / 4
|
||||
-- calcolo la portata
|
||||
local Vf = dLayerFeed * ( ( dStrand - dSliceStep) * dSliceStep + pi * pow( dSliceStep / 2, 2)) / 1000
|
||||
local Vf = dLayerFeed * dSect / 1000
|
||||
-- calcolo speed
|
||||
local dSpeed = ( MATERIAL.K_EXTRUSION / 100.0) * ( MACHINING.K / 100.0) * pow( Vf / MATERIAL.C1, 1 / MATERIAL.C2)
|
||||
-- verifico se speed esce da minimo e massimo della macchina
|
||||
@@ -179,16 +206,42 @@ function RunMachParamFromSWCalc.Exec()
|
||||
dSpeed = dSMax
|
||||
end
|
||||
if not bSpeedOk then
|
||||
dLayerFeed = ( MATERIAL.C1 * pow( ( dSpeed / (( MATERIAL.K_EXTRUSION / 100.0) * ( MACHINING.K / 100.0))), MATERIAL.C2)) * 1000 / ( ( dStrand - dSliceStep) * dSliceStep + pi * pow( dSliceStep / 2, 2))
|
||||
dLayerTime = dTotLayerLength / dLayerFeed * 60
|
||||
if dTotLayerLength > 0.1 then
|
||||
dLayerFeed = ( MATERIAL.C1 * pow( ( dSpeed / (( MATERIAL.K_EXTRUSION / 100.0) * ( MACHINING.K / 100.0))), MATERIAL.C2)) * 1000 / dSect
|
||||
dLayerTime = dTotLayerLength / dLayerFeed * 60
|
||||
end
|
||||
dLayerWait = floor( dTMin + 0.5) - floor( dLayerTime + 0.5)
|
||||
end
|
||||
-- calcolo massa dello strato
|
||||
local dLayerMass = dTotLayerLengthForMass * dSliceStep * dStrand * MATERIAL.Density * 1e-6
|
||||
local dLayerMass = dTotLayerLengthForMass * dSliceStep * dStrandMean * MATERIAL.Density * 1e-6
|
||||
if dLayerMass and dLayerMass > 0 then
|
||||
dPrintMass = dPrintMass + dLayerMass
|
||||
end
|
||||
-- scrivo info feed e speed in group toolpath
|
||||
-- scrivo info feed su tutti i tratti
|
||||
local dFeedMax = 0
|
||||
for nWidthIndex = 1, #LengthCrvList do
|
||||
local CurrWidth = LengthCrvList[nWidthIndex]
|
||||
local CurrFeed = EgtIf( CurrWidth.Width > 0, dLayerFeed * dStrandMean / CurrWidth.Width, dLayerFeed)
|
||||
for nCurveIdIndex = 1, #CurrWidth.IdList do
|
||||
local dNewFeed = CurrFeed
|
||||
-- verifico se coefficiente moltiplicativo per feed
|
||||
local dCoeff = EgtGetInfo( CurrWidth.IdList[nCurveIdIndex], KEY_FEED_COEFF, 'd')
|
||||
if dCoeff then
|
||||
dNewFeed = dCoeff * CurrFeed
|
||||
if dNewFeed > dFLimit then
|
||||
local dNewSpeed = dSpeed * dFLimit / dNewFeed
|
||||
dNewSpeed = EgtClamp( dNewSpeed, dSMin, dSMax)
|
||||
dNewFeed = dFLimit
|
||||
EgtSetInfo( CurrWidth.IdList[nCurveIdIndex], KEY_SPEED, dNewSpeed)
|
||||
end
|
||||
end
|
||||
EgtSetInfo( CurrWidth.IdList[nCurveIdIndex], KEY_FEED, dNewFeed)
|
||||
if dNewFeed > dFeedMax then
|
||||
dFeedMax = dNewFeed
|
||||
end
|
||||
end
|
||||
end
|
||||
-- scrivo info speed in group toolpath
|
||||
nCrvId = EgtGetFirstNameInGroup( nLayerId, CONTOUR_GRP .. '*')
|
||||
while nCrvId do
|
||||
local nToolPathId = EgtGetFirstNameInGroup( nCrvId, TOOLPATH_GRP) or GDB_ID.NULL
|
||||
@@ -202,13 +255,11 @@ function RunMachParamFromSWCalc.Exec()
|
||||
EgtSetInfo( nLayerResultId, KEY_WAITING_TIME, dLayerWait)
|
||||
end
|
||||
-- scrivo valori in struttura dati
|
||||
--local nLayerResultId = EgtGetFirstNameInGroup( nResultLayerId, nLayerIndex)
|
||||
EgtSetInfo( nLayerResultId, KEY_TMIN, dTMin)
|
||||
EgtSetInfo( nLayerResultId, KEY_TTRG, dTTrg)
|
||||
EgtSetInfo( nLayerResultId, KEY_TMAX, dTMax)
|
||||
EgtSetInfo( nLayerResultId, KEY_FMIN, dFMin)
|
||||
EgtSetInfo( nLayerResultId, KEY_FTRG, dFTrg)
|
||||
EgtSetInfo( nLayerResultId, KEY_FMAX, dFMax)
|
||||
EgtSetInfo( nLayerResultId, KEY_FMAX, dFeedMax)
|
||||
EgtSetInfo( nLayerResultId, KEY_TCUR, dLayerTime)
|
||||
EgtSetInfo( nLayerResultId, KEY_FCUR, dLayerFeed)
|
||||
EgtSetInfo( nLayerResultId, KEY_LENGTH, dTotLayerLength)
|
||||
@@ -220,11 +271,12 @@ function RunMachParamFromSWCalc.Exec()
|
||||
EgtEmptyGroup( nResultLayerId)
|
||||
return
|
||||
end
|
||||
|
||||
-- passo al layer successivo
|
||||
nLayerIndex = nLayerIndex + 1
|
||||
nLayerId = EgtGetFirstNameInGroup( nPartId, SLICE_LAYER .. nLayerIndex) or EgtGetFirstNameInGroup( nPartId, "__" .. SLICE_LAYER .. nLayerIndex)
|
||||
end
|
||||
if nMaxIndex < nLayerIndex then nMaxIndex = nLayerIndex end
|
||||
-- passo al pezzo successivo
|
||||
nPartId = EgtGetNextPart( nPartId)
|
||||
::continue::
|
||||
end
|
||||
|
||||
@@ -0,0 +1,211 @@
|
||||
-- RunPrepareExport.lua by Egaltech s.r.l. 2023/10/19
|
||||
-- Creo le geometrie da esportare con 3dm
|
||||
|
||||
-- Tabella per definizione modulo
|
||||
local RunPrepareExport = {}
|
||||
|
||||
-- Intestazioni
|
||||
require( 'EgtBase')
|
||||
|
||||
EgtOutLog( ' RunPreprareExport started', 1)
|
||||
|
||||
-- Dati
|
||||
local AMD = require( 'AddManData')
|
||||
|
||||
------------------------------------------------------------------
|
||||
local function CalcCurves( nSliceId, nDestGrp, vtSlicing, dStrandBase)
|
||||
|
||||
-- scorro tutti i gruppi di curve
|
||||
local vCrvs = EgtGetNameInGroup( nSliceId, CONTOUR_GRP .. '*')
|
||||
for j = 1, #vCrvs do
|
||||
-- cerco il gruppo del toolpath
|
||||
local nTPath = EgtGetFirstNameInGroup( vCrvs[j], TOOLPATH_GRP)
|
||||
if nTPath then
|
||||
local nId = EgtGetFirstInGroup( nTPath)
|
||||
while nId do
|
||||
-- se non è wipe creo la fat curve da estrudere per creare il solido
|
||||
local nType = EgtGetInfo( nId, KEY_TYPE, 'i')
|
||||
if nType ~= TYPE.WIPE then
|
||||
local dStrand = EgtGetInfo( nId, KEY_CRV_STRAND, 'd') or dStrandBase
|
||||
|
||||
-- calcolo fat region a partire da una copia della curva ( in questo modo nel DB geometrico non restano
|
||||
-- salvati i diagrammi di Voronoi che non servono per conti futuri)
|
||||
local nCopy = EgtCopyGlob( nId, nDestGrp)
|
||||
local nSurf = EgtSurfFrFatCurve( nDestGrp, nCopy, 0.5 * dStrand, false)
|
||||
-- se fallisce ritento con valore leggermente diverso
|
||||
if not nSurf or nSurf == GDB_ID.NULL then
|
||||
nSurf = EgtSurfFrFatCurve( nDestGrp, nCopy, 0.5 * dStrand - 0.05, false)
|
||||
end
|
||||
EgtErase( nCopy)
|
||||
|
||||
if nSurf then
|
||||
local nChunks = EgtSurfFrChunkCount( nSurf)
|
||||
for k = 0, nChunks - 1 do
|
||||
-- estraggo i loop associati
|
||||
local nCrv, nCnt = EgtExtractSurfFrChunkLoops( nSurf, k, nDestGrp)
|
||||
-- eventuali aggiustamenti per creare un percorso unico
|
||||
if nCnt > 1 then
|
||||
for nLoopId = nCrv + 1, nCrv + nCnt - 1 do
|
||||
local dLen = EgtCurveLength( nLoopId)
|
||||
local dPar1 = EgtCurveParamAtLength( nLoopId, dLen * 0.5)
|
||||
local dPar2 = EgtCurveParamAtLength( nLoopId, dLen * 0.5 + 2 * GEO.EPS_SMALL)
|
||||
local ptM = EgtUP( nLoopId, dPar1)
|
||||
local ptM2 = EgtUP( nLoopId, dPar2)
|
||||
local _, _, dParRef1 = EgtPointCurveDist( ptM2, nCrv)
|
||||
local _, _, dParRef2 = EgtPointCurveDist( ptM, nCrv)
|
||||
EgtTrimCurveStartEndAtParam( nCrv, dParRef2, dParRef1)
|
||||
EgtTrimCurveStartEndAtParam( nLoopId, dPar2, dPar1)
|
||||
EgtAddCurveCompoLine( nCrv, EgtSP( nLoopId))
|
||||
EgtAddCurveCompoCurve( nCrv, nLoopId)
|
||||
EgtCloseCurveCompo( nCrv)
|
||||
end
|
||||
end
|
||||
|
||||
if nType == TYPE.OUTER_SHELL or nType == TYPE.EXTRA_OUTER_SHELL then
|
||||
EgtSetColor( nCrv, EgtStdColor( 'TEAL'))
|
||||
elseif nType == TYPE.INNER_SHELL or nType == TYPE.EXTRA_SHELL then
|
||||
EgtSetColor( nCrv, EgtStdColor( 'ORANGE'))
|
||||
elseif nType == TYPE.LINK then
|
||||
EgtSetColor( nCrv, EgtStdColor( 'GRAY'))
|
||||
elseif nType == TYPE.INFILL then
|
||||
EgtSetColor( nCrv, EgtStdColor( 'YELLOW'))
|
||||
elseif nType == TYPE.COASTING then
|
||||
EgtSetColor( nCrv, EgtStdColor( 'BLUE'))
|
||||
elseif nType == TYPE.RIB then
|
||||
EgtSetColor( nCrv, EgtStdColor( 'OLIVE'))
|
||||
elseif nType == TYPE.AUX_SOLID then
|
||||
EgtSetColor( nCrv, EgtStdColor( 'AQUA'))
|
||||
end
|
||||
end
|
||||
EgtErase( nSurf)
|
||||
end
|
||||
end
|
||||
|
||||
nId = EgtGetNext( nId)
|
||||
end
|
||||
end
|
||||
|
||||
-- copio le frecce direzione dal gruppo dei solidi
|
||||
local nSolidGrp = EgtGetFirstNameInGroup( vCrvs[j], SOLID_GRP)
|
||||
if nSolidGrp then
|
||||
local nId = EgtGetFirstNameInGroup( nSolidGrp, DIR_ARROW)
|
||||
while nId do
|
||||
local nCopy = EgtCopyGlob( nId, nDestGrp)
|
||||
EgtSetMode( nCopy, GDB_MD.STD)
|
||||
EgtSetStatus( nCopy, GDB_ST.ON)
|
||||
nId = EgtGetNextName( nId, DIR_ARROW)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
------------------------------------------------------------------
|
||||
local function GetSolids( nSliceId, nDestGrp)
|
||||
|
||||
-- scorro tutti i gruppi di curve
|
||||
local vCrvs = EgtGetNameInGroup( nSliceId, CONTOUR_GRP .. '*')
|
||||
for j = 1, #vCrvs do
|
||||
-- recupero il solido dal gruppo
|
||||
local nSolidGrp = EgtGetFirstNameInGroup( vCrvs[j], SOLID_GRP)
|
||||
if nSolidGrp then
|
||||
-- copio solo la prima freccia direzionale
|
||||
local nArrow = EgtGetFirstNameInGroup( nSolidGrp, DIR_ARROW) or GDB_ID.NULL
|
||||
EgtCopyGlob( nArrow, nDestGrp)
|
||||
local vSolids = EgtGetAllInGroup( nSolidGrp)
|
||||
for i = 1, #vSolids do
|
||||
if EgtGetName( vSolids[i]) ~= DIR_ARROW then
|
||||
EgtCopyGlob( vSolids[i], nDestGrp)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
------------------------------------------------------------------
|
||||
function RunPrepareExport.Exec()
|
||||
|
||||
local nPartId = EgtGetFirstNameInGroup( GDB_ID.ROOT, PART .. '*')
|
||||
if not nPartId then
|
||||
EgtOutBox( 'Error : no part', 'Export')
|
||||
return GDB_ID.NULL
|
||||
end
|
||||
|
||||
-- creo o recupero il gruppo per l'esportazione
|
||||
local nGrp = EgtGetFirstNameInGroup( GDB_ID.ROOT, LAY_EXPORT)
|
||||
if not nGrp then
|
||||
-- se non esiste creo il gruppo
|
||||
nGrp = EgtGroup( GDB_ID.ROOT)
|
||||
EgtSetName( nGrp, LAY_EXPORT)
|
||||
EgtSetStatus( nGrp, GDB_ST.OFF)
|
||||
EgtSetLevel( nGrp, GDB_LV.TEMP)
|
||||
else
|
||||
-- se il gruppo esiste già non devo fare nulla
|
||||
return nGrp
|
||||
end
|
||||
|
||||
-- creo il punto di origine del riferimento
|
||||
local ptRef = EgtGetInfo( nPartId, KEY_ORIG_REF, 'p')
|
||||
if not ptRef then
|
||||
local nFrameId = EgtGetFirstNameInGroup( EgtGetFirstNameInGroup( nPartId, LAY_FRAME), FRAME_PART)
|
||||
ptRef = EgtSP( nFrameId or GDB_ID.NULL, GDB_ID.ROOT)
|
||||
end
|
||||
local nPnt = EgtPoint( nGrp, ptRef, GDB_RT.GLOB)
|
||||
EgtSetName( nPnt, KEY_ORIG_REF)
|
||||
EgtSetStatus( nPnt, GDB_ST.OFF)
|
||||
|
||||
-- recupero alcune info utili e le assegno al punto per poterle leggere da ThreeJS
|
||||
local dH = EgtGetInfo( nPartId, KEY_SLICE_STEP, 'd')
|
||||
EgtSetInfo( nPnt, KEY_SLICE_STEP, dH)
|
||||
local vtSlicing = EgtGetInfo( nPartId, KEY_SLICE_DIR, 'v')
|
||||
EgtSetInfo( nPnt, "SlicingDir", vtSlicing)
|
||||
local bSpiralVase = EgtGetInfo( nPartId, KEY_SPIRAL_VASE, 'b') or false
|
||||
EgtSetInfo( nPnt, KEY_SPIRAL_VASE, bSpiralVase)
|
||||
local nSlicingType = EgtGetInfo( nPartId, KEY_SLICING_TYPE, 'i')
|
||||
|
||||
-- recupero lo strand dai parametri generale nel caso non fosse definito sulle singole curve
|
||||
local dStrandBase = EgtGetInfo( nPartId, KEY_STRAND, 'd') or 0
|
||||
|
||||
-- recupero gli slices
|
||||
local vSlices = EgtGetNameInGroup( nPartId, SLICE_LAYER .. '*') or {}
|
||||
if #vSlices == 0 then
|
||||
EgtOutBox( 'Error : no slices', 'Export')
|
||||
return GDB_ID.NULL
|
||||
end
|
||||
|
||||
-- verifico che nel primo slice siano presenti sia i toolpath sia i solidi
|
||||
local nCrvGrp = EgtGetFirstNameInGroup( vSlices[1], CONTOUR_GRP .. '*')
|
||||
if not nCrvGrp then
|
||||
EgtOutBox( 'Error : no toolpaths', 'Export')
|
||||
return GDB_ID.NULL
|
||||
end
|
||||
local nTPath = EgtGetFirstNameInGroup( nCrvGrp, TOOLPATH_GRP)
|
||||
if not nTPath then
|
||||
EgtOutBox( 'Error : no toolpaths', 'Export')
|
||||
return GDB_ID.NULL
|
||||
end
|
||||
local nSolid = EgtGetFirstNameInGroup( nCrvGrp, SOLID_GRP)
|
||||
if not nSolid then
|
||||
EgtOutBox( 'Error : no solids', 'Export')
|
||||
return GDB_ID.NULL
|
||||
end
|
||||
|
||||
for i = 1, #vSlices do
|
||||
|
||||
-- creo il gruppo corrispondente
|
||||
local nDestGrp = EgtGroup( nGrp)
|
||||
EgtSetName( nDestGrp, EgtGetName( vSlices[i]))
|
||||
EgtSetStatus( nDestGrp, GDB_ST.OFF)
|
||||
|
||||
-- se multiplanare o spiral vase esporto direttamente i solidi altrimenti esporto le curve che verranno estruse nel visualizzatore
|
||||
if nSlicingType == SLICING_TYPE.MULTIPLANAR or bSpiralVase then
|
||||
GetSolids( vSlices[i], nDestGrp)
|
||||
else
|
||||
CalcCurves( vSlices[i], nDestGrp, vtSlicing, dStrandBase)
|
||||
end
|
||||
end
|
||||
|
||||
return nGrp
|
||||
end
|
||||
|
||||
---------------------------------------------------------------------
|
||||
return RunPrepareExport
|
||||
+15
-5
@@ -72,6 +72,20 @@ local function RemoveOldSlices( nPartId)
|
||||
if nRibsLoopsGrp then
|
||||
EgtErase( nRibsLoopsGrp)
|
||||
end
|
||||
|
||||
-- rimuovo eventuali gruppi di infill (anche per aux solids)
|
||||
local nInfillId = EgtGetFirstNameInGroup( nPartId, INFILL_GRP .. '*')
|
||||
while nInfillId do
|
||||
EgtErase( nInfillId)
|
||||
nInfillId = EgtGetFirstNameInGroup( nPartId, INFILL_GRP .. '*')
|
||||
end
|
||||
|
||||
-- rimuovo gruppo per export
|
||||
local nExportGrpId = EgtGetFirstNameInGroup( GDB_ID.ROOT, LAY_EXPORT)
|
||||
if nExportGrpId then
|
||||
EgtErase( nExportGrpId)
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
---------------------------------------------------------------------
|
||||
@@ -150,10 +164,6 @@ function RunSlicing.Exec()
|
||||
EgtRemoveAllOperations()
|
||||
EgtResetCurrMachGroup()
|
||||
|
||||
-- Lettura dati macchina
|
||||
local sMachIni = EgtGetCurrMachineDir() .. '\\' .. EgtGetCurrMachineName() .. '.ini'
|
||||
local HMax = tonumber( EgtGetStringFromIni( '3dPrinting', 'HMax', 500, sMachIni))
|
||||
|
||||
-- Eventuale ripristino posizione originaria
|
||||
RestoreOriginalPosition( nPartId)
|
||||
|
||||
@@ -164,7 +174,7 @@ function RunSlicing.Exec()
|
||||
RemoveOldTFS()
|
||||
|
||||
-- Calcolo delle fette
|
||||
local bOk = CSLICES.Exec( nPartId, nStmId, HMax)
|
||||
local bOk = CSLICES.Exec( nPartId, nStmId)
|
||||
EgtDraw()
|
||||
|
||||
-- Calcolo dei percorsi sul centro strand in basso
|
||||
|
||||
@@ -0,0 +1,17 @@
|
||||
-- PrepareExport.lua by Egaltech s.r.l. 2023/10/19
|
||||
-- Creo le geometrie da esportare con 3dm
|
||||
|
||||
-- Intestazioni
|
||||
require( 'EgtBase')
|
||||
_ENV = EgtProtectGlobal()
|
||||
EgtEnableDebug( false)
|
||||
|
||||
-- Imposto direttorio libreria specializzata per Stampa 3d
|
||||
EgtAddToPackagePath( PRINT.BASEDIR .. '\\LuaLibs\\?.lua')
|
||||
|
||||
-- Librerie
|
||||
_G.package.loaded.RunPrepareExport = nil
|
||||
local RPE = require( 'RunPrepareExport')
|
||||
|
||||
-- Calcolo
|
||||
PRINT.EXPORTLAYER = RPE.Exec()
|
||||
+2
-2
@@ -1,4 +1,4 @@
|
||||
-- Version.lua by Egaltech s.r.l. 2023/02/28
|
||||
-- Version.lua by Egaltech s.r.l. 2026/03/04
|
||||
-- Gestione della versione di 3dPrinting
|
||||
|
||||
VERSION = '2.5d5'
|
||||
VERSION = '3.1c1'
|
||||
Reference in New Issue
Block a user