Compare commits
25 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 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 |
+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
|
||||
|
||||
+16
-16
@@ -1,21 +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\RunPrepareExport.lua LuaLibs\RunPrepareExport.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\PrepareExport.lua PrepareExport.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
|
||||
|
||||
+10
-1
@@ -111,6 +111,7 @@ 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"
|
||||
@@ -140,6 +141,8 @@ 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"
|
||||
@@ -176,9 +179,13 @@ 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_DELTAZ = "DeltaZ"
|
||||
@@ -204,8 +211,10 @@ 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,
|
||||
DEG45_X = 2,
|
||||
DEG45_Y = 3,
|
||||
|
||||
+153
-39
@@ -21,7 +21,7 @@ local s_vtSlicing
|
||||
local s_dOffsTol = 50 * GEO.EPS_SMALL
|
||||
|
||||
---------------------------------------------------------------------
|
||||
local function GetLayerParamsForPathCalc()
|
||||
local function GetLayerParamsForPathCalc()
|
||||
local LayerParams = {}
|
||||
LayerParams.bSpiralVase = EgtGetInfo( s_nPartId, KEY_SPIRAL_VASE, 'b') or false
|
||||
LayerParams.nShellsNbr = EgtGetInfo( s_nPartId, KEY_SHELLS_NBR, 'i')
|
||||
@@ -184,6 +184,7 @@ local function GetPathsFromSurf( nSrfId, sName, nType, nGrpId, vPtStart)
|
||||
for nInd = 0, nCrvCnt - 1 do
|
||||
EgtSetName( nCrvId + nInd, sName)
|
||||
EgtSetInfo( nCrvId + nInd, KEY_TYPE, nType)
|
||||
EgtModifyCurveExtrusion( nCrvId + nInd, s_vtSlicing, GDB_ID.ROOT)
|
||||
|
||||
-- se è loop interno lo inverto per averlo orientato in senso antiorario
|
||||
if nInd > 0 then
|
||||
@@ -450,7 +451,8 @@ end
|
||||
---------------------------------------------------------------------------
|
||||
local function ReorderPath( vOldIds, vNewIds)
|
||||
|
||||
if not vNewIds or not vOldIds then return end
|
||||
if not vNewIds or #vNewIds == 0 then return end
|
||||
if not vOldIds or #vOldIds == 0 then return end
|
||||
|
||||
-- suddivido in base alla tipologia di loop ( esterno o interno)
|
||||
local tOldIds = {{}, {}}
|
||||
@@ -720,33 +722,26 @@ local function VerifyRibsHoles( vIds)
|
||||
local ptS2 = EgtSP( vIds[i])
|
||||
local ptE2 = EgtEP( vIds[i])
|
||||
|
||||
local bAdd1 = dist( ptS1, ptE2) < dStrand + 10 * GEO.EPS_SMALL or dist( ptS1, ptS2) < dStrand + 10 * GEO.EPS_SMALL
|
||||
local bAdd2 = dist( ptE1, ptS2) < dStrand + 10 * GEO.EPS_SMALL or dist( ptE1, ptE2) < dStrand + 10 * GEO.EPS_SMALL
|
||||
local bInvert = dist( ptE1, ptE2) < dStrand + 10 * GEO.EPS_SMALL or dist( ptS1, ptS2) < dStrand + 10 * GEO.EPS_SMALL
|
||||
|
||||
if bInvert then
|
||||
EgtInvertCurve( vIds[i])
|
||||
end
|
||||
local bAdd1 = dist( ptS1, ptE2) < dStrand + 10 * GEO.EPS_SMALL
|
||||
local bAdd2 = dist( ptE1, ptS2) < dStrand + 10 * GEO.EPS_SMALL
|
||||
bAdd = bAdd1 or bAdd2
|
||||
|
||||
if bAdd1 and bAdd2 then
|
||||
-- se da unire in setto chiuso
|
||||
bAdd = true
|
||||
EgtAddCurveCompoLine( vIds[i-1], EgtEP( vIds[i]), false)
|
||||
EgtAddCurveCompoLine( vIds[i-1], EgtSP( vIds[i]))
|
||||
-- da unire in setto chiuso
|
||||
EgtAddCurveCompoLine( vIds[i-1], ptE2, false)
|
||||
EgtAddCurveCompoLine( vIds[i-1], ptS2)
|
||||
EgtAddCurveCompoCurve( vIds[i-1], vIds[i])
|
||||
table.remove( vIds, i) -- rimuovo il setto dalla tabella
|
||||
|
||||
elseif bAdd2 then
|
||||
bAdd = true
|
||||
-- unisco il secondo tratto al primo
|
||||
EgtAddCurveCompoLine( vIds[i-1], EgtSP( vIds[i]))
|
||||
EgtAddCurveCompoLine( vIds[i-1], ptS2)
|
||||
EgtAddCurveCompoCurve( vIds[i-1], vIds[i])
|
||||
table.remove( vIds, i) -- rimuovo il setto dalla tabella
|
||||
|
||||
elseif bAdd1 then
|
||||
bAdd = true
|
||||
-- unisco il primo tratto al secondo
|
||||
EgtAddCurveCompoLine( vIds[i], EgtSP( vIds[i-1]))
|
||||
EgtAddCurveCompoLine( vIds[i], ptS1)
|
||||
EgtAddCurveCompoCurve( vIds[i], vIds[i-1])
|
||||
table.remove( vIds, i-1) -- rimuovo il setto dalla tabella
|
||||
end
|
||||
@@ -979,7 +974,7 @@ end
|
||||
-------------------------------------------------------------------
|
||||
local function FindHoleCurve( pt, vLoopIds)
|
||||
-- trovo indice della curva di vLoopIds a cui appartiene pt ( in globale)
|
||||
if not vLoopIds then return end
|
||||
if not vLoopIds or #vLoopIds == 0 then return end
|
||||
for i = 1, #vLoopIds do
|
||||
local dPar = EgtCurveParamAtPoint( vLoopIds[i], pt, 100 * GEO.EPS_SMALL, GDB_RT.GLOB)
|
||||
if dPar then
|
||||
@@ -1285,7 +1280,8 @@ local function ComputeRibsOrientedOffset( nRibsGrp)
|
||||
local bCCW = EgtGetInfo( vIds[i], KEY_RIBS_USER_LINK_CCW, 'b') or false
|
||||
local nLinkOrder = EgtGetInfo( vIds[i], KEY_RIBS_USER_LINK_ORDER, 'i') or 0
|
||||
local dStrand = EgtGetInfo( vIds[i], KEY_RIBS_STRAND, 'd')
|
||||
local dOffs = ( nShellsNbr - 1) * dStrand / 2
|
||||
local dStrandOverlap = EgtGetInfo( vIds[i], KEY_RIBS_STRAND_OVERLAP, 'd') or 0
|
||||
local dOffs = ( nShellsNbr - 1) * ( 1 - dStrandOverlap / 100) * dStrand / 2
|
||||
|
||||
-- ordine di realizzazione degli offset
|
||||
if not bUserLinked then
|
||||
@@ -1301,7 +1297,7 @@ local function ComputeRibsOrientedOffset( nRibsGrp)
|
||||
|
||||
local vOffsRib = {}
|
||||
for k = 0, nShellsNbr - 1 do
|
||||
local dOffsCurr = dOffs - k * dStrand
|
||||
local dOffsCurr = dOffs - k * ( 1 - dStrandOverlap / 100) * dStrand
|
||||
local nNewId
|
||||
if abs( dOffsCurr) < GEO.EPS_SMALL then
|
||||
nNewId = EgtCopyGlob( vIds[i], nOffsGrp)
|
||||
@@ -1422,7 +1418,7 @@ local function ComputeTrimSurfWithOverlapsForRibs( vIds, nGrp, nSrfInt, nSrfExt,
|
||||
|
||||
elseif nType == RIB_TYPE.EXTERNAL then
|
||||
if not nSrfExt then
|
||||
-- il setto va cancellato
|
||||
-- sono in un CrvGrp intermedio, il setto va cancellato
|
||||
elseif nSrfExt == GDB_ID.NULL then
|
||||
-- se la superficie non esiste il setto va conservato
|
||||
tSurfOffs[vIds[i]] = GDB_ID.NULL
|
||||
@@ -1441,8 +1437,11 @@ local function ComputeTrimSurfWithOverlapsForRibs( vIds, nGrp, nSrfInt, nSrfExt,
|
||||
end
|
||||
|
||||
else
|
||||
-- se unbounded non va mai trimmato
|
||||
tSurfOffs[vIds[i]] = GDB_ID.NULL
|
||||
-- il setto unbounded deve comparire solo nell'ultimo CrvGrp senza alcun trim. Se nSrfExt non è definita sono in un CrvGrp intermedio e il setto va cancellato
|
||||
-- se nSrfExt è definita allora il setto non va trimmato
|
||||
if nSrfExt then
|
||||
tSurfOffs[vIds[i]] = GDB_ID.NULL
|
||||
end
|
||||
end
|
||||
|
||||
tOffs[vIds[i]] = dOffs
|
||||
@@ -1605,10 +1604,11 @@ local function AdjustRibsOffsetForIntersection( nCrv1, nCrv2, nOffsGrp, nLoopGrp
|
||||
|
||||
local nShells = EgtGetInfo( nCrv1, KEY_RIBS_SHELLS_NBR, 'i')
|
||||
local dStrand1 = EgtGetInfo( nCrv1, KEY_RIBS_STRAND, 'd')
|
||||
local dStrandOverlap1 = EgtGetInfo( nCrv1, KEY_RIBS_STRAND_OVERLAP, 'd') or 0
|
||||
local dOverlap = EgtGetInfo( nCrv2, KEY_RIBS_OVERLAP, 'i')
|
||||
local dStrand2 = EgtGetInfo( nCrv2, KEY_RIBS_STRAND, 'd')
|
||||
|
||||
if dOverlap / 100 * dStrand2 > nShells * dStrand1 * 0.5 - GEO.EPS_SMALL then
|
||||
if dOverlap / 100 * dStrand2 > ( nShells - 1) * ( 1 - dStrandOverlap1 / 100) * dStrand1 * 0.5 + dStrand1 * 0.5 - GEO.EPS_SMALL then
|
||||
-- non ha senso spezzare la curva, aggiorno solo split order dei suoi offset
|
||||
for i = 1, #vOffs2 do
|
||||
CopyInfo( nCrv2, vOffs2[i], KEY_SPLIT_ORDER, 'i')
|
||||
@@ -1617,7 +1617,7 @@ local function AdjustRibsOffsetForIntersection( nCrv1, nCrv2, nOffsGrp, nLoopGrp
|
||||
end
|
||||
|
||||
-- calcolo la superficie della curva principale ( nCrv1) da usare per trim
|
||||
local dOffs = nShells * dStrand1 * 0.5 + dStrand2 * ( 0.5 - dOverlap / 100)
|
||||
local dOffs = ( nShells - 1) * ( 1 - dStrandOverlap1 / 100) * dStrand1 * 0.5 + dStrand1 * 0.5 + dStrand2 * ( 0.5 - dOverlap / 100)
|
||||
local nSrf = EgtSurfFrFatCurve( nOffsGrp, nCrv1, dOffs, false, false, s_dOffsTol)
|
||||
if not nSrf then
|
||||
EgtOutLog( 'Error : ribs intersection failed (layer '.. EgtNumToString( s_nCurrIdx) ..') - CalcPaths')
|
||||
@@ -1676,9 +1676,11 @@ local function AdjustRibsOffsetForIntersection2Shells( nCrv1, nCrv2, nOffsGrp)
|
||||
|
||||
-- costruisco le superfici da usare per trim
|
||||
local dStrand1 = EgtGetInfo( nCrv1, KEY_RIBS_STRAND, 'd')
|
||||
local nSrf1 = EgtSurfFrFatCurve( nOffsGrp, nCrv1, dStrand1 * 0.5, false, false, s_dOffsTol)
|
||||
local dStrandOverlap1 = EgtGetInfo( nCrv1, KEY_RIBS_STRAND_OVERLAP, 'd') or 0
|
||||
local nSrf1 = EgtSurfFrFatCurve( nOffsGrp, nCrv1, ( 1 - dStrandOverlap1 / 100) * dStrand1 * 0.5, false, false, s_dOffsTol)
|
||||
local dStrand2 = EgtGetInfo( nCrv2, KEY_RIBS_STRAND, 'd')
|
||||
local nSrf2 = EgtSurfFrFatCurve( nOffsGrp, nCrv2, dStrand2 * 0.5, false, false, s_dOffsTol)
|
||||
local dStrandOverlap2 = EgtGetInfo( nCrv2, KEY_RIBS_STRAND_OVERLAP, 'd') or 0
|
||||
local nSrf2 = EgtSurfFrFatCurve( nOffsGrp, nCrv2, ( 1 - dStrandOverlap2 / 100) * dStrand2 * 0.5, false, false, s_dOffsTol)
|
||||
|
||||
-- trim degli offset di nCrv1
|
||||
local vOffs1 = EgtGetNameInGroup( nOffsGrp, EgtGetName( nCrv1)) or {}
|
||||
@@ -1725,13 +1727,12 @@ end
|
||||
local function HandleRibsIntersections( nRibsGrp, nOffsGrp, nRibsPathGrp, nSrfInt, nSrfExt, bAllTwoStrands, vTypeSequence, nLoopGrp, tSurfOffs)
|
||||
|
||||
local bSpecialCase = false
|
||||
local vOffsIds = EgtGetNameInGroup( nRibsPathGrp, RIBS_CRV .. '*') -- passate dei setti
|
||||
local vAllRibsIds = EgtGetNameInGroup( nRibsGrp, RIBS_CRV .. '*') -- setti originali
|
||||
local vRibsIds = {}
|
||||
-- ignoro setti che non hanno passate corrispondenti
|
||||
for i = 1, #vAllRibsIds do
|
||||
local vOffs = EgtGetNameInGroup( nRibsPathGrp, EgtGetName( vAllRibsIds[i]))
|
||||
if vOffs then table.insert( vRibsIds, vAllRibsIds[i]) end
|
||||
if vOffs and #vOffs > 0 then table.insert( vRibsIds, vAllRibsIds[i]) end
|
||||
end
|
||||
|
||||
-- creo un gruppo con frame locale per calcolare le intersezioni ( è il piano XY locale dove calcolare intersezioni)
|
||||
@@ -2142,8 +2143,11 @@ local function ReassignInfo( nCrv, nCnt, vOrig)
|
||||
CopyInfo( vOrig[i], nId, KEY_RIBS_LEAD_IN_LEN, 'd')
|
||||
CopyInfo( vOrig[i], nId, KEY_ASSOCIATED_SURF, 'i')
|
||||
CopyInfo( vOrig[i], nId, KEY_RIBS_OVERLAP, 'd')
|
||||
CopyInfo( vOrig[i], nId, KEY_RIBS_STRAND_OVERLAP, 'd')
|
||||
CopyInfo( vOrig[i], nId, KEY_RIBS_TYPE, 'i')
|
||||
CopyInfo( vOrig[i], nId, KEY_RIBS_LINK, 'b')
|
||||
CopyInfo( vOrig[i], nId, KEY_RIBS_LINK_FILLET, 'd')
|
||||
CopyInfo( vOrig[i], nId, KEY_RIBS_LEAD_FILLET, 'd')
|
||||
bStart = true
|
||||
end
|
||||
-- verifico se corrisponde al suo end
|
||||
@@ -2391,7 +2395,7 @@ local function CalcRibsPaths( nSliceGrp, nRibsGrp, LayerParams, vPtStart, bIgnor
|
||||
local nSrfInt = EgtGetFirstNameInGroup( vCrvGrps[i], TOT_SHELL_TRIM_SURF) or GDB_ID.NULL
|
||||
if nTotSrfInt == GDB_ID.NULL and nSrfInt ~= GDB_ID.NULL then
|
||||
nTotSrfInt = EgtCopyGlob( nSrfInt, nRibsGrp)
|
||||
elseif nTotSrfInt ~= GDB_ID.NULL then
|
||||
elseif nTotSrfInt ~= GDB_ID.NULL and nSrfInt ~= GDB_ID.NULL then
|
||||
if not EgtSurfFrAdd( nTotSrfInt, nSrfInt) then
|
||||
EgtOutLog( 'Error : EgtSurfFrAdd for external ribs failed. Errors may occur with user-linked ribs (layer '.. EgtNumToString( s_nCurrIdx) ..') - CalcPaths')
|
||||
end
|
||||
@@ -2500,7 +2504,7 @@ local function CalcRibsPaths( nSliceGrp, nRibsGrp, LayerParams, vPtStart, bIgnor
|
||||
bAllTwoStrands, vTypeSequence, nLoopGrp, tSurfOffs)
|
||||
EgtSetInfo( nRibsPathGrp or GDB_ID.NULL, KEY_RIBS_INTERS, bInters)
|
||||
EgtSetInfo( nRibsPathGrp or GDB_ID.NULL, KEY_RIBS_SPECIAL_CASE, bSpecialCase)
|
||||
|
||||
|
||||
-- riordino le costolature
|
||||
if bSpecialCase then
|
||||
-- gestione caso speciale di intersezione e 2 passate
|
||||
@@ -2526,6 +2530,90 @@ end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
--------------------- RIBS-MERGED SHELLS ---------------------------
|
||||
--------------------------------------------------------------------
|
||||
local function CalcFillet( nCrv1, nCrv2, dFillet, nGrpId, nGrpTmp)
|
||||
|
||||
if dFillet < GEO.EPS_SMALL then return end
|
||||
|
||||
-- creo il fillet
|
||||
local dParRef1 = EgtCurveParamAtLength( nCrv1, EgtCurveLength( nCrv1) - 100 * GEO.EPS_SMALL)
|
||||
local dParRef2 = EgtCurveParamAtLength( nCrv2, 100 * GEO.EPS_SMALL)
|
||||
local nFillet = EgtCurveFillet( nGrpTmp, nCrv1, EgtUP( nCrv1, dParRef1, nGrpTmp), nCrv2, EgtUP( nCrv2, dParRef2, nGrpTmp), dFillet, true, GDB_RT.LOC)
|
||||
if not nFillet then
|
||||
-- ritento con valore di fillet leggermente inferiore
|
||||
nFillet = EgtCurveFillet( nGrpTmp, nCrv1, EgtUP( nCrv1, dParRef1, nGrpTmp), nCrv2, EgtUP( nCrv2, dParRef2, nGrpTmp), dFillet - 50 * GEO.EPS_SMALL, true, GDB_RT.LOC)
|
||||
end
|
||||
|
||||
-- spezzo a metà il fillet per assegnarlo alle due curve
|
||||
if nFillet then
|
||||
local nNewFillet = EgtSplitCurve( nFillet, 2)
|
||||
|
||||
-- aggiungo a nCrv1
|
||||
if EgtExistsObj( nCrv1) then
|
||||
EgtAddCurveCompoArcTg( nCrv1, EgtEP( nNewFillet, GDB_ID.ROOT), true, GDB_RT.GLOB)
|
||||
EgtErase( nNewFillet)
|
||||
else
|
||||
-- nCrv1 viene sostituita completamente dal fillet
|
||||
local nNewCrv = EgtCurveCompo( nGrpId, {nNewFillet})
|
||||
EgtChangeId( nNewCrv, nCrv1)
|
||||
end
|
||||
|
||||
-- aggiungo a nCrv2
|
||||
if EgtExistsObj( nCrv2) then
|
||||
EgtAddCurveCompoArcTg( nCrv2, EgtSP( nNewFillet + 1, GDB_ID.ROOT), false, GDB_RT.GLOB)
|
||||
EgtErase( nNewFillet + 1)
|
||||
else
|
||||
-- nCrv2 viene sostituita completamente dal fillet
|
||||
local nNewCrv = EgtCurveCompo( nGrpId, {nNewFillet + 1})
|
||||
EgtChangeId( nNewCrv, nCrv2)
|
||||
end
|
||||
else
|
||||
EgtOutLog( 'Warning : ribs-merged shells fillet not possible (layer '..tostring( s_nCurrIdx)..') - CalcPath')
|
||||
end
|
||||
|
||||
EgtRelocateGlob( nFillet or GDB_ID.NULL, nGrpId)
|
||||
end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
local function AddFillet( nRib1, vLinks, nRib2, nGrpId)
|
||||
|
||||
local dFillet1 = EgtGetInfo( nRib1, KEY_RIBS_LINK_FILLET, 'd')
|
||||
local dFillet2 = EgtGetInfo( nRib2, KEY_RIBS_LINK_FILLET, 'd')
|
||||
-- verifico se necessaria correzione per passate dello stesso setto
|
||||
local nOrig1 = EgtGetInfo( nRib1, KEY_ORIGINAL_RIB, 'i')
|
||||
local nOrig2 = EgtGetInfo( nRib2, KEY_ORIGINAL_RIB, 'i')
|
||||
local nSplit1 = EgtGetInfo( nRib1, KEY_SPLIT_ID, 'i') or 0
|
||||
local nSplit2 = EgtGetInfo( nRib2, KEY_SPLIT_ID, 'i') or 0
|
||||
if nOrig1 == nOrig2 and nSplit1 == nSplit2 then
|
||||
local dStrand = EgtGetInfo( nRib1, KEY_RIBS_STRAND, 'd')
|
||||
local dStrandOverlap = EgtGetInfo( nRib1, KEY_RIBS_STRAND_OVERLAP, 'd')
|
||||
dFillet1 = min( dFillet1, 0.5 * ( 1 - dStrandOverlap / 100) * dStrand)
|
||||
dFillet2 = dFillet1
|
||||
end
|
||||
|
||||
-- creo un gruppo con riferimento locale allo slicing per i conti del fillet
|
||||
local nGrpTmp = EgtGroup( nGrpId, Frame3d( ORIG(), s_vtSlicing), GDB_RT.GLOB)
|
||||
|
||||
-- calcolo il primo fillet
|
||||
local ptRib1 = EgtEP( nRib1, GDB_ID.ROOT)
|
||||
for i = 1, #vLinks do
|
||||
if AreSamePointApprox( ptRib1, EgtSP( vLinks[i], GDB_ID.ROOT)) then
|
||||
CalcFillet( nRib1, vLinks[i], dFillet1, nGrpId, nGrpTmp)
|
||||
break
|
||||
end
|
||||
end
|
||||
-- calcolo il secondo fillet
|
||||
local ptRib2 = EgtSP( nRib2, GDB_ID.ROOT)
|
||||
for i = 1, #vLinks do
|
||||
if AreSamePointApprox( EgtEP( vLinks[i], GDB_ID.ROOT), ptRib2) then
|
||||
CalcFillet( vLinks[i], nRib2, dFillet2, nGrpId, nGrpTmp)
|
||||
break
|
||||
end
|
||||
end
|
||||
|
||||
EgtErase( nGrpTmp)
|
||||
end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
local function ComputeShortestLinkOnCurve( nCrv, dParS, dParE, nGrp)
|
||||
|
||||
@@ -2721,7 +2809,7 @@ local function HandleRibsIntersectionForRibsMergedShells( vOrigRibs, nRibsGrp, n
|
||||
-- ignoro setti che non hanno passate corrispondenti
|
||||
for i = 1, #vOrigRibs do
|
||||
local vOffs = EgtGetNameInGroup( nRibsGrp, EgtGetName( vOrigRibs[i]))
|
||||
if vOffs then table.insert( vRibsIds, vOrigRibs[i]) end
|
||||
if vOffs and #vOffs > 0 then table.insert( vRibsIds, vOrigRibs[i]) end
|
||||
end
|
||||
|
||||
-- creo un gruppo con frame locale per calcolare le intersezioni ( è il piano XY locale dove calcolare intersezioni)
|
||||
@@ -2747,9 +2835,18 @@ local function HandleRibsIntersectionForRibsMergedShells( vOrigRibs, nRibsGrp, n
|
||||
nCrv1, nCrv2 = nCrv2, nCrv1
|
||||
end
|
||||
|
||||
-- verifico che la curva secondaria abbia una sola passata
|
||||
local nShells2 = EgtGetInfo( nCrv2, KEY_RIBS_SHELLS_NBR, 'i')
|
||||
if nShells2 > 1 then
|
||||
EgtOutLog( 'Error : shell-merged ribs intersect in a non valid way (layer '.. EgtNumToString( s_nCurrIdx) ..') - CalcPaths')
|
||||
table.insert( s_vErr, ' - layer ' .. EgtNumToString( s_nCurrIdx) .. ' : error in ribs-merged shells intersection')
|
||||
return false
|
||||
end
|
||||
|
||||
-- calcolo la superficie della curva principale ( nCrv1) da usare per trim
|
||||
local nShells = EgtGetInfo( nCrv1, KEY_RIBS_SHELLS_NBR, 'i')
|
||||
local dOffs = (( nShells + 1) * 0.5 - dOverlap / 100) * dStrand
|
||||
local dStrandOverlap = EgtGetInfo( nCrv1, KEY_RIBS_STRAND_OVERLAP, 'd')
|
||||
local dOffs = (( nShells - 1) * ( 1 - dStrandOverlap / 100) * 0.5 + 1 - dOverlap / 100) * dStrand
|
||||
local nSrf = EgtSurfFrFatCurve( nGrpTmp, nCrv1, dOffs, false, false, s_dOffsTol)
|
||||
if not nSrf then
|
||||
EgtOutLog( 'Error : EgtSurfFrFatCurve for shell-merged ribs intersection failed (layer '.. EgtNumToString( s_nCurrIdx) ..') - CalcPaths')
|
||||
@@ -2776,6 +2873,8 @@ local function HandleRibsIntersectionForRibsMergedShells( vOrigRibs, nRibsGrp, n
|
||||
if nLinkId then
|
||||
local nRes = EgtCurveWithRegionClassify( nLinkId, nShellSrf)
|
||||
if nRes == GDB_CRC.IN then
|
||||
-- fillet
|
||||
AddFillet( nCrv, {nLinkId}, nCrv + 1, nRibsGrp)
|
||||
EgtAddCurveCompoCurve( nCrv + 1, nLinkId, true, false)
|
||||
EgtAddCurveCompoCurve( nCrv + 1, nCrv, true, false)
|
||||
else
|
||||
@@ -2881,6 +2980,7 @@ local function CreateRibsMergedShellLastLink( vShells, vRibs, nGrp, bInvert)
|
||||
if bInvert then
|
||||
-- conservo tratto dParS->dParE
|
||||
EgtTrimCurveStartEndAtParam( nLink, dParS, dParE)
|
||||
EgtInvertCurve( nLink)
|
||||
else
|
||||
-- conservo tratto dParE->dParS
|
||||
EgtTrimCurveStartEndAtParam( nLink, dParE, dParS)
|
||||
@@ -2923,6 +3023,8 @@ local function CreateRibsMergedShellLastLink( vShells, vRibs, nGrp, bInvert)
|
||||
end
|
||||
end
|
||||
if nPartLink then
|
||||
-- fillet
|
||||
AddFillet( vRibs[i], {nPartLink}, nOtherPart, nGrp)
|
||||
EgtAddCurveCompoCurve( vRibs[i], nPartLink)
|
||||
EgtAddCurveCompoCurve( vRibs[i], nOtherPart)
|
||||
end
|
||||
@@ -3015,6 +3117,7 @@ local function AdjustRibsMergedExtraShellLink( nLinkId, vExtraShells, nGrp)
|
||||
|
||||
local frLoc = Frame3d( ORIG(), s_vtSlicing)
|
||||
local nGrpLoc = EgtGroup( nGrp, frLoc)
|
||||
local vLinks = {}
|
||||
|
||||
-- devo conservare solo le intersezioni fra link ed extra shell
|
||||
for i = 1, #vExtraShells do
|
||||
@@ -3022,6 +3125,8 @@ local function AdjustRibsMergedExtraShellLink( nLinkId, vExtraShells, nGrp)
|
||||
if nRes then
|
||||
for nId = nRes + nPntCnt, nRes + nPntCnt + nCrvCnt - 1 do
|
||||
EgtRelocateGlob( nId, nGrp)
|
||||
EgtModifyCurveExtrusion( nId, s_vtSlicing, GDB_ID.ROOT)
|
||||
table.insert( vLinks, nId)
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -3029,6 +3134,7 @@ local function AdjustRibsMergedExtraShellLink( nLinkId, vExtraShells, nGrp)
|
||||
-- cancello il link originale
|
||||
EgtErase( nLinkId)
|
||||
EgtErase( nGrpLoc)
|
||||
return vLinks
|
||||
end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
@@ -3070,7 +3176,7 @@ local function CreateRibsMergedShellCurve( nGrp, nRibsGrp, vShells, vOrigShells,
|
||||
-- creo il link
|
||||
local nLinkId = CreateRibsMergedShellLink( nCurr, nNext, nGrp, EgtIf( bLinkOnShell, vLoopsShell, vLoopsTrim), nRibsGrp)
|
||||
if not nLinkId then
|
||||
return false
|
||||
return false
|
||||
end
|
||||
|
||||
-- se link fatto sulla shell verifico non si sovrapponga al last link
|
||||
@@ -3092,16 +3198,24 @@ local function CreateRibsMergedShellCurve( nGrp, nRibsGrp, vShells, vOrigShells,
|
||||
end
|
||||
|
||||
-- verifico se necessari aggiustamenti per extra shell
|
||||
local vLinks
|
||||
if bExtraShell and bLinkOnShell then
|
||||
AdjustRibsMergedExtraShellLink( nLinkId, vOrigShells, nGrp)
|
||||
vLinks = AdjustRibsMergedExtraShellLink( nLinkId, vOrigShells, nGrp)
|
||||
end
|
||||
|
||||
-- fillet
|
||||
AddFillet( nCurr, vLinks or {nLinkId}, nNext, nGrp)
|
||||
|
||||
end
|
||||
|
||||
-- eventuali aggiustamenti del last link per extra shell
|
||||
local vLastLinks
|
||||
if bExtraShell then
|
||||
AdjustRibsMergedExtraShellLink( nLastLink, vOrigShells, nGrp)
|
||||
vLastLinks = AdjustRibsMergedExtraShellLink( nLastLink, vOrigShells, nGrp)
|
||||
end
|
||||
|
||||
-- fillet sul last link
|
||||
AddFillet( vRibs[#vRibs], vLastLinks or {nLastLink}, vRibs[1], nGrp)
|
||||
|
||||
-- elimino le curve inutili e le superfici
|
||||
EgtErase( nRibsGrp)
|
||||
@@ -3649,7 +3763,7 @@ local function ReorderExtraShells( nPathGrp, vPtStart, LayerParams)
|
||||
end
|
||||
|
||||
local vIds = EgtGetNameInGroup( nPathGrp, EXTRA_SHELL_CRV .. '*')
|
||||
if not vIds then return end
|
||||
if not vIds or #vIds == 0 then return end
|
||||
|
||||
-- eventuale inversione di tutte le curve
|
||||
if LayerParams.bPrintInvert then
|
||||
@@ -3998,7 +4112,7 @@ end
|
||||
local function AddExtraZigZag( nSrf, sName, dStrand, nGrp, nSrfTrim)
|
||||
|
||||
local vIds = EgtGetNameInGroup( nGrp, sName)
|
||||
if not vIds then return end
|
||||
if not vIds or #vIds == 0 then return end
|
||||
local vtDir = EgtSV( vIds[1], GDB_ID.ROOT)
|
||||
local vtYLoc = s_vtSlicing ^ vtDir
|
||||
|
||||
@@ -4205,7 +4319,7 @@ function CalcPaths.Exec( nPartId)
|
||||
s_nPartId = nPartId
|
||||
|
||||
local vLayIds = EgtGetNameInGroup( s_nPartId, SLICE_LAYER.."*")
|
||||
if not vLayIds then
|
||||
if not vLayIds or #vLayIds == 0 then
|
||||
EgtOutBox( 'Error no slice', 'PathCalc')
|
||||
return true
|
||||
end
|
||||
|
||||
+14
-4
@@ -27,11 +27,19 @@ local MIN_AREA = 25.0
|
||||
---------------------------------------------------------------------
|
||||
local function ComputeZSlices( dSliceStep, dZmin, dDeltaZ, dZmax)
|
||||
|
||||
-- verifico se è impostato un numero massimo di slices
|
||||
local nMaxSlicesNbr = EgtGetInfo( s_nPartId, KEY_MAX_SLICES_NBR, 'i') or 0
|
||||
if nMaxSlicesNbr == 0 then
|
||||
nMaxSlicesNbr = GEO.INFINITO -- da gestire come caso illimitato
|
||||
end
|
||||
|
||||
local nCnt = 1
|
||||
local ptSlices = { dZmin + dDeltaZ}
|
||||
local dPosZ = dZmin + dSliceStep
|
||||
while dPosZ < dZmax do
|
||||
while dPosZ < dZmax and nCnt < nMaxSlicesNbr do
|
||||
table.insert( ptSlices, dPosZ)
|
||||
dPosZ = dPosZ + dSliceStep
|
||||
nCnt = nCnt + 1
|
||||
end
|
||||
return ptSlices
|
||||
end
|
||||
@@ -117,11 +125,14 @@ local function GetRibParams( nId)
|
||||
ReadParam( nId, KEY_RIBS_LEAD_OUT_WIPE, 'd', 0, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_LEAD_OUT_WIPE_DIR, 'd', 0, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_OVERLAP, 'd', 0, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_STRAND_OVERLAP, 'd', 0, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_LINK, 'b', false, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_TYPE, 'i', RIB_TYPE.INTERNAL, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_INVERT_STRAND_ORDER, 'b', false, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_MERGE_WITH_SHELLS, 'b', false, RibParam)
|
||||
|
||||
ReadParam( nId, KEY_RIBS_LEAD_FILLET, 'd', 0, RibParam)
|
||||
ReadParam( nId, KEY_RIBS_LINK_FILLET, 'd', 0, RibParam)
|
||||
|
||||
return RibParam
|
||||
end
|
||||
|
||||
@@ -998,6 +1009,7 @@ local function SlicingWithSolid( nStmId, vZSlices, dDeltaZStart, dZmin, frSlicin
|
||||
|
||||
if #vOpenId > 1 then
|
||||
EgtOutLog( 'Error : hole in solid (layer '.. EgtNumToString( nLayCnt) ..') - CalcSlices')
|
||||
table.insert( s_vErr, nLayCnt)
|
||||
end
|
||||
else
|
||||
|
||||
@@ -1141,8 +1153,6 @@ function CalcSlices.Exec( nPartId, nStmId)
|
||||
local dZmax = b3Box:getMax():getZ()
|
||||
local dMaxH = ComputeMaxH( vRefIds, frSlicing, dSliceStep)
|
||||
dZmax = min( dZmax, dMaxH)
|
||||
--dZmin = 708
|
||||
--dZmax = 712
|
||||
|
||||
-- Eseguo slicing
|
||||
local nLayCnt = 1
|
||||
|
||||
+378
-134
@@ -16,6 +16,10 @@ local AMD = require( 'AddManData')
|
||||
local s_nPartId
|
||||
local s_nDefaultWipeAng = -90 -- angolo = 0° per wipe significa che esce ortogonalmente alla direzione del movimento
|
||||
local s_dApproxTol = 0.1
|
||||
local s_dHSafeWipe = 2
|
||||
local s_nCurrIdx
|
||||
local s_dSpiralVaseMaxLen = 10
|
||||
local s_dSpralVaseFirstDelta = 30 -- lunghezza del tratto sul primo layer che va alzato
|
||||
|
||||
---------------------------------------------------------------------
|
||||
local function GetLayerParamsForToolPathCalc()
|
||||
@@ -51,6 +55,15 @@ local function GetLayerParamsForToolPathCalc()
|
||||
LayerParams.dInfillCoasting = EgtGetInfo( s_nPartId, KEY_INFILL_COASTING, 'd') or 0
|
||||
LayerParams.dInfillWipe = EgtGetInfo( s_nPartId, KEY_INFILL_WIPE, 'd') or 0
|
||||
LayerParams.dInfillWipeDir = EgtGetInfo( s_nPartId, KEY_INFILL_WIPE_DIR, 'd') or 0
|
||||
|
||||
-- parametri dal file macchina per eventuale approssimazione lineare dei percorsi
|
||||
local sMachIni = EgtGetCurrMachineDir() .. '\\' .. EgtGetCurrMachineName() .. '.ini'
|
||||
LayerParams.bLinearApprox = ( EgtGetNumberFromIni( SEC_3DPRINTING, KEY_LINEAR_APPROX, 0, sMachIni) == 1)
|
||||
LayerParams.dLinearApproxTol = EgtGetNumberFromIni( SEC_3DPRINTING, KEY_LINEAR_TOL, 0.1, sMachIni)
|
||||
|
||||
-- parametri da file ini del programma
|
||||
local sIniFile = EgtGetIniFile()
|
||||
LayerParams.dSpiralVaseInterpLen = EgtGetNumberFromIni( '3dPrinting', 'SpiralVaseInterpLen', 100.0, sIniFile)
|
||||
|
||||
return LayerParams
|
||||
end
|
||||
@@ -97,7 +110,7 @@ local function AddZCorrection( b3Box, LayerParams)
|
||||
|
||||
-- correzione per i wipe
|
||||
-- altezza minima necessaria per i wipe
|
||||
local dHMinWipe = LayerParams.dTDiam / 2 * dNxy + max( dHBox, 0)
|
||||
local dHMinWipe = LayerParams.dTDiam / 2 * dNxy + max( dHBox, 0) + s_dHSafeWipe
|
||||
local vLayIds = EgtGetNameInGroup( s_nPartId, SLICE_LAYER.."*")
|
||||
for i = 1, #vLayIds do
|
||||
local vCrvGrps = EgtGetNameInGroup( vLayIds[i], CONTOUR_GRP.."*")
|
||||
@@ -108,13 +121,23 @@ local function AddZCorrection( b3Box, LayerParams)
|
||||
for k = 1, #vIds do
|
||||
-- se wipe verifico se ha lunghezza sensata per non finire nella tavola
|
||||
if EgtGetInfo( vIds[k], KEY_TYPE, 'i') == TYPE.WIPE then
|
||||
local dLen = EgtCurveLength( vIds[k])
|
||||
local vtDir = EgtSV( vIds[k], GDB_ID.ROOT)
|
||||
local ptE = EgtEP( vIds[k], GDB_ID.ROOT)
|
||||
if ptE:getZ() < dHMinWipe then
|
||||
-- modifico la lunghezza per non finire nella tavola
|
||||
local dDiffLen = ( dHMinWipe - ptE:getZ()) / vtDir:getZ()
|
||||
EgtTrimCurveEndAtLen( vIds[k], dLen - abs( dDiffLen))
|
||||
-- da controllare solo se non segue l'andamento di una curva chiusa
|
||||
local bOnCurve = EgtGetInfo( vIds[k], KEY_WIPE_ON_CRV, 'b') or false
|
||||
if not bOnCurve then
|
||||
local dLen = EgtCurveLength( vIds[k])
|
||||
local vtDir = EgtSV( vIds[k], GDB_ID.ROOT)
|
||||
local ptE = EgtEP( vIds[k], GDB_ID.ROOT)
|
||||
if ptE:getZ() < dHMinWipe then
|
||||
-- modifico la lunghezza per non finire nella tavola
|
||||
local dDiffLen = abs( ( dHMinWipe - ptE:getZ()) / vtDir:getZ())
|
||||
if dDiffLen > dLen - GEO.EPS_SMALL then
|
||||
-- l'intero tratto di wipe va eliminato
|
||||
EgtErase( vIds[k])
|
||||
EgtOutLog( 'Warning : wipe was removed due to wrong direction (layer '..tostring( i)..') - CalcToolPath')
|
||||
else
|
||||
EgtTrimCurveEndAtLen( vIds[k], dLen - dDiffLen)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -332,6 +355,8 @@ local function AddLeadIn( nCrvId, LayerParams, nGrpId)
|
||||
local dStrand = EgtGetInfo( nCrvId, KEY_CRV_STRAND, 'd')
|
||||
EgtSetInfo( nLeadInCrv, KEY_CRV_STRAND, dStrand)
|
||||
end
|
||||
|
||||
return nLeadInCrv
|
||||
end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
@@ -378,19 +403,29 @@ local function AddRetraction( nCrvId, vtSlicing, dCoastingLen, dWipeLen, dWipeDi
|
||||
|
||||
-- curva ausiliaria per generare correttamente wipe
|
||||
local nCopyId = EgtCopyGlob( nCrvId, nCrvId, GDB_IN.AFTER)
|
||||
if not EgtCurveIsClosed( nCopyId) then
|
||||
local ptNewStart = EgtEP( nCrvId)
|
||||
local dPar = EgtCurveParamAtPoint( nCopyId, ptNewStart)
|
||||
local _, dParE = EgtCurveDomain( nCopyId)
|
||||
if abs( dPar - dParE) < GEO.EPS_SMALL then
|
||||
EgtCloseCurveCompo( nCopyId)
|
||||
EgtChangeClosedCurveStartPoint( nCopyId, ptNewStart)
|
||||
else
|
||||
if not EgtCurveIsClosed( nCopyId) and EgtCurveIsFlat( nCopyId) then
|
||||
local ptNewStart = EgtEP( nCopyId, GDB_ID.ROOT)
|
||||
-- mi posiziono in un frame locale per fare i conti
|
||||
local nGrp = EgtGroup( EgtGetParent( nCrvId), Frame3d( ORIG(), vtSlicing), GDB_RT.GLOB)
|
||||
EgtRelocateGlob( nCopyId, nGrp)
|
||||
local nInters = EgtCurveSelfIntersCount( nCopyId)
|
||||
local nCrvCnt
|
||||
if nInters > 0 then
|
||||
-- caso con sovrapposizione
|
||||
EgtTrimCurveStartAtParam( nCopyId, dPar)
|
||||
nCopyId, nCrvCnt = EgtSplitCurveAtSelfInters( nCopyId)
|
||||
for nIdx = 1, nCrvCnt - 2 do
|
||||
EgtAddCurveCompoCurve( nCopyId, nCopyId + nIdx)
|
||||
end
|
||||
if nCrvCnt > 1 then
|
||||
EgtErase( nCopyId + nCrvCnt - 1)
|
||||
end
|
||||
end
|
||||
EgtCloseCurveCompo( nCopyId)
|
||||
EgtChangeClosedCurveStartPoint( nCopyId, ptNewStart, GDB_RT.GLOB)
|
||||
EgtRelocateGlob( nCopyId, nCrvId, GDB_IN.AFTER)
|
||||
EgtErase( nGrp)
|
||||
end
|
||||
|
||||
|
||||
local nCoastingId
|
||||
if dCoastingLen > GEO.EPS_SMALL then
|
||||
nCoastingId = EgtCopyGlob( nCrvId, nCrvId, GDB_IN.AFTER)
|
||||
@@ -421,6 +456,7 @@ local function AddRetraction( nCrvId, vtSlicing, dCoastingLen, dWipeLen, dWipeDi
|
||||
nWipeId = nCopyId
|
||||
nCopyId = nil
|
||||
EgtTrimCurveEndAtLen( nWipeId, dWipeLen)
|
||||
EgtSetInfo( nWipeId, KEY_WIPE_ON_CRV, true)
|
||||
else
|
||||
-- se extra shell, infill, spiral vase o rib che non termina sulla parete
|
||||
local ptS = EgtEP( nCoastingId or nCrvId, GDB_ID.ROOT)
|
||||
@@ -513,12 +549,12 @@ end
|
||||
---------------------------------------------------------------------
|
||||
local function CalcShellsToolPath( vEntIds, nTpathGrpId, LayerParams)
|
||||
|
||||
if not vEntIds then return end
|
||||
if not vEntIds or #vEntIds == 0 then return end
|
||||
|
||||
-- aggiungo le curve nel toolpath
|
||||
local vIds = AddCurvesToToolPath( vEntIds, nTpathGrpId, LayerParams.nOrder, LayerParams.bInvert, LayerParams.vtSlicing, LayerParams.dLayHeight)
|
||||
local nFirstCopy = EgtCopyGlob( vIds[1], nTpathGrpId) -- necessaria per corretto offset lead point sulla shell esterna
|
||||
|
||||
|
||||
-- assegno lo strand
|
||||
for i = 1, #vIds do
|
||||
local nType = EgtGetInfo( vIds[i], KEY_TYPE, 'i')
|
||||
@@ -530,7 +566,7 @@ local function CalcShellsToolPath( vEntIds, nTpathGrpId, LayerParams)
|
||||
EgtSetInfo( vIds[i], KEY_CRV_STRAND, LayerParams.dInfillStrand)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
-- aggiungo gli opportuni raccordi
|
||||
AddLink( vIds, nTpathGrpId, LayerParams.nLinkType, LayerParams.dLinkParam, LayerParams.dSPOffs, LayerParams.nOrder, LayerParams.vtSlicing)
|
||||
|
||||
@@ -561,7 +597,7 @@ end
|
||||
---------------------------------------------------------------------
|
||||
local function CalcExtraShellToolPath( vEntIds, nTpathGrpId, LayerParams)
|
||||
|
||||
if not vEntIds then return end
|
||||
if not vEntIds or #vEntIds == 0 then return end
|
||||
-- aggiungo le curve nel toolpath
|
||||
local vIds = AddCurvesToToolPath( vEntIds, nTpathGrpId, PRINT_ORDER.EXT_INT, false, LayerParams.vtSlicing, LayerParams.dLayHeight)
|
||||
|
||||
@@ -914,7 +950,7 @@ local function JoinShellsAndSolidFills( nInfillGrp, vShellIds, vExtraShells, Lay
|
||||
|
||||
local nFillType = EgtGetInfo( nInfillGrp, KEY_FILL_TYPE, 'i') or FILL_TYPE.NONE
|
||||
|
||||
if nFillType == FILL_TYPE.OFFSET and vShellIds then
|
||||
if nFillType == FILL_TYPE.OFFSET and vShellIds and #vShellIds > 0 then
|
||||
|
||||
-- cerco indice di realizzazione dei vari elementi di stampa
|
||||
local vTypeSequence = {}
|
||||
@@ -931,7 +967,7 @@ local function JoinShellsAndSolidFills( nInfillGrp, vShellIds, vExtraShells, Lay
|
||||
end
|
||||
|
||||
-- verifico se extra shell realizzate tra shell e infill
|
||||
if vExtraShells and nMin < vTypeSequence[PRINT_ELEMENT.EXTRA_SHELL] and vTypeSequence[PRINT_ELEMENT.EXTRA_SHELL] < nMax then
|
||||
if vExtraShells and #vExtraShells > 0 and nMin < vTypeSequence[PRINT_ELEMENT.EXTRA_SHELL] and vTypeSequence[PRINT_ELEMENT.EXTRA_SHELL] < nMax then
|
||||
return
|
||||
end
|
||||
|
||||
@@ -972,7 +1008,7 @@ local function CalcAuxSolidsToolPath( nAuxSolidsGrp, nAuxSolidsPathGrp, nTpathGr
|
||||
-- recupero tutti i percorsi relativi a quel solido
|
||||
local sName = EgtGetName( nSolidId)
|
||||
local vEntIds = EgtGetNameInGroup( nAuxSolidsPathGrp, sName .. '*')
|
||||
if vEntIds then
|
||||
if vEntIds and #vEntIds > 0 then
|
||||
|
||||
-- recupero i parametri relativi al solido dalla curva di slicing
|
||||
local nFillType = EgtGetInfo( nSolidId, KEY_AUX_SOLIDS_INFILL, 'i')
|
||||
@@ -1040,6 +1076,78 @@ end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
--------------------------- RIBS -----------------------------------
|
||||
--------------------------------------------------------------------
|
||||
local function AddFillet( nCrv1, nCrv2, dFillet, vtSlicing)
|
||||
|
||||
if dFillet < GEO.EPS_SMALL then
|
||||
return
|
||||
end
|
||||
|
||||
local nRefPosId = EgtGetPrev( nCrv1)
|
||||
local nRefGrpId = EgtGetParent( nCrv1)
|
||||
local vsInfo1 = EgtGetAllInfo( nCrv1)
|
||||
local vsInfo2 = EgtGetAllInfo( nCrv2)
|
||||
|
||||
-- creo un gruppo con riferimento locale allo slicing per i conti del fillet
|
||||
local nGrpTmp = EgtGroup( EgtGetParent( nCrv1), Frame3d( ORIG(), vtSlicing), GDB_RT.GLOB)
|
||||
|
||||
-- creo il fillet
|
||||
local dParRef1 = EgtCurveParamAtLength( nCrv1, EgtCurveLength( nCrv1) - 100 * GEO.EPS_SMALL)
|
||||
local dParRef2 = EgtCurveParamAtLength( nCrv2, 100 * GEO.EPS_SMALL)
|
||||
local nFillet = EgtCurveFillet( nGrpTmp, nCrv1, EgtUP( nCrv1, dParRef1, nGrpTmp), nCrv2, EgtUP( nCrv2, dParRef2, nGrpTmp), dFillet, true, GDB_RT.LOC)
|
||||
if not nFillet then
|
||||
-- ritento con valore di fillet leggermente inferiore
|
||||
nFillet = EgtCurveFillet( nGrpTmp, nCrv1, EgtUP( nCrv1, dParRef1, nGrpTmp), nCrv2, EgtUP( nCrv2, dParRef2, nGrpTmp), dFillet - 50 * GEO.EPS_SMALL, true, GDB_RT.LOC)
|
||||
end
|
||||
|
||||
-- spezzo a metà il fillet per assegnarlo alle due curve
|
||||
if nFillet then
|
||||
|
||||
local nNewFillet = EgtSplitCurve( nFillet, 2)
|
||||
|
||||
-- aggiungo a nCrv1
|
||||
if EgtExistsObj( nCrv1) then
|
||||
EgtAddCurveCompoArcTg( nCrv1, EgtEP( nNewFillet, GDB_ID.ROOT), true, GDB_RT.GLOB)
|
||||
EgtErase( nNewFillet)
|
||||
else
|
||||
-- nCrv1 viene sostituita completamente dal fillet
|
||||
local nNewCrv = EgtCurveCompo( nRefGrpId, {nNewFillet})
|
||||
-- riposiziono dopo il precedente di nCrv1 ( se esiste) oppure in testa al gruppo
|
||||
if nRefPosId ~= GDB_ID.NULL then
|
||||
EgtRelocateGlob( nNewFillet, nRefPosId, GDB_IN.AFTER)
|
||||
else
|
||||
EgtRelocateGlob( nNewFillet, nRefGrpId, GDB_IN.FIRST_SON)
|
||||
end
|
||||
-- modifico l'id per conservare quello di nCrv1
|
||||
EgtChangeId( nNewCrv, nCrv1)
|
||||
-- riassegno le info
|
||||
for i = 1, #vsInfo1 do
|
||||
local vsInfo = EgtSplitString( vsInfo1[i], '=')
|
||||
EgtSetInfo( nCrv1, vsInfo[1], vsInfo[2])
|
||||
end
|
||||
end
|
||||
|
||||
-- aggiungo a nCrv2
|
||||
if EgtExistsObj( nCrv2) then
|
||||
EgtAddCurveCompoArcTg( nCrv2, EgtSP( nNewFillet + 1, GDB_ID.ROOT), false, GDB_RT.GLOB)
|
||||
EgtErase( nNewFillet + 1)
|
||||
else
|
||||
-- nCrv2 viene sostituita completamente dal fillet
|
||||
local nNewCrv = EgtCurveCompo( nRefGrpId, {nNewFillet + 1})
|
||||
EgtRelocateGlob( nNewCrv, nCrv1, GDB_IN.AFTER)
|
||||
EgtChangeId( nNewCrv, nCrv2)
|
||||
for i = 1, #vsInfo2 do
|
||||
local vsInfo = EgtSplitString( vsInfo2[i], '=')
|
||||
EgtSetInfo( nCrv2, vsInfo[1], vsInfo[2])
|
||||
end
|
||||
end
|
||||
else
|
||||
EgtOutLog( 'Warning : ribs fillet not possible (layer '..tostring( s_nCurrIdx)..') - CalcToolPath')
|
||||
end
|
||||
|
||||
EgtErase( nGrpTmp)
|
||||
end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
local function VerifyRibsLink( nLinkId, nCurr, nNext, nGrpTmp, dStrand)
|
||||
|
||||
@@ -1074,7 +1182,7 @@ local function VerifyRibsLink( nLinkId, nCurr, nNext, nGrpTmp, dStrand)
|
||||
end
|
||||
|
||||
-- se collegamento non ottimale verifico che abbia una parte esterna alla regione occupata dai setti abbsatanza lunga ( > 20% della lunghezza totale)
|
||||
if dist( EgtEP( nCurr, GDB_ID.ROOT), EgtSP( nNext, GDB_ID.ROOT)) > dist( EgtEP( nCurr, GDB_ID.ROOT), EgtEP( nNext, GDB_ID.ROOT)) + GEO.EPS_SMALL then
|
||||
if dist( EgtEP( nCurr, GDB_ID.ROOT), EgtSP( nNext, GDB_ID.ROOT)) > dist( EgtEP( nCurr, GDB_ID.ROOT), EgtEP( nNext, GDB_ID.ROOT)) + 1000 * GEO.EPS_SMALL then
|
||||
local nSrfRibs = EgtSurfFrFatCurve( nGrpTmp, nCurr, dStrand, false) or GDB_ID.NULL
|
||||
local nSrfRibs2 = EgtSurfFrFatCurve( nGrpTmp, nNext, dStrand, false) or GDB_ID.NULL
|
||||
EgtSurfFrAdd( nSrfRibs, nSrfRibs2)
|
||||
@@ -1113,10 +1221,11 @@ local function VerifyRibsLink( nLinkId, nCurr, nNext, nGrpTmp, dStrand)
|
||||
local dOffs
|
||||
if nOrigId == nOrigCurr or nOrigId == nOrigNext then
|
||||
-- se passata relativa ad un setto coinvolto nel link verifico soltanto che il percorso del link non entri nella regione occupata dal setto
|
||||
dOffs = dCurrStrand * 0.5
|
||||
local dStrandOverlap = EgtGetInfo( vRibsIds[i], KEY_RIBS_STRAND_OVERLAP, 'd')
|
||||
dOffs = dCurrStrand * ( 0.5 - dStrandOverlap / 100)
|
||||
else
|
||||
-- altrimenti verifico che le regioni del link e del setto non si sovrappongono ( a meno dell'overlap fissato)
|
||||
dOffs = dCurrStrand * 0.5 + ( 0.5 - dOverlap / 100) * dStrand - 10 * GEO.EPS_SMALL
|
||||
dOffs = dCurrStrand * 0.5 + ( 0.5 - dOverlap / 100) * dStrand - 50 * GEO.EPS_SMALL
|
||||
end
|
||||
|
||||
if dOffs > GEO.EPS_SMALL then
|
||||
@@ -1243,6 +1352,15 @@ local function CalcRibsLink( nCurr, nNext, nLoopGrp, bForceLink, vtSlicing, nGrp
|
||||
local dStrand2 = EgtGetInfo( nNext, KEY_CRV_STRAND, 'd')
|
||||
local dStrand = max( dStrand1, dStrand2)
|
||||
|
||||
local dFillet1 = EgtGetInfo( nCurr, KEY_RIBS_LINK_FILLET, 'd')
|
||||
local dFillet2 = EgtGetInfo( nNext, KEY_RIBS_LINK_FILLET, 'd')
|
||||
if bForceLink then
|
||||
local dStrandOverlap1 = EgtGetInfo( nCurr, KEY_RIBS_STRAND_OVERLAP, 'd')
|
||||
local dStrandOverlap2 = EgtGetInfo( nNext, KEY_RIBS_STRAND_OVERLAP, 'd')
|
||||
dFillet1 = min( dFillet1, ( 1 - dStrandOverlap1 / 100) * dStrand1 * 0.5)
|
||||
dFillet2 = min( dFillet2, ( 1 - dStrandOverlap2 / 100) * dStrand2 * 0.5)
|
||||
end
|
||||
|
||||
local vCrvIds = EgtGetAllInGroup( nLoopGrp)
|
||||
-- recupero le curve di bordo su cui poggiano i setti e i corrispondenti parametri
|
||||
local vIdsS, vIdsE = {}, {}
|
||||
@@ -1273,6 +1391,10 @@ local function CalcRibsLink( nCurr, nNext, nLoopGrp, bForceLink, vtSlicing, nGrp
|
||||
end
|
||||
|
||||
if nLinkId then
|
||||
-- fillet
|
||||
AddFillet( nCurr, nLinkId, dFillet1, vtSlicing)
|
||||
AddFillet( nLinkId, nNext, dFillet2, vtSlicing)
|
||||
-- assegno le info
|
||||
EgtRelocateGlob( nLinkId, nCurr, GDB_IN.AFTER)
|
||||
EgtSetInfo( nLinkId, KEY_TYPE, TYPE.RIB)
|
||||
EgtSetName( nLinkId, LINK_CRV)
|
||||
@@ -1286,6 +1408,7 @@ local function CalcRibsLink( nCurr, nNext, nLoopGrp, bForceLink, vtSlicing, nGrp
|
||||
-- se non ho trovato un collegamento lungo bordi ma link deve esserci creo una linea tra ptS e ptE
|
||||
if bForceLink then
|
||||
local nLinkId = EgtCurveCompoFromPoints( EgtGetParent( nCurr), {ptS, ptE})
|
||||
-- assegno le info
|
||||
EgtSetInfo( nLinkId, KEY_TYPE, TYPE.RIB)
|
||||
EgtSetName( nLinkId, LINK_CRV)
|
||||
EgtModifyCurveExtrusion( nLinkId, vtSlicing, GDB_RT.GLOB)
|
||||
@@ -1293,6 +1416,9 @@ local function CalcRibsLink( nCurr, nNext, nLoopGrp, bForceLink, vtSlicing, nGrp
|
||||
EgtSetInfo( nLinkId, KEY_CRV_STRAND, dStrand)
|
||||
local bValid = VerifyRibsLink( nLinkId, nCurr, nNext, nGrpTmp, dStrand)
|
||||
if bValid then
|
||||
-- fillet
|
||||
AddFillet( nCurr, nLinkId, dFillet1, vtSlicing)
|
||||
AddFillet( nLinkId, nNext, dFillet2, vtSlicing)
|
||||
return nLinkId
|
||||
else
|
||||
EgtErase( nLinkId)
|
||||
@@ -1304,12 +1430,13 @@ local function CalcRibsLink( nCurr, nNext, nLoopGrp, bForceLink, vtSlicing, nGrp
|
||||
end
|
||||
|
||||
--------------------------------------------------------------------
|
||||
local function CalcLoopRibLink( nCurr, nNext, nLoopGrp, vtSlicing, nGrpTmp)
|
||||
local function CalcLoopRibLink( nCurr, nNext, nLoopGrp, vtSlicing, nGrpTmp, bForceLink)
|
||||
|
||||
local ptS = EgtEP( nCurr)
|
||||
local ptE = EgtSP( nNext)
|
||||
if AreSamePointApprox( ptS, ptE) then return end
|
||||
local dStrand = EgtGetInfo( nCurr, KEY_CRV_STRAND, 'd')
|
||||
local dFillet = EgtGetInfo( nCurr, KEY_RIBS_LINK_FILLET, 'd')
|
||||
|
||||
local vCrvIds = EgtGetAllInGroup( nLoopGrp)
|
||||
-- scorro le curve di bordo e verifico se posso creare il link
|
||||
@@ -1325,6 +1452,12 @@ local function CalcLoopRibLink( nCurr, nNext, nLoopGrp, vtSlicing, nGrpTmp)
|
||||
EgtModifyCurveExtrusion( nLinkId, vtSlicing, GDB_RT.GLOB)
|
||||
EgtSetInfo( nLinkId, KEY_CRV_STRAND, dStrand)
|
||||
if VerifyRibsLink( nLinkId, nCurr, nNext, nGrpTmp, dStrand) then
|
||||
-- fillet
|
||||
if bForceLink then
|
||||
dFillet = min( dFillet, dStrand * 0.5)
|
||||
end
|
||||
AddFillet( nCurr, nLinkId, dFillet, vtSlicing)
|
||||
AddFillet( nLinkId, nNext, dFillet, vtSlicing)
|
||||
return nLinkId
|
||||
else
|
||||
EgtErase( nLinkId)
|
||||
@@ -1339,56 +1472,49 @@ end
|
||||
local function VerifyRibsLead( nId, nRibId, bInVsOut, nGrpTmp)
|
||||
|
||||
local dStrand = EgtGetInfo( nRibId, KEY_CRV_STRAND, 'd')
|
||||
local dOverlap = EgtGetInfo( nRibId, KEY_RIBS_OVERLAP, 'd')
|
||||
local dShellOverlap = EgtGetInfo( nRibId, KEY_RIBS_OVERLAP, 'd')
|
||||
local dStrandOverlap = EgtGetInfo( nRibId, KEY_RIBS_STRAND_OVERLAP, 'd')
|
||||
local dOverlap = max( dShellOverlap, dStrandOverlap)
|
||||
local nOrigRib = EgtGetInfo( nRibId, KEY_ORIGINAL_RIB, 'i')
|
||||
local dLen = EgtCurveLength( nId)
|
||||
|
||||
-- porto il lead nel gruppo locale
|
||||
local nLeadLoc = EgtCopyGlob( nId, nGrpTmp)
|
||||
|
||||
-- individuo eventuale lead in o link relativo al setto corrente ( solo se collega due passate dello stesso setto)
|
||||
local nCurrLI
|
||||
local nCurrLink
|
||||
if bInVsOut then
|
||||
-- se è lead in devo solo verificare se seguito da un link
|
||||
local nNext = EgtGetNext( nRibId)
|
||||
if nNext and EgtGetName( nNext) == LINK_CRV then
|
||||
local nNextRib = EgtGetNext( nNext)
|
||||
local nOrigRib = EgtGetInfo( nRibId, KEY_ORIGINAL_RIB, 'i') or -1
|
||||
local nOrigRibPrev = EgtGetInfo( nNextRib, KEY_ORIGINAL_RIB, 'i') or -1
|
||||
if nOrigRib == nOrigRibPrev then
|
||||
nCurrLink = nNext
|
||||
end
|
||||
end
|
||||
else
|
||||
-- se è lead out devo verificare se preceduto da lead in o da link
|
||||
local nPrev = EgtGetPrev( nRibId)
|
||||
if nPrev and EgtGetName( nPrev) == LEAD_IN_CRV then
|
||||
nCurrLI = nPrev
|
||||
elseif nPrev and EgtGetName( nPrev) == LINK_CRV then
|
||||
local nPrevRib = EgtGetPrev( nPrev)
|
||||
local nOrigRib = EgtGetInfo( nRibId, KEY_ORIGINAL_RIB, 'i') or -1
|
||||
local nOrigRibPrev = EgtGetInfo( nPrevRib, KEY_ORIGINAL_RIB, 'i') or -1
|
||||
if nOrigRib == nOrigRibPrev then
|
||||
nCurrLink = nPrev
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
-- 1) verifico se interseca altri setti, lead in, lead out o collegamenti
|
||||
-- recupero gli id degli elementi da controllare
|
||||
local vCheckIds = {}
|
||||
local nCurrId = EgtGetFirstInGroup( EgtGetParent( nRibId))
|
||||
while nCurrId do
|
||||
-- considero solo i setti e gli elementi a loro associati ( tranne i wipe perchè non corrispondono a materiale depositato)
|
||||
local nType = EgtGetInfo( nCurrId, KEY_TYPE, 'i')
|
||||
if nType == TYPE.RIB or ( nType == TYPE.COASTING and EgtGetInfo( EgtGetPrev( nCurrId), KEY_TYPE, 'i') == TYPE.RIB) then
|
||||
-- verifico non sia un tratto relativo al setto corrente
|
||||
if nCurrId ~= nCurrLI and nCurrId ~= nRibId and nCurrId ~= nId and nCurrId ~= nCurrLink then
|
||||
table.insert( vCheckIds, nCurrId)
|
||||
if nCurrId ~= nRibId and nCurrId ~= nId then
|
||||
-- considero solo i setti e gli elementi a loro associati ( tranne i wipe perchè non corrispondono a materiale depositato)
|
||||
local nType = EgtGetInfo( nCurrId, KEY_TYPE, 'i')
|
||||
if nType == TYPE.RIB or ( nType == TYPE.COASTING and EgtGetInfo( EgtGetPrev( nCurrId), KEY_TYPE, 'i') == TYPE.RIB) then
|
||||
-- controllo che non sia un elemento relativo ad un'altra passata del setto corrente
|
||||
if EgtGetName( nCurrId) == LEAD_IN_CRV then
|
||||
-- il setto di riferimento è l'elemento successivo
|
||||
local nCurrOrigRib = EgtGetInfo( EgtGetNext( nCurrId), KEY_ORIGINAL_RIB, 'i') or -1
|
||||
if nOrigRib ~= nCurrOrigRib then
|
||||
table.insert( vCheckIds, nCurrId)
|
||||
end
|
||||
elseif EgtGetName( nCurrId) == LINK_CRV then
|
||||
-- il link va controllato se non congiunge due passate del setto corrente
|
||||
local nOrigRib1 = EgtGetInfo( EgtGetPrev( nCurrId), KEY_ORIGINAL_RIB, 'i') or -1
|
||||
local nOrigRib2 = EgtGetInfo( EgtGetNext( nCurrId), KEY_ORIGINAL_RIB, 'i') or -1
|
||||
if nOrigRib ~= nOrigRib1 or nOrigRib ~= nOrigRib2 then
|
||||
table.insert( vCheckIds, nCurrId)
|
||||
end
|
||||
else
|
||||
local nCurrOrigRib = EgtGetInfo( nCurrId, KEY_ORIGINAL_RIB, 'i')
|
||||
if nOrigRib ~= nCurrOrigRib then
|
||||
table.insert( vCheckIds, nCurrId)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
nCurrId = EgtGetNext( nCurrId)
|
||||
end
|
||||
|
||||
-- tra gli id da controllare devo aggiungere anche altri setti non ancora presenti nel toolpath ( tipologie di setti realizzate in seguito)
|
||||
local nCrvGrp = EgtGetParent( EgtGetParent( nRibId))
|
||||
local nRibsPathGrp = EgtGetFirstNameInGroup( nCrvGrp, RIBS_GRP)
|
||||
@@ -1402,7 +1528,7 @@ local function VerifyRibsLead( nId, nRibId, bInVsOut, nGrpTmp)
|
||||
-- controllo se intersezione
|
||||
for i = 1, #vCheckIds do
|
||||
local dCurrStrand = EgtGetInfo( vCheckIds[i], KEY_CRV_STRAND, 'd') or EgtGetInfo( vCheckIds[i], KEY_RIBS_STRAND, 'd')
|
||||
local dCurrOffs = dCurrStrand * 0.5 + ( 0.5 - dOverlap / 100) * dStrand - 10 * GEO.EPS_SMALL
|
||||
local dCurrOffs = dCurrStrand * 0.5 + ( 0.5 - dOverlap / 100) * dStrand - 50 * GEO.EPS_SMALL
|
||||
if dCurrOffs > GEO.EPS_SMALL then
|
||||
local nSrfCurr = EgtSurfFrFatCurve( nGrpTmp, vCheckIds[i], dCurrOffs, false)
|
||||
if nSrfCurr then
|
||||
@@ -1431,8 +1557,9 @@ local function VerifyRibsLead( nId, nRibId, bInVsOut, nGrpTmp)
|
||||
local vtE = EgtUV( nLeadLoc, dParCrv, -1)
|
||||
local dLenCrv = EgtCurveCompoLength( nLeadLoc, dParCrv - 1)
|
||||
if AreSameVectorApprox( vtS, vtE) and vtS * vtDir < - 1 + GEO.EPS_SMALL and dLenCrv > dStrand + GEO.EPS_SMALL then
|
||||
local dDist = EgtPointCurveDist( EgtUP( nLeadLoc, dParCrv - 0.5), nRibLoc)
|
||||
EgtCopyGlob( nLeadLoc, nGrpTmp)
|
||||
local vtDist = EgtUP( nLeadLoc, dParCrv - 0.5) - EgtMP( nRibLoc)
|
||||
local vtOrthoDist = vtDist - ( vtDist * vtDir) * vtDir
|
||||
local dDist = vtOrthoDist:len()
|
||||
if dDist < dStrand + GEO.EPS_SMALL then
|
||||
return false
|
||||
end
|
||||
@@ -1440,26 +1567,29 @@ local function VerifyRibsLead( nId, nRibId, bInVsOut, nGrpTmp)
|
||||
end
|
||||
|
||||
-- 3) verifiche con eventuale lead in
|
||||
if nCurrLI then
|
||||
local nLeadInLoc = EgtCopyGlob( nCurrLI, nGrpTmp)
|
||||
-- verifico se intersezione fra curve
|
||||
local _, nPnt, nCrv = EgtCurveCurveInters( nLeadLoc, nLeadInLoc, nGrpTmp)
|
||||
if nPnt ~= 0 or nCrv ~= 0 then
|
||||
return false
|
||||
end
|
||||
local dLeadInLen = EgtCurveLength( nLeadInLoc)
|
||||
if dLeadInLen > dStrand + GEO.EPS_SMALL then
|
||||
local nSrfLeadIn = EgtSurfFrFatCurve( nGrpTmp, nId, dStrand * ( 1 - dOverlap / 100), false)
|
||||
if nSrfLeadIn then
|
||||
-- EgtSetStatus( nSrfLeadIn, GDB_ST.OFF)
|
||||
-- verifico di avere un solo tratto esterno di lunghezza sufficiente
|
||||
local nRes, nCnt = EgtTrimCurveWithRegion( nLeadInLoc, nSrfLeadIn, false, false)
|
||||
if nCnt ~= 1 then
|
||||
return false
|
||||
else
|
||||
local dLen = EgtCurveLength( nRes)
|
||||
if dLen < dStrand / 2 + GEO.EPS_SMALL then
|
||||
if not bInVsOut then
|
||||
local nCurrLI = EgtGetPrev( nRibId)
|
||||
if nCurrLI and EgtGetName( nCurrLI) == LEAD_IN_CRV then
|
||||
local nLeadInLoc = EgtCopyGlob( nCurrLI, nGrpTmp)
|
||||
-- verifico se intersezione fra curve
|
||||
local _, nPnt, nCrv = EgtCurveCurveInters( nLeadLoc, nLeadInLoc, nGrpTmp)
|
||||
if nPnt ~= 0 or nCrv ~= 0 then
|
||||
return false
|
||||
end
|
||||
local dLeadInLen = EgtCurveLength( nLeadInLoc)
|
||||
if dLeadInLen > dStrand + GEO.EPS_SMALL then
|
||||
local nSrfLeadIn = EgtSurfFrFatCurve( nGrpTmp, nId, dStrand * ( 1 - dOverlap / 100), false)
|
||||
if nSrfLeadIn then
|
||||
-- EgtSetStatus( nSrfLeadIn, GDB_ST.OFF)
|
||||
-- verifico di avere un solo tratto esterno di lunghezza sufficiente
|
||||
local nRes, nCnt = EgtTrimCurveWithRegion( nLeadInLoc, nSrfLeadIn, false, false)
|
||||
if nCnt ~= 1 then
|
||||
return false
|
||||
else
|
||||
local dLen = EgtCurveLength( nRes)
|
||||
if dLen < dStrand / 2 + GEO.EPS_SMALL then
|
||||
return false
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -1571,6 +1701,7 @@ local function AddRibsLeadIn( nCrv, nLoopsGrp, vtSlicing, nGrpTmp, bForceNoSolid
|
||||
local dLILen = EgtGetInfo( nCrv, KEY_RIBS_LEAD_IN_LEN, 'd')
|
||||
local bLIInvert = EgtGetInfo( nCrv, KEY_RIBS_LEAD_IN_INVERT, 'b')
|
||||
local dStrand = EgtGetInfo( nCrv, KEY_CRV_STRAND, 'd')
|
||||
local dFillet = EgtGetInfo( nCrv, KEY_RIBS_LEAD_FILLET, 'd')
|
||||
|
||||
if dLILen < GEO.EPS_SMALL then return end
|
||||
|
||||
@@ -1589,6 +1720,8 @@ local function AddRibsLeadIn( nCrv, nLoopsGrp, vtSlicing, nGrpTmp, bForceNoSolid
|
||||
local nLeadIn = FindCorrectRibLead( dParS, nCrv, vCrvOffs[i], bLIInvert, dLILen, true, nGrpTmp, bSpecialCase)
|
||||
-- se lead in possibile
|
||||
if nLeadIn then
|
||||
AddFillet( nLeadIn, nCrv, dFillet, vtSlicing)
|
||||
|
||||
EgtModifyCurveExtrusion( nLeadIn, vtSlicing, GDB_RT.GLOB)
|
||||
EgtSetInfo( nLeadIn, KEY_TYPE, TYPE.RIB)
|
||||
EgtSetName( nLeadIn, LEAD_IN_CRV)
|
||||
@@ -1608,6 +1741,7 @@ local function AddRibsLeadOut( nCrv, nLoopsGrp, vtSlicing, nGrpTmp, bForceNoSoli
|
||||
local dRibsLOWipeAng = EgtGetInfo( nCrv, KEY_RIBS_LEAD_OUT_WIPE_DIR, 'd')
|
||||
local bRibsLOInvert = EgtGetInfo( nCrv, KEY_RIBS_LEAD_OUT_INVERT, 'b')
|
||||
local dStrand = EgtGetInfo( nCrv, KEY_CRV_STRAND, 'd')
|
||||
local dFillet = EgtGetInfo( nCrv, KEY_RIBS_LEAD_FILLET, 'd')
|
||||
|
||||
if abs( dRibsLOLen) < GEO.EPS_SMALL and
|
||||
abs( dRibsLOCoasting) < GEO.EPS_SMALL and
|
||||
@@ -1641,7 +1775,12 @@ local function AddRibsLeadOut( nCrv, nLoopsGrp, vtSlicing, nGrpTmp, bForceNoSoli
|
||||
local nCrvRef, bInvert = FindCorrectRibLead( dParE, nCrv, vCrvOffs[i], bRibsLOInvert, dRibsLOLen + dRibsLOCoasting, false, nGrpTmp, bSpecialCase)
|
||||
|
||||
if nCrvRef then
|
||||
|
||||
|
||||
-- aggiungo il fillet ( potrebbe coinvolgere sia lead out sia coasting)
|
||||
AddFillet( nCrv, nCrvRef, dFillet, vtSlicing)
|
||||
-- calcolo la nuova lunghezza per il lead out per conservare la lunghezza del coasting dopo il fillet
|
||||
dRibsLOLen = EgtCurveLength( nCrvRef) - dRibsLOCoasting
|
||||
|
||||
-- primo tratto ( segue offset con flusso aperto)
|
||||
if dRibsLOLen > GEO.EPS_SMALL then
|
||||
nCrvLO = EgtCopyGlob( nCrvRef, nCrv, GDB_IN.AFTER)
|
||||
@@ -1711,7 +1850,7 @@ local function CalcRibsToolPath( vEntIds, nRibsGrp, nTpathGrpId, LayerParams)
|
||||
local nGrpTmp = EgtGroup( nRibsGrp, frLoc, GDB_RT.GLOB)
|
||||
|
||||
-- aggiungo le costolature nel toolpath
|
||||
local nNewFirstEnt
|
||||
local nLastEnt = EgtGetLastInGroup( nTpathGrpId) or GDB_ID.NULL
|
||||
for i = 1, #vEntIds do
|
||||
-- copio entità nel gruppo toolpath
|
||||
local nNewEntId = EgtCopyGlob( vEntIds[i], nTpathGrpId, GDB_IN.LAST_SON)
|
||||
@@ -1733,13 +1872,11 @@ local function CalcRibsToolPath( vEntIds, nRibsGrp, nTpathGrpId, LayerParams)
|
||||
|
||||
EgtSetInfo( nNewEntId, KEY_ASSOCIATED_P_CRV, vEntIds[i])
|
||||
EgtSetInfo( vEntIds[i], KEY_ASSOCIATED_TP_CRV, nNewEntId)
|
||||
|
||||
if i == 1 then nNewFirstEnt = nNewEntId end
|
||||
end
|
||||
|
||||
-- recupero i gruppi delle costolature
|
||||
local tabRibs = {}
|
||||
local nFirst = nNewFirstEnt
|
||||
local nFirst = EgtGetNext( nLastEnt) or EgtGetFirstInGroup( nTpathGrpId)
|
||||
while nFirst do
|
||||
local sName = EgtGetName( nFirst)
|
||||
local vIds = EgtGetNameInGroup( nTpathGrpId, sName)
|
||||
@@ -1771,12 +1908,17 @@ local function CalcRibsToolPath( vEntIds, nRibsGrp, nTpathGrpId, LayerParams)
|
||||
if not bLoopRib then
|
||||
CalcRibsLink( tabRibs[i][j], tabRibs[i][j + 1], nLoopGrp, bForceLink, LayerParams.vtSlicing, nGrpTmp)
|
||||
else
|
||||
local nLinkId = CalcLoopRibLink( tabRibs[i][j], tabRibs[i][j + 1], nLoopGrp, LayerParams.vtSlicing, nGrpTmp)
|
||||
local nLinkId = CalcLoopRibLink( tabRibs[i][j], tabRibs[i][j + 1], nLoopGrp, LayerParams.vtSlicing, nGrpTmp, bForceLink)
|
||||
-- se collegamento congiungo i setti in unico percorso
|
||||
if nLinkId then
|
||||
EgtAddCurveCompoCurve( tabRibs[i][j], nLinkId)
|
||||
EgtAddCurveCompoCurve( tabRibs[i][j], tabRibs[i][j + 1])
|
||||
tabRibs[i][j+1] = tabRibs[i][j] -- aggiorno id nel vettore dei setti per gestire correttamente la curva allo step successivo
|
||||
EgtAddCurveCompoCurve( tabRibs[i][j+1], nLinkId, true, false)
|
||||
EgtAddCurveCompoCurve( tabRibs[i][j+1], tabRibs[i][j], true, false)
|
||||
-- aggiorno id nel vettore dei setti per gestire correttamente le curve negli step successivi
|
||||
for k = 0, j do
|
||||
if tabRibs[i][k] == tabRibs[i][j] then
|
||||
tabRibs[i][k] = tabRibs[i][j+1]
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
@@ -1785,7 +1927,7 @@ local function CalcRibsToolPath( vEntIds, nRibsGrp, nTpathGrpId, LayerParams)
|
||||
-- se LoopRib aggiungo collegamento tra primo e ultimo setto del gruppo
|
||||
if bLoopRib then
|
||||
local nTotCrv = #tabRibs[i]
|
||||
local nLinkId = CalcLoopRibLink( tabRibs[i][nTotCrv], tabRibs[i][1], nLoopGrp, LayerParams.vtSlicing, nGrpTmp)
|
||||
local nLinkId = CalcLoopRibLink( tabRibs[i][nTotCrv], tabRibs[i][1], nLoopGrp, LayerParams.vtSlicing, nGrpTmp, false)
|
||||
if nLinkId then
|
||||
-- se curva unica
|
||||
if tabRibs[i][nTotCrv] == tabRibs[i][1] then
|
||||
@@ -1830,7 +1972,7 @@ local function CalcRibsToolPath( vEntIds, nRibsGrp, nTpathGrpId, LayerParams)
|
||||
if nType == RIB_TYPE.UNBOUNDED then
|
||||
bForceNoSolidBorder = true
|
||||
end
|
||||
local nCrvRib = nNewFirstEnt
|
||||
local nCrvRib = EgtGetNext( nLastEnt)
|
||||
while nCrvRib do
|
||||
-- verifico se necessario lead in
|
||||
local nPrev = EgtGetPrev( nCrvRib)
|
||||
@@ -1853,10 +1995,13 @@ end
|
||||
--------------------------------------------------------------------
|
||||
local function AddSpiralVaseLeadOut( nOldId, LayerParams)
|
||||
|
||||
if LayerParams.nLeadOutType ~= LEAD_TYPE.NONE then
|
||||
if LayerParams.nLeadOutType ~= LEAD_TYPE.NONE then
|
||||
EgtTrimCurveEndAtLen( nOldId, EgtCurveLength( nOldId) - LayerParams.dOffsetLP)
|
||||
local nLeadOut = AddLeadOut( nOldId, LayerParams, EgtGetParent( nOldId))
|
||||
if nLeadOut then
|
||||
if LayerParams.bLinearApprox then
|
||||
EgtApproxCurve( nLeadOut, GDB_CA.LINES, LayerParams.dLinearApproxTol)
|
||||
end
|
||||
local dDelta = LayerParams.dLayHeight / EgtCurveLength( nOldId) * EgtCurveLength( nLeadOut)
|
||||
EgtSpiralizeCurveAlongExtrusion( nLeadOut, dDelta)
|
||||
end
|
||||
@@ -1872,6 +2017,7 @@ local function SpiralVase( vLayIds, LayerParams)
|
||||
|
||||
local nOldId, nOldPathId
|
||||
local bFirst = true
|
||||
local nRealLayer = 1
|
||||
local nSlicingType = EgtGetInfo( s_nPartId, KEY_SLICING_TYPE, 'i')
|
||||
|
||||
-- copio ultimo layer
|
||||
@@ -1948,55 +2094,142 @@ local function SpiralVase( vLayIds, LayerParams)
|
||||
EgtSetColor( nNewEntId, EgtStdColor('GRAY'))
|
||||
|
||||
-- se primo layer
|
||||
if bFirst then
|
||||
if nRealLayer == 1 then
|
||||
-- mi sposto dell'altezza layer
|
||||
EgtMove( nNewEntId, LayerParams.dLayHeight * LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||
-- modifico altezza ultimo tratto
|
||||
local dTrimPar = EgtCurveParamAtLength( nNewEntId, EgtCurveLength( nNewEntId) - s_dSpralVaseFirstDelta)
|
||||
local nNewPart = EgtSplitCurveAtParam( nNewEntId, dTrimPar)
|
||||
EgtSpiralizeCurveAlongExtrusion( nNewPart, 0.5 * LayerParams.dLayHeight)
|
||||
|
||||
if LayerParams.bLinearApprox then
|
||||
EgtApproxCurve( nNewEntId, GDB_CA.LINES, LayerParams.dLinearApproxTol)
|
||||
EgtApproxCurve( nNewPart, GDB_CA.LINES, LayerParams.dLinearApproxTol)
|
||||
end
|
||||
|
||||
-- eventuale lead in
|
||||
if LayerParams.nLeadInType ~= LEAD_TYPE.NONE then
|
||||
EgtTrimCurveStartAtLen( nNewEntId, LayerParams.dOffsetLP)
|
||||
AddLeadIn( nNewEntId, LayerParams, nTpathGrpId)
|
||||
end
|
||||
bFirst = false
|
||||
else
|
||||
local ptOld = EgtEP( nOldId, GDB_ID.ROOT)
|
||||
local ptNew = EgtSP( nNewEntId, GDB_ID.ROOT)
|
||||
if dist( ptNew, ptOld) < LayerParams.dStrand then
|
||||
-- se i punti sono vicini ma non coincidenti modifico la curva per avere transizione più uniforme
|
||||
if not AreSamePointApprox( ptOld, ptNew) then
|
||||
-- recupero la curva da usare come guida
|
||||
local nGuideId = EgtCopyGlob( nOldPathId, nTpathGrpId)
|
||||
-- la porto alla stessa quota del toolpath
|
||||
EgtMove( nGuideId, vtMove + LayerParams.dLayHeight * LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||
EgtChangeClosedCurveStartPoint( nGuideId, ptOld, GDB_RT.GLOB)
|
||||
|
||||
EgtSpiralizeCurveAlongGuide( nNewEntId, nGuideId)
|
||||
EgtErase( nGuideId)
|
||||
local nLeadInCrv = AddLeadIn( nNewEntId, LayerParams, nTpathGrpId)
|
||||
if nLeadInCrv and LayerParams.bLinearApprox then
|
||||
EgtApproxCurve( nLeadInCrv, GDB_CA.LINES, LayerParams.dLinearApproxTol)
|
||||
end
|
||||
else
|
||||
EgtOutLog( 'Warning : in spiral vase mode no link betweeen toolpaths (layer '..tostring( nIdx)..') - CalcToolPath')
|
||||
-- aggiungo uscita, coasting e wipe sulla curva precedente
|
||||
AddSpiralVaseLeadOut( nOldId, LayerParams)
|
||||
end
|
||||
EgtSpiralizeCurveAlongExtrusion( nNewEntId, LayerParams.dLayHeight)
|
||||
end
|
||||
|
||||
-- approssimo la curva
|
||||
if nNewEntId then
|
||||
else
|
||||
-- a) garantisco continuità con layer precedente
|
||||
local ptOld = EgtEP( nOldId, GDB_ID.ROOT)
|
||||
if nRealLayer == 2 then
|
||||
-- aggiusto la quota per confronto sensato
|
||||
ptOld = ptOld - 0.5 * LayerParams.dLayHeight * LayerParams.vtSlicing
|
||||
end
|
||||
local ptNew = EgtSP( nNewEntId, GDB_ID.ROOT)
|
||||
|
||||
-- se il punto di inizio non coincide con quello finale del percorso calcolato fino ad ora, modifico la curva per avere una transizione più uniforme tra i due layers
|
||||
if not AreSamePointApprox( ptOld, ptNew) then
|
||||
-- recupero la curva da usare come guida
|
||||
local nGuideId = EgtCopyGlob( nOldPathId, nPathGrpId)
|
||||
-- la rendo coerente con il toolpath
|
||||
EgtMove( nGuideId, vtMove + LayerParams.dLayHeight * LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||
if LayerParams.bInvert then
|
||||
EgtInvertCurve( nGuideId)
|
||||
end
|
||||
-- approssimo con tratti lineari imponendo lunghezza massima per migliorare spiralize
|
||||
EgtApproxCurve( nGuideId, GDB_CA.SPECIAL_LINES, 0.01, s_dSpiralVaseMaxLen)
|
||||
EgtApproxCurve( nNewEntId, GDB_CA.SPECIAL_LINES, 0.01, s_dSpiralVaseMaxLen)
|
||||
-- modifico i punti iniziali affinchè coincidano con il punto finale del percorso precedente
|
||||
EgtChangeClosedCurveStartPoint( nGuideId, ptOld, GDB_RT.GLOB)
|
||||
EgtChangeClosedCurveStartPoint( nNewEntId, ptOld, GDB_RT.GLOB)
|
||||
|
||||
-- distribuisco la differenza sulla curva
|
||||
local dLen = EgtCurveLength( nNewEntId)
|
||||
if LayerParams.dSpiralVaseInterpLen < GEO.EPS_SMALL or LayerParams.dSpiralVaseInterpLen > dLen - GEO.EPS_SMALL then
|
||||
-- la differenza deve essere distribuita su tutta la curva
|
||||
EgtSpiralizeCurveAlongGuide( nNewEntId, nGuideId)
|
||||
-- forzo il punto di inizio a coincidere con il layer precedente ( non è garantito dallo spiralize con il path a causa dell'approx
|
||||
-- con gli archi che potrebbe modificare il punto finale del tpath rispetto a quello del path associato)
|
||||
EgtModifyCurveStartPoint( nNewEntId, ptOld, GDB_RT.GLOB)
|
||||
|
||||
else
|
||||
-- la differenza deve essere distribuita solo su un sottotratto di lunghezza LayerParams.dSpiralVaseAdjLen
|
||||
local dParSplit = EgtCurveParamAtLength( nNewEntId, LayerParams.dSpiralVaseInterpLen)
|
||||
local nNewEndId2 = EgtSplitCurveAtParam( nNewEntId, dParSplit)
|
||||
-- trim della curva guida
|
||||
local _, _, dParMinDist = EgtPointCurveDist( EgtEP( nNewEntId, GDB_ID.ROOT), nGuideId, GDB_RT.GLOB)
|
||||
local nGuideId2 = EgtSplitCurveAtParam( nGuideId, dParMinDist)
|
||||
EgtErase( nGuideId2)
|
||||
-- spiralize solo del primo pezzo
|
||||
EgtSpiralizeCurveAlongGuide( nNewEntId, nGuideId)
|
||||
EgtModifyCurveStartPoint( nNewEntId, ptOld, GDB_RT.GLOB)
|
||||
EgtModifyCurveEndPoint( nNewEntId, EgtSP( nNewEndId2, GDB_ID.ROOT), GDB_RT.GLOB)
|
||||
-- riassemblo la curva
|
||||
EgtAddCurveCompoCurve( nNewEntId, nNewEndId2)
|
||||
end
|
||||
|
||||
EgtErase( nGuideId)
|
||||
end
|
||||
|
||||
-- b) approssimo
|
||||
local ptS = EgtSP( nNewEntId, GDB_ID.ROOT)
|
||||
EgtApproxCurve( nNewEntId, GDB_CA.ARCS, s_dApproxTol)
|
||||
if LayerParams.bLinearApprox then
|
||||
EgtApproxCurve( nNewEntId, GDB_CA.LINES, LayerParams.dLinearApproxTol)
|
||||
end
|
||||
if EgtCurveIsClosed( nNewEntId) then
|
||||
EgtChangeClosedCurveStartPoint( nNewEntId, ptS, GDB_RT.GLOB)
|
||||
end
|
||||
|
||||
-- c) modifica graduale dell'altezza
|
||||
if nRealLayer == 2 then
|
||||
-- se seconda passata la prima metà deve essere a quota costante 0.5 * dLayHeight, la seconda metà deve salire gradualmente di 0.5 * dLayHeight
|
||||
EgtMove( nNewEntId, 0.5 * LayerParams.dLayHeight * LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||
local nNewId = EgtSplitCurve( nNewEntId, 2)
|
||||
EgtSpiralizeCurveAlongExtrusion( nNewId + 1, 0.5 * LayerParams.dLayHeight)
|
||||
else
|
||||
EgtSpiralizeCurveAlongExtrusion( nNewEntId, LayerParams.dLayHeight)
|
||||
end
|
||||
end
|
||||
|
||||
local vTPathsCrvs = EgtGetAllInGroup( nTpathGrpId)
|
||||
nOldPathId = vEntIds[1]
|
||||
nOldId = vTPathsCrvs[#vTPathsCrvs]
|
||||
|
||||
-- moltiplicatore per feed
|
||||
if nRealLayer == 2 then
|
||||
-- il primo tratto si trova a metà altezza rispetto allo strato precedente, quindi il coefficiente moltiplicativo è due
|
||||
EgtSetInfo( vTPathsCrvs[1], KEY_FEED_COEFF, 2)
|
||||
-- nel secondo tratto l'altezza è variabile quindi devo calcolare il coefficiente per ogni sottotratto
|
||||
local dLenTot = EgtCurveLength( vTPathsCrvs[1]) + EgtCurveLength( vTPathsCrvs[2])
|
||||
local dLen = EgtCurveLength( vTPathsCrvs[1])
|
||||
local nFirst, nCnt = EgtExplodeCurveCompo( vTPathsCrvs[2])
|
||||
for nId = nFirst, nFirst + nCnt - 1 do
|
||||
-- calcolo l'altezza effettiva basandomi sulla lunghezza parziale ( viene mimato il conto fatto in EgtSpiralizeCurveAlongExtrusion)
|
||||
dLen = dLen + EgtCurveLength( nId)
|
||||
local dHEff = LayerParams.dLayHeight * dLen / dLenTot
|
||||
local dFeedCoeff = LayerParams.dLayHeight / dHEff
|
||||
EgtSetInfo( nId, KEY_FEED_COEFF, dFeedCoeff)
|
||||
end
|
||||
nOldId = nFirst + nCnt - 1
|
||||
|
||||
elseif nRealLayer == 3 then
|
||||
-- solo la prima metà si trova ad un'altezza variabile rispetto allo strato precedente
|
||||
local dLenTot = EgtCurveLength( vTPathsCrvs[1])
|
||||
local dLen = 0
|
||||
local nNewId = EgtSplitCurve( vTPathsCrvs[1], 2)
|
||||
local nFirst, nCnt = EgtExplodeCurveCompo( nNewId)
|
||||
for nId = nFirst, nFirst + nCnt - 1 do
|
||||
dLen = dLen + EgtCurveLength( nId)
|
||||
local dHeff = LayerParams.dLayHeight * ( dLen / dLenTot + 0.5)
|
||||
local dFeedCoeff = LayerParams.dLayHeight / dHeff
|
||||
EgtSetInfo( nId, KEY_FEED_COEFF, dFeedCoeff)
|
||||
end
|
||||
nOldId = nNewId + 1
|
||||
end
|
||||
|
||||
nOldPathId = vEntIds[1]
|
||||
nOldId = nNewEntId
|
||||
nRealLayer = nRealLayer + 1
|
||||
-- aggiorno il box dei toolpath
|
||||
local b3Box = ComputeToolPathBox( nTpathGrpId)
|
||||
b3Tot:Add( b3Box)
|
||||
end
|
||||
|
||||
-- aggiorno il box dei toolpath
|
||||
local b3Box = ComputeToolPathBox( nTpathGrpId)
|
||||
b3Tot:Add( b3Box)
|
||||
|
||||
end
|
||||
|
||||
if EgtProcessEvents( EgtIf( PRINT, 300, 0) + nIdx / #vLayIds * 100, 0) == 1 then
|
||||
@@ -2021,7 +2254,7 @@ function CalcToolPath.Exec( nPartId)
|
||||
|
||||
-- Recupero i layer da processare
|
||||
local vLayIds = EgtGetNameInGroup( s_nPartId, SLICE_LAYER.."*")
|
||||
if not vLayIds then
|
||||
if not vLayIds or #vLayIds == 0 then
|
||||
EgtOutBox( 'Error missing slices', 'ToolPathCalc')
|
||||
return true
|
||||
end
|
||||
@@ -2039,6 +2272,8 @@ function CalcToolPath.Exec( nPartId)
|
||||
-- Ciclo sui layer
|
||||
for nIdx = 1, #vLayIds do
|
||||
|
||||
s_nCurrIdx = nIdx
|
||||
|
||||
-- scorro tutti i gruppi di contorni
|
||||
local nCrvGrpId = EgtGetFirstNameInGroup( vLayIds[ nIdx], CONTOUR_GRP.."*")
|
||||
while nCrvGrpId do
|
||||
@@ -2123,6 +2358,15 @@ function CalcToolPath.Exec( nPartId)
|
||||
nLayCnt = nIdx
|
||||
end
|
||||
|
||||
-- eventuale approssimazione delle curve
|
||||
if LayerParams.bLinearApprox then
|
||||
local nCrvId = EgtGetFirstInGroup( nTpathGrpId)
|
||||
while nCrvId do
|
||||
EgtApproxCurve( nCrvId, GDB_CA.LINES, LayerParams.dLinearApproxTol)
|
||||
nCrvId = EgtGetNext( nCrvId)
|
||||
end
|
||||
end
|
||||
|
||||
-- passo al gruppo di contorni successivo
|
||||
nCrvGrpId = EgtGetNextName( nCrvGrpId, CONTOUR_GRP.."*")
|
||||
end
|
||||
|
||||
+183
-103
@@ -14,6 +14,7 @@ local AMD = require( 'AddManData')
|
||||
|
||||
--------------------------------------------------------------------
|
||||
local s_dTol = 0.1
|
||||
local s_nSimplifiedSection = 0
|
||||
|
||||
---------------------------------------------------------------------
|
||||
local function GetLayerParamsForSolidCalc( nPartId)
|
||||
@@ -27,46 +28,40 @@ end
|
||||
|
||||
---------------------------------------------------------------------
|
||||
local function CalcSectionParams( dStrand, dH)
|
||||
local dL = dStrand
|
||||
local dLm = dStrand / 10
|
||||
local dHm = dH / 6
|
||||
local dD1 = 0.5 * dL - dLm
|
||||
local dD2 = 0.5 * dL - dD1
|
||||
local dD3 = dHm
|
||||
local dD4 = dH - 2 * dD3
|
||||
return dD1, dD2, dD3, dD4
|
||||
local dBevelX = 0
|
||||
local dBevelY = 0
|
||||
if s_nSimplifiedSection == 0 then
|
||||
-- sezione ottagonale
|
||||
dBevelX = dStrand / 10
|
||||
dBevelY = dH / 6
|
||||
end
|
||||
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
|
||||
|
||||
---------------------------------------------------------------------
|
||||
local function CreateSection( 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 dBevelX, dBevelY = CalcSectionParams( dStrand, dH)
|
||||
local ptA = ptS - dH * vtSlicing + ( 0.5 * dStrand - dBevelX) * vtDir
|
||||
local ptB = ptA + dBevelY * vtSlicing + dBevelX * vtDir
|
||||
local ptC = ptB + ( dH - 2 * dBevelY) * vtSlicing
|
||||
local ptD = ptA + dH * vtSlicing
|
||||
local ptE = ptD - 2 * dD1 * vtDir
|
||||
local ptF = ptC - 2 * ( dD1 + dD2) * vtDir
|
||||
local ptG = ptB - 2 * ( dD1 + dD2) * vtDir
|
||||
local ptH = ptA - 2 * dD1 * vtDir
|
||||
local ptE = ptD - ( dStrand - 2 * dBevelX) * vtDir
|
||||
local ptF = ptC - dStrand * vtDir
|
||||
local ptG = ptB - dStrand * vtDir
|
||||
local ptH = ptA - ( dStrand - 2 * dBevelX) * vtDir
|
||||
|
||||
local nId = EgtCurveCompoFromPoints( nSolidGrp, {ptA, ptB, ptC, ptD, ptE, ptF, ptG, ptH, ptA}, GDB_RT.GLOB)
|
||||
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
|
||||
end
|
||||
|
||||
@@ -74,30 +69,48 @@ end
|
||||
local function CreateSpiralVaseCap( nSectId, vtDir, nSolidGrp)
|
||||
|
||||
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)
|
||||
end
|
||||
|
||||
local vCrvs = {}
|
||||
vCrvs[1] = EgtArc2PV( nSolidGrp, vPt[1], vPt[2], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[2] = EgtArc2PV( nSolidGrp, vPt[8], vPt[3], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[3] = EgtArc2PV( nSolidGrp, vPt[7], vPt[4], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[4] = EgtArc2PV( nSolidGrp, vPt[6], vPt[5], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[5] = EgtCurveCompo( nSolidGrp, {vCrvs[1]}, false, GDB_RT.GLOB)
|
||||
EgtCloseCurveCompo( vCrvs[5])
|
||||
vCrvs[6] = EgtCurveCompo( nSolidGrp, {vCrvs[4]}, false, GDB_RT.GLOB)
|
||||
EgtCloseCurveCompo( vCrvs[6])
|
||||
local nSurf1 = EgtSurfTmRuled( nSolidGrp, vCrvs[1], vCrvs[2], GDB_RUL.ISOPAR, s_dTol)
|
||||
local nSurf2 = EgtSurfTmRuled( nSolidGrp, vCrvs[2], vCrvs[3], GDB_RUL.ISOPAR, s_dTol)
|
||||
local nSurf3 = EgtSurfTmRuled( nSolidGrp, vCrvs[3], vCrvs[4], GDB_RUL.ISOPAR, s_dTol)
|
||||
local nSurf4 = EgtSurfTmByRegion( nSolidGrp, vCrvs[5], s_dTol)
|
||||
local nSurf5 = EgtSurfTmByRegion( nSolidGrp, vCrvs[6], s_dTol)
|
||||
local nCapSrf = EgtSurfTmBySewing( nSolidGrp, {nSurf1, nSurf2, nSurf3, nSurf4, nSurf5})
|
||||
|
||||
-- calcolo gli archi che definiscono la superficie laterale
|
||||
if s_nSimplifiedSection == 1 then
|
||||
-- sezione quadrata
|
||||
vCrvs[1] = EgtArc2PV( nSolidGrp, vPt[1], vPt[2], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[2] = EgtArc2PV( nSolidGrp, vPt[4], vPt[3], vtDir, GDB_RT.GLOB)
|
||||
else
|
||||
-- sezione ottagonale
|
||||
vCrvs[1] = EgtArc2PV( nSolidGrp, vPt[1], vPt[2], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[2] = EgtArc2PV( nSolidGrp, vPt[8], vPt[3], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[3] = EgtArc2PV( nSolidGrp, vPt[7], vPt[4], vtDir, GDB_RT.GLOB)
|
||||
vCrvs[4] = EgtArc2PV( nSolidGrp, vPt[6], vPt[5], vtDir, GDB_RT.GLOB)
|
||||
end
|
||||
-- creo le rigate
|
||||
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
|
||||
EgtErase( vCrvs[i])
|
||||
end
|
||||
|
||||
EgtErase( nCrvTop)
|
||||
EgtErase( nCrvBottom)
|
||||
|
||||
return nCapSrf
|
||||
end
|
||||
|
||||
@@ -105,16 +118,26 @@ end
|
||||
local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
||||
|
||||
-- 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 vtS = EgtSV( nCrvId, GDB_ID.ROOT)
|
||||
local ptE = EgtEP( 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
|
||||
local nCrvCopy = EgtCopyGlob( nCrvId, nGrpTmp)
|
||||
local dDelta = ( ptE - ptS) * LayerParams.vtSlicing
|
||||
EgtSpiralizeCurveAlongExtrusion( nCrvCopy, - dDelta)
|
||||
EgtModifyCurveExtrusion( nCrvCopy, LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||
EgtProjectCurveOnPlane( nCrvCopy, ptS, LayerParams.vtSlicing, GDB_RT.GLOB)
|
||||
EgtMergeCurvesInCurveCompo( nCrvCopy)
|
||||
EgtChangeClosedCurveStartPoint( nCrvCopy, ptS, GDB_RT.GLOB)
|
||||
|
||||
@@ -141,12 +164,19 @@ local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
||||
local dMove = ( ptRef - ptS) * LayerParams.vtSlicing
|
||||
EgtMove( vCrvs[i+1], LayerParams.vtSlicing * dMove, GDB_RT.GLOB)
|
||||
EgtSpiralizeCurveAlongExtrusion( vCrvs[i+1], dDelta)
|
||||
|
||||
|
||||
-- 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)
|
||||
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
|
||||
|
||||
local vSurfs = {}
|
||||
for i = 1, #vCrvs - 1 do
|
||||
vSurfs[i] = EgtSurfTmRuled( nGrpTmp, vCrvs[i], vCrvs[i+1], GDB_RUL.MINDIST, s_dTol)
|
||||
@@ -156,10 +186,7 @@ local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
||||
end
|
||||
end
|
||||
|
||||
local nSrfId = EgtSurfTmBySewing( nSolidGrp, vSurfs)
|
||||
if not nSrfId then
|
||||
nSrfId = EgtSurfTmByTriangles( nSolidGrp, vSurfs)
|
||||
end
|
||||
local nSrfId = EgtSurfTmByTriangles( nSolidGrp, vSurfs)
|
||||
|
||||
-- creazione del mezzo disco iniziale
|
||||
local nCap1 = CreateSpiralVaseCap( nSectId, - vtS, nSolidGrp)
|
||||
@@ -170,15 +197,7 @@ local function CreateSpiralVaseSolid( nCrvId, nSolidGrp, LayerParams, dStrand)
|
||||
-- cancello le curve usate per la costruzione
|
||||
EgtErase( nGrpTmp)
|
||||
|
||||
return EgtSurfTmBySewing( nSolidGrp, { nSrfId, nCap1, nCap2}) or 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
|
||||
return EgtSurfTmByTriangles( nSolidGrp, { nSrfId, nCap1, nCap2})
|
||||
end
|
||||
|
||||
--------------------------------------------------------------------------------------
|
||||
@@ -220,6 +239,36 @@ local function CreateDirectionArrow( nCrvId, nSolidGrp, vtSlicing, dStrand, nLay
|
||||
|
||||
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)
|
||||
|
||||
@@ -272,44 +321,42 @@ local function CreateSolidFromCurve( nCrvId, nSolidGrp, LayerParams, nLayer)
|
||||
local nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, dStrand - 5 * GEO.EPS_SMALL)
|
||||
if not nSrfId then
|
||||
EgtOutLog( 'Warning : CreateSolid failed '.. '(layer '..tostring( nLayer)..', curve '..tostring( nCrvId)..')')
|
||||
-- se non ultima, provo a spostare l'estremità finale
|
||||
if nInd < nParts - 1 then
|
||||
local nCopyId = EgtCopy( nGuideId + 1, nGuideId, GDB_IN.AFTER)
|
||||
if nCopyId then
|
||||
local LEN_TRIM = 10
|
||||
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)
|
||||
-- ritento con strand più piccolo
|
||||
nSrfId = CreateSolid( nGuideId, nSolidGrp, LayerParams, dStrand - 50 * GEO.EPS_SMALL)
|
||||
|
||||
if not nSrfId then
|
||||
EgtOutLog( 'Warning : CreateSolid_1 failed '.. '(layer '..tostring( nLayer)..', curve '..tostring( nCrvId)..')')
|
||||
-- se non ultima, provo a spostare l'estremità finale
|
||||
if nInd < nParts - 1 then
|
||||
local nCopyId = EgtCopy( nGuideId + 1, nGuideId, GDB_IN.AFTER)
|
||||
if nCopyId then
|
||||
local LEN_TRIM = 10
|
||||
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
|
||||
-- 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
|
||||
EgtOutLog( 'Warning : CreateSolid_2 failed')
|
||||
local nGrp = EgtGroup( nSolidGrp, Frame3d( ORIG(), LayerParams.vtSlicing), GDB_RT.GLOB)
|
||||
EgtRelocateGlob( nGuideId, nGrp)
|
||||
EgtApproxCurve( nGuideId, GDB_CA.LINES, 100 * GEO.EPS_SMALL)
|
||||
EgtRelocateGlob( nGuideId, nSolidGrp)
|
||||
local nFirstCrv, nCrvNbr = EgtSplitCurveAtCorners( nGuideId, 30)
|
||||
if nFirstCrv and nCrvNbr > 1 then
|
||||
local nSrfIds = {}
|
||||
for nInd2 = 0, nCrvNbr-1 do
|
||||
local nSrfId2 = CreateSolid( nFirstCrv + nInd2, nSolidGrp, LayerParams, dStrand - 50 * GEO.EPS_SMALL)
|
||||
EgtErase( nFirstCrv + nInd2)
|
||||
if nSrfId2 then
|
||||
table.insert( nSrfIds, nSrfId2)
|
||||
end
|
||||
end
|
||||
if #nSrfIds == nCrvNbr then
|
||||
nSrfId = EgtSurfTmBySewing( nSolidGrp, nSrfIds)
|
||||
else
|
||||
EgtOutLog( 'Warning : CreateSolid_3 failed')
|
||||
end
|
||||
else
|
||||
EgtErase( nFirstCrv)
|
||||
|
||||
local vSurfs = {}
|
||||
local bOk = CreateRecursiveSolid( nGuideId, vSurfs, nSolidGrp, LayerParams, dStrand)
|
||||
if #vSurfs > 0 then
|
||||
nSrfId = EgtSurfTmByTriangles( nSolidGrp, vSurfs)
|
||||
end
|
||||
if not nSrfId or bOk == false then
|
||||
EgtOutLog( 'Warning : CreateSolid_3 failed')
|
||||
end
|
||||
EgtErase( nGrp)
|
||||
end
|
||||
@@ -319,7 +366,7 @@ local function CreateSolidFromCurve( nCrvId, nSolidGrp, LayerParams, nLayer)
|
||||
EgtSetColor( nSrfId, Color)
|
||||
EgtSetInfo( nSrfId, KEY_TYPE, nType)
|
||||
EgtSetInfo( nSrfId, KEY_SLICE_NBR, nLayer)
|
||||
else
|
||||
else
|
||||
bOk = false
|
||||
EgtOutLog( 'Warning : CreateSolid_Sewing failed')
|
||||
end
|
||||
@@ -334,6 +381,10 @@ function RunCalcSolids.Exec()
|
||||
|
||||
-- per determinare il tempo di calcolo
|
||||
EgtStartCounter()
|
||||
|
||||
-- verifico se richiesta sezione semplificata ( rettangolare)
|
||||
local sIniFile = EgtGetIniFile()
|
||||
s_nSimplifiedSection = EgtGetNumberFromIni( 'Solids', 'SimplifiedSection', 0, sIniFile)
|
||||
|
||||
local nPartIndex = 1
|
||||
local nPartId = EgtGetFirstNameInGroup( GDB_ID.ROOT, PART .. nPartIndex) or EgtGetFirstNameInGroup( GDB_ID.ROOT, PART)
|
||||
@@ -352,7 +403,7 @@ function RunCalcSolids.Exec()
|
||||
|
||||
-- recupero i suoi slice
|
||||
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')
|
||||
return
|
||||
end
|
||||
@@ -384,12 +435,41 @@ function RunCalcSolids.Exec()
|
||||
nSolidGrpId = EgtGroup( nCrvGrpId)
|
||||
EgtSetName( nSolidGrpId, SOLID_GRP)
|
||||
EgtSetLevel( nSolidGrpId, GDB_LV.TEMP)
|
||||
-- scorro le curve del percorso utensile
|
||||
local nId = EgtGetFirstInGroup( nTPathGrpId)
|
||||
while nId do
|
||||
local bOk = CreateSolidFromCurve( nId, nSolidGrpId, LayerParams, nLayer)
|
||||
nId = EgtGetNext( nId)
|
||||
-- scorro le curve del percorso utensile per creare i solidi
|
||||
local vIds = EgtGetAllInGroup( nTPathGrpId)
|
||||
|
||||
if LayerParams.bSpiralVase and #vIds > 2 and EgtGetName( vIds[#vIds]) ~= WIPE_CRV then
|
||||
-- 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
|
||||
|
||||
else
|
||||
bSolidsOk = true
|
||||
break
|
||||
@@ -418,7 +498,7 @@ function RunCalcSolids.Exec()
|
||||
for i = 1, #vLayIds do
|
||||
local vGrpId = EgtGetNameInGroup( vLayIds[i], CONTOUR_GRP .. '*') or {}
|
||||
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)
|
||||
end
|
||||
end
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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
|
||||
@@ -187,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 * ( ( dStrandMean - 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
|
||||
@@ -203,7 +207,7 @@ function RunMachParamFromSWCalc.Exec()
|
||||
end
|
||||
if not bSpeedOk then
|
||||
if dTotLayerLength > 0.1 then
|
||||
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))
|
||||
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)
|
||||
@@ -219,10 +223,22 @@ function RunMachParamFromSWCalc.Exec()
|
||||
local CurrWidth = LengthCrvList[nWidthIndex]
|
||||
local CurrFeed = EgtIf( CurrWidth.Width > 0, dLayerFeed * dStrandMean / CurrWidth.Width, dLayerFeed)
|
||||
for nCurveIdIndex = 1, #CurrWidth.IdList do
|
||||
EgtSetInfo( CurrWidth.IdList[nCurveIdIndex], KEY_FEED, CurrFeed)
|
||||
end
|
||||
if CurrFeed > dFeedMax then
|
||||
dFeedMax = CurrFeed
|
||||
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
|
||||
|
||||
@@ -28,52 +28,56 @@ local function CalcCurves( nSliceId, nDestGrp, vtSlicing, dStrandBase)
|
||||
if nType ~= TYPE.WIPE then
|
||||
local dStrand = EgtGetInfo( nId, KEY_CRV_STRAND, 'd') or dStrandBase
|
||||
|
||||
-- calcolo fat curve a partire da una copia della curva ( in questo modo nel DB geometrico non restano
|
||||
-- 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 nCrv, nCnt = EgtCurveGetFatCurve( nCopy, nDestGrp, 0.5 * dStrand, false)
|
||||
local nSurf = EgtSurfFrFatCurve( nDestGrp, nCopy, 0.5 * dStrand, false)
|
||||
-- se fallisce ritento con valore leggermente diverso
|
||||
if not nCrv or nCnt == 0 then
|
||||
nCrv, nCnt = EgtCurveGetFatCurve( nCopy, nDestGrp, 0.5 * dStrand - 0.05, false)
|
||||
if not nSurf or nSurf == GDB_ID.NULL then
|
||||
nSurf = EgtSurfFrFatCurve( nDestGrp, nCopy, 0.5 * dStrand - 0.05, false)
|
||||
end
|
||||
EgtErase( nCopy)
|
||||
|
||||
if nCrv and nCnt > 0 then
|
||||
-- se sono curve chiuse piccoli aggistamenti per creare un percorso unico
|
||||
if nCnt > 1 then
|
||||
for nLoopId = nCrv + 1, nCrv + nCnt - 1 do
|
||||
EgtInvertCurve( nLoopId)
|
||||
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( ptM, nCrv)
|
||||
local _, _, dParRef2 = EgtPointCurveDist( ptM, nCrv)
|
||||
EgtTrimCurveStartEndAtParam( nCrv, dParRef2, dParRef1)
|
||||
EgtTrimCurveStartEndAtParam( nLoopId, dPar2, dPar1)
|
||||
EgtInvertCurve( nLoopId)
|
||||
EgtAddCurveCompoLine( nCrv, EgtSP( nLoopId))
|
||||
EgtAddCurveCompoCurve( nCrv, nLoopId)
|
||||
EgtCloseCurveCompo( nCrv)
|
||||
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
|
||||
|
||||
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
|
||||
EgtErase( nSurf)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
+2
-2
@@ -1,4 +1,4 @@
|
||||
-- Version.lua by Egaltech s.r.l. 2024/02/13
|
||||
-- Version.lua by Egaltech s.r.l. 2025/09/12
|
||||
-- Gestione della versione di 3dPrinting
|
||||
|
||||
VERSION = '2.6b1'
|
||||
VERSION = '2.7j1'
|
||||
Reference in New Issue
Block a user