Compare commits
81 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 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 | |||
| 72d1b61c6a | |||
| 02fe05d5e1 | |||
| 3c839716f8 | |||
| 2fc63b0d25 | |||
| 9c42a70c6a | |||
| 922c5510c0 | |||
| 56ff8468f0 | |||
| 63efafde60 | |||
| 49c8361bc5 | |||
| a7c7bd63ed | |||
| 4da4b8cf4d |
+4
-4
@@ -16,14 +16,14 @@ variables:
|
|||||||
$FileList = Get-ChildItem("*.lua")
|
$FileList = Get-ChildItem("*.lua")
|
||||||
ForEach ($File in $FileList) {
|
ForEach ($File in $FileList) {
|
||||||
$FileName = Split-Path $File -leaf
|
$FileName = Split-Path $File -leaf
|
||||||
lua54 -o bin\$FileName $FileName
|
lua54 -o bin\$FileName -s $FileName
|
||||||
echo "lua54 -o bin\$FileName $FileName"
|
echo "lua54 -o bin\$FileName -s $FileName"
|
||||||
}
|
}
|
||||||
$FileList = Get-ChildItem("LuaLibs\*.lua")
|
$FileList = Get-ChildItem("LuaLibs\*.lua")
|
||||||
ForEach ($File in $FileList) {
|
ForEach ($File in $FileList) {
|
||||||
$FileName = Split-Path $File -leaf
|
$FileName = Split-Path $File -leaf
|
||||||
lua54 -o bin\LuaLibs\$FileName LuaLibs\$FileName
|
lua54 -o bin\LuaLibs\$FileName -s LuaLibs\$FileName
|
||||||
echo "lua54 -o bin\LuaLibs\$FileName LuaLibs\$FileName"
|
echo "lua54 -o bin\LuaLibs\$FileName -s LuaLibs\$FileName"
|
||||||
}
|
}
|
||||||
|
|
||||||
# helper copia SORGENTI verso cartella di rete R:\ dei SORGENTI
|
# 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
-13
@@ -1,18 +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 Per togliere info di debug aggiungere flag -s prima del nome del file di input
|
||||||
|
|
||||||
REM Compilazione 32 e 64 bit
|
REM Compilazione 32 e 64 bit
|
||||||
|
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\AddManData.lua LuaLibs\AddManData.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\AddManData.lua -s LuaLibs\AddManData.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcPaths.lua LuaLibs\CalcPaths.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcPaths.lua -s LuaLibs\CalcPaths.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcSlices.lua LuaLibs\CalcSlices.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcSlices.lua -s LuaLibs\CalcSlices.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcToolPath.lua LuaLibs\CalcToolPath.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\CalcToolPath.lua -s LuaLibs\CalcToolPath.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunCalcSolids.lua LuaLibs\RunCalcSolids.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunCalcSolids.lua -s LuaLibs\RunCalcSolids.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunGcodeGenerate.lua LuaLibs\RunGcodeGenerate.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunGcodeGenerate.lua -s LuaLibs\RunGcodeGenerate.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunMachParamFromSWCalc.lua LuaLibs\RunMachParamFromSWCalc.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunMachParamFromSWCalc.lua -s LuaLibs\RunMachParamFromSWCalc.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunSlicing.lua LuaLibs\RunSlicing.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunPrepareExport.lua -s LuaLibs\RunPrepareExport.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\CalcMachParamFromSW.lua CalcMachParamFromSW.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\RunSlicing.lua -s LuaLibs\RunSlicing.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\CalcSolids.lua CalcSolids.lua
|
\EgtProg\Dll32\luac54 -o bin\CalcMachParamFromSW.lua -s CalcMachParamFromSW.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\GcodeGenerate.lua GcodeGenerate.lua
|
\EgtProg\Dll32\luac54 -o bin\CalcSolids.lua -s CalcSolids.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\Slicing.lua Slicing.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
|
||||||
|
|||||||
+88
-14
@@ -28,12 +28,17 @@ LINK_CRV = "Link"
|
|||||||
FRAME_PART = "FramePart"
|
FRAME_PART = "FramePart"
|
||||||
START_GEOM = "Start"
|
START_GEOM = "Start"
|
||||||
TOT_SHELL_TRIM_SURF = "TotalShellSurfForTrim"
|
TOT_SHELL_TRIM_SURF = "TotalShellSurfForTrim"
|
||||||
|
SHELL_SURF = "ShellSurf"
|
||||||
|
COARSE_TRIM_SURF = "CoarseTrimSurf"
|
||||||
TRIM_SURF_LOOP = "TrimSurfLoop"
|
TRIM_SURF_LOOP = "TrimSurfLoop"
|
||||||
SURF_LOOP = "SurfLoop"
|
SURF_LOOP = "SurfLoop"
|
||||||
|
LOOP_GRP = "LoopGrp"
|
||||||
|
DIR_ARROW = "Arrow"
|
||||||
|
|
||||||
MIN_LEN = 0.1
|
MIN_LEN = 0.1
|
||||||
MIN_AREA = 0.01
|
MIN_AREA = 0.01
|
||||||
MIN_RIBS_LEN = 2
|
MIN_RIBS_LEN = 2
|
||||||
|
MIN_INFILL_LEN = 2
|
||||||
|
|
||||||
-- Parametri di lavorazione
|
-- Parametri di lavorazione
|
||||||
SEC_DEFAULT = "Default"
|
SEC_DEFAULT = "Default"
|
||||||
@@ -45,6 +50,7 @@ KEY_SLICING_DIR = "SlicingDir"
|
|||||||
KEY_SLICE_STEP = "StrandH"
|
KEY_SLICE_STEP = "StrandH"
|
||||||
KEY_SHELLS_NBR = "StrandCount"
|
KEY_SHELLS_NBR = "StrandCount"
|
||||||
KEY_STRAND = "StrandW"
|
KEY_STRAND = "StrandW"
|
||||||
|
KEY_INNER_STRAND = "InnerStrandW"
|
||||||
KEY_STRAND_OVERLAP = "StrandOverlap"
|
KEY_STRAND_OVERLAP = "StrandOverlap"
|
||||||
KEY_OFFSET_SLICE = "Offset"
|
KEY_OFFSET_SLICE = "Offset"
|
||||||
KEY_SP_OFFSET_ON_SLICE = "StartPointOffsetOnSlice"
|
KEY_SP_OFFSET_ON_SLICE = "StartPointOffsetOnSlice"
|
||||||
@@ -55,10 +61,6 @@ KEY_TYPE = "Type"
|
|||||||
KEY_LINK_TYPE = "LinkType"
|
KEY_LINK_TYPE = "LinkType"
|
||||||
KEY_LINK_PARAM = "LinkParam"
|
KEY_LINK_PARAM = "LinkParam"
|
||||||
KEY_LINK_ZUP = "LinkZup"
|
KEY_LINK_ZUP = "LinkZup"
|
||||||
KEY_FLOOR_NBR = "FloorCount"
|
|
||||||
KEY_FLOOR_TYPE = "FloorType"
|
|
||||||
KEY_CEIL_NBR = "CeilCount"
|
|
||||||
KEY_CEIL_TYPE = "CeilType"
|
|
||||||
KEY_SPEED = "Speed"
|
KEY_SPEED = "Speed"
|
||||||
KEY_FEED = "Feed"
|
KEY_FEED = "Feed"
|
||||||
KEY_EXT_FEED = "ExtFeed"
|
KEY_EXT_FEED = "ExtFeed"
|
||||||
@@ -81,9 +83,31 @@ KEY_COASTING_FEED = "CoastingFeed"
|
|||||||
KEY_WIPE_LEN = "WipeLen"
|
KEY_WIPE_LEN = "WipeLen"
|
||||||
KEY_WIPE_DIR = "WipeDir"
|
KEY_WIPE_DIR = "WipeDir"
|
||||||
KEY_WIPE_FEEDPU = "WipeFeedPu"
|
KEY_WIPE_FEEDPU = "WipeFeedPu"
|
||||||
KEY_TOOL_DIAM = "ToolDiam"
|
KEY_TOOL_DIAM = "ToolDiam"
|
||||||
|
|
||||||
|
-- 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
|
-- Ribs
|
||||||
|
KEY_RIBS_STRAND = "RibsStrandW"
|
||||||
KEY_RIBS_TYPE = "RibsType"
|
KEY_RIBS_TYPE = "RibsType"
|
||||||
KEY_LIMIT_UNBDD_RIBS = "LimitUnboundedRibsWithSolid"
|
KEY_LIMIT_UNBDD_RIBS = "LimitUnboundedRibsWithSolid"
|
||||||
KEY_RIBS_OVERLAP = "RibsOverlap"
|
KEY_RIBS_OVERLAP = "RibsOverlap"
|
||||||
@@ -109,10 +133,15 @@ KEY_START_RIB = "StartRib"
|
|||||||
KEY_ORIGINAL_RIB = "OriginalRib"
|
KEY_ORIGINAL_RIB = "OriginalRib"
|
||||||
KEY_LOOP_RIB = "LoopRib"
|
KEY_LOOP_RIB = "LoopRib"
|
||||||
KEY_RIBS_USER_LINK = "RibWithUserLink"
|
KEY_RIBS_USER_LINK = "RibWithUserLink"
|
||||||
|
KEY_RIBS_USER_LINK_SAME_SIDE = "RibUserLinkOnSameSide"
|
||||||
KEY_RIBS_USER_LINK_CCW = "RibUserLinkCCW"
|
KEY_RIBS_USER_LINK_CCW = "RibUserLinkCCW"
|
||||||
KEY_RIBS_USER_LINK_ORDER = "RibUserLinkOrder"
|
KEY_RIBS_USER_LINK_ORDER = "RibUserLinkOrder"
|
||||||
KEY_RIBS_USER_LINK_TOT = "RibsUserLinkParts"
|
KEY_RIBS_USER_LINK_TOT = "RibsUserLinkParts"
|
||||||
KEY_RIBS_INVERT_STRAND_ORDER = "RibsInvertStrandOrder"
|
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
|
-- Regioni con diverso numero di passate
|
||||||
KEY_SHELL_NBR_DIFF = "ShellNbrDifference"
|
KEY_SHELL_NBR_DIFF = "ShellNbrDifference"
|
||||||
@@ -124,12 +153,21 @@ KEY_EXTRA_SHELL_WIPE = "ExtraShellWipe"
|
|||||||
KEY_EXTRA_SHELL_WIPE_DIR = "ExtraShellWipeDir"
|
KEY_EXTRA_SHELL_WIPE_DIR = "ExtraShellWipeDir"
|
||||||
|
|
||||||
-- Solidi ausiliari
|
-- 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_INFILL = "AuxSolidsInfill"
|
||||||
KEY_AUX_SOLIDS_PRINT_ORDER = "AuxSolidsStrandOrder"
|
KEY_AUX_SOLIDS_PRINT_ORDER = "AuxSolidsStrandOrder"
|
||||||
KEY_AUX_SOLIDS_OVERLAP = "AuxSolidsOverlap"
|
|
||||||
KEY_AUX_SOLIDS_LINK_TYPE = "AuxSolidsLinkType"
|
KEY_AUX_SOLIDS_LINK_TYPE = "AuxSolidsLinkType"
|
||||||
KEY_AUX_SOLIDS_SP_OFFSET = "AuxSolidsStartPointOffsetOnSlice"
|
|
||||||
KEY_AUX_SOLIDS_LINK_PARAM = "AuxSolidsLinkParam"
|
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_COASTING_LEN = "AuxSolidsCoastingLen"
|
||||||
KEY_AUX_SOLIDS_WIPE_LEN = "AuxSolidsWipeLen"
|
KEY_AUX_SOLIDS_WIPE_LEN = "AuxSolidsWipeLen"
|
||||||
KEY_AUX_SOLIDS_WIPE_DIR = "AuxSolidsWipeDir"
|
KEY_AUX_SOLIDS_WIPE_DIR = "AuxSolidsWipeDir"
|
||||||
@@ -140,8 +178,12 @@ KEY_COEFF_X = "CoeffX"
|
|||||||
KEY_COEFF_Y = "CoeffY"
|
KEY_COEFF_Y = "CoeffY"
|
||||||
KEY_SPEED_MIN = "SpeedMin"
|
KEY_SPEED_MIN = "SpeedMin"
|
||||||
KEY_SPEED_MAX = "SpeedMax"
|
KEY_SPEED_MAX = "SpeedMax"
|
||||||
|
KEY_FEED_MAX = 'FeedMax'
|
||||||
|
KEY_LINEAR_APPROX = 'LinearApprox'
|
||||||
|
KEY_LINEAR_TOL = 'LinearTol'
|
||||||
|
|
||||||
-- Altre chiavi
|
-- Altre chiavi
|
||||||
|
KEY_MAX_H = "SlicingHeight"
|
||||||
KEY_SLICE_NBR = "SliceNbr"
|
KEY_SLICE_NBR = "SliceNbr"
|
||||||
KEY_SLICE_Z = "SliceZ"
|
KEY_SLICE_Z = "SliceZ"
|
||||||
KEY_SLICE_DELTAZ = "DeltaZ"
|
KEY_SLICE_DELTAZ = "DeltaZ"
|
||||||
@@ -152,11 +194,25 @@ KEY_INVERTED_CRV = "InvertedCrv"
|
|||||||
KEY_CLOSED_CRV = "ClosedCrv"
|
KEY_CLOSED_CRV = "ClosedCrv"
|
||||||
KEY_ASSOCIATED_SURF = "AssociatedSurf"
|
KEY_ASSOCIATED_SURF = "AssociatedSurf"
|
||||||
KEY_ASSOCIATED_CRVS = "AssociatedCrvs"
|
KEY_ASSOCIATED_CRVS = "AssociatedCrvs"
|
||||||
|
KEY_ORIGINAL_SURF = "OriginalSurf"
|
||||||
KEY_HAS_SOLIDS = "Solids"
|
KEY_HAS_SOLIDS = "Solids"
|
||||||
KEY_BOX_MIN_Z = "PartBoxMinZ"
|
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'
|
||||||
|
|
||||||
SLICING_TYPE = {
|
SLICING_TYPE = {
|
||||||
VERTICAL = 1,
|
VERTICAL = 1,
|
||||||
DEG45_X = 2,
|
DEG45_X = 2,
|
||||||
DEG45_Y = 3,
|
DEG45_Y = 3,
|
||||||
@@ -200,7 +256,7 @@ PRINT_DIRECTION = {
|
|||||||
LINK_TYPE = {
|
LINK_TYPE = {
|
||||||
NONE = 1,
|
NONE = 1,
|
||||||
LINEAR = 2,
|
LINEAR = 2,
|
||||||
BIARC = 3,
|
BIARC = 3,
|
||||||
}
|
}
|
||||||
|
|
||||||
LEAD_TYPE = {
|
LEAD_TYPE = {
|
||||||
@@ -209,10 +265,21 @@ LEAD_TYPE = {
|
|||||||
ARC = 3,
|
ARC = 3,
|
||||||
}
|
}
|
||||||
|
|
||||||
INFILL_TYPE = {
|
FILL_CATEGORY = {
|
||||||
NONE = 1,
|
NONE = 0,
|
||||||
OFFSET = 2,
|
SOLID_FILL = 16,
|
||||||
ZIGZAG = 3,
|
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 = {
|
RIB_TYPE = {
|
||||||
@@ -236,6 +303,7 @@ LAY_FRAME = "Frame"
|
|||||||
VIEWPARAMS = 'ViewParams'
|
VIEWPARAMS = 'ViewParams'
|
||||||
IMPORTED_SOLID = 'ImportedSolid'
|
IMPORTED_SOLID = 'ImportedSolid'
|
||||||
RESULT_READ_PROG = 'ResultReadProg'
|
RESULT_READ_PROG = 'ResultReadProg'
|
||||||
|
LAY_EXPORT = "ExportLayer"
|
||||||
|
|
||||||
KEY_PART_ON_TABLE = 'PartOnTable'
|
KEY_PART_ON_TABLE = 'PartOnTable'
|
||||||
KEY_RESULT = 'Result'
|
KEY_RESULT = 'Result'
|
||||||
@@ -284,15 +352,21 @@ SLICE_ADV_TYPE = {
|
|||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
RIBS_GRP = "Ribs"
|
RIBS_GRP = "Ribs"
|
||||||
RIBS_CRV = "Rib"
|
RIBS_CRV = "Rib"
|
||||||
|
RIBS_LOOP_GRP = "RibsLoops"
|
||||||
|
|
||||||
SHELL_NBR_GRP = "ShellNbrRegions"
|
SHELL_NBR_GRP = "ShellNbrRegions"
|
||||||
SHELL_NBR_CRV = "ShellNbrRegion"
|
SHELL_NBR_CRV = "ShellNbrRegion"
|
||||||
SHELL_NBR_SURF = "ShellNbrSurf"
|
SHELL_NBR_SURF = "ShellNbrSurf"
|
||||||
|
|
||||||
AUX_SOLIDS_GRP = "AuxSolids"
|
AUX_SOLIDS_GRP = "AuxSolids"
|
||||||
|
AUX_SOLIDS_INFILL_GRP = "InfillAuxSolids"
|
||||||
AUX_SOLIDS_CRV = "AuxSolid"
|
AUX_SOLIDS_CRV = "AuxSolid"
|
||||||
|
AUX_SOLIDS_INFILL_CRV = "InfillAuxSolid"
|
||||||
AUX_SOLIDS_SRF = "SrfAuxSolid"
|
AUX_SOLIDS_SRF = "SrfAuxSolid"
|
||||||
|
|
||||||
|
INFILL_GRP = "Infill"
|
||||||
|
INFILL_CRV = "InfillCrv"
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- parametri calcolo tempi, F ed S
|
-- parametri calcolo tempi, F ed S
|
||||||
LAY_TFSCALC = "TFSCalc"
|
LAY_TFSCALC = "TFSCalc"
|
||||||
|
|||||||
+3039
-832
File diff suppressed because it is too large
Load Diff
+626
-184
File diff suppressed because it is too large
Load Diff
+1514
-534
File diff suppressed because it is too large
Load Diff
+233
-109
@@ -14,59 +14,54 @@ local AMD = require( 'AddManData')
|
|||||||
|
|
||||||
--------------------------------------------------------------------
|
--------------------------------------------------------------------
|
||||||
local s_dTol = 0.1
|
local s_dTol = 0.1
|
||||||
|
local s_nSimplifiedSection = 0
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
local function GetLayerParamsForSolidCalc( nPartId)
|
local function GetLayerParamsForSolidCalc( nPartId)
|
||||||
local LayerParams = {}
|
local LayerParams = {}
|
||||||
LayerParams.bSpiralVase = EgtGetInfo( nPartId, KEY_SPIRAL_VASE, 'b') or false
|
LayerParams.bSpiralVase = EgtGetInfo( nPartId, KEY_SPIRAL_VASE, 'b') or false
|
||||||
LayerParams.dLayHeight = EgtGetInfo( nPartId, KEY_SLICE_STEP, 'd')
|
LayerParams.dLayHeight = EgtGetInfo( nPartId, KEY_SLICE_STEP, 'd')
|
||||||
LayerParams.dStrand = EgtGetInfo( nPartId, KEY_STRAND, 'd')
|
|
||||||
LayerParams.vtSlicing = EgtGetInfo( nPartId, KEY_SLICING_DIR, 'v')
|
LayerParams.vtSlicing = EgtGetInfo( nPartId, KEY_SLICING_DIR, 'v')
|
||||||
|
LayerParams.dStrand = EgtGetInfo( nPartId, KEY_STRAND, 'd')
|
||||||
return LayerParams
|
return LayerParams
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
local function CalcSectionParams( dStrand, dH)
|
local function CalcSectionParams( dStrand, dH)
|
||||||
local dL = dStrand
|
local dBevelX = 0
|
||||||
local dLm = dStrand / 10
|
local dBevelY = 0
|
||||||
local dHm = dH / 6
|
if s_nSimplifiedSection == 0 then
|
||||||
local dD1 = 0.5 * dL - dLm
|
-- sezione ottagonale
|
||||||
local dD2 = 0.5 * dL - dD1
|
dBevelX = dStrand / 10
|
||||||
local dD3 = dHm
|
dBevelY = dH / 6
|
||||||
local dD4 = dH - 2 * dD3
|
end
|
||||||
return dD1, dD2, dD3, dD4
|
return dBevelX, dBevelY
|
||||||
|
end
|
||||||
|
|
||||||
|
----------------------------------------------------------------------
|
||||||
|
local function CreateStandardSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
||||||
|
|
||||||
|
local dBevelX, dBevelY = CalcSectionParams( dStrand, LayerParams.dLayHeight)
|
||||||
|
local nSrfId = EgtSurfTmRectSwept( nSolidGrp, dStrand, LayerParams.dLayHeight, dBevelX, dBevelY, nCrvId, GDB_RSCT.BEVEL, s_dTol)
|
||||||
|
return nSrfId
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
local function CreateSection( ptS, vtDir, dStrand, dH, vtSlicing, nSolidGrp)
|
local function CreateSection( ptS, vtDir, dStrand, dH, vtSlicing, nSolidGrp)
|
||||||
|
|
||||||
local dD1, dD2, dD3, dD4 = CalcSectionParams( dStrand, dH)
|
local dBevelX, dBevelY = CalcSectionParams( dStrand, dH)
|
||||||
local ptA = ptS - dH * vtSlicing + dD1 * vtDir
|
local ptA = ptS - dH * vtSlicing + ( 0.5 * dStrand - dBevelX) * vtDir
|
||||||
local ptB = ptA + dD2 * vtDir + dD3 *vtSlicing
|
local ptB = ptA + dBevelY * vtSlicing + dBevelX * vtDir
|
||||||
local ptC = ptB + dD4 * vtSlicing
|
local ptC = ptB + ( dH - 2 * dBevelY) * vtSlicing
|
||||||
local ptD = ptA + dH * vtSlicing
|
local ptD = ptA + dH * vtSlicing
|
||||||
local ptE = ptD - 2 * dD1 * vtDir
|
local ptE = ptD - ( dStrand - 2 * dBevelX) * vtDir
|
||||||
local ptF = ptC - 2 * ( dD1 + dD2) * vtDir
|
local ptF = ptC - dStrand * vtDir
|
||||||
local ptG = ptB - 2 * ( dD1 + dD2) * vtDir
|
local ptG = ptB - dStrand * vtDir
|
||||||
local ptH = ptA - 2 * dD1 * vtDir
|
local ptH = ptA - ( dStrand - 2 * dBevelX) * vtDir
|
||||||
|
|
||||||
local nId = EgtCurveCompoFromPoints( nSolidGrp, {ptA, ptB, ptC, ptD, ptE, ptF, ptG, ptH, ptA}, GDB_RT.GLOB)
|
local nId = EgtCurveCompoFromPoints( nSolidGrp, {ptA, ptB, ptC, ptD, ptE, ptF, ptG, ptH, ptA}, GDB_RT.GLOB)
|
||||||
EgtInvertCurve( nId)
|
EgtInvertCurve( nId)
|
||||||
|
|
||||||
return nId
|
|
||||||
end
|
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
|
||||||
local function CreateHalfSection( ptS, vtDir, dStrand, dH, vtSlicing, nSolidGrp)
|
|
||||||
|
|
||||||
local dD1, dD2, dD3, dD4 = CalcSectionParams( dStrand, dH)
|
|
||||||
local ptA = ptS - dH * vtSlicing + dD1 * vtDir
|
|
||||||
local ptB = ptA + dD2 * vtDir + dD3 * vtSlicing
|
|
||||||
local ptC = ptB + dD4 * vtSlicing
|
|
||||||
local ptD = ptA + dH * vtSlicing
|
|
||||||
|
|
||||||
local nId = EgtCurveCompoFromPoints( nSolidGrp, { ptS - dH * vtSlicing, ptA, ptB, ptC, ptD, ptS}, GDB_RT.GLOB)
|
|
||||||
|
|
||||||
return nId
|
return nId
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -74,30 +69,48 @@ end
|
|||||||
local function CreateSpiralVaseCap( nSectId, vtDir, nSolidGrp)
|
local function CreateSpiralVaseCap( nSectId, vtDir, nSolidGrp)
|
||||||
|
|
||||||
local vPt = {}
|
local vPt = {}
|
||||||
for i = 0, 7 do
|
local nLast = EgtIf( s_nSimplifiedSection == 1, 3, 7)
|
||||||
|
for i = 0, nLast do
|
||||||
vPt[i + 1] = EgtUP( nSectId, i, GDB_ID.ROOT)
|
vPt[i + 1] = EgtUP( nSectId, i, GDB_ID.ROOT)
|
||||||
end
|
end
|
||||||
|
|
||||||
local vCrvs = {}
|
local vCrvs = {}
|
||||||
vCrvs[1] = EgtArc2PV( nSolidGrp, vPt[1], vPt[2], vtDir, GDB_RT.GLOB)
|
-- calcolo gli archi che definiscono la superficie laterale
|
||||||
vCrvs[2] = EgtArc2PV( nSolidGrp, vPt[8], vPt[3], vtDir, GDB_RT.GLOB)
|
if s_nSimplifiedSection == 1 then
|
||||||
vCrvs[3] = EgtArc2PV( nSolidGrp, vPt[7], vPt[4], vtDir, GDB_RT.GLOB)
|
-- sezione quadrata
|
||||||
vCrvs[4] = EgtArc2PV( nSolidGrp, vPt[6], vPt[5], vtDir, GDB_RT.GLOB)
|
vCrvs[1] = EgtArc2PV( nSolidGrp, vPt[1], vPt[2], vtDir, GDB_RT.GLOB)
|
||||||
vCrvs[5] = EgtCurveCompo( nSolidGrp, {vCrvs[1]}, false, GDB_RT.GLOB)
|
vCrvs[2] = EgtArc2PV( nSolidGrp, vPt[4], vPt[3], vtDir, GDB_RT.GLOB)
|
||||||
EgtCloseCurveCompo( vCrvs[5])
|
else
|
||||||
vCrvs[6] = EgtCurveCompo( nSolidGrp, {vCrvs[4]}, false, GDB_RT.GLOB)
|
-- sezione ottagonale
|
||||||
EgtCloseCurveCompo( vCrvs[6])
|
vCrvs[1] = EgtArc2PV( nSolidGrp, vPt[1], vPt[2], vtDir, GDB_RT.GLOB)
|
||||||
local nSurf1 = EgtSurfTmRuled( nSolidGrp, vCrvs[1], vCrvs[2], GDB_RUL.ISOPAR, s_dTol)
|
vCrvs[2] = EgtArc2PV( nSolidGrp, vPt[8], vPt[3], vtDir, GDB_RT.GLOB)
|
||||||
local nSurf2 = EgtSurfTmRuled( nSolidGrp, vCrvs[2], vCrvs[3], GDB_RUL.ISOPAR, s_dTol)
|
vCrvs[3] = EgtArc2PV( nSolidGrp, vPt[7], vPt[4], vtDir, GDB_RT.GLOB)
|
||||||
local nSurf3 = EgtSurfTmRuled( nSolidGrp, vCrvs[3], vCrvs[4], GDB_RUL.ISOPAR, s_dTol)
|
vCrvs[4] = EgtArc2PV( nSolidGrp, vPt[6], vPt[5], vtDir, GDB_RT.GLOB)
|
||||||
local nSurf4 = EgtSurfTmByRegion( nSolidGrp, vCrvs[5], s_dTol)
|
end
|
||||||
local nSurf5 = EgtSurfTmByRegion( nSolidGrp, vCrvs[6], s_dTol)
|
-- creo le rigate
|
||||||
local nCapSrf = EgtSurfTmBySewing( nSolidGrp, {nSurf1, nSurf2, nSurf3, nSurf4, nSurf5})
|
local vSurfs = {}
|
||||||
|
for i = 1, #vCrvs - 1 do
|
||||||
|
vSurfs[i] = EgtSurfTmRuled( nSolidGrp, vCrvs[i], vCrvs[i+1], GDB_RUL.ISOPAR, s_dTol)
|
||||||
|
end
|
||||||
|
-- calcolo le superfici top e bottom del cap
|
||||||
|
local nCrvBottom = EgtCurveCompo( nSolidGrp, {vCrvs[1]}, false, GDB_RT.GLOB)
|
||||||
|
EgtCloseCurveCompo( nCrvBottom)
|
||||||
|
local nSurfBottom = EgtSurfTmByRegion( nSolidGrp, nCrvBottom, s_dTol)
|
||||||
|
local nCrvTop = EgtCurveCompo( nSolidGrp, {vCrvs[#vCrvs]}, false, GDB_RT.GLOB)
|
||||||
|
EgtCloseCurveCompo( nCrvTop)
|
||||||
|
local nSurfTop = EgtSurfTmByRegion( nSolidGrp, nCrvTop, s_dTol)
|
||||||
|
table.insert( vSurfs, nSurfTop)
|
||||||
|
table.insert( vSurfs, nSurfBottom)
|
||||||
|
|
||||||
|
local nCapSrf = EgtSurfTmByTriangles( nSolidGrp, vSurfs)
|
||||||
|
|
||||||
|
-- cancello curve di costruzione
|
||||||
for i = 1, #vCrvs do
|
for i = 1, #vCrvs do
|
||||||
EgtErase( vCrvs[i])
|
EgtErase( vCrvs[i])
|
||||||
end
|
end
|
||||||
|
EgtErase( nCrvTop)
|
||||||
|
EgtErase( nCrvBottom)
|
||||||
|
|
||||||
return nCapSrf
|
return nCapSrf
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -105,16 +118,26 @@ end
|
|||||||
local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
||||||
|
|
||||||
-- gruppo temporaneo per conti
|
-- gruppo temporaneo per conti
|
||||||
local nGrpTmp = EgtGroup( nSolidGrp)
|
local nGrpTmp = EgtGroup( nSolidGrp, Frame3d( ORIG(), LayerParams.vtSlicing, GDB_RT.GLOB))
|
||||||
|
|
||||||
|
-- accorcio leggermente la curva per evitare problemi di inconsistent orientation nel solido
|
||||||
|
local dLen = EgtCurveLength( nCrvId)
|
||||||
|
EgtTrimCurveEndAtLen( nCrvId, dLen - 20 * GEO.EPS_SMALL)
|
||||||
|
|
||||||
local ptS = EgtSP( nCrvId, GDB_ID.ROOT)
|
local ptS = EgtSP( nCrvId, GDB_ID.ROOT)
|
||||||
local vtS = EgtSV( nCrvId, GDB_ID.ROOT)
|
local vtS = EgtSV( nCrvId, GDB_ID.ROOT)
|
||||||
local ptE = EgtEP( nCrvId, GDB_ID.ROOT)
|
local ptE = EgtEP( nCrvId, GDB_ID.ROOT)
|
||||||
local vtE = EgtEV( nCrvId, GDB_ID.ROOT)
|
local vtE = EgtEV( nCrvId, GDB_ID.ROOT)
|
||||||
|
local dDelta = ( ptE - ptS) * LayerParams.vtSlicing
|
||||||
|
-- se non è vero spiral vase, chiamo funzione standard
|
||||||
|
if dDelta < GEO.EPS_SMALL then
|
||||||
|
return CreateStandardSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
||||||
|
end
|
||||||
|
|
||||||
-- appiattisco la curva
|
-- appiattisco la curva
|
||||||
local nCrvCopy = EgtCopyGlob( nCrvId, nGrpTmp)
|
local nCrvCopy = EgtCopyGlob( nCrvId, nGrpTmp)
|
||||||
local dDelta = ( ptE - ptS) * LayerParams.vtSlicing
|
EgtModifyCurveExtrusion( nCrvCopy, LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||||
EgtSpiralizeCurveAlongExtrusion( nCrvCopy, - dDelta)
|
EgtProjectCurveOnPlane( nCrvCopy, ptS, LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||||
EgtMergeCurvesInCurveCompo( nCrvCopy)
|
EgtMergeCurvesInCurveCompo( nCrvCopy)
|
||||||
EgtChangeClosedCurveStartPoint( nCrvCopy, ptS, GDB_RT.GLOB)
|
EgtChangeClosedCurveStartPoint( nCrvCopy, ptS, GDB_RT.GLOB)
|
||||||
|
|
||||||
@@ -141,12 +164,19 @@ local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
|||||||
local dMove = ( ptRef - ptS) * LayerParams.vtSlicing
|
local dMove = ( ptRef - ptS) * LayerParams.vtSlicing
|
||||||
EgtMove( vCrvs[i+1], LayerParams.vtSlicing * dMove, GDB_RT.GLOB)
|
EgtMove( vCrvs[i+1], LayerParams.vtSlicing * dMove, GDB_RT.GLOB)
|
||||||
EgtSpiralizeCurveAlongExtrusion( vCrvs[i+1], dDelta)
|
EgtSpiralizeCurveAlongExtrusion( vCrvs[i+1], dDelta)
|
||||||
|
|
||||||
-- modifico la curva per congiungerla ai caps
|
-- modifico la curva per congiungerla ai caps
|
||||||
EgtAddCurveCompoLine( vCrvs[i+1], ptRef, false, GDB_RT.GLOB)
|
EgtApproxCurve( vCrvs[i+1], GDB_CA.LINES, s_dTol)
|
||||||
|
EgtModifyCurveStartPoint( vCrvs[i+1], ptRef, GDB_RT.GLOB)
|
||||||
local ptRefEnd = EgtUP( nSectE, i, GDB_ID.ROOT)
|
local ptRefEnd = EgtUP( nSectE, i, GDB_ID.ROOT)
|
||||||
EgtAddCurveCompoLine( vCrvs[i+1], ptRefEnd, true, GDB_RT.GLOB)
|
local _, _, dParMinDist = EgtPointCurveDist( ptRefEnd, vCrvs[i+1], GDB_ID.ROOT)
|
||||||
|
local _, dParE = EgtCurveDomain( vCrvs[i+1])
|
||||||
|
if abs( dParE - dParMinDist) > GEO.EPS_SMALL and dParMinDist > 0.5 * dParE then
|
||||||
|
EgtTrimCurveEndAtParam( vCrvs[i+1], dParMinDist)
|
||||||
|
end
|
||||||
|
EgtModifyCurveEndPoint( vCrvs[i+1], ptRefEnd, GDB_RT.GLOB)
|
||||||
end
|
end
|
||||||
|
|
||||||
local vSurfs = {}
|
local vSurfs = {}
|
||||||
for i = 1, #vCrvs - 1 do
|
for i = 1, #vCrvs - 1 do
|
||||||
vSurfs[i] = EgtSurfTmRuled( nGrpTmp, vCrvs[i], vCrvs[i+1], GDB_RUL.MINDIST, s_dTol)
|
vSurfs[i] = EgtSurfTmRuled( nGrpTmp, vCrvs[i], vCrvs[i+1], GDB_RUL.MINDIST, s_dTol)
|
||||||
@@ -155,7 +185,8 @@ local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
|||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local nSrfId = EgtSurfTmBySewing( nSolidGrp, vSurfs)
|
|
||||||
|
local nSrfId = EgtSurfTmByTriangles( nSolidGrp, vSurfs)
|
||||||
|
|
||||||
-- creazione del mezzo disco iniziale
|
-- creazione del mezzo disco iniziale
|
||||||
local nCap1 = CreateSpiralVaseCap( nSectId, - vtS, nSolidGrp)
|
local nCap1 = CreateSpiralVaseCap( nSectId, - vtS, nSolidGrp)
|
||||||
@@ -166,15 +197,7 @@ local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
|||||||
-- cancello le curve usate per la costruzione
|
-- cancello le curve usate per la costruzione
|
||||||
EgtErase( nGrpTmp)
|
EgtErase( nGrpTmp)
|
||||||
|
|
||||||
return EgtSurfTmBySewing( nSolidGrp, { nSrfId, nCap1, nCap2})
|
return EgtSurfTmByTriangles( nSolidGrp, { nSrfId, nCap1, nCap2})
|
||||||
end
|
|
||||||
|
|
||||||
----------------------------------------------------------------------
|
|
||||||
local function CreateStandardSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
|
||||||
|
|
||||||
local dD1, dD2, dD3, dD4 = CalcSectionParams( dStrand, LayerParams.dLayHeight)
|
|
||||||
local nSrfId = EgtSurfTmRectSwept( nSolidGrp, dStrand, LayerParams.dLayHeight, dD2, dD3, nCrvId, GDB_RSCT.BEVEL, s_dTol)
|
|
||||||
return nSrfId
|
|
||||||
end
|
end
|
||||||
|
|
||||||
--------------------------------------------------------------------------------------
|
--------------------------------------------------------------------------------------
|
||||||
@@ -186,13 +209,73 @@ local function CreateSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
local function CreateDirectionArrow( nCrvId, nSolidGrp, vtSlicing, dStrand, nLayer)
|
||||||
|
|
||||||
|
local ptS = EgtSP( nCrvId, GDB_RT.GLOB)
|
||||||
|
local vtS = EgtSV( nCrvId, GDB_RT.GLOB)
|
||||||
|
local dCrvLen = EgtCurveLength( nCrvId)
|
||||||
|
if dCrvLen > 2 * dStrand then
|
||||||
|
local dPar = EgtCurveParamAtLength( nCrvId, 4/5 * dStrand)
|
||||||
|
ptS = EgtUP( nCrvId, dPar, GDB_RT.GLOB)
|
||||||
|
vtS = EgtUV( nCrvId, dPar, -1, GDB_RT.GLOB)
|
||||||
|
end
|
||||||
|
|
||||||
|
local vt2 = Vector3d( vtS)
|
||||||
|
vt2:rotate( vtSlicing, 90)
|
||||||
|
local dLen = 4/5 * dStrand
|
||||||
|
local pt1 = ptS + 0.5 * dLen * vt2
|
||||||
|
local pt2 = ptS - 0.5 * dLen * vt2
|
||||||
|
local pt3 = ptS + vtS * dLen
|
||||||
|
local nCompo = EgtCurveCompoFromPoints( nSolidGrp, { pt1, pt2, pt3, pt1}, GDB_RT.GLOB)
|
||||||
|
EgtMove( nCompo, 100 * GEO.EPS_SMALL * vtSlicing, GDB_RT.GLOB)
|
||||||
|
local nSrf = EgtSurfFlatRegion( nSolidGrp, { nCompo})
|
||||||
|
EgtErase( nCompo)
|
||||||
|
EgtSetColor( nSrf, RED())
|
||||||
|
EgtSetInfo( nSrf, KEY_SLICE_NBR, nLayer)
|
||||||
|
EgtSetStatus( nSrf, GDB_ST.OFF)
|
||||||
|
EgtSetMode( nSrf, GDB_MD.HIDDEN)
|
||||||
|
EgtSetName( nSrf, DIR_ARROW)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
local function CreateRecursiveSolid( nCrvId, vSurfs, nSolidGrp, LayerParams, dStrand)
|
||||||
|
|
||||||
|
-- tento la creazione del solido
|
||||||
|
local nSurf = CreateSolid( nCrvId, nSolidGrp, LayerParams, dStrand - 50 * GEO.EPS_SMALL)
|
||||||
|
if nSurf then
|
||||||
|
EgtErase( nCrvId)
|
||||||
|
table.insert( vSurfs, nSurf)
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
-- se curva singola esco perchè non è possibile spezzare ulteriormente
|
||||||
|
local _, dParE = EgtCurveDomain( nCrvId)
|
||||||
|
if abs( dParE - 1) < GEO.EPS_SMALL then
|
||||||
|
EgtErase( nCrvId)
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
-- se non si tratta di curva singola, spezzo a metà e tento sulle due sottocurve
|
||||||
|
local dParSplit = floor( dParE / 2 + 0.5)
|
||||||
|
local nCrvSplit = EgtSplitCurveAtParam( nCrvId, dParSplit)
|
||||||
|
if not nCrvSplit then
|
||||||
|
-- errore nello split
|
||||||
|
EgtErase( nCrvId)
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
local bOk = CreateRecursiveSolid( nCrvId, vSurfs, nSolidGrp, LayerParams, dStrand)
|
||||||
|
bOk = bOk and CreateRecursiveSolid( nCrvSplit, vSurfs, nSolidGrp, LayerParams, dStrand)
|
||||||
|
return bOk
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
local function CreateSolidFromCurve( nCrvId, nSolidGrp, LayerParams, nLayer)
|
local function CreateSolidFromCurve( nCrvId, nSolidGrp, LayerParams, nLayer)
|
||||||
|
|
||||||
local nType = EgtGetInfo( nCrvId, KEY_TYPE, 'i')
|
local nType = EgtGetInfo( nCrvId, KEY_TYPE, 'i')
|
||||||
if nType == TYPE.WIPE then return true end
|
if nType == TYPE.WIPE then return true end
|
||||||
-- scelta del colore
|
-- scelta del colore
|
||||||
local Color = EgtStdColor( 'GRAY')
|
local Color = EgtStdColor( 'GRAY')
|
||||||
if nType == TYPE.OUTER_SHELL or nType == TYPE.EXTRA_OUTER_SHELL then
|
if nType == TYPE.OUTER_SHELL or nType == TYPE.EXTRA_OUTER_SHELL then
|
||||||
Color = EgtStdColor( 'TEAL')
|
Color = EgtStdColor( 'TEAL')
|
||||||
elseif nType == TYPE.INNER_SHELL or nType == TYPE.EXTRA_SHELL then
|
elseif nType == TYPE.INNER_SHELL or nType == TYPE.EXTRA_SHELL then
|
||||||
@@ -203,14 +286,13 @@ local function CreateSolidFromCurve( nCrvId, nSolidGrp, LayerParams, nLayer)
|
|||||||
Color = EgtStdColor( 'YELLOW')
|
Color = EgtStdColor( 'YELLOW')
|
||||||
elseif nType == TYPE.COASTING then
|
elseif nType == TYPE.COASTING then
|
||||||
Color = EgtStdColor( 'BLUE')
|
Color = EgtStdColor( 'BLUE')
|
||||||
elseif nType == TYPE.WIPE then
|
|
||||||
Color = EgtStdColor( 'LIME')
|
|
||||||
elseif nType == TYPE.RIB then
|
elseif nType == TYPE.RIB then
|
||||||
Color = EgtStdColor( 'OLIVE')
|
Color = EgtStdColor( 'OLIVE')
|
||||||
elseif nType == TYPE.AUX_SOLID then
|
elseif nType == TYPE.AUX_SOLID then
|
||||||
Color = EgtStdColor( 'AQUA')
|
Color = EgtStdColor( 'AQUA')
|
||||||
end
|
end
|
||||||
|
local dStrand = EgtGetInfo( nCrvId, KEY_CRV_STRAND, 'd') or LayerParams.dStrand
|
||||||
|
|
||||||
local nCopyId = EgtCopyGlob( nCrvId, nSolidGrp)
|
local nCopyId = EgtCopyGlob( nCrvId, nSolidGrp)
|
||||||
local nId = GDB_ID.NULL
|
local nId = GDB_ID.NULL
|
||||||
local nParts = 1
|
local nParts = 1
|
||||||
@@ -226,51 +308,55 @@ local function CreateSolidFromCurve( nCrvId, nSolidGrp, LayerParams, nLayer)
|
|||||||
nId = EgtSplitCurve( nCopyId, nParts)
|
nId = EgtSplitCurve( nCopyId, nParts)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- freccia direzionale
|
||||||
|
local sName = EgtGetName( nCrvId)
|
||||||
|
if nType ~= TYPE.COASTING and nType ~= TYPE.LINK and sName ~= LEAD_IN_CRV and sName ~= LEAD_OUT_CRV and sName ~= LINK_CRV then
|
||||||
|
CreateDirectionArrow( nCrvId, nSolidGrp, LayerParams.vtSlicing, dStrand, nLayer)
|
||||||
|
end
|
||||||
|
|
||||||
if nId == GDB_ID.NULL then return false end
|
if nId == GDB_ID.NULL then return false end
|
||||||
local bOk = true
|
local bOk = true
|
||||||
for nInd = 0, nParts - 1 do
|
for nInd = 0, nParts - 1 do
|
||||||
local nGuideId = nId + nInd
|
local nGuideId = nId + nInd
|
||||||
local nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, LayerParams.dStrand - 5 * GEO.EPS_SMALL)
|
local nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, dStrand - 5 * GEO.EPS_SMALL)
|
||||||
if not nSrfId then
|
if not nSrfId then
|
||||||
EgtOutLog( 'Warning : CreateSolid failed '.. '(layer '..tostring( nLayer)..', curve '..tostring( nCrvId)..')')
|
EgtOutLog( 'Warning : CreateSolid failed '.. '(layer '..tostring( nLayer)..', curve '..tostring( nCrvId)..')')
|
||||||
-- se non ultima, provo a spostare l'estremità finale
|
-- ritento con strand più piccolo
|
||||||
if nInd < nParts - 1 then
|
nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, dStrand - 50 * GEO.EPS_SMALL)
|
||||||
local nCopyId = EgtCopy( nGuideId + 1, nGuideId, GDB_IN.AFTER)
|
|
||||||
if nCopyId then
|
if not nSrfId then
|
||||||
local LEN_TRIM = 10
|
EgtOutLog( 'Warning : CreateSolid_1 failed '.. '(layer '..tostring( nLayer)..', curve '..tostring( nCrvId)..')')
|
||||||
local bOk1 = EgtTrimCurveEndAtLen( nCopyId, LEN_TRIM)
|
-- se non ultima, provo a spostare l'estremità finale
|
||||||
local bOk2 = EgtAddCurveCompoCurve( nGuideId, nCopyId)
|
if nInd < nParts - 1 then
|
||||||
local bOk3 = EgtTrimCurveStartAtLen( nGuideId + 1, LEN_TRIM)
|
local nCopyId = EgtCopy( nGuideId + 1, nGuideId, GDB_IN.AFTER)
|
||||||
nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, LayerParams.dStrand - 5 * GEO.EPS_SMALL)
|
if nCopyId then
|
||||||
if not nSrfId then
|
local LEN_TRIM = 10
|
||||||
nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, LayerParams.dStrand - 50 * GEO.EPS_SMALL)
|
local bOk1 = EgtTrimCurveEndAtLen( nCopyId, LEN_TRIM)
|
||||||
|
local bOk2 = EgtAddCurveCompoCurve( nGuideId, nCopyId)
|
||||||
|
local bOk3 = EgtTrimCurveStartAtLen( nGuideId + 1, LEN_TRIM)
|
||||||
|
nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, dStrand - 5 * GEO.EPS_SMALL)
|
||||||
|
if not nSrfId then
|
||||||
|
nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, dStrand - 50 * GEO.EPS_SMALL)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- ritento spezzando la curva
|
|
||||||
|
-- ritento spezzando la curva in modo ricorsivo fino ad inidividuare delle sottocurve su cui è possibile calcolare il solido
|
||||||
if not nSrfId then
|
if not nSrfId then
|
||||||
EgtOutLog( 'Warning : CreateSolid_2 failed')
|
EgtOutLog( 'Warning : CreateSolid_2 failed')
|
||||||
local nGrp = EgtGroup( nSolidGrp, Frame3d( ORIG(), LayerParams.vtSlicing), GDB_RT.GLOB)
|
local nGrp = EgtGroup( nSolidGrp, Frame3d( ORIG(), LayerParams.vtSlicing), GDB_RT.GLOB)
|
||||||
EgtRelocateGlob( nGuideId, nGrp)
|
EgtRelocateGlob( nGuideId, nGrp)
|
||||||
EgtApproxCurve( nGuideId, GDB_CA.LINES, 100 * GEO.EPS_SMALL)
|
EgtApproxCurve( nGuideId, GDB_CA.LINES, 100 * GEO.EPS_SMALL)
|
||||||
EgtRelocateGlob( nGuideId, nSolidGrp)
|
EgtRelocateGlob( nGuideId, nSolidGrp)
|
||||||
local nFirstCrv, nCrvNbr = EgtSplitCurveAtCorners( nGuideId, 30)
|
|
||||||
if nFirstCrv and nCrvNbr > 1 then
|
local vSurfs = {}
|
||||||
local nSrfIds = {}
|
local bOk = CreateRecursiveSolid( nGuideId, vSurfs, nSolidGrp, LayerParams, dStrand)
|
||||||
for nInd2 = 0, nCrvNbr-1 do
|
if #vSurfs > 0 then
|
||||||
local nSrfId2 = CreateSolid( nFirstCrv + nInd2, nSolidGrp, LayerParams, LayerParams.dStrand - 50 * GEO.EPS_SMALL)
|
nSrfId = EgtSurfTmByTriangles( nSolidGrp, vSurfs)
|
||||||
EgtErase( nFirstCrv + nInd2)
|
end
|
||||||
if nSrfId2 then
|
if not nSrfId or bOk == false then
|
||||||
table.insert( nSrfIds, nSrfId2)
|
EgtOutLog( 'Warning : CreateSolid_3 failed')
|
||||||
end
|
|
||||||
end
|
|
||||||
if #nSrfIds == nCrvNbr then
|
|
||||||
nSrfId = EgtSurfTmBySewing( nSolidGrp, nSrfIds)
|
|
||||||
else
|
|
||||||
EgtOutLog( 'Warning : CreateSolid_3 failed')
|
|
||||||
end
|
|
||||||
else
|
|
||||||
EgtErase( nFirstCrv)
|
|
||||||
end
|
end
|
||||||
EgtErase( nGrp)
|
EgtErase( nGrp)
|
||||||
end
|
end
|
||||||
@@ -279,7 +365,8 @@ local function CreateSolidFromCurve( nCrvId, nSolidGrp, LayerParams, nLayer)
|
|||||||
if nSrfId then
|
if nSrfId then
|
||||||
EgtSetColor( nSrfId, Color)
|
EgtSetColor( nSrfId, Color)
|
||||||
EgtSetInfo( nSrfId, KEY_TYPE, nType)
|
EgtSetInfo( nSrfId, KEY_TYPE, nType)
|
||||||
else
|
EgtSetInfo( nSrfId, KEY_SLICE_NBR, nLayer)
|
||||||
|
else
|
||||||
bOk = false
|
bOk = false
|
||||||
EgtOutLog( 'Warning : CreateSolid_Sewing failed')
|
EgtOutLog( 'Warning : CreateSolid_Sewing failed')
|
||||||
end
|
end
|
||||||
@@ -294,6 +381,10 @@ function RunCalcSolids.Exec()
|
|||||||
|
|
||||||
-- per determinare il tempo di calcolo
|
-- per determinare il tempo di calcolo
|
||||||
EgtStartCounter()
|
EgtStartCounter()
|
||||||
|
|
||||||
|
-- verifico se richiesta sezione semplificata ( rettangolare)
|
||||||
|
local sIniFile = EgtGetIniFile()
|
||||||
|
s_nSimplifiedSection = EgtGetNumberFromIni( 'Solids', 'SimplifiedSection', 0, sIniFile)
|
||||||
|
|
||||||
local nPartIndex = 1
|
local nPartIndex = 1
|
||||||
local nPartId = EgtGetFirstNameInGroup( GDB_ID.ROOT, PART .. nPartIndex) or EgtGetFirstNameInGroup( GDB_ID.ROOT, PART)
|
local nPartId = EgtGetFirstNameInGroup( GDB_ID.ROOT, PART .. nPartIndex) or EgtGetFirstNameInGroup( GDB_ID.ROOT, PART)
|
||||||
@@ -305,9 +396,14 @@ function RunCalcSolids.Exec()
|
|||||||
|
|
||||||
if bCalcSolid then
|
if bCalcSolid then
|
||||||
|
|
||||||
|
-- recupero il suo frame
|
||||||
|
local nFrameId = EgtGetFirstNameInGroup( EgtGetFirstNameInGroup( nPartId, 'Frame'), 'FramePart')
|
||||||
|
local ptOrig = EgtSP( nFrameId or GDB_ID.NULL, GDB_ID.ROOT)
|
||||||
|
EgtSetInfo( nPartId, KEY_ORIG_REF, ptOrig)
|
||||||
|
|
||||||
-- recupero i suoi slice
|
-- recupero i suoi slice
|
||||||
local vLayIds = EgtGetNameInGroup( nPartId, SLICE_LAYER .. '*')
|
local vLayIds = EgtGetNameInGroup( nPartId, SLICE_LAYER .. '*')
|
||||||
if not vLayIds then
|
if not vLayIds or #vLayIds == 0 then
|
||||||
EgtOutBox( 'No sliced part in this project!', 'Error', 'ERROR')
|
EgtOutBox( 'No sliced part in this project!', 'Error', 'ERROR')
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
@@ -330,7 +426,7 @@ function RunCalcSolids.Exec()
|
|||||||
local nTPathGrpId = EgtGetFirstNameInGroup( nCrvGrpId, TOOLPATH_GRP) or GDB_ID.NULL
|
local nTPathGrpId = EgtGetFirstNameInGroup( nCrvGrpId, TOOLPATH_GRP) or GDB_ID.NULL
|
||||||
if nTPathGrpId == GDB_ID.NULL then
|
if nTPathGrpId == GDB_ID.NULL then
|
||||||
EgtOutBox( 'Error no tool paths', 'SolidCalc')
|
EgtOutBox( 'Error no tool paths', 'SolidCalc')
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
-- recupero il gruppo dei solidi
|
-- recupero il gruppo dei solidi
|
||||||
@@ -339,12 +435,41 @@ function RunCalcSolids.Exec()
|
|||||||
nSolidGrpId = EgtGroup( nCrvGrpId)
|
nSolidGrpId = EgtGroup( nCrvGrpId)
|
||||||
EgtSetName( nSolidGrpId, SOLID_GRP)
|
EgtSetName( nSolidGrpId, SOLID_GRP)
|
||||||
EgtSetLevel( nSolidGrpId, GDB_LV.TEMP)
|
EgtSetLevel( nSolidGrpId, GDB_LV.TEMP)
|
||||||
-- scorro le curve del percorso utensile
|
-- scorro le curve del percorso utensile per creare i solidi
|
||||||
local nId = EgtGetFirstInGroup( nTPathGrpId)
|
local vIds = EgtGetAllInGroup( nTPathGrpId)
|
||||||
while nId do
|
|
||||||
local bOk = CreateSolidFromCurve( nId, nSolidGrpId, LayerParams, nLayer)
|
if LayerParams.bSpiralVase and #vIds > 2 and EgtGetName( vIds[#vIds]) ~= WIPE_CRV then
|
||||||
nId = EgtGetNext( nId)
|
-- nel caso a spirale gestione speciale per unire i tratti dei primi layers che sono stati spezzati per feed variabile
|
||||||
|
local bHasDelta = EgtExistsInfo( vIds[#vIds], KEY_FEED_COEFF)
|
||||||
|
if bHasDelta then
|
||||||
|
-- prima curva è a quota costante
|
||||||
|
CreateSolidFromCurve( vIds[1], nSolidGrpId, LayerParams, nLayer)
|
||||||
|
-- le rimanenti curve possono essere unite
|
||||||
|
local vNewIds = EgtTableFill( vIds[2], #vIds-1)
|
||||||
|
local nNewCrv = EgtCurveCompo( nSolidGrpId, vNewIds, false)
|
||||||
|
local dStrand = EgtGetInfo( vIds[2], KEY_CRV_STRAND, 'd') or LayerParams.dStrand
|
||||||
|
EgtSetInfo( nNewCrv, KEY_CRV_STRAND, dStrand)
|
||||||
|
EgtSetInfo( nNewCrv, KEY_TYPE, TYPE.OUTER_SHELL)
|
||||||
|
CreateSolidFromCurve( nNewCrv, nSolidGrpId, LayerParams, nLayer)
|
||||||
|
EgtErase( nNewCrv)
|
||||||
|
else
|
||||||
|
local vNewIds = EgtTableFill( vIds[1], #vIds-1)
|
||||||
|
local nNewCrv = EgtCurveCompo( nSolidGrpId, vNewIds, false)
|
||||||
|
local dStrand = EgtGetInfo( vIds[2], KEY_CRV_STRAND, 'd') or LayerParams.dStrand
|
||||||
|
EgtSetInfo( nNewCrv, KEY_CRV_STRAND, dStrand)
|
||||||
|
EgtSetInfo( nNewCrv, KEY_TYPE, TYPE.OUTER_SHELL)
|
||||||
|
CreateSolidFromCurve( nNewCrv, nSolidGrpId, LayerParams, nLayer)
|
||||||
|
EgtErase( nNewCrv)
|
||||||
|
CreateSolidFromCurve( vIds[#vIds], nSolidGrpId, LayerParams, nLayer)
|
||||||
|
end
|
||||||
|
|
||||||
|
else
|
||||||
|
-- caso standard
|
||||||
|
for i = 1, #vIds do
|
||||||
|
CreateSolidFromCurve( vIds[i], nSolidGrpId, LayerParams, nLayer)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
else
|
else
|
||||||
bSolidsOk = true
|
bSolidsOk = true
|
||||||
break
|
break
|
||||||
@@ -373,7 +498,7 @@ function RunCalcSolids.Exec()
|
|||||||
for i = 1, #vLayIds do
|
for i = 1, #vLayIds do
|
||||||
local vGrpId = EgtGetNameInGroup( vLayIds[i], CONTOUR_GRP .. '*') or {}
|
local vGrpId = EgtGetNameInGroup( vLayIds[i], CONTOUR_GRP .. '*') or {}
|
||||||
for j = 1, #vGrpId do
|
for j = 1, #vGrpId do
|
||||||
local nSolidId = EgtGetNameInGroup( vGrpId[j], SOLID_GRP .. '*') or GDB_ID.NULL
|
local nSolidId = EgtGetFirstNameInGroup( vGrpId[j], SOLID_GRP .. '*') or GDB_ID.NULL
|
||||||
EgtErase( nSolidId)
|
EgtErase( nSolidId)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -390,9 +515,8 @@ function RunCalcSolids.Exec()
|
|||||||
EgtSetInfo( nViewId, SOLID_GRP, true)
|
EgtSetInfo( nViewId, SOLID_GRP, true)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
nPartIndex = nPartIndex + 1
|
nPartIndex = nPartIndex + 1
|
||||||
nPartId = EgtGetFirstNameInGroup( GDB_ID.ROOT, PART .. nPartIndex) or EgtGetNextName( nPartId, PART)
|
nPartId = EgtGetFirstNameInGroup( GDB_ID.ROOT, PART .. nPartIndex) or EgtGetNextName( nPartId, PART)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
-- RunGcodeGenerate.lua by Egaltech s.r.l. 2023/02/02
|
-- RunGcodeGenerate.lua by Egaltech s.r.l. 2023/04/11
|
||||||
-- Calcoli prima fase per Stampa 3d
|
-- Calcoli prima fase per Stampa 3d
|
||||||
|
|
||||||
-- Tabella per definizione modulo
|
-- Tabella per definizione modulo
|
||||||
@@ -36,7 +36,7 @@ function RunGcodeGenerate.Exec()
|
|||||||
|
|
||||||
-- Recupero i layer da processare
|
-- Recupero i layer da processare
|
||||||
local vLayIds = EgtGetNameInGroup( nPartId, SLICE_LAYER.."*")
|
local vLayIds = EgtGetNameInGroup( nPartId, SLICE_LAYER.."*")
|
||||||
if not vLayIds then
|
if not vLayIds or #vLayIds == 0 then
|
||||||
EgtOutBox( 'Error missing slices', 'GcodeGenerate')
|
EgtOutBox( 'Error missing slices', 'GcodeGenerate')
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
@@ -131,7 +131,7 @@ function RunGcodeGenerate.Exec()
|
|||||||
|
|
||||||
-- Salvo il progetto
|
-- Salvo il progetto
|
||||||
local sFilePath = EgtGetCurrFilePath()
|
local sFilePath = EgtGetCurrFilePath()
|
||||||
sFilePath = EgtChangePathExtension( sFilePath, 'nge')
|
sFilePath = EgtChangePathExtension( sFilePath, 'icrs')
|
||||||
EgtSetCurrFilePath( sFilePath)
|
EgtSetCurrFilePath( sFilePath)
|
||||||
EgtSaveFile()
|
EgtSaveFile()
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
-- Calcolo dei parametri di stampa
|
||||||
|
|
||||||
-- Tabella per definizione modulo
|
-- Tabella per definizione modulo
|
||||||
@@ -53,6 +53,8 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
local sMachIni = EgtGetCurrMachineDir() .. '\\' .. EgtGetCurrMachineName() .. '.ini'
|
local sMachIni = EgtGetCurrMachineDir() .. '\\' .. EgtGetCurrMachineName() .. '.ini'
|
||||||
local dSMin = tonumber( EgtGetStringFromIni( SEC_3DPRINTING, KEY_SPEED_MIN, 0, sMachIni))
|
local dSMin = tonumber( EgtGetStringFromIni( SEC_3DPRINTING, KEY_SPEED_MIN, 0, sMachIni))
|
||||||
local dSMax = tonumber( EgtGetStringFromIni( SEC_3DPRINTING, KEY_SPEED_MAX, 50000, 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
|
-- massa materiale utilizzato
|
||||||
local dPrintMass = 0
|
local dPrintMass = 0
|
||||||
-- massimo indice di layer calcolato
|
-- massimo indice di layer calcolato
|
||||||
@@ -62,7 +64,7 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
while nPartId do
|
while nPartId do
|
||||||
if not EgtGetInfo( nPartId, KEY_PART_ON_TABLE, 'b') then
|
if not EgtGetInfo( nPartId, KEY_PART_ON_TABLE, 'b') then
|
||||||
nPartId = EgtGetNextPart( nPartId)
|
nPartId = EgtGetNextPart( nPartId)
|
||||||
goto continue
|
goto continue
|
||||||
end
|
end
|
||||||
-- recupero i parametri di lavorazione del pezzo
|
-- recupero i parametri di lavorazione del pezzo
|
||||||
local dSliceStep = EgtGetInfo( nPartId, KEY_SLICE_STEP, 'd')
|
local dSliceStep = EgtGetInfo( nPartId, KEY_SLICE_STEP, 'd')
|
||||||
@@ -77,6 +79,8 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
while nLayerId do
|
while nLayerId do
|
||||||
-- rimuovo eventuale info precedente del tempo di attesa
|
-- rimuovo eventuale info precedente del tempo di attesa
|
||||||
EgtRemoveInfo( nLayerId, KEY_WAITING_TIME)
|
EgtRemoveInfo( nLayerId, KEY_WAITING_TIME)
|
||||||
|
-- divido curve in base alla larghezza strand
|
||||||
|
local LengthCrvList = {}
|
||||||
-- calcolo lunghezza totale del layer
|
-- calcolo lunghezza totale del layer
|
||||||
local dTotLayerLength = 0
|
local dTotLayerLength = 0
|
||||||
local dTotLayerLengthForMass = 0
|
local dTotLayerLengthForMass = 0
|
||||||
@@ -84,14 +88,29 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
local nCrvId = EgtGetFirstNameInGroup( nLayerId, CONTOUR_GRP .. '*')
|
local nCrvId = EgtGetFirstNameInGroup( nLayerId, CONTOUR_GRP .. '*')
|
||||||
while nCrvId do
|
while nCrvId do
|
||||||
local nToolPathId = EgtGetFirstNameInGroup( nCrvId, TOOLPATH_GRP)
|
local nToolPathId = EgtGetFirstNameInGroup( nCrvId, TOOLPATH_GRP)
|
||||||
-- sommo lunghezze percorsi
|
-- recupero lunghezze percorsi
|
||||||
local dTotCrvLength = 0
|
local dTotCrvLength = 0
|
||||||
local dTotCrvLengthForMass = 0
|
local dTotCrvLengthForMass = 0
|
||||||
nShellId = EgtGetFirstInGroup( nToolPathId)
|
local nShellId = EgtGetFirstInGroup( nToolPathId)
|
||||||
while nShellId do
|
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
|
if EgtGetName( nShellId) ~= WIPE_CRV then
|
||||||
dTotCrvLengthForMass = dTotCrvLengthForMass + EgtCurveLength( nShellId)
|
dTotCrvLengthForMass = dTotCrvLengthForMass + dShellLength
|
||||||
end
|
end
|
||||||
nShellId = EgtGetNext( nShellId)
|
nShellId = EgtGetNext( nShellId)
|
||||||
end
|
end
|
||||||
@@ -132,11 +151,17 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
table.insert( nOrigLayers, nLayerId)
|
table.insert( nOrigLayers, nLayerId)
|
||||||
end
|
end
|
||||||
EgtSetInfo( nLayerResultId, KEY_SLICEID, nOrigLayers)
|
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
|
-- calcolo costante MF
|
||||||
local dMF = 1
|
local dMF = 1
|
||||||
local dSC = 1
|
local dSC = 1
|
||||||
if dTotLayerArea > 1 then
|
if dTotLayerArea > 1 then
|
||||||
dMF = dTotLayerLength * dStrand / dTotLayerArea * 100
|
dMF = dTotLayerLength * dStrandMean / dTotLayerArea * 100
|
||||||
dSC = dStrandCount
|
dSC = dStrandCount
|
||||||
else
|
else
|
||||||
dMF = 100
|
dMF = 100
|
||||||
@@ -151,12 +176,12 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- calcolo tempi stimati del layer
|
-- 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 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 * 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 * 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 * 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 * dStrandMean, MATERIAL.KW) * pow( dSliceStep, MATERIAL.KZ) * pow( dSC, MATERIAL.KN)
|
||||||
local dFMin = dTotLayerLength / dTMax * 60
|
local dFMin = dTotLayerLength / EgtIf( dTMax > 0.1, dTMax, 1) * 60
|
||||||
local dFTrg = dTotLayerLength / dTTrg * 60
|
local dFTrg = dTotLayerLength / EgtIf( dTTrg > 0.1, dTTrg, 1) * 60
|
||||||
local dFMax = dTotLayerLength / dTMin * 60
|
local dFMax = dTotLayerLength / EgtIf( dTMin > 0.1, dTMin, 1) * 60
|
||||||
local dLayerTime = dTTrg
|
local dLayerTime = dTTrg
|
||||||
if dLayerFeed == 0 then
|
if dLayerFeed == 0 then
|
||||||
dLayerFeed = dFTrg
|
dLayerFeed = dFTrg
|
||||||
@@ -165,7 +190,7 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
end
|
end
|
||||||
dLayerWait = floor( dTMin + 0.5) - floor( dLayerTime + 0.5)
|
dLayerWait = floor( dTMin + 0.5) - floor( dLayerTime + 0.5)
|
||||||
-- calcolo la portata
|
-- calcolo la portata
|
||||||
local Vf = dLayerFeed * ( ( dStrand - dSliceStep) * dSliceStep + pi * pow( dSliceStep / 2, 2)) / 1000
|
local Vf = dLayerFeed * ( ( dStrandMean - dSliceStep) * dSliceStep + pi * pow( dSliceStep / 2, 2)) / 1000
|
||||||
-- calcolo speed
|
-- calcolo speed
|
||||||
local dSpeed = ( MATERIAL.K_EXTRUSION / 100.0) * ( MACHINING.K / 100.0) * pow( Vf / MATERIAL.C1, 1 / MATERIAL.C2)
|
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
|
-- verifico se speed esce da minimo e massimo della macchina
|
||||||
@@ -179,16 +204,42 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
dSpeed = dSMax
|
dSpeed = dSMax
|
||||||
end
|
end
|
||||||
if not bSpeedOk then
|
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))
|
if dTotLayerLength > 0.1 then
|
||||||
dLayerTime = dTotLayerLength / dLayerFeed * 60
|
dLayerFeed = ( MATERIAL.C1 * pow( ( dSpeed / (( MATERIAL.K_EXTRUSION / 100.0) * ( MACHINING.K / 100.0))), MATERIAL.C2)) * 1000 / ( ( dStrandMean - dSliceStep) * dSliceStep + pi * pow( dSliceStep / 2, 2))
|
||||||
|
dLayerTime = dTotLayerLength / dLayerFeed * 60
|
||||||
|
end
|
||||||
dLayerWait = floor( dTMin + 0.5) - floor( dLayerTime + 0.5)
|
dLayerWait = floor( dTMin + 0.5) - floor( dLayerTime + 0.5)
|
||||||
end
|
end
|
||||||
-- calcolo massa dello strato
|
-- 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
|
if dLayerMass and dLayerMass > 0 then
|
||||||
dPrintMass = dPrintMass + dLayerMass
|
dPrintMass = dPrintMass + dLayerMass
|
||||||
end
|
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 .. '*')
|
nCrvId = EgtGetFirstNameInGroup( nLayerId, CONTOUR_GRP .. '*')
|
||||||
while nCrvId do
|
while nCrvId do
|
||||||
local nToolPathId = EgtGetFirstNameInGroup( nCrvId, TOOLPATH_GRP) or GDB_ID.NULL
|
local nToolPathId = EgtGetFirstNameInGroup( nCrvId, TOOLPATH_GRP) or GDB_ID.NULL
|
||||||
@@ -202,13 +253,11 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
EgtSetInfo( nLayerResultId, KEY_WAITING_TIME, dLayerWait)
|
EgtSetInfo( nLayerResultId, KEY_WAITING_TIME, dLayerWait)
|
||||||
end
|
end
|
||||||
-- scrivo valori in struttura dati
|
-- scrivo valori in struttura dati
|
||||||
--local nLayerResultId = EgtGetFirstNameInGroup( nResultLayerId, nLayerIndex)
|
|
||||||
EgtSetInfo( nLayerResultId, KEY_TMIN, dTMin)
|
EgtSetInfo( nLayerResultId, KEY_TMIN, dTMin)
|
||||||
EgtSetInfo( nLayerResultId, KEY_TTRG, dTTrg)
|
EgtSetInfo( nLayerResultId, KEY_TTRG, dTTrg)
|
||||||
EgtSetInfo( nLayerResultId, KEY_TMAX, dTMax)
|
EgtSetInfo( nLayerResultId, KEY_TMAX, dTMax)
|
||||||
EgtSetInfo( nLayerResultId, KEY_FMIN, dFMin)
|
|
||||||
EgtSetInfo( nLayerResultId, KEY_FTRG, dFTrg)
|
EgtSetInfo( nLayerResultId, KEY_FTRG, dFTrg)
|
||||||
EgtSetInfo( nLayerResultId, KEY_FMAX, dFMax)
|
EgtSetInfo( nLayerResultId, KEY_FMAX, dFeedMax)
|
||||||
EgtSetInfo( nLayerResultId, KEY_TCUR, dLayerTime)
|
EgtSetInfo( nLayerResultId, KEY_TCUR, dLayerTime)
|
||||||
EgtSetInfo( nLayerResultId, KEY_FCUR, dLayerFeed)
|
EgtSetInfo( nLayerResultId, KEY_FCUR, dLayerFeed)
|
||||||
EgtSetInfo( nLayerResultId, KEY_LENGTH, dTotLayerLength)
|
EgtSetInfo( nLayerResultId, KEY_LENGTH, dTotLayerLength)
|
||||||
@@ -220,11 +269,12 @@ function RunMachParamFromSWCalc.Exec()
|
|||||||
EgtEmptyGroup( nResultLayerId)
|
EgtEmptyGroup( nResultLayerId)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
-- passo al layer successivo
|
||||||
nLayerIndex = nLayerIndex + 1
|
nLayerIndex = nLayerIndex + 1
|
||||||
nLayerId = EgtGetFirstNameInGroup( nPartId, SLICE_LAYER .. nLayerIndex) or EgtGetFirstNameInGroup( nPartId, "__" .. SLICE_LAYER .. nLayerIndex)
|
nLayerId = EgtGetFirstNameInGroup( nPartId, SLICE_LAYER .. nLayerIndex) or EgtGetFirstNameInGroup( nPartId, "__" .. SLICE_LAYER .. nLayerIndex)
|
||||||
end
|
end
|
||||||
if nMaxIndex < nLayerIndex then nMaxIndex = nLayerIndex end
|
if nMaxIndex < nLayerIndex then nMaxIndex = nLayerIndex end
|
||||||
|
-- passo al pezzo successivo
|
||||||
nPartId = EgtGetNextPart( nPartId)
|
nPartId = EgtGetNextPart( nPartId)
|
||||||
::continue::
|
::continue::
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -0,0 +1,204 @@
|
|||||||
|
-- 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 CalcSpiralVase( 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
|
||||||
|
local vSolids = EgtGetAllInGroup( nSolidGrp)
|
||||||
|
for i = 1, #vSolids do
|
||||||
|
EgtCopyGlob( vSolids[i], nDestGrp)
|
||||||
|
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_SLICING_DIR, 'v')
|
||||||
|
EgtSetInfo( nPnt, KEY_SLICING_DIR, vtSlicing)
|
||||||
|
local bSpiralVase = EgtGetInfo( nPartId, KEY_SPIRAL_VASE, 'b') or false
|
||||||
|
EgtSetInfo( nPnt, KEY_SPIRAL_VASE, bSpiralVase)
|
||||||
|
|
||||||
|
-- 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)
|
||||||
|
|
||||||
|
if bSpiralVase then
|
||||||
|
CalcSpiralVase( vSlices[i], nDestGrp)
|
||||||
|
else
|
||||||
|
CalcCurves( vSlices[i], nDestGrp, vtSlicing, dStrandBase)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return nGrp
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
return RunPrepareExport
|
||||||
+21
-5
@@ -66,6 +66,26 @@ local function RemoveOldSlices( nPartId)
|
|||||||
EgtErase( vOldSliceId[i])
|
EgtErase( vOldSliceId[i])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- rimuovo gruppo con i loop dei setti
|
||||||
|
local nRibsLoopsGrp = EgtGetFirstNameInGroup( nPartId, RIBS_LOOP_GRP)
|
||||||
|
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
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
@@ -144,10 +164,6 @@ function RunSlicing.Exec()
|
|||||||
EgtRemoveAllOperations()
|
EgtRemoveAllOperations()
|
||||||
EgtResetCurrMachGroup()
|
EgtResetCurrMachGroup()
|
||||||
|
|
||||||
-- Lettura dati macchina
|
|
||||||
local sMachIni = EgtGetCurrMachineDir() .. '\\' .. EgtGetCurrMachineName() .. '.ini'
|
|
||||||
local HMax = tonumber( EgtGetStringFromIni( '3dPrinting', 'HMax', 500, sMachIni))
|
|
||||||
|
|
||||||
-- Eventuale ripristino posizione originaria
|
-- Eventuale ripristino posizione originaria
|
||||||
RestoreOriginalPosition( nPartId)
|
RestoreOriginalPosition( nPartId)
|
||||||
|
|
||||||
@@ -158,7 +174,7 @@ function RunSlicing.Exec()
|
|||||||
RemoveOldTFS()
|
RemoveOldTFS()
|
||||||
|
|
||||||
-- Calcolo delle fette
|
-- Calcolo delle fette
|
||||||
local bOk = CSLICES.Exec( nPartId, nStmId, HMax)
|
local bOk = CSLICES.Exec( nPartId, nStmId)
|
||||||
EgtDraw()
|
EgtDraw()
|
||||||
|
|
||||||
-- Calcolo dei percorsi sul centro strand in basso
|
-- 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. 2024/05/06
|
||||||
-- Gestione della versione di 3dPrinting
|
-- Gestione della versione di 3dPrinting
|
||||||
|
|
||||||
VERSION = '2.5c2'
|
VERSION = '2.7f1'
|
||||||
Reference in New Issue
Block a user