Compare commits
315 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| a813d5d742 | |||
| 93e92da027 | |||
| d862e8a2c5 | |||
| d79151c1d3 | |||
| 3d62e41811 | |||
| c796a5351f | |||
| 00d7dd2970 | |||
| eb09d0b65d | |||
| 0c7a7daba4 | |||
| 6f14e4f2c2 | |||
| 950060f4dc | |||
| 1007e08e9d | |||
| 04acc25535 | |||
| 38e26b9e48 | |||
| 72b7cbac1b | |||
| 5f1b863013 | |||
| 250802048a | |||
| a8d0bcfec4 | |||
| 459eff5610 | |||
| a749895229 | |||
| 04489421e7 | |||
| 0c16b5e969 | |||
| 9193924fbd | |||
| adbd5e944e | |||
| f76797cbd8 | |||
| 09e93d600d | |||
| 63f4df2a7d | |||
| 80c5035c74 | |||
| c9451e65e1 | |||
| 19706d6264 | |||
| 46ca7c793f | |||
| e26540193c | |||
| af107a780e | |||
| 4befa4eee3 | |||
| 07db2da825 | |||
| a4e6600510 | |||
| cb8465d977 | |||
| e867e1decf | |||
| 1cd697cf80 | |||
| 729143ce45 | |||
| 3f707396bb | |||
| 2b3a36a496 | |||
| d9e4285748 | |||
| 91d5b0ac84 | |||
| db5334217b | |||
| 54c835f717 | |||
| 86e2324856 | |||
| 36f4014969 | |||
| 7248c44406 | |||
| 044a074b76 | |||
| c0e3dab107 | |||
| 2b2157c971 | |||
| 8c697d73ac | |||
| c35d032da8 | |||
| 7447d3cc1b | |||
| bfdf80a44a | |||
| 3755521d2e | |||
| 104663a89a | |||
| e322c15099 | |||
| 5f55bc2f42 | |||
| 6c3a16d59c | |||
| 8218fcc438 | |||
| 6a83320321 | |||
| b8b5ab2a65 | |||
| e27998599b | |||
| a386c74516 | |||
| bb9dc261c1 | |||
| 0e2067e802 | |||
| 3008196992 | |||
| 876e45e1a4 | |||
| fa4d3ab9f6 | |||
| 4e6c38d82c | |||
| d3e1ac5805 | |||
| bc017d0de7 | |||
| 18e180cd12 | |||
| 6d8d32c9fb | |||
| 20074c6ea0 | |||
| 806864e360 | |||
| 052407a9be | |||
| b5660a8431 | |||
| 103d8d7eec | |||
| df47842888 | |||
| 5db475bcf7 | |||
| 010e1421c7 | |||
| e908562ab6 | |||
| aba4ebecc4 | |||
| a022ecbb7d | |||
| 605f0fcaf1 | |||
| 2676d67737 | |||
| ea64a9a3f4 | |||
| a996d4beb3 | |||
| 919f71481c | |||
| cac9ec767c | |||
| 85e6c3c86d | |||
| c548172635 | |||
| 9869d1a61e | |||
| e0c66df59b | |||
| c0156a4a97 | |||
| 93f1bc4d0d | |||
| adaeb1e19c | |||
| 2430b4e787 | |||
| b08710451a | |||
| 4adf62069f | |||
| b6e904845e | |||
| 118b9a88d2 | |||
| 73c86bd35f | |||
| d0283d7885 | |||
| 5de62b9563 | |||
| a7a9a23cf3 | |||
| 21fe8ca47d | |||
| 0f536b07c4 | |||
| 3e01fb36b0 | |||
| 3c4af3c335 | |||
| 9480453e57 | |||
| e98f924630 | |||
| eabbc883e4 | |||
| 8e19e87d3f | |||
| 0c4f57a90b | |||
| 77310576bd | |||
| 1e2f559937 | |||
| 6a6dc27560 | |||
| ab6ed79a0e | |||
| 7bb237f7d2 | |||
| 67bb55537e | |||
| 777179d1b2 | |||
| 06adbb0b5d | |||
| 872a3ec899 | |||
| 5dae07e2aa | |||
| fc26a8ad4a | |||
| ccf88745aa | |||
| 04046787e3 | |||
| a12aaf86bc | |||
| 70d16909f5 | |||
| b5145d4e99 | |||
| 5007cda21f | |||
| 76d03160c5 | |||
| 534302f48e | |||
| 60d73199e4 | |||
| 71a51e56e1 | |||
| bf9791ca9c | |||
| 249cb4eea5 | |||
| 46cda4d472 | |||
| 72b0e7f4a4 | |||
| 0e02959467 | |||
| b7837fe95c | |||
| d66eaf5322 | |||
| 05ecf76312 | |||
| 6e3a1ddc7a | |||
| df47691da1 | |||
| 8a2200e0de | |||
| 0136ccac19 | |||
| 7ee683aeb8 | |||
| e81d1aef66 | |||
| 5331466c4f | |||
| 7a972cccc8 | |||
| 2ed5af9661 | |||
| e25c24a33a | |||
| aeca298feb | |||
| a09565cfb7 | |||
| 862b375ee5 | |||
| a34147ce15 | |||
| cb3ad1d24c | |||
| 06e266226a | |||
| 74b40a6ad7 | |||
| ab7971e5f9 | |||
| e188753f49 | |||
| 9b12a74591 | |||
| e17e8189f7 | |||
| a5d4503180 | |||
| 41f92e9dd4 | |||
| c5a6300d15 | |||
| bf5c12ec8a | |||
| 777ba74e4d | |||
| 268e578125 | |||
| 13f0545ebe | |||
| 445a76f543 | |||
| 4b52653a2e | |||
| ced290604a | |||
| 2c68515b93 | |||
| b26ad523ab | |||
| cd346b8536 | |||
| 2853731c4c | |||
| d31efb1f2a | |||
| e1702d1263 | |||
| 236254fed6 | |||
| 82f20f3c87 | |||
| adc75c0504 | |||
| 761778b87c | |||
| 5fa40fad99 | |||
| 8e608bd623 | |||
| 60a1707d43 | |||
| 1848ed85d0 | |||
| 197673de11 | |||
| 19e1d4e760 | |||
| abb1509314 | |||
| b9e4d9b01f | |||
| fcb541175a | |||
| 99e0b9967e | |||
| b88caa12ab | |||
| 40912bb7b7 | |||
| 7d6903d181 | |||
| 43cf75d400 | |||
| 2fa3ea24a5 | |||
| c82a27ebae | |||
| a7df54d8d2 | |||
| e8d11f150e | |||
| 6d8bd01266 | |||
| 65a256ba7b | |||
| d403f9cfcf | |||
| 30cc274c2e | |||
| 6564bdc74f | |||
| 6cdf1583c0 | |||
| 5441ff7b50 | |||
| d03ed02b2c | |||
| 8c4000a74c | |||
| 4c48085e4f | |||
| 37265932e9 | |||
| 8f602fc10a | |||
| f7ef38162b | |||
| 1bc17e7bb7 | |||
| 4d545c38ea | |||
| 83b9b3858d | |||
| 0de82a5fd9 | |||
| 8dc16e1ed9 | |||
| 4500f96d6d | |||
| a9921f9b17 | |||
| 8c4f0e15de | |||
| 46802be7d8 | |||
| 0a77cc2e12 | |||
| 6d07e1638b | |||
| 09d3df0fe1 | |||
| 838671d968 | |||
| f286f50855 | |||
| ff2dff29ee | |||
| 28cdaff2d0 | |||
| 3c4d299c58 | |||
| f388cf47f3 | |||
| 38b1eba03e | |||
| 6caa4fb6b5 | |||
| c1b781c142 | |||
| c219a6842b | |||
| 677ff492e7 | |||
| e4ba021482 | |||
| 24218e8d8c | |||
| 739311a02b | |||
| 61ef5dd9ed | |||
| aed21e027c | |||
| 1c64f500b3 | |||
| 542c421ac8 | |||
| 95e6f49e4f | |||
| 4c19cc49e2 | |||
| 74681a1f1d | |||
| d7b88e738f | |||
| d4c9843597 | |||
| 077cb2c586 | |||
| 8e9de6026e | |||
| b382560cfa | |||
| 339c6acb37 | |||
| 570a65c7a1 | |||
| e18a816647 | |||
| d578194d43 | |||
| e0f20d19f0 | |||
| cff4ef0d47 | |||
| d9fb464066 | |||
| 9d6a5fb496 | |||
| c3fab404a5 | |||
| fa139c84f3 | |||
| ae6853cd3f | |||
| c0618cd628 | |||
| 524b6a470c | |||
| cd4aa8ee11 | |||
| 242f5f4516 | |||
| e6a3e0c519 | |||
| 640c8af05f | |||
| 48ceceb8e0 | |||
| 5165463dbd | |||
| 9e1d424bc7 | |||
| 15c96303de | |||
| 3211f21869 | |||
| 1f4fe3597b | |||
| 0749e56b9f | |||
| 7424bdc147 | |||
| a623072e89 | |||
| 7f15b08b20 | |||
| 82d4fadaaa | |||
| d9f4d0584a | |||
| 2e5b4c9976 | |||
| 511af04c8b | |||
| 8b1d38c451 | |||
| abe3465514 | |||
| fc753c47be | |||
| ad8a7bf73f | |||
| 4a21a4be36 | |||
| aafe565474 | |||
| b6ef0a8d7a | |||
| 779f2105ba | |||
| c2b9c4b19f | |||
| 8eadb81e91 | |||
| 2bac228fe9 | |||
| c312e72fd2 | |||
| fd4683e4fa | |||
| 70661aa3d2 | |||
| a82486e9fb | |||
| cd4a7d3b91 | |||
| 3764c58394 | |||
| e49b505fbe | |||
| 72c1eb81f3 | |||
| 037ac0d030 | |||
| f1b64b1496 | |||
| 69ab03f3ec | |||
| 3b86cd9633 | |||
| 56fc63d5ff | |||
| f27eeb9c3d | |||
| 5d603a57db | |||
| 6f45e63f11 |
+66
-6
@@ -101,6 +101,21 @@ local function WriteTimeToLogFile( dTime)
|
|||||||
hFile:close()
|
hFile:close()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Funzioni per riportare stato lavorazione o pezzo in nge
|
||||||
|
local function WriteErrToNge( nProcId, sErr, sMsg, sRot, sCutId, sTaskId)
|
||||||
|
EgtSetInfo( nProcId, 'STATUS.ERR', sErr)
|
||||||
|
EgtSetInfo( nProcId, 'STATUS.MSG', sMsg)
|
||||||
|
EgtSetInfo( nProcId, 'STATUS.ROT', sRot)
|
||||||
|
EgtSetInfo( nProcId, 'CUTID', sCutId)
|
||||||
|
EgtSetInfo( nProcId, 'TASKID', sTaskId)
|
||||||
|
end
|
||||||
|
local function WriteFallToNge( nPartId, sErr, sMsg, sCutId, sFall)
|
||||||
|
EgtSetInfo( nPartId, 'STATUS.ERR', sErr)
|
||||||
|
EgtSetInfo( nPartId, 'STATUS.MSG', sMsg)
|
||||||
|
EgtSetInfo( nPartId, 'CUTID', sCutId)
|
||||||
|
EgtSetInfo( nPartId, 'STATUS.FALL', sFall)
|
||||||
|
end
|
||||||
|
|
||||||
-- Funzione per gestire visualizzazione dopo errore
|
-- Funzione per gestire visualizzazione dopo errore
|
||||||
local function PostErrView( nErr, sMsg)
|
local function PostErrView( nErr, sMsg)
|
||||||
if nErr ~= 0 and ( BEAM.FLAG == 1 or BEAM.FLAG == 2) then
|
if nErr ~= 0 and ( BEAM.FLAG == 1 or BEAM.FLAG == 2) then
|
||||||
@@ -122,13 +137,25 @@ end
|
|||||||
-- Funzione per aggiornare dati ausiliari
|
-- Funzione per aggiornare dati ausiliari
|
||||||
local function UpdateAuxData( sAuxFile)
|
local function UpdateAuxData( sAuxFile)
|
||||||
local bModif = false
|
local bModif = false
|
||||||
|
local BtlInfoId = EgtGetFirstNameInGroup( GDB_ID.ROOT, 'BtlInfo') or GDB_ID.NULL
|
||||||
-- Se definito LOAD90, aggiorno
|
-- Se definito LOAD90, aggiorno
|
||||||
local sLoad90 = EgtGetStringFromIni( 'AuxData', 'LOAD90', '', sAuxFile)
|
local sLoad90 = EgtGetStringFromIni( 'AuxData', 'LOAD90', '', sAuxFile)
|
||||||
if sLoad90 ~= '' then
|
if sLoad90 ~= '' then
|
||||||
local BtlInfoId = EgtGetFirstNameInGroup( GDB_ID.ROOT, 'BtlInfo') or GDB_ID.NULL
|
|
||||||
EgtSetInfo( BtlInfoId, 'LOAD90', sLoad90)
|
EgtSetInfo( BtlInfoId, 'LOAD90', sLoad90)
|
||||||
bModif = true
|
bModif = true
|
||||||
end
|
end
|
||||||
|
-- Se definito PROJID, aggiorno
|
||||||
|
local sProjId = EgtGetStringFromIni( 'AuxData', 'PROJID', '', sAuxFile)
|
||||||
|
if sProjId ~= '' then
|
||||||
|
EgtSetInfo( BtlInfoId, 'PROJECTNUMBER', sProjId)
|
||||||
|
bModif = true
|
||||||
|
end
|
||||||
|
-- Se definito PRODID, aggiorno
|
||||||
|
local sProdId = EgtGetStringFromIni( 'AuxData', 'PRODID', '', sAuxFile)
|
||||||
|
if sProdId ~= '' then
|
||||||
|
EgtSetInfo( BtlInfoId, 'PRODID', sProdId)
|
||||||
|
bModif = true
|
||||||
|
end
|
||||||
return bModif
|
return bModif
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -401,6 +428,9 @@ if bToProcess then
|
|||||||
BEAM.CUTID = Stats[i].CutId
|
BEAM.CUTID = Stats[i].CutId
|
||||||
BEAM.TASKID = Stats[i].TaskId
|
BEAM.TASKID = Stats[i].TaskId
|
||||||
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
||||||
|
if Stats[i].ProcId then
|
||||||
|
WriteErrToNge( Stats[i].ProcId, BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
||||||
|
end
|
||||||
elseif Stats[i].Err > 0 then
|
elseif Stats[i].Err > 0 then
|
||||||
nErrCnt = nErrCnt + 1
|
nErrCnt = nErrCnt + 1
|
||||||
sOutput = sOutput .. string.format( '[%d,%d] %s\n', Stats[i].CutId, Stats[i].TaskId, sMsg)
|
sOutput = sOutput .. string.format( '[%d,%d] %s\n', Stats[i].CutId, Stats[i].TaskId, sMsg)
|
||||||
@@ -410,6 +440,9 @@ if bToProcess then
|
|||||||
BEAM.CUTID = Stats[i].CutId
|
BEAM.CUTID = Stats[i].CutId
|
||||||
BEAM.TASKID = Stats[i].TaskId
|
BEAM.TASKID = Stats[i].TaskId
|
||||||
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
||||||
|
if Stats[i].ProcId then
|
||||||
|
WriteErrToNge( Stats[i].ProcId, BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
||||||
|
end
|
||||||
elseif Stats[i].Err < 0 then
|
elseif Stats[i].Err < 0 then
|
||||||
-- se segnalazione scarico pezzo standard, incompleto o a caduta
|
-- se segnalazione scarico pezzo standard, incompleto o a caduta
|
||||||
if Stats[i].Err == -100 or Stats[i].Err == -101 or Stats[i].Err == -102 then
|
if Stats[i].Err == -100 or Stats[i].Err == -101 or Stats[i].Err == -102 then
|
||||||
@@ -418,6 +451,9 @@ if bToProcess then
|
|||||||
BEAM.CUTID = Stats[i].CutId
|
BEAM.CUTID = Stats[i].CutId
|
||||||
BEAM.FALL = abs( Stats[i].Err + 100)
|
BEAM.FALL = abs( Stats[i].Err + 100)
|
||||||
WriteFallToLogFile( BEAM.ERR, BEAM.MSG, BEAM.CUTID, BEAM.FALL)
|
WriteFallToLogFile( BEAM.ERR, BEAM.MSG, BEAM.CUTID, BEAM.FALL)
|
||||||
|
if Stats[i].ProcId then
|
||||||
|
WriteFallToNge( Stats[i].PartId, BEAM.ERR, BEAM.MSG, BEAM.CUTID, BEAM.FALL)
|
||||||
|
end
|
||||||
-- altri avvertimenti
|
-- altri avvertimenti
|
||||||
else
|
else
|
||||||
nWarnCnt = nWarnCnt + 1
|
nWarnCnt = nWarnCnt + 1
|
||||||
@@ -428,6 +464,9 @@ if bToProcess then
|
|||||||
BEAM.CUTID = Stats[i].CutId
|
BEAM.CUTID = Stats[i].CutId
|
||||||
BEAM.TASKID = Stats[i].TaskId
|
BEAM.TASKID = Stats[i].TaskId
|
||||||
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
||||||
|
if Stats[i].ProcId then
|
||||||
|
WriteErrToNge( Stats[i].ProcId, BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -443,35 +482,56 @@ if bToProcess then
|
|||||||
PostWarnView( 19, sOutput)
|
PostWarnView( 19, sOutput)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Altrimenti carico il progetto salvato e dichiaro nessun errore
|
-- Altrimenti carico il progetto salvato, rileggo gli errori da nge e riscrivo il log txt con gli stati precedenti
|
||||||
else
|
else
|
||||||
EgtOutLog( ' +++ Loading Project already processed >>>')
|
EgtOutLog( ' +++ Loading Project already processed >>>')
|
||||||
-- Carico il progetto già fatto
|
-- Carico il progetto già fatto
|
||||||
EgtOpenFile( sNgeFile)
|
EgtOpenFile( sNgeFile)
|
||||||
-- Dichiaro nessun errore
|
-- Riscrivo il log txt
|
||||||
local nPartId = EgtGetFirstPart()
|
local nPartId = EgtGetFirstPart()
|
||||||
while nPartId do
|
while nPartId do
|
||||||
local nCutId = EgtGetInfo( nPartId, 'CUTID')
|
local nCutId = EgtGetInfo( nPartId, 'CUTID')
|
||||||
if nCutId then
|
if nCutId then
|
||||||
|
-- stato a livello di singola feature
|
||||||
local nProcId = EgtGetFirstInGroup( EgtGetFirstNameInGroup( nPartId, 'Processings') or GDB_ID.NULL)
|
local nProcId = EgtGetFirstInGroup( EgtGetFirstNameInGroup( nPartId, 'Processings') or GDB_ID.NULL)
|
||||||
while nProcId do
|
while nProcId do
|
||||||
local bIsFea = EgtExistsInfo( nProcId, 'GRP') and EgtExistsInfo( nProcId, 'PRC')
|
local bIsFea = EgtExistsInfo( nProcId, 'GRP') and EgtExistsInfo( nProcId, 'PRC')
|
||||||
local nTaskId = EgtGetInfo( nProcId, 'TASKID')
|
local nTaskId = EgtGetInfo( nProcId, 'TASKID')
|
||||||
|
local sErr = EgtGetInfo( nProcId, 'STATUS.ERR') or 0
|
||||||
|
local sMsg = EgtGetInfo( nProcId, 'STATUS.MSG') or '---'
|
||||||
|
local sRot = EgtGetInfo( nProcId, 'STATUS.ROT') or 0
|
||||||
if bIsFea and nTaskId then
|
if bIsFea and nTaskId then
|
||||||
BEAM.ERR = 0
|
BEAM.ERR = sErr
|
||||||
BEAM.MSG = '---'
|
BEAM.MSG = sMsg
|
||||||
BEAM.ROT = 0
|
BEAM.ROT = sRot
|
||||||
BEAM.CUTID = nCutId
|
BEAM.CUTID = nCutId
|
||||||
BEAM.TASKID = nTaskId
|
BEAM.TASKID = nTaskId
|
||||||
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
WriteErrToLogFile( BEAM.ERR, BEAM.MSG, BEAM.ROT, BEAM.CUTID, BEAM.TASKID)
|
||||||
end
|
end
|
||||||
nProcId = EgtGetNext( nProcId)
|
nProcId = EgtGetNext( nProcId)
|
||||||
end
|
end
|
||||||
|
-- stato a livello di pezzo
|
||||||
|
local sErr = EgtGetInfo( nPartId, 'STATUS.ERR') or 0
|
||||||
|
if sErr == -100 or sErr == -101 or sErr == -102 then
|
||||||
|
local sMsg = EgtGetInfo( nPartId, 'STATUS.MSG') or '---'
|
||||||
|
local sFall = EgtGetInfo( nPartId, 'STATUS.FALL') or 0
|
||||||
|
BEAM.ERR = sErr
|
||||||
|
BEAM.MSG = sMsg
|
||||||
|
BEAM.CUTID = nCutId
|
||||||
|
BEAM.FALL = sFall
|
||||||
|
WriteFallToLogFile( BEAM.ERR, BEAM.MSG, BEAM.CUTID, BEAM.FALL)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
nPartId = EgtGetNextPart( nPartId)
|
nPartId = EgtGetNextPart( nPartId)
|
||||||
end
|
end
|
||||||
-- Aggiorno eventuali dati ausiliari
|
-- Aggiorno eventuali dati ausiliari
|
||||||
UpdateAuxData( sBtmFile)
|
UpdateAuxData( sBtmFile)
|
||||||
|
|
||||||
|
-- Anche se non è da riprocessare, imposto nome file CN.
|
||||||
|
-- Se file TS7 importato da altro PC, 'BEAM.FILE' è cambiato da un PC all'altro. Di conseguenza si deve aggiornare nome file che si andrà a generare.
|
||||||
|
local _, sName, _ = EgtSplitPath( BEAM.FILE)
|
||||||
|
EgtSetInfo( EgtGetLastMachGroup(), 'NcName', sName .. '.cnc')
|
||||||
|
|
||||||
-- Passo in modalità lavora
|
-- Passo in modalità lavora
|
||||||
EgtSetCurrMachGroup( EgtGetLastMachGroup())
|
EgtSetCurrMachGroup( EgtGetLastMachGroup())
|
||||||
-- Se necessario eseguo aggiornamento con setup corrente e ricalcolo delle lavorazioni
|
-- Se necessario eseguo aggiornamento con setup corrente e ricalcolo delle lavorazioni
|
||||||
|
|||||||
@@ -45,6 +45,7 @@ REM Compilazione 32 e 64 bit
|
|||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\ProcessText.lua -s LuaLibs\ProcessText.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\ProcessText.lua -s LuaLibs\ProcessText.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\ProcessTyroleanDovetail.lua -s LuaLibs\ProcessTyroleanDovetail.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\ProcessTyroleanDovetail.lua -s LuaLibs\ProcessTyroleanDovetail.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\LuaLibs\ProcessVariant.lua -s LuaLibs\ProcessVariant.lua
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\ProcessVariant.lua -s LuaLibs\ProcessVariant.lua
|
||||||
|
\EgtProg\Dll32\luac54 -o bin\LuaLibs\ProcessProbing.lua -s LuaLibs\ProcessProbing.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\BatchProcess.lua -s BatchProcess.lua
|
\EgtProg\Dll32\luac54 -o bin\BatchProcess.lua -s BatchProcess.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\BatchProcessNew.lua -s BatchProcessNew.lua
|
\EgtProg\Dll32\luac54 -o bin\BatchProcessNew.lua -s BatchProcessNew.lua
|
||||||
\EgtProg\Dll32\luac54 -o bin\GetBeamData.lua -s GetBeamData.lua
|
\EgtProg\Dll32\luac54 -o bin\GetBeamData.lua -s GetBeamData.lua
|
||||||
|
|||||||
+202
-46
@@ -108,6 +108,7 @@ _G.package.loaded.ProcessScarfJoint = nil
|
|||||||
_G.package.loaded.ProcessSimpleScarf = nil
|
_G.package.loaded.ProcessSimpleScarf = nil
|
||||||
_G.package.loaded.ProcessStepJoint = nil
|
_G.package.loaded.ProcessStepJoint = nil
|
||||||
_G.package.loaded.ProcessStepJointNotch = nil
|
_G.package.loaded.ProcessStepJointNotch = nil
|
||||||
|
_G.package.loaded.ProcessProbing = nil
|
||||||
_G.package.loaded.ProcessProfFront = nil
|
_G.package.loaded.ProcessProfFront = nil
|
||||||
_G.package.loaded.ProcessProfConcave = nil
|
_G.package.loaded.ProcessProfConcave = nil
|
||||||
_G.package.loaded.ProcessProfConvex = nil
|
_G.package.loaded.ProcessProfConvex = nil
|
||||||
@@ -395,6 +396,8 @@ local function CollectFeatures( PartId, b3Raw, dCurrOvmH, dCurrOvmT)
|
|||||||
Proc2.TaskId = Proc.TaskId
|
Proc2.TaskId = Proc.TaskId
|
||||||
Proc2.AdjId = Proc.AdjId
|
Proc2.AdjId = Proc.AdjId
|
||||||
Proc2.MainId = Proc.MainId
|
Proc2.MainId = Proc.MainId
|
||||||
|
-- recupero l'elenco delle facce della parte interessate dalla feature
|
||||||
|
Proc2.AffectedFaces = BL.GetProcessAffectedFaces( Proc2)
|
||||||
table.insert( vProc, Proc2)
|
table.insert( vProc, Proc2)
|
||||||
-- verifico se devo inserire i prefori
|
-- verifico se devo inserire i prefori
|
||||||
if Drill.IsPredrillNeeded( Proc2) then
|
if Drill.IsPredrillNeeded( Proc2) then
|
||||||
@@ -464,6 +467,7 @@ end
|
|||||||
local function AnalyzeHeadFeatures( b3Solid, vProc, dRawW, dRawH)
|
local function AnalyzeHeadFeatures( b3Solid, vProc, dRawW, dRawH)
|
||||||
local nReplacedFeatureId = nil
|
local nReplacedFeatureId = nil
|
||||||
local bHeadFinishingNeeded = true
|
local bHeadFinishingNeeded = true
|
||||||
|
local nCuttingFeatureId = nil
|
||||||
for i = 1, #vProc do
|
for i = 1, #vProc do
|
||||||
local Proc = vProc[i]
|
local Proc = vProc[i]
|
||||||
-- controllo se esiste già una feature taglio di testa
|
-- controllo se esiste già una feature taglio di testa
|
||||||
@@ -478,15 +482,19 @@ local function AnalyzeHeadFeatures( b3Solid, vProc, dRawW, dRawH)
|
|||||||
if Proc.Head and Proc.Id ~= nReplacedFeatureId and Proc.Prc ~= 340 then
|
if Proc.Head and Proc.Id ~= nReplacedFeatureId and Proc.Prc ~= 340 then
|
||||||
-- controllo se la feature taglia l'intera sezione; in caso positivo la finitura non è necessaria
|
-- controllo se la feature taglia l'intera sezione; in caso positivo la finitura non è necessaria
|
||||||
bHeadFinishingNeeded = not BL.IsFeatureCuttingEntireSection( Proc.Box, dRawW, dRawH)
|
bHeadFinishingNeeded = not BL.IsFeatureCuttingEntireSection( Proc.Box, dRawW, dRawH)
|
||||||
|
if not bHeadFinishingNeeded and ( ( Proc.Grp == 1 or Proc.Grp == 2) and Proc.Prc == 10) and ( Proc.Flg > 0) then
|
||||||
|
nCuttingFeatureId = Proc.Id
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return bHeadFinishingNeeded, nReplacedFeatureId
|
return bHeadFinishingNeeded, nReplacedFeatureId, nCuttingFeatureId
|
||||||
end
|
end
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
local function AnalyzeTailFeatures( b3Solid, vProc, dRawW, dRawH)
|
local function AnalyzeTailFeatures( b3Solid, vProc, dRawW, dRawH)
|
||||||
local nReplacedFeatureId = nil
|
local nReplacedFeatureId = nil
|
||||||
local bTailFinishingNeeded = true
|
local bTailFinishingNeeded = true
|
||||||
|
local nCuttingFeatureId = nil
|
||||||
for i = 1, #vProc do
|
for i = 1, #vProc do
|
||||||
local Proc = vProc[i]
|
local Proc = vProc[i]
|
||||||
-- controllo se esistè già una feature taglio di coda
|
-- controllo se esistè già una feature taglio di coda
|
||||||
@@ -501,9 +509,12 @@ local function AnalyzeTailFeatures( b3Solid, vProc, dRawW, dRawH)
|
|||||||
if Proc.Tail and Proc.Id ~= nReplacedFeatureId and Proc.Prc ~= 350 then
|
if Proc.Tail and Proc.Id ~= nReplacedFeatureId and Proc.Prc ~= 350 then
|
||||||
-- controllo se la feature taglia l'intera sezione; in caso positivo la finitura non è necessaria
|
-- controllo se la feature taglia l'intera sezione; in caso positivo la finitura non è necessaria
|
||||||
bTailFinishingNeeded = not BL.IsFeatureCuttingEntireSection( Proc.Box, dRawW, dRawH)
|
bTailFinishingNeeded = not BL.IsFeatureCuttingEntireSection( Proc.Box, dRawW, dRawH)
|
||||||
|
if not bTailFinishingNeeded and ( ( Proc.Grp == 1 or Proc.Grp == 2) and Proc.Prc == 10) and ( Proc.Flg > 0) then
|
||||||
|
nCuttingFeatureId = Proc.Id
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return bTailFinishingNeeded, nReplacedFeatureId
|
return bTailFinishingNeeded, nReplacedFeatureId, nCuttingFeatureId
|
||||||
end
|
end
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
@@ -597,6 +608,17 @@ function BeamExec.ProcessBeams( dRawW, dRawH, dRawL, dOvmHead, dOvmMid, vBeam, b
|
|||||||
local b3Part = EgtGetBBoxGlob( Pz or GDB_ID.NULL, GDB_BB.EXACT)
|
local b3Part = EgtGetBBoxGlob( Pz or GDB_ID.NULL, GDB_BB.EXACT)
|
||||||
local b3Solid = vBeam[i].Box
|
local b3Solid = vBeam[i].Box
|
||||||
if b3Part:isEmpty() or b3Solid:isEmpty() then break end
|
if b3Part:isEmpty() or b3Solid:isEmpty() then break end
|
||||||
|
-- analizzo le features per valutare l'esistenza di feature head/tail che renderebbero inutili le rispettive finiture o di tagli di testa/coda sostituiti da cui leggere il parametro Q05
|
||||||
|
local vProc = CollectFeatures( Pz, b3Solid, 0)
|
||||||
|
local bSFinishingNeeded, nReplacedHeadCutFeatureId, nHeadCuttingFeatureId = AnalyzeHeadFeatures( b3Solid, vProc, dRawW, dRawH)
|
||||||
|
local bEFinishingNeeded, nReplacedTailCutFeatureId, nTailCuttingFeatureId = AnalyzeTailFeatures( b3Solid, vProc, dRawW, dRawH)
|
||||||
|
-- Scrivo gli di delle facce di taglio custom: serviranno dopo per calcolare l'elevazione rispetto a queste
|
||||||
|
if nHeadCuttingFeatureId then
|
||||||
|
EgtSetInfo( vBeam[i].Id, 'HEADCUTFEATUREID', nHeadCuttingFeatureId)
|
||||||
|
end
|
||||||
|
if nTailCuttingFeatureId then
|
||||||
|
EgtSetInfo( vBeam[i].Id, 'TAILCUTFEATUREID', nTailCuttingFeatureId)
|
||||||
|
end
|
||||||
if bBigSectionCut then
|
if bBigSectionCut then
|
||||||
-- lascio in coda solo il materiale necessario; il resto verrà tolto nell'head cut successivo
|
-- lascio in coda solo il materiale necessario; il resto verrà tolto nell'head cut successivo
|
||||||
local lastB3Solid = nil
|
local lastB3Solid = nil
|
||||||
@@ -609,9 +631,6 @@ function BeamExec.ProcessBeams( dRawW, dRawH, dRawL, dOvmHead, dOvmMid, vBeam, b
|
|||||||
dOffset = dOvmMid
|
dOffset = dOvmMid
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- analizzo le features per valutare l'esistenza di feature head/tail che renderebbero inutili le rispettive finiture o di tagli di testa/coda sostituiti da cui leggere il parametro Q05
|
|
||||||
local vProc = CollectFeatures( Pz, b3Solid, 0)
|
|
||||||
local bSFinishingNeeded, nReplacedHeadCutFeatureId = AnalyzeHeadFeatures( b3Solid, vProc, dRawW, dRawH)
|
|
||||||
local iSQ05Value = nil
|
local iSQ05Value = nil
|
||||||
if nReplacedHeadCutFeatureId then
|
if nReplacedHeadCutFeatureId then
|
||||||
iSQ05Value = EgtGetInfo( nReplacedHeadCutFeatureId, 'Q05', 'i')
|
iSQ05Value = EgtGetInfo( nReplacedHeadCutFeatureId, 'Q05', 'i')
|
||||||
@@ -621,7 +640,6 @@ function BeamExec.ProcessBeams( dRawW, dRawH, dRawL, dOvmHead, dOvmMid, vBeam, b
|
|||||||
else
|
else
|
||||||
DeltaSMin = BD.OVM_BLADE_HBEAM
|
DeltaSMin = BD.OVM_BLADE_HBEAM
|
||||||
end
|
end
|
||||||
local bEFinishingNeeded, nReplacedTailCutFeatureId = AnalyzeTailFeatures( b3Solid, vProc, dRawW, dRawH)
|
|
||||||
local iEQ05Value = nil
|
local iEQ05Value = nil
|
||||||
if nReplacedTailCutFeatureId then
|
if nReplacedTailCutFeatureId then
|
||||||
iEQ05Value = EgtGetInfo( nReplacedTailCutFeatureId, 'Q05', 'i')
|
iEQ05Value = EgtGetInfo( nReplacedTailCutFeatureId, 'Q05', 'i')
|
||||||
@@ -777,7 +795,82 @@ local function PrintFeatures( vProc, b3Raw)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
local function OrderFeatures( vProc, b3Raw)
|
-- mi assicuro che i tagli di testa e coda troncanti (usati per ridurre i percorsi utensile in testa e coda) siano sempre fatti per primi
|
||||||
|
local function ReorderTruncatingCuts( vProc, nPartId)
|
||||||
|
if not nPartId or #vProc == 0 then return end
|
||||||
|
|
||||||
|
local nHeadCuttingFeatureId = EgtGetInfo( nPartId, 'HEADCUTFEATUREID', 'i')
|
||||||
|
local nTailCuttingFeatureId = EgtGetInfo( nPartId, 'TAILCUTFEATUREID', 'i')
|
||||||
|
|
||||||
|
-- tagli di testa
|
||||||
|
-- 1: si trovano gli indici del taglio di testa e del rispettivo taglio troncante
|
||||||
|
local nHeadCutIndex, nHeadCuttingFeatureIndex
|
||||||
|
for index, value in ipairs( vProc) do
|
||||||
|
if value.Prc == 340 then
|
||||||
|
nHeadCutIndex = index
|
||||||
|
end
|
||||||
|
if value.Id == nHeadCuttingFeatureId then
|
||||||
|
nHeadCuttingFeatureIndex = index
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- 2: se non c'è il taglio di testa, il taglio troncante è il primo. Se c'è il taglio di testa, il taglio troncante lo deve seguire.
|
||||||
|
if not nHeadCutIndex and nHeadCuttingFeatureIndex then
|
||||||
|
local HeadCuttingFeature = vProc[ nHeadCuttingFeatureIndex]
|
||||||
|
table.remove( vProc, nHeadCuttingFeatureIndex)
|
||||||
|
table.insert( vProc, 1, HeadCuttingFeature)
|
||||||
|
elseif nHeadCutIndex and nHeadCuttingFeatureIndex then
|
||||||
|
if abs( nHeadCutIndex - nHeadCuttingFeatureIndex) ~= 1 then
|
||||||
|
local HeadCut = vProc[ nHeadCutIndex]
|
||||||
|
local HeadCuttingFeature = vProc[ nHeadCuttingFeatureIndex]
|
||||||
|
|
||||||
|
table.remove( vProc, nHeadCutIndex)
|
||||||
|
-- rimuovere il primo potrebbe aver cambiato l'indice del secondo
|
||||||
|
if nHeadCutIndex < nHeadCuttingFeatureIndex then
|
||||||
|
nHeadCuttingFeatureIndex = nHeadCuttingFeatureIndex - 1
|
||||||
|
end
|
||||||
|
table.remove( vProc, nHeadCuttingFeatureIndex)
|
||||||
|
|
||||||
|
table.insert( vProc, nHeadCutIndex, HeadCut)
|
||||||
|
table.insert( vProc, nHeadCutIndex + 1, HeadCuttingFeature)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- tagli di coda
|
||||||
|
-- 1: si trovano gli indici del taglio di coda e del rispettivo taglio troncante
|
||||||
|
local nTailCutIndex, nTailCuttingFeatureIndex
|
||||||
|
for index, value in ipairs( vProc) do
|
||||||
|
if value.Prc == 350 then
|
||||||
|
nTailCutIndex = index
|
||||||
|
end
|
||||||
|
if value.Id == nTailCuttingFeatureId then
|
||||||
|
nTailCuttingFeatureIndex = index
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- 2: il taglio di coda c'è sempre. Il taglio troncante lo deve seguire.
|
||||||
|
if nTailCutIndex and nTailCuttingFeatureIndex then
|
||||||
|
if abs( nTailCutIndex - nTailCuttingFeatureIndex) ~= 1 then
|
||||||
|
local TailCut = vProc[ nTailCutIndex]
|
||||||
|
local TailCuttingFeature = vProc[ nTailCuttingFeatureIndex]
|
||||||
|
|
||||||
|
table.remove( vProc, nTailCutIndex)
|
||||||
|
-- rimuovere il primo potrebbe aver cambiato l'indice del secondo
|
||||||
|
if nTailCutIndex < nTailCuttingFeatureIndex then
|
||||||
|
nTailCuttingFeatureIndex = nTailCuttingFeatureIndex - 1
|
||||||
|
end
|
||||||
|
table.remove( vProc, nTailCuttingFeatureIndex)
|
||||||
|
|
||||||
|
table.insert( vProc, nTailCutIndex, TailCut)
|
||||||
|
table.insert( vProc, nTailCutIndex + 1, TailCuttingFeature)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------------------------------------
|
||||||
|
local function OrderFeatures( vProc, b3Raw, nPartId)
|
||||||
|
|
||||||
local dDrillPenalty = EgtIf( BD.PRESS_ROLLER, 200, 100)
|
local dDrillPenalty = EgtIf( BD.PRESS_ROLLER, 200, 100)
|
||||||
local dSmallDrillRange = EgtIf( b3Raw:getDimX() < BD.LEN_SHORT_PART, BD.DRILL_RANGE_SP or 200, BD.DRILL_RANGE or 600)
|
local dSmallDrillRange = EgtIf( b3Raw:getDimX() < BD.LEN_SHORT_PART, BD.DRILL_RANGE_SP or 200, BD.DRILL_RANGE or 600)
|
||||||
@@ -835,13 +928,13 @@ local function OrderFeatures( vProc, b3Raw)
|
|||||||
if B2.AdvTail and ( not Split.Identify( B1) or not B1.Tail) then
|
if B2.AdvTail and ( not Split.Identify( B1) or not B1.Tail) then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
-- se primo è foro e secondo è un ribasso, il foro va sempre prima a meno che il ribasso non sia di testa
|
-- se primo è foro e secondo è un ribasso o tenone, il foro va sempre prima a meno che il ribasso non sia di testa
|
||||||
if Drill.Identify(B1) and ( LapJoint.Identify(B2) or Mortise.Identify(B2)) and B2.PassedByHole and
|
if Drill.Identify(B1) and ( LapJoint.Identify(B2) or Mortise.Identify(B2) or Tenon.Identify(B2)) and B2.PassedByHole and
|
||||||
B1.Box:getCenter():getX() > B2.Box:getMin():getX() and B1.Box:getCenter():getX() < B2.Box:getMax():getX() then
|
B1.Box:getCenter():getX() > B2.Box:getMin():getX() and B1.Box:getCenter():getX() < B2.Box:getMax():getX() then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
-- se primo è un ribasso e secondo è un foro, il ribasso va sempre dopo a meno che il ribasso non sia di testa
|
-- se primo è un ribasso e secondo è un foro o tenone, il ribasso va sempre dopo a meno che il ribasso non sia di testa
|
||||||
if ( LapJoint.Identify(B1) or Mortise.Identify(B1))and B1.PassedByHole and Drill.Identify(B2) and
|
if ( LapJoint.Identify(B1) or Mortise.Identify(B1) or Tenon.Identify(B1)) and B1.PassedByHole and Drill.Identify(B2) and
|
||||||
B2.Box:getCenter():getX() > B1.Box:getMin():getX() and B2.Box:getCenter():getX() < B1.Box:getMax():getX() then
|
B2.Box:getCenter():getX() > B1.Box:getMin():getX() and B2.Box:getCenter():getX() < B1.Box:getMax():getX() then
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
@@ -898,12 +991,12 @@ local function OrderFeatures( vProc, b3Raw)
|
|||||||
if abs( B2.Box:getDimX() - b3Raw:getDimX()) < 0.2 * b3Raw:getDimX() then
|
if abs( B2.Box:getDimX() - b3Raw:getDimX()) < 0.2 * b3Raw:getDimX() then
|
||||||
return not ( B1.Tail or B2.Box:getMin():getX() + 20 > B1.Box:getCenter():getX())
|
return not ( B1.Tail or B2.Box:getMin():getX() + 20 > B1.Box:getCenter():getX())
|
||||||
end
|
end
|
||||||
-- se primo è foro e l'altro no, lo penalizzo
|
-- se primo è foro e l'altro no, lo penalizzo (a patto che il foro non attraversi nessuna feature)
|
||||||
if Drill.Identify(B1) and not Drill.Identify(B2) then
|
if Drill.Identify(B1) and not B1.Dependency and not Drill.Identify(B2) then
|
||||||
return ( B1.Box:getCenter():getX() > B2.Box:getMax():getX() + dDrillPenalty)
|
return ( B1.Box:getCenter():getX() > B2.Box:getMax():getX() + dDrillPenalty)
|
||||||
end
|
end
|
||||||
-- se primo è altro e secondo è foro, lo premio
|
-- se primo è altro e secondo è foro, lo premio (a patto che il foro non attraversi nessuna feature)
|
||||||
if not Drill.Identify(B1) and Drill.Identify(B2) then
|
if not Drill.Identify(B1) and not B2.Dependency and Drill.Identify(B2) then
|
||||||
return ( B1.Box:getMax():getX() + dDrillPenalty > B2.Box:getCenter():getX())
|
return ( B1.Box:getMax():getX() + dDrillPenalty > B2.Box:getCenter():getX())
|
||||||
end
|
end
|
||||||
-- se prima è mortasa coda di rondine sul fianco e secondo taglio longitudinale, la coda di rondine va sempre prima
|
-- se prima è mortasa coda di rondine sul fianco e secondo taglio longitudinale, la coda di rondine va sempre prima
|
||||||
@@ -1096,6 +1189,8 @@ local function OrderFeatures( vProc, b3Raw)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
ReorderTruncatingCuts( vProc, nPartId)
|
||||||
end
|
end
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
@@ -1221,7 +1316,7 @@ local function ClassifyFeatures( vProc, b3Raw, Stats)
|
|||||||
bOk, bDown, bSide = ProfHead.Classify( Proc, b3Raw)
|
bOk, bDown, bSide = ProfHead.Classify( Proc, b3Raw)
|
||||||
-- se contorno libero
|
-- se contorno libero
|
||||||
elseif FreeContour.Identify( Proc) then
|
elseif FreeContour.Identify( Proc) then
|
||||||
bOk, bDown, bSide = FreeContour.Classify( Proc, b3Raw)
|
bOk, bDown, bSide, bDownSideOnHeadOk = FreeContour.Classify( Proc, b3Raw)
|
||||||
-- se decorazione
|
-- se decorazione
|
||||||
elseif Decor.Identify( Proc) then
|
elseif Decor.Identify( Proc) then
|
||||||
bOk, bDown = Decor.Classify( Proc)
|
bOk, bDown = Decor.Classify( Proc)
|
||||||
@@ -1231,12 +1326,12 @@ local function ClassifyFeatures( vProc, b3Raw, Stats)
|
|||||||
end
|
end
|
||||||
-- assegno risultato
|
-- assegno risultato
|
||||||
if bOk then
|
if bOk then
|
||||||
-- non ammessa feature di testa da lavorare ribaltata o ruotata
|
-- non ammessa feature di testa da lavorare ribaltata o ruotata (lettura laser)
|
||||||
if Proc.Head and ( bDown or bSide) and not bDownSideOnHeadOk then
|
if Proc.Head and ( bDown or bSide) and not bDownSideOnHeadOk then
|
||||||
Proc.Flg = 0
|
Proc.Flg = 0
|
||||||
Proc.Down = true
|
Proc.Down = true
|
||||||
bAllOk = false
|
bAllOk = false
|
||||||
table.insert( Stats, {Err = 1, Msg='Error : impossible to machine by orientation', CutId=Proc.CutId, TaskId=Proc.TaskId})
|
table.insert( Stats, {Err = 1, Msg='Error : impossible to machine by orientation', CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id})
|
||||||
-- gestione feature di coda da lavorare ribaltata
|
-- gestione feature di coda da lavorare ribaltata
|
||||||
elseif Proc.Tail and bDown then
|
elseif Proc.Tail and bDown then
|
||||||
Proc.Down = true
|
Proc.Down = true
|
||||||
@@ -1257,12 +1352,12 @@ local function ClassifyFeatures( vProc, b3Raw, Stats)
|
|||||||
elseif Proc.Flg == 0 then
|
elseif Proc.Flg == 0 then
|
||||||
bAllOk = false
|
bAllOk = false
|
||||||
Proc.ErrMsg = 'Error : out of the part'
|
Proc.ErrMsg = 'Error : out of the part'
|
||||||
table.insert( Stats, {Err = 1, Msg=Proc.ErrMsg, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
table.insert( Stats, {Err = 1, Msg=Proc.ErrMsg, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id})
|
||||||
else
|
else
|
||||||
Proc.Flg = 0
|
Proc.Flg = 0
|
||||||
bAllOk = false
|
bAllOk = false
|
||||||
if not Proc.ErrMsg then Proc.ErrMsg = 'Error : impossible to machine' end
|
if not Proc.ErrMsg then Proc.ErrMsg = 'Error : impossible to machine' end
|
||||||
table.insert( Stats, {Err = 1, Msg=Proc.ErrMsg, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
table.insert( Stats, {Err = 1, Msg=Proc.ErrMsg, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- se necessario ribaltamento, assegno intestatura alla fase ribaltata
|
-- se necessario ribaltamento, assegno intestatura alla fase ribaltata
|
||||||
@@ -1824,7 +1919,10 @@ local function VerifyDrillMirrored( Proc, vProc, b3Raw)
|
|||||||
sDrilling, sType, dMaxDepth = ML.FindDrilling( dDiam, 0, true, false, true)
|
sDrilling, sType, dMaxDepth = ML.FindDrilling( dDiam, 0, true, false, true)
|
||||||
dMachiningDepth = dMaxDepth or dMachiningDepth
|
dMachiningDepth = dMaxDepth or dMachiningDepth
|
||||||
end
|
end
|
||||||
if not sDrilling or ( sType ~= 'Drill' and sType ~= 'Pocket') or not EgtMdbSetCurrMachining( sDrilling) then
|
if not sDrilling
|
||||||
|
or ( sType ~= 'Drill' and ( sType ~= 'Pocket'or ( Proc.Fcs ~= 0 and Proc.Fce ~= 0)))
|
||||||
|
or not EgtMdbSetCurrMachining( sDrilling) then
|
||||||
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local dDrillingStep = EgtMdbGetCurrMachiningParam( MCH_MP.STEP)
|
local dDrillingStep = EgtMdbGetCurrMachiningParam( MCH_MP.STEP)
|
||||||
@@ -1858,10 +1956,16 @@ local function VerifyDrillMirrored( Proc, vProc, b3Raw)
|
|||||||
( BD.DOWN_HEAD and AreOppositeVectorApprox( vtExtr, Y_AX())) then
|
( BD.DOWN_HEAD and AreOppositeVectorApprox( vtExtr, Y_AX())) then
|
||||||
Proc.Double = 2
|
Proc.Double = 2
|
||||||
Proc.MachDepthDouble = dMachiningDepth
|
Proc.MachDepthDouble = dMachiningDepth
|
||||||
|
Proc.MirrorId = ProcToDisable.Id
|
||||||
|
Proc.MirrorCutId = ProcToDisable.CutId
|
||||||
|
Proc.MirrorTaskId = ProcToDisable.TaskId
|
||||||
DisableOtherDrilling( ProcToDisable, vProc)
|
DisableOtherDrilling( ProcToDisable, vProc)
|
||||||
elseif BD.DOWN_HEAD and AreSameVectorApprox( vtExtr, Z_AX()) then
|
elseif BD.DOWN_HEAD and AreSameVectorApprox( vtExtr, Z_AX()) then
|
||||||
Proc.Double = 3
|
Proc.Double = 3
|
||||||
Proc.MachDepthDouble = dMachiningDepth
|
Proc.MachDepthDouble = dMachiningDepth
|
||||||
|
Proc.MirrorId = ProcToDisable.Id
|
||||||
|
Proc.MirrorCutId = ProcToDisable.CutId
|
||||||
|
Proc.MirrorTaskId = ProcToDisable.TaskId
|
||||||
DisableOtherDrilling( ProcToDisable, vProc)
|
DisableOtherDrilling( ProcToDisable, vProc)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -2009,7 +2113,7 @@ local function AreDrillingsMirrored( Proc, ProcMirror, b3Raw)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
function GetFeatureInfoAndDependency( vProc, b3Raw)
|
function GetFeatureInfoAndDependency( vProc, b3Raw, nPartId)
|
||||||
-- ciclo tutte le feature
|
-- ciclo tutte le feature
|
||||||
for i = 1, #vProc do
|
for i = 1, #vProc do
|
||||||
local Proc = vProc[i]
|
local Proc = vProc[i]
|
||||||
@@ -2026,14 +2130,21 @@ function GetFeatureInfoAndDependency( vProc, b3Raw)
|
|||||||
local ProcB = vProc[j]
|
local ProcB = vProc[j]
|
||||||
-- verifico se feature tipo LapJoint è attraversata da almeno un foro
|
-- verifico se feature tipo LapJoint è attraversata da almeno un foro
|
||||||
if ( Proc.Topology == 'Pocket' or Proc.Topology == 'Tunnel' or Proc.Topology == 'Groove' or Mortise.Identify( Proc)) and Drill.Identify( ProcB) and Overlaps( Proc.Box, ProcB.Box) then
|
if ( Proc.Topology == 'Pocket' or Proc.Topology == 'Tunnel' or Proc.Topology == 'Groove' or Mortise.Identify( Proc)) and Drill.Identify( ProcB) and Overlaps( Proc.Box, ProcB.Box) then
|
||||||
Proc.PassedByHole = true
|
-- se foro in coda non setto la dipendenza
|
||||||
ProcB.Dependency = {}
|
if not ProcB.AffectedFaces.Left then
|
||||||
ProcB.Dependency.ExecBefore = Proc
|
Proc.PassedByHole = true
|
||||||
|
ProcB.Dependency = {}
|
||||||
|
ProcB.Dependency.ExecBefore = Proc
|
||||||
|
end
|
||||||
end
|
end
|
||||||
-- verifico se feature tipo LapJoint è attraversata da almeno una mortasa a coda di rondine
|
-- verifico se feature tipo LapJoint è attraversata da almeno una mortasa a coda di rondine
|
||||||
if ( Proc.Topology == 'Pocket' or Proc.Topology == 'Tunnel' or Proc.Topology == 'Groove') and DtMortise.SideIdentify( ProcB) and Overlaps( Proc.Box, ProcB.Box) then
|
if ( Proc.Topology == 'Pocket' or Proc.Topology == 'Tunnel' or Proc.Topology == 'Groove') and DtMortise.SideIdentify( ProcB) and Overlaps( Proc.Box, ProcB.Box) then
|
||||||
Proc.PassedByDtMortise = true
|
Proc.PassedByDtMortise = true
|
||||||
end
|
end
|
||||||
|
-- se tenone è attraversato da foro allora il foro deve essere fatto prima
|
||||||
|
if Tenon.Identify( Proc) and Drill.Identify( ProcB) and Overlaps( Proc.Box, ProcB.Box) then
|
||||||
|
Proc.PassedByHole = true
|
||||||
|
end
|
||||||
-- verifiche per specchiature
|
-- verifiche per specchiature
|
||||||
if BD.DOWN_HEAD or BD.TWO_EQUAL_HEADS then
|
if BD.DOWN_HEAD or BD.TWO_EQUAL_HEADS then
|
||||||
-- forature
|
-- forature
|
||||||
@@ -2043,6 +2154,22 @@ function GetFeatureInfoAndDependency( vProc, b3Raw)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
-- verifiche per tagli troncanti testa e coda: devono sempre essere subito dopo il taglio di testa e il taglio di coda, rispettivamente
|
||||||
|
local nHeadCuttingFeatureId = EgtGetInfo( nPartId, 'HEADCUTFEATUREID', 'i')
|
||||||
|
local nTailCuttingFeatureId = EgtGetInfo( nPartId, 'TAILCUTFEATUREID', 'i')
|
||||||
|
if Proc.Prc == 340 and ProcB == nHeadCuttingFeatureId then
|
||||||
|
Proc.Dependency = {}
|
||||||
|
Proc.Dependency.ExecBefore = ProcB
|
||||||
|
elseif Proc == nHeadCuttingFeatureId and ProcB.Prc == 340 then
|
||||||
|
ProcB.Dependency = {}
|
||||||
|
ProcB.Dependency.ExecBefore = Proc
|
||||||
|
elseif Proc.Prc == 350 and ProcB == nTailCuttingFeatureId then
|
||||||
|
Proc.Dependency = {}
|
||||||
|
Proc.Dependency.ExecBefore = ProcB
|
||||||
|
elseif Proc == nTailCuttingFeatureId and ProcB.Prc == 350 then
|
||||||
|
ProcB.Dependency = {}
|
||||||
|
ProcB.Dependency.ExecBefore = Proc
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -2054,7 +2181,7 @@ function BeamExec.ProcessFeatures()
|
|||||||
end
|
end
|
||||||
-- costanti per doppio
|
-- costanti per doppio
|
||||||
MIRROR_DRILLINGS_MIN_DISTANCE = 40
|
MIRROR_DRILLINGS_MIN_DISTANCE = 40
|
||||||
MIRROR_POCKETS_MIN_DISTANCE = 50
|
MIRROR_POCKETS_MIN_DISTANCE = EgtIf( BD.DOWN_HEAD, 35, 50)
|
||||||
-- verifica se possibile rotazione di 90 gradi
|
-- verifica se possibile rotazione di 90 gradi
|
||||||
BD.ROT90 = BD.ROT90 and Verify90DegRotation( EgtGetFirstRawPart())
|
BD.ROT90 = BD.ROT90 and Verify90DegRotation( EgtGetFirstRawPart())
|
||||||
-- ciclo sui pezzi
|
-- ciclo sui pezzi
|
||||||
@@ -2084,7 +2211,7 @@ function BeamExec.ProcessFeatures()
|
|||||||
-- recupero le feature di lavorazione della trave
|
-- recupero le feature di lavorazione della trave
|
||||||
local vProc = CollectFeatures( nPartId, b3Raw, dCurrOvmH, dCurrOvmT)
|
local vProc = CollectFeatures( nPartId, b3Raw, dCurrOvmH, dCurrOvmT)
|
||||||
-- recupero informazioni ausiliarie feature e dipendenze tra feature stesse
|
-- recupero informazioni ausiliarie feature e dipendenze tra feature stesse
|
||||||
GetFeatureInfoAndDependency( vProc, b3Raw)
|
GetFeatureInfoAndDependency( vProc, b3Raw, nPartId)
|
||||||
|
|
||||||
-- verifica presenza forature influenzate da lavorazioni di testa o coda
|
-- verifica presenza forature influenzate da lavorazioni di testa o coda
|
||||||
if BD.IMPROVE_HEAD_TAIL_DRILLINGS then
|
if BD.IMPROVE_HEAD_TAIL_DRILLINGS then
|
||||||
@@ -2096,7 +2223,7 @@ function BeamExec.ProcessFeatures()
|
|||||||
SetMirroredFeatures( vProc, b3Raw)
|
SetMirroredFeatures( vProc, b3Raw)
|
||||||
end
|
end
|
||||||
-- le ordino lungo X
|
-- le ordino lungo X
|
||||||
OrderFeatures( vProc, b3Raw)
|
OrderFeatures( vProc, b3Raw, nPartId)
|
||||||
-- le classifico
|
-- le classifico
|
||||||
local bAllOk, bSomeDown, bSomeSide, bSplitRot = ClassifyFeatures( vProc, b3Raw, Stats)
|
local bAllOk, bSomeDown, bSomeSide, bSplitRot = ClassifyFeatures( vProc, b3Raw, Stats)
|
||||||
if not bAllOk then
|
if not bAllOk then
|
||||||
@@ -2107,6 +2234,17 @@ function BeamExec.ProcessFeatures()
|
|||||||
PrintFeatures( vProc, b3Raw)
|
PrintFeatures( vProc, b3Raw)
|
||||||
end
|
end
|
||||||
EgtOutLog( ' *** AddMachinings ***', 1)
|
EgtOutLog( ' *** AddMachinings ***', 1)
|
||||||
|
-- scrivo nel RawPart se ci sono feature lavorate con trave ruotata a 90 o 180 deg
|
||||||
|
if bSomeSide then
|
||||||
|
EgtSetInfo( nRawId, 'ROTATE90', 1)
|
||||||
|
else
|
||||||
|
EgtSetInfo( nRawId, 'ROTATE90', 0)
|
||||||
|
end
|
||||||
|
if bSomeDown then
|
||||||
|
EgtSetInfo( nRawId, 'ROTATE180', 1)
|
||||||
|
else
|
||||||
|
EgtSetInfo( nRawId, 'ROTATE180', 0)
|
||||||
|
end
|
||||||
-- verifico se comunque necessario taglio di testa
|
-- verifico se comunque necessario taglio di testa
|
||||||
local bNeedHCut = VerifyNeedForHeadCut( vProc, bSomeDown, bSomeSide)
|
local bNeedHCut = VerifyNeedForHeadCut( vProc, bSomeDown, bSomeSide)
|
||||||
-- inserisco corrispondenze di tagli coincidenti con mortase normali o a coda di rondine di testa
|
-- inserisco corrispondenze di tagli coincidenti con mortase normali o a coda di rondine di testa
|
||||||
@@ -2149,13 +2287,19 @@ function BeamExec.ProcessFeatures()
|
|||||||
end
|
end
|
||||||
if not bOk then
|
if not bOk then
|
||||||
nTotErr = nTotErr + 1
|
nTotErr = nTotErr + 1
|
||||||
table.insert( Stats, {Err=1, Msg=sMsg, Rot=-2, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
table.insert( Stats, {Err=1, Msg=sMsg, Rot=-2, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
elseif sMsg and #sMsg > 0 then
|
|
||||||
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=-2, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
|
||||||
else
|
|
||||||
table.insert( Stats, {Err=0, Msg='', Rot=-2, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
|
||||||
if Proc.Double == 2 or Proc.Double == 3 then
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
table.insert( Stats, {Err=0, Msg='', Rot=-2, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId})
|
table.insert( Stats, {Err=1, Msg=sMsg, Rot=-2, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
|
end
|
||||||
|
elseif sMsg and #sMsg > 0 then
|
||||||
|
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=-2, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
|
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=-2, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
table.insert( Stats, {Err=0, Msg='', Rot=-2, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
|
table.insert( Stats, {Err=0, Msg='', Rot=-2, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- se è taglio di separazione, verifico se ha già aggiunto una nuova fase oppure se è da creare
|
-- se è taglio di separazione, verifico se ha già aggiunto una nuova fase oppure se è da creare
|
||||||
@@ -2239,13 +2383,19 @@ function BeamExec.ProcessFeatures()
|
|||||||
end
|
end
|
||||||
if not bOk then
|
if not bOk then
|
||||||
nTotErr = nTotErr + 1
|
nTotErr = nTotErr + 1
|
||||||
table.insert( Stats, {Err=1, Msg=sMsg, Rot=-1, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
table.insert( Stats, {Err=1, Msg=sMsg, Rot=-1, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
elseif sMsg and #sMsg > 0 then
|
|
||||||
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=-1, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
|
||||||
else
|
|
||||||
table.insert( Stats, {Err=0, Msg='', Rot=-1, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
|
||||||
if Proc.Double == 2 or Proc.Double == 3 then
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
table.insert( Stats, {Err=0, Msg='', Rot=-1, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId})
|
table.insert( Stats, {Err=1, Msg=sMsg, Rot=-1, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
|
end
|
||||||
|
elseif sMsg and #sMsg > 0 then
|
||||||
|
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=-1, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
|
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=-1, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
table.insert( Stats, {Err=0, Msg='', Rot=-1, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
|
table.insert( Stats, {Err=0, Msg='', Rot=-1, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if bOk then nSideMchOk = nSideMchOk + 1 end
|
if bOk then nSideMchOk = nSideMchOk + 1 end
|
||||||
@@ -2317,13 +2467,19 @@ function BeamExec.ProcessFeatures()
|
|||||||
end
|
end
|
||||||
if not bOk then
|
if not bOk then
|
||||||
nTotErr = nTotErr + 1
|
nTotErr = nTotErr + 1
|
||||||
table.insert( Stats, {Err=1, Msg=sMsg, Rot=0, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
table.insert( Stats, {Err=1, Msg=sMsg, Rot=0, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
elseif sMsg and #sMsg > 0 then
|
|
||||||
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=0, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
|
||||||
else
|
|
||||||
table.insert( Stats, {Err=0, Msg='', Rot=0, CutId=Proc.CutId, TaskId=Proc.TaskId})
|
|
||||||
if Proc.Double == 2 or Proc.Double == 3 then
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
table.insert( Stats, {Err=0, Msg='', Rot=0, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId})
|
table.insert( Stats, {Err=1, Msg=sMsg, Rot=0, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
|
end
|
||||||
|
elseif sMsg and #sMsg > 0 then
|
||||||
|
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=0, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
|
table.insert( Stats, {Err=-1, Msg=sMsg, Rot=0, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
|
end
|
||||||
|
else
|
||||||
|
table.insert( Stats, {Err=0, Msg='', Rot=0, CutId=Proc.CutId, TaskId=Proc.TaskId, ProcId = Proc.Id, PartId = nPartId})
|
||||||
|
if Proc.Double == 2 or Proc.Double == 3 then
|
||||||
|
table.insert( Stats, {Err=0, Msg='', Rot=0, CutId=Proc.MirrorCutId, TaskId=Proc.MirrorTaskId, ProcId = Proc.MirrorId, PartId = nPartId})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- se era taglio di separazione, aggiungo nuova fase
|
-- se era taglio di separazione, aggiungo nuova fase
|
||||||
|
|||||||
+103
-3
@@ -551,7 +551,7 @@ function BeamLib.GetFaceWithMostAdj( Proc, nPartId, bCompare3Fc, dCosSideAng)
|
|||||||
local nAddGrpId = BeamLib.GetAddGroup( nPartId)
|
local nAddGrpId = BeamLib.GetAddGroup( nPartId)
|
||||||
if not nAddGrpId then
|
if not nAddGrpId then
|
||||||
EgtOutLog( 'Error : missing AddGroup')
|
EgtOutLog( 'Error : missing AddGroup')
|
||||||
return 0, 0, 0
|
return 0, 0, 0, 0
|
||||||
end
|
end
|
||||||
-- verifico eventuale intersezione tra la faccia i-1 esima e la proiezione dell'altra sulla stessa
|
-- verifico eventuale intersezione tra la faccia i-1 esima e la proiezione dell'altra sulla stessa
|
||||||
local nShadowFacetId = EgtCopySurfTmFacet( nSurfId, j - 1, nAddGrpId)
|
local nShadowFacetId = EgtCopySurfTmFacet( nSurfId, j - 1, nAddGrpId)
|
||||||
@@ -642,7 +642,7 @@ function BeamLib.GetFaceWithMostAdj( Proc, nPartId, bCompare3Fc, dCosSideAng)
|
|||||||
-- premio quella che non è sottosquadra e che ha la X minore
|
-- premio quella che non è sottosquadra e che ha la X minore
|
||||||
local bDiffSmall = true
|
local bDiffSmall = true
|
||||||
for i = 1, #dtElev do
|
for i = 1, #dtElev do
|
||||||
if dtElev[i] > dMinElev + 5 or dtElev[i] > 80 then
|
if ( dtElev[i] > dMinElev + 5 or dtElev[i] > 80) and dMinElev < 0.85 * dtElev[i] then
|
||||||
bDiffSmall = false
|
bDiffSmall = false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -899,6 +899,27 @@ function BeamLib.FindFaceBestOrientedAsAxis( Proc, vtAx, fctExclude)
|
|||||||
return nFaceIndMax, ptC, vtN
|
return nFaceIndMax, ptC, vtN
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
function BeamLib.GetEdgeToMachineFromVector( nSurfId, nFacet, vtOrtho)
|
||||||
|
local _, EdgesEgt = EgtSurfTmGetFacetOutlineInfo( nSurfId, nFacet, GDB_ID.ROOT)
|
||||||
|
|
||||||
|
local nEdgeIndMax = 0
|
||||||
|
local dMaxComp = - GEO.INFINITO
|
||||||
|
for i = 1, #EdgesEgt do
|
||||||
|
local vtN = EdgesEgt[i].Norm
|
||||||
|
if EdgesEgt[i].Open then
|
||||||
|
vtN = -vtN
|
||||||
|
end
|
||||||
|
local dComp = vtN * vtOrtho
|
||||||
|
if dComp > dMaxComp then
|
||||||
|
nEdgeIndMax = i -1
|
||||||
|
dMaxComp = dComp
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return nEdgeIndMax
|
||||||
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
function BeamLib.GetTunnelDimension( Proc, nPartId)
|
function BeamLib.GetTunnelDimension( Proc, nPartId)
|
||||||
-- sono necessarie almeno due facce
|
-- sono necessarie almeno due facce
|
||||||
@@ -1168,7 +1189,7 @@ end
|
|||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
-- restituisce vero se la feature con box b3Proc taglia l'intera sezione della barra, rappresentata dalle sue dimensioni W e H
|
-- restituisce vero se la feature con box b3Proc taglia l'intera sezione della barra, rappresentata dalle sue dimensioni W e H
|
||||||
function BeamLib.IsFeatureCuttingEntireSection( b3Proc, dRawW, dRawH)
|
function BeamLib.IsFeatureCuttingEntireSection( b3Proc, dRawW, dRawH)
|
||||||
return ((abs(b3Proc:getDimY() - dRawW) < 10 * GEO.EPS_SMALL or b3Proc:getDimY() > dRawW) and (abs(b3Proc:getDimZ() - dRawH) < 10 * GEO.EPS_SMALL or b3Proc:getDimZ() > dRawH))
|
return ( b3Proc:getDimY() > ( dRawW - 500 * GEO.EPS_SMALL) and b3Proc:getDimZ() > ( dRawH - 500 * GEO.EPS_SMALL))
|
||||||
end
|
end
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
@@ -1239,6 +1260,40 @@ function BeamLib.GetFacetsInfo( Proc, b3Raw)
|
|||||||
return Face
|
return Face
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
function BeamLib.GetEdgesInfo( Proc, Face)
|
||||||
|
local Edges = {}
|
||||||
|
local nFaceType, vEdges = EgtSurfTmGetFacetOutlineInfo( Proc.Id, Face.Id, GDB_ID.ROOT)
|
||||||
|
|
||||||
|
if nFaceType < 1 then
|
||||||
|
for j = 1, #vEdges do
|
||||||
|
local nPreviousEdgeIndex = j - 1
|
||||||
|
if j == 1 then
|
||||||
|
nPreviousEdgeIndex = #vEdges
|
||||||
|
end
|
||||||
|
local nNextEdgeIndex = j + 1
|
||||||
|
if j == #vEdges then
|
||||||
|
nNextEdgeIndex = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
local CurrentEdge = {}
|
||||||
|
CurrentEdge.AdjacentFaceId = vEdges[j].Adj
|
||||||
|
CurrentEdge.ToolDirection = Vector3d( vEdges[j].Norm)
|
||||||
|
CurrentEdge.Length = vEdges[j].Len
|
||||||
|
CurrentEdge.Elevation = vEdges[j].Elev
|
||||||
|
CurrentEdge.IsOpen = vEdges[j].Open
|
||||||
|
CurrentEdge.IsStartOpen = ( vEdges[nPreviousEdgeIndex].Open)
|
||||||
|
CurrentEdge.IsEndOpen = ( vEdges[nNextEdgeIndex].Open)
|
||||||
|
|
||||||
|
table.insert( Edges, CurrentEdge)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
error( 'Face with closed hole')
|
||||||
|
end
|
||||||
|
|
||||||
|
return Edges
|
||||||
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- restituisce la matrice delle adiacenze di Proc dove i e j sono le facce e a(ij) è l'angolo tra di esse; 0 se nessuna adiacenza
|
-- restituisce la matrice delle adiacenze di Proc dove i e j sono le facce e a(ij) è l'angolo tra di esse; 0 se nessuna adiacenza
|
||||||
function BeamLib.GetAdjacencyMatrix( Proc)
|
function BeamLib.GetAdjacencyMatrix( Proc)
|
||||||
@@ -1301,5 +1356,50 @@ function BeamLib.IsCutNeeded( Proc, b3Raw, dOvmHead, dOvmTail)
|
|||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-------------------------------------------------------------------------------------------------------------
|
||||||
|
function BeamLib.GetToolFromMachining( sMachiningName)
|
||||||
|
local Tool = {}
|
||||||
|
if EgtMdbSetCurrMachining( sMachiningName) then
|
||||||
|
local sTuuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
||||||
|
if EgtTdbSetCurrTool( EgtTdbGetToolFromUUID( sTuuid) or '') then
|
||||||
|
Tool.Name = EgtTdbGetCurrToolParam( MCH_TP.NAME)
|
||||||
|
Tool.IsCCW = ( EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) < 0)
|
||||||
|
Tool.Type = EgtTdbGetCurrToolParam( MCH_TP.TYPE)
|
||||||
|
Tool.Diameter = EgtTdbGetCurrToolParam( MCH_TP.DIAM) or 0
|
||||||
|
Tool.HeadType = {}
|
||||||
|
Tool.PreferredSide = {}
|
||||||
|
if BD.GetSetupInfo then
|
||||||
|
Tool.HeadType = BD.GetSetupInfo( EgtTdbGetCurrToolParam( MCH_TP.HEAD)).HeadType
|
||||||
|
Tool.PreferredSide = BD.GetSetupInfo( EgtTdbGetCurrToolParam( MCH_TP.HEAD)).PreferredSide
|
||||||
|
end
|
||||||
|
-- lama
|
||||||
|
if Tool.Type == MCH_TY.SAW_STD or Tool.Type == MCH_TY.SAW_FLAT then
|
||||||
|
Tool.Thickness = EgtTdbGetCurrToolParam(MCH_TP.THICK) or 0
|
||||||
|
Tool.MaxDepth = EgtTdbGetCurrToolMaxDepth() or 0
|
||||||
|
Tool.SideStep = EgtTdbGetCurrToolValInNotes( MCH_TP.USERNOTES, 'SIDESTEP', 'd')
|
||||||
|
-- sega a catena
|
||||||
|
elseif Tool.Type == MCH_TY.MORTISE_STD then
|
||||||
|
Tool.Length = EgtTdbGetCurrToolParam( MCH_TP.LEN) or 0
|
||||||
|
Tool.MaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT) or 0
|
||||||
|
Tool.Width = EgtTdbGetCurrToolParam( MCH_TP.DIAM) or 0
|
||||||
|
Tool.Thickness = EgtTdbGetCurrToolParam( MCH_TP.THICK) or 0
|
||||||
|
Tool.CornerRadius = EgtTdbGetCurrToolParam( MCH_TP.CORNRAD) or 0
|
||||||
|
-- fresa (TODO al momento aggiunte solo le informazioni che servono)
|
||||||
|
elseif Tool.Type == MCH_TY.MILL_STD or MCH_TY.MILL_NOTIP then
|
||||||
|
if BD.GetSetupInfo then
|
||||||
|
Tool.IsOnAggregate = BD.GetSetupInfo( EgtTdbGetCurrToolParam( MCH_TP.HEAD)).bToolOnAggregate
|
||||||
|
else
|
||||||
|
Tool.IsOnAggregate = false
|
||||||
|
end
|
||||||
|
-- altri utensili al momento non previsti
|
||||||
|
else
|
||||||
|
error( 'Wrong tool type')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return Tool
|
||||||
|
end
|
||||||
|
|
||||||
-------------------------------------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------------------------------------
|
||||||
return BeamLib
|
return BeamLib
|
||||||
+5
-2
@@ -275,12 +275,15 @@ local function VerifyFirstOrthoCut( CutTable, OffsetP, BBoxRawPart, dNzLimDwnUp)
|
|||||||
-- normale alla faccia ortogonale
|
-- normale alla faccia ortogonale
|
||||||
local _, vtO = EgtSurfTmFacetCenter( CutOId, 0, GDB_ID.ROOT)
|
local _, vtO = EgtSurfTmFacetCenter( CutOId, 0, GDB_ID.ROOT)
|
||||||
vtO = vtO - vtO * vtN1 * vtN1 ; vtO:normalize()
|
vtO = vtO - vtO * vtN1 * vtN1 ; vtO:normalize()
|
||||||
|
local dMaxElev = EgtSurfTmFacetElevationInBBox( CutOId, 0, BBoxRawPart, true, GDB_ID.ROOT)
|
||||||
-- calcolo lunghezza prima semi-faccia
|
-- calcolo lunghezza prima semi-faccia
|
||||||
local asseX1 = vtO
|
local asseX1 = vtO
|
||||||
local asseY1 = vtN1 ^ asseX1
|
local asseY1 = vtN1 ^ asseX1
|
||||||
local Frame1 = Frame3d( ptC1, ptC1+asseX1, ptC1+asseY1)
|
local Frame1 = Frame3d( ptC1, ptC1+asseX1, ptC1+asseY1)
|
||||||
local Box1 = EgtGetBBoxRef( Cut1Id, GDB_BB.STANDARD, Frame1)
|
local Box1 = EgtGetBBoxRef( Cut1Id, GDB_BB.STANDARD, Frame1)
|
||||||
local x1 = Box1:getDimX()
|
local x1 = Box1:getDimX()
|
||||||
|
-- prendo il massimo tra la lugnhezza della faccia parallela e l'elevazione della corrispondente ortogonale
|
||||||
|
x1 = max( x1, dMaxElev)
|
||||||
-- calcolo lunghezza seconda semi-faccia
|
-- calcolo lunghezza seconda semi-faccia
|
||||||
local asseX2 = vtO
|
local asseX2 = vtO
|
||||||
local asseY2 = vtN2 ^ asseX2
|
local asseY2 = vtN2 ^ asseX2
|
||||||
@@ -404,7 +407,7 @@ function DiceCut.GetDice( nParent, BBoxRawPart, ptCPlanes, vtNPlanes, bGetOrtoPl
|
|||||||
local dNzLimDwnUp = BL.GetNzLimDownUp( BBoxRawPart)
|
local dNzLimDwnUp = BL.GetNzLimDownUp( BBoxRawPart)
|
||||||
|
|
||||||
-- se non c'è testa da sotto e normali senza componenti in Y con faccia quasi verticale e trave non alta, uso per offset i limiti dei tagli di testa e coda
|
-- se non c'è testa da sotto e normali senza componenti in Y con faccia quasi verticale e trave non alta, uso per offset i limiti dei tagli di testa e coda
|
||||||
if not BD.DOWN_HEAD and abs( vtNPlanes:getY()) < 0.1 and vtNPlanes:getZ() < 0.7071 and ( not vtNBond or abs( vtNBond:getY()) < 0.1) and BBoxRawPart:getDimZ() < BD.MIN_DIM_HBEAM then
|
if not BD.TURN and not BD.DOWN_HEAD and abs( vtNPlanes:getY()) < 0.1 and vtNPlanes:getZ() < 0.7071 and ( not vtNBond or abs( vtNBond:getY()) < 0.1) and BBoxRawPart:getDimZ() < BD.MIN_DIM_HBEAM then
|
||||||
OffsetO = dOrthoMaxDim or BD.MAX_DIM_HTCUT
|
OffsetO = dOrthoMaxDim or BD.MAX_DIM_HTCUT
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -563,7 +566,7 @@ function DiceCut.GetDice( nParent, BBoxRawPart, ptCPlanes, vtNPlanes, bGetOrtoPl
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return UltimateTable
|
return UltimateTable, OffsetP, OffsetO
|
||||||
end
|
end
|
||||||
|
|
||||||
----------------------------------------------------------------------------------------------------------------------------------------------------
|
----------------------------------------------------------------------------------------------------------------------------------------------------
|
||||||
|
|||||||
+113
-22
@@ -46,7 +46,7 @@ local BD = require( 'BeamData')
|
|||||||
local ML = require( 'MachiningLib')
|
local ML = require( 'MachiningLib')
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
function MakeParallelOne( nSurfId, nFacet, sCutting, dSawDiam, nFaceUse, dVzLimDwnUp, dCutExtra, dCutSic, dCutOffset, dAccStart, dAccEnd, sNotes, b3Raw, bForceInvert, bForceTangentLeadInOut)
|
function MakeParallelOne( nSurfId, nFacet, sCutting, dSawDiam, nFaceUse, dVzLimDwnUp, dCutExtra, dCutSic, dCutOffset, dAccStart, dAccEnd, sNotes, b3Raw, bForceInvert, sLeadInOutType, dActualElevation)
|
||||||
EgtOutLog( 'FacesBySaw.MakeParallelOne', 3)
|
EgtOutLog( 'FacesBySaw.MakeParallelOne', 3)
|
||||||
-- dati della faccia
|
-- dati della faccia
|
||||||
local ptC, vtN = EgtSurfTmFacetCenter( nSurfId, nFacet, GDB_ID.ROOT)
|
local ptC, vtN = EgtSurfTmFacetCenter( nSurfId, nFacet, GDB_ID.ROOT)
|
||||||
@@ -68,16 +68,28 @@ function MakeParallelOne( nSurfId, nFacet, sCutting, dSawDiam, nFaceUse, dVzLimD
|
|||||||
local dLiPerp = dDistX + dCutExtra + dCutSic
|
local dLiPerp = dDistX + dCutExtra + dCutSic
|
||||||
local dLoTang = dLiTang
|
local dLoTang = dLiTang
|
||||||
local dLoPerp = dLiPerp
|
local dLoPerp = dLiPerp
|
||||||
|
local dLiCompLength = 0
|
||||||
|
local dLoCompLength = 0
|
||||||
-- lunghezza attacco/uscita tangenti
|
-- lunghezza attacco/uscita tangenti
|
||||||
local dLi2Tang = dSawDiam / 2 + dCutSic
|
local dLi2Tang = dSawDiam / 2 + dCutSic
|
||||||
local dLi2Perp = 0
|
local dLi2Perp = 0
|
||||||
local dLo2Tang = dLi2Tang
|
local dLo2Tang = dLi2Tang
|
||||||
local dLo2Perp = dLi2Perp
|
local dLo2Perp = dLi2Perp
|
||||||
|
local dLi2CompLength = 0
|
||||||
|
local dLo2CompLength = 0
|
||||||
-- scelgo l'attacco più conveniente
|
-- scelgo l'attacco più conveniente
|
||||||
local bLioTang
|
local bLioTang
|
||||||
local Ktp = 1.1
|
local Ktp = 1.1
|
||||||
if BD.KIOTP then Ktp = BD.KIOTP end
|
if BD.KIOTP then Ktp = BD.KIOTP end
|
||||||
if bForceTangentLeadInOut or ( Ktp * dLi2Tang < dLiPerp) then
|
if ( sLeadInOutType == 'PerpendicularOutraw') then
|
||||||
|
bLioTang = false
|
||||||
|
dLiCompLength = dActualElevation + EgtMdbGetGeneralParam( MCH_GP.SAFEZ)
|
||||||
|
dLoCompLength = dActualElevation + EgtMdbGetGeneralParam( MCH_GP.SAFEZ)
|
||||||
|
dLiTang = 1
|
||||||
|
dLoTang = 1
|
||||||
|
dLiPerp = 0
|
||||||
|
dLoPerp = 0
|
||||||
|
elseif ( sLeadInOutType ~= 'Perpendicular') and ( ( sLeadInOutType == 'Tangent') or ( Ktp * dLi2Tang < dLiPerp)) then
|
||||||
bLioTang = true
|
bLioTang = true
|
||||||
dLiTang, dLiPerp, dLoTang, dLoPerp = dLi2Tang, dLi2Perp, dLo2Tang, dLo2Perp
|
dLiTang, dLiPerp, dLoTang, dLoPerp = dLi2Tang, dLi2Perp, dLo2Tang, dLo2Perp
|
||||||
if BD.TURN then
|
if BD.TURN then
|
||||||
@@ -136,9 +148,11 @@ function MakeParallelOne( nSurfId, nFacet, sCutting, dSawDiam, nFaceUse, dVzLimD
|
|||||||
-- imposto attacco/uscita
|
-- imposto attacco/uscita
|
||||||
EgtSetMachiningParam( MCH_MP.LITANG, dLiTang)
|
EgtSetMachiningParam( MCH_MP.LITANG, dLiTang)
|
||||||
EgtSetMachiningParam( MCH_MP.LIPERP, dLiPerp)
|
EgtSetMachiningParam( MCH_MP.LIPERP, dLiPerp)
|
||||||
|
EgtSetMachiningParam( MCH_MP.LICOMPLEN, dLiCompLength)
|
||||||
if BD.TURN and bLioTang then EgtSetMachiningParam( MCH_MP.LEADOUTTYPE, MCH_MILL_LO.PERP_TG) end
|
if BD.TURN and bLioTang then EgtSetMachiningParam( MCH_MP.LEADOUTTYPE, MCH_MILL_LO.PERP_TG) end
|
||||||
EgtSetMachiningParam( MCH_MP.LOTANG, dLoTang)
|
EgtSetMachiningParam( MCH_MP.LOTANG, dLoTang)
|
||||||
EgtSetMachiningParam( MCH_MP.LOPERP, dLoPerp)
|
EgtSetMachiningParam( MCH_MP.LOPERP, dLoPerp)
|
||||||
|
EgtSetMachiningParam( MCH_MP.LOCOMPLEN, dLoCompLength)
|
||||||
-- imposto allungamenti iniziale e finale
|
-- imposto allungamenti iniziale e finale
|
||||||
EgtSetMachiningParam( MCH_MP.STARTADDLEN, -dAccStart)
|
EgtSetMachiningParam( MCH_MP.STARTADDLEN, -dAccStart)
|
||||||
EgtSetMachiningParam( MCH_MP.ENDADDLEN, -dAccEnd)
|
EgtSetMachiningParam( MCH_MP.ENDADDLEN, -dAccEnd)
|
||||||
@@ -157,6 +171,9 @@ function MakeParallelOne( nSurfId, nFacet, sCutting, dSawDiam, nFaceUse, dVzLimD
|
|||||||
local vtOut = EgtIf( vtN:getX() > 0, X_AX(), -X_AX())
|
local vtOut = EgtIf( vtN:getX() > 0, X_AX(), -X_AX())
|
||||||
EgtSetMachiningParam( MCH_MP.BLOCKEDAXIS, BL.GetBlockedAxis( sCutting, 'perpendicular', b3Raw, vtTool, vtOut))
|
EgtSetMachiningParam( MCH_MP.BLOCKEDAXIS, BL.GetBlockedAxis( sCutting, 'perpendicular', b3Raw, vtTool, vtOut))
|
||||||
-- eventuali note
|
-- eventuali note
|
||||||
|
if ( sLeadInOutType == 'PerpendicularOutraw') then
|
||||||
|
sNotes = EgtSetValInNotes( sNotes, 'OutRaw', 3)
|
||||||
|
end
|
||||||
if sNotes and #sNotes > 0 then EgtSetMachiningParam( MCH_MP.USERNOTES, sNotes) end
|
if sNotes and #sNotes > 0 then EgtSetMachiningParam( MCH_MP.USERNOTES, sNotes) end
|
||||||
-- eseguo
|
-- eseguo
|
||||||
if not ML.ApplyMachining( true, false) then
|
if not ML.ApplyMachining( true, false) then
|
||||||
@@ -193,7 +210,28 @@ local function GetNameSolidFaceIncludingLine( b3Solid, ptP1Comp, ptP2Comp)
|
|||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDwnUp, dCutExtra, dCutSic, dCutOffset, dAccStart, dAccEnd, sNotes, b3Raw, bForceInvert, bMaximizeVerticalDepth, bSpecialTangentLeadInOut, bForceTangentLeadInOut, Par5Alternative)
|
local function AreSameOrOppositeDirApprox( vDir1, vDir2)
|
||||||
|
if abs( abs( vDir1) - abs( vDir2)) < 10 * GEO.EPS_SMALL then
|
||||||
|
return true
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
local function GetEdgeToMachineFromVector( nSurfId, nFacet, vtOrthO)
|
||||||
|
local _, EdgesEgt = EgtSurfTmGetFacetOutlineInfo( nSurfId, nFacet, GDB_ID.ROOT)
|
||||||
|
|
||||||
|
for i = 1, #EdgesEgt do
|
||||||
|
if AreOppositeVectorApprox( EdgesEgt[i].Norm, vtOrthO) then
|
||||||
|
return ( i - 1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDwnUp, dCutExtra, dCutSic, dCutOffset, dAccStart, dAccEnd, sNotes, b3Raw, bForceInvert, bMaximizeVerticalDepth, bSpecialTangentLeadInOut, sLeadInOutType, Par5Alternative, dActualElevation)
|
||||||
-- se lama con asse parallelo alla faccia, passo alla apposita funzione
|
-- se lama con asse parallelo alla faccia, passo alla apposita funzione
|
||||||
if ( Par5 == MCH_MILL_FU.PARAL_DOWN or
|
if ( Par5 == MCH_MILL_FU.PARAL_DOWN or
|
||||||
Par5 == MCH_MILL_FU.PARAL_TOP or
|
Par5 == MCH_MILL_FU.PARAL_TOP or
|
||||||
@@ -201,7 +239,7 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
Par5 == MCH_MILL_FU.PARAL_BACK or
|
Par5 == MCH_MILL_FU.PARAL_BACK or
|
||||||
Par5 == MCH_MILL_FU.PARAL_LEFT or
|
Par5 == MCH_MILL_FU.PARAL_LEFT or
|
||||||
Par5 == MCH_MILL_FU.PARAL_RIGHT) then
|
Par5 == MCH_MILL_FU.PARAL_RIGHT) then
|
||||||
return MakeParallelOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDwnUp, dCutExtra, dCutSic, dCutOffset, dAccStart, dAccEnd, sNotes, b3Raw, bForceInvert, bForceTangentLeadInOut)
|
return MakeParallelOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDwnUp, dCutExtra, dCutSic, dCutOffset, dAccStart, dAccEnd, sNotes, b3Raw, bForceInvert, sLeadInOutType, dActualElevation)
|
||||||
end
|
end
|
||||||
-- la lama ha asse perpendicolare alla faccia
|
-- la lama ha asse perpendicolare alla faccia
|
||||||
EgtOutLog( 'FacesBySaw.MakeOne', 3)
|
EgtOutLog( 'FacesBySaw.MakeOne', 3)
|
||||||
@@ -233,8 +271,9 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
if not dVzLimDwnUp then dVzLimDwnUp = BL.GetNzLimDownUp( b3Raw, vtN, vtOrthO) end
|
if not dVzLimDwnUp then dVzLimDwnUp = BL.GetNzLimDownUp( b3Raw, vtN, vtOrthO) end
|
||||||
local bDownHead = ( dVzLimDwnUp and dVzLimDwnUp < - 1.5)
|
local bDownHead = ( dVzLimDwnUp and dVzLimDwnUp < - 1.5)
|
||||||
local bDownUp = ( vtN:getZ() < dVzLimDwnUp)
|
local bDownUp = ( vtN:getZ() < dVzLimDwnUp)
|
||||||
-- linea o bilinea di lavorazione
|
|
||||||
local ptP1, ptPm, ptP2, vtV1, vtV2, dLen, dWidth = EgtSurfTmFacetOppositeSide( nSurfId, nFacet, vtOrthO, GDB_ID.ROOT)
|
local ptP1, ptPm, ptP2, vtV1, vtV2, dLen, dWidth = EgtSurfTmFacetOppositeSide( nSurfId, nFacet, vtOrthO, GDB_ID.ROOT)
|
||||||
|
|
||||||
|
|
||||||
if not dLen or dLen < 1.1 or not dWidth or dWidth < 1.1 then
|
if not dLen or dLen < 1.1 or not dWidth or dWidth < 1.1 then
|
||||||
local sWarn = 'Face ' .. string.format( '%d,%d', nSurfId, nFacet) .. ' skipped : too small'
|
local sWarn = 'Face ' .. string.format( '%d,%d', nSurfId, nFacet) .. ' skipped : too small'
|
||||||
EgtOutLog( sWarn, 1)
|
EgtOutLog( sWarn, 1)
|
||||||
@@ -246,6 +285,12 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
local bIsSawCCW = ( EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) < 0)
|
local bIsSawCCW = ( EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) < 0)
|
||||||
|
-- se settato nelle note lavorazione si lavora in discordanza
|
||||||
|
EgtMdbSetCurrMachining( sCutting)
|
||||||
|
local sMachiningNotes = EgtMdbGetCurrMachiningParam( MCH_MP.USERNOTES) or ''
|
||||||
|
if ( EgtGetValInNotes( sMachiningNotes, 'PATHINVERT', 'd') or 0) == 1 then
|
||||||
|
bIsSawCCW = not bIsSawCCW
|
||||||
|
end
|
||||||
local bInvert = bForceInvert
|
local bInvert = bForceInvert
|
||||||
-- l'inversione può essere comandata da rotazione lama (direzione concorde, legata anche a DownUp) oppure da direzione Z del percorso (si preferisce lavorare dal basso verso l'alto per limitare le corse)
|
-- l'inversione può essere comandata da rotazione lama (direzione concorde, legata anche a DownUp) oppure da direzione Z del percorso (si preferisce lavorare dal basso verso l'alto per limitare le corse)
|
||||||
-- se c'è disaccordo tra rotazione e direzione si cambia il lato di lavoro, se possibile. Se ciò non è possbile comanda la direzione. Se percorso orizzontale comanda la rotazione.
|
-- se c'è disaccordo tra rotazione e direzione si cambia il lato di lavoro, se possibile. Se ciò non è possbile comanda la direzione. Se percorso orizzontale comanda la rotazione.
|
||||||
@@ -309,7 +354,7 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
bIsBiLinea = true
|
bIsBiLinea = true
|
||||||
local vtTg1 = ptPm - ptP1 ; vtTg1:normalize()
|
local vtTg1 = ptPm - ptP1 ; vtTg1:normalize()
|
||||||
local vtTg2 = ptP2 - ptPm ; vtTg2:normalize()
|
local vtTg2 = ptP2 - ptPm ; vtTg2:normalize()
|
||||||
local dCosMax = 0.951 -- cos( 18°)
|
local dCosMax = 0.966 -- cos( 15°)
|
||||||
local dLenMin = 30
|
local dLenMin = 30
|
||||||
local dLenMax = max( 0.5 * dSawDiam * 0.17365 + 1, 2 * dLenMin)
|
local dLenMax = max( 0.5 * dSawDiam * 0.17365 + 1, 2 * dLenMin)
|
||||||
dCosAngleL1L2 = vtTg1 * vtTg2
|
dCosAngleL1L2 = vtTg1 * vtTg2
|
||||||
@@ -367,6 +412,7 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
local dLenLi = sqrt( dLiTang * dLiTang + dLiPerp * dLiPerp)
|
local dLenLi = sqrt( dLiTang * dLiTang + dLiPerp * dLiPerp)
|
||||||
local dLenLo = sqrt( dLoTang * dLoTang + dLoPerp * dLoPerp)
|
local dLenLo = sqrt( dLoTang * dLoTang + dLoPerp * dLoPerp)
|
||||||
local dLiCompLength = 0
|
local dLiCompLength = 0
|
||||||
|
local dLoCompLength = 0
|
||||||
-- attacco tangente
|
-- attacco tangente
|
||||||
local dLi2Tang = 0
|
local dLi2Tang = 0
|
||||||
local dLi2Perp = 0
|
local dLi2Perp = 0
|
||||||
@@ -388,6 +434,7 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
end
|
end
|
||||||
local dLenLi2 = abs( dLi2Tang)
|
local dLenLi2 = abs( dLi2Tang)
|
||||||
local dLenLo2 = abs( dLo2Tang)
|
local dLenLo2 = abs( dLo2Tang)
|
||||||
|
local dBiLineaAddLength = 0
|
||||||
|
|
||||||
-- se il lato non lavorato della bilinea è aperto, setto entrata/uscita con la stessa direzione
|
-- se il lato non lavorato della bilinea è aperto, setto entrata/uscita con la stessa direzione
|
||||||
if bIsBiLinea then
|
if bIsBiLinea then
|
||||||
@@ -416,6 +463,7 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
local dDistPointToCenter = sqrt( dDistPtTang * dDistPtTang + dDistToCenter * dDistToCenter)
|
local dDistPointToCenter = sqrt( dDistPtTang * dDistPtTang + dDistToCenter * dDistToCenter)
|
||||||
-- se distanza al punto è maggiore del raggio lama, significa che non ho già lavorato, quindi calcolo uscita opportunamente
|
-- se distanza al punto è maggiore del raggio lama, significa che non ho già lavorato, quindi calcolo uscita opportunamente
|
||||||
if dDistPointToCenter > 0.5 * dSawDiam then
|
if dDistPointToCenter > 0.5 * dSawDiam then
|
||||||
|
dBiLineaAddLength = dDistPointToCenter - ( 0.5 * dSawDiam)
|
||||||
dLoTang = -dAllEnd * dCosAlpha
|
dLoTang = -dAllEnd * dCosAlpha
|
||||||
dLoPerp = dDist2 * dSinAlpha
|
dLoPerp = dDist2 * dSinAlpha
|
||||||
end
|
end
|
||||||
@@ -426,14 +474,24 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
local bLioTang
|
local bLioTang
|
||||||
local Ktp = 1.1
|
local Ktp = 1.1
|
||||||
if BD.KIOTP then Ktp = BD.KIOTP end
|
if BD.KIOTP then Ktp = BD.KIOTP end
|
||||||
if ( not bDownUp or abs( vtTg:getY()) > 0.5) and
|
if ( sLeadInOutType == 'PerpendicularOutraw') then
|
||||||
|
bLioTang = false
|
||||||
|
dLiCompLength = dActualElevation + EgtMdbGetGeneralParam( MCH_GP.SAFEZ) + dCutExtra
|
||||||
|
dLoCompLength = dActualElevation + EgtMdbGetGeneralParam( MCH_GP.SAFEZ) + dCutExtra
|
||||||
|
dLiTang = 1
|
||||||
|
dLoTang = 1
|
||||||
|
dLiPerp = 0
|
||||||
|
dLoPerp = 0
|
||||||
|
dLenLi = sqrt( dLiTang * dLiTang + dLiPerp * dLiPerp)
|
||||||
|
dLenLo = sqrt( dLoTang * dLoTang + dLoPerp * dLoPerp)
|
||||||
|
elseif ( sLeadInOutType ~= 'Perpendicular') and ( ( sLeadInOutType == 'Tangent') or ( not bDownUp or abs( vtTg:getY()) > 0.5) and
|
||||||
( not bDownHead or abs( vtTg:getZ()) < 0.51) and
|
( not bDownHead or abs( vtTg:getZ()) < 0.51) and
|
||||||
abs( vtTg:getX()) < 0.9848 and
|
abs( vtTg:getX()) < 0.9848 and
|
||||||
( ( abs( vtTg:getZ()) < 0.17 and ( vtV1:getZ() < -0.5 or vtV2:getZ() < -0.5) and not bDownHead) or
|
( ( abs( vtTg:getZ()) < 0.17 and ( vtV1:getZ() < -0.5 or vtV2:getZ() < -0.5) and not bDownHead) or
|
||||||
( abs( vtTg:getZ()) < 0.51 and b3Box:getDimZ() > 300 and BD.C_SIMM and BD.MAX_HEIGHT > 450 and b3Box:getDimX() > BD.LEN_SHORT_PART) or
|
( abs( vtTg:getZ()) < 0.51 and b3Box:getDimZ() > 300 and BD.C_SIMM and BD.MAX_HEIGHT > 450 and b3Box:getDimX() > BD.LEN_SHORT_PART) or
|
||||||
( abs( vtTg:getZ()) < 0.51 and ( dLenLi2 + dLenLo2) < ( dLenLi + dLenLo)) or
|
( abs( vtTg:getZ()) < 0.51 and ( dLenLi2 + dLenLo2) < ( dLenLi + dLenLo)) or
|
||||||
Ktp * ( dLenLi2 + dLenLo2) < ( dLenLi + dLenLo) or
|
Ktp * ( dLenLi2 + dLenLo2) < ( dLenLi + dLenLo) or
|
||||||
( BD.TURN == 2 and vtRef:getZ() < -0.1)) then
|
( BD.TURN == 2 and vtRef:getZ() < -0.1))) then
|
||||||
if BD.TURN == 2 then
|
if BD.TURN == 2 then
|
||||||
if vtTg:getY() < -0.1 then
|
if vtTg:getY() < -0.1 then
|
||||||
bLioTang = 1
|
bLioTang = 1
|
||||||
@@ -449,11 +507,23 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
-- dLoPerp rimane invariato
|
-- dLoPerp rimane invariato
|
||||||
end
|
end
|
||||||
elseif BD.TURN then
|
elseif BD.TURN then
|
||||||
bLioTang = 2
|
|
||||||
local dMove = dist( ptP1, ptP2)
|
|
||||||
dLiTang, dLiPerp = dLi2Tang, dLi2Perp
|
dLiTang, dLiPerp = dLi2Tang, dLi2Perp
|
||||||
dLoTang = -( dLiTang - dAccStart - dAccEnd + dMove)
|
-- se angolo bilinea ottuso si segue bilinea per un tratto per tagliare completamente cubetto a forma di rombo
|
||||||
dLoPerp = BD.COLL_SIC
|
if dCosAngleL1L2 > 0.707 and bIsBiLinea then
|
||||||
|
-- calcolo uscita per prolungare solo della parte mancante per completare il taglio
|
||||||
|
if dBiLineaAddLength > 0 then
|
||||||
|
dLoTang = dLoTang * ( dBiLineaAddLength + BD.COLL_SIC) / 100
|
||||||
|
dLoPerp = dLoPerp * ( dBiLineaAddLength + BD.COLL_SIC) / 100
|
||||||
|
end
|
||||||
|
-- aggiungo componente perpendicolare a percorso per ritornare dal punto di ingresso, altrimenti l'uscita viene allungata fino dall'altra parte del grezzo
|
||||||
|
dLoCompLength = 100
|
||||||
|
-- se angolo bilinea oltre 45°, faccio movimento in retrazione
|
||||||
|
else
|
||||||
|
bLioTang = 2
|
||||||
|
local dMove = dist( ptP1, ptP2)
|
||||||
|
dLoTang = -( dLiTang - dAccStart - dAccEnd + dMove)
|
||||||
|
dLoPerp = BD.COLL_SIC
|
||||||
|
end
|
||||||
else
|
else
|
||||||
bLioTang = true
|
bLioTang = true
|
||||||
dLiTang, dLiPerp, dLoTang, dLoPerp, dLiCompLength = dLi2Tang, dLi2Perp, dLo2Tang, dLo2Perp, dLi2CompLength
|
dLiTang, dLiPerp, dLoTang, dLoPerp, dLiCompLength = dLi2Tang, dLi2Perp, dLo2Tang, dLo2Perp, dLi2CompLength
|
||||||
@@ -467,9 +537,19 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
if BD.C_SIMM and bMaximizeVerticalDepth then
|
if BD.C_SIMM and bMaximizeVerticalDepth then
|
||||||
nSCC = MCH_SCC.ADIR_ZM
|
nSCC = MCH_SCC.ADIR_ZM
|
||||||
elseif abs( vtAux:getX()) > abs( vtAux:getY()) - GEO.EPS_SMALL then
|
elseif abs( vtAux:getX()) > abs( vtAux:getY()) - GEO.EPS_SMALL then
|
||||||
nSCC = EgtIf( ( vtAux:getX() > -GEO.EPS_SMALL), MCH_SCC.ADIR_XP, MCH_SCC.ADIR_XM)
|
-- se il taglio è orizzontale, si gira aggregato lama per facilitare caduta del legno
|
||||||
|
if abs( vtTg:getZ()) < 10 * GEO.EPS_SMALL and not AreSameOrOppositeVectorApprox( vtN, Z_AX()) then
|
||||||
|
nSCC = EgtIf( ( vtAux:getX() > -GEO.EPS_SMALL), MCH_SCC.ADIR_XM, MCH_SCC.ADIR_XP)
|
||||||
|
else
|
||||||
|
nSCC = EgtIf( ( vtAux:getX() > -GEO.EPS_SMALL), MCH_SCC.ADIR_XP, MCH_SCC.ADIR_XM)
|
||||||
|
end
|
||||||
else
|
else
|
||||||
nSCC = EgtIf( ( vtAux:getY() > -GEO.EPS_SMALL), MCH_SCC.ADIR_YP, MCH_SCC.ADIR_YM)
|
-- se il taglio è orizzontale, si gira aggregato lama per facilitare caduta del legno
|
||||||
|
if abs( vtTg:getZ()) < 10 * GEO.EPS_SMALL and not AreSameOrOppositeVectorApprox( vtN, Z_AX()) then
|
||||||
|
nSCC = EgtIf( ( vtAux:getY() > -GEO.EPS_SMALL), MCH_SCC.ADIR_YM, MCH_SCC.ADIR_YP)
|
||||||
|
else
|
||||||
|
nSCC = EgtIf( ( vtAux:getY() > -GEO.EPS_SMALL), MCH_SCC.ADIR_YP, MCH_SCC.ADIR_YM)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if BD.TURN == 2 then
|
if BD.TURN == 2 then
|
||||||
@@ -516,8 +596,18 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
EgtSetMachiningGeometry( {{ nSurfId, nFacet}})
|
EgtSetMachiningGeometry( {{ nSurfId, nFacet}})
|
||||||
-- imposto uso faccia
|
-- imposto uso faccia
|
||||||
EgtSetMachiningParam( MCH_MP.FACEUSE, nFaceUse)
|
EgtSetMachiningParam( MCH_MP.FACEUSE, nFaceUse)
|
||||||
local sNoteVtFaceUse = 'VtFaceUse=' .. EgtNumToString( vtOrthO:getX(),3) .. ',' .. EgtNumToString( vtOrthO:getY(),3) .. ',' .. EgtNumToString( vtOrthO:getZ(),3) .. ';'
|
-- vtFaceUse non funziona correttaemnte in caso che il lato da lavorare sia a 45°. Potrebbe ritornare una trilinea, non gestibile. Quindi si setta l'EDGE
|
||||||
EgtSetMachiningParam( MCH_MP.USERNOTES, sNoteVtFaceUse)
|
local nEdgeFaceUse = GetEdgeToMachineFromVector( nSurfId, nFacet, vtOrthO)
|
||||||
|
if nEdgeFaceUse and ( AreSameOrOppositeDirApprox( vtOrthO:getX(), 0.707) or AreSameOrOppositeDirApprox( vtOrthO:getY(), 0.707) or AreSameOrOppositeDirApprox( vtOrthO:getZ(), 0.707)) then
|
||||||
|
local sNoteEdgeFaceUse = 'EdgesFaceUse=' .. EgtNumToString( nEdgeFaceUse) .. ';'
|
||||||
|
EgtSetMachiningParam( MCH_MP.USERNOTES, sNoteEdgeFaceUse)
|
||||||
|
else
|
||||||
|
local sNoteVtFaceUse = 'VtFaceUse=' .. EgtNumToString( vtOrthO:getX(),3) .. ',' .. EgtNumToString( vtOrthO:getY(),3) .. ',' .. EgtNumToString( vtOrthO:getZ(),3) .. ';'
|
||||||
|
EgtSetMachiningParam( MCH_MP.USERNOTES, sNoteVtFaceUse)
|
||||||
|
-- imposto allungamenti iniziale e finale (in caso si utilizzi EDGE, non serve prolungare o accorciare)
|
||||||
|
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dAllStart - dAccStart)
|
||||||
|
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dAllEnd - dAccEnd)
|
||||||
|
end
|
||||||
-- imposto posizione braccio porta testa
|
-- imposto posizione braccio porta testa
|
||||||
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
||||||
-- imposto inversione e lato correzione
|
-- imposto inversione e lato correzione
|
||||||
@@ -535,13 +625,14 @@ function FacesBySaw.MakeOne( nSurfId, nFacet, sCutting, dSawDiam, Par5, dVzLimDw
|
|||||||
if BD.TURN and bLioTang == 2 then EgtSetMachiningParam( MCH_MP.LEADOUTTYPE, MCH_MILL_LO.PERP_TG) end
|
if BD.TURN and bLioTang == 2 then EgtSetMachiningParam( MCH_MP.LEADOUTTYPE, MCH_MILL_LO.PERP_TG) end
|
||||||
EgtSetMachiningParam( MCH_MP.LOTANG, dLoTang)
|
EgtSetMachiningParam( MCH_MP.LOTANG, dLoTang)
|
||||||
EgtSetMachiningParam( MCH_MP.LOPERP, dLoPerp)
|
EgtSetMachiningParam( MCH_MP.LOPERP, dLoPerp)
|
||||||
-- imposto allungamenti iniziale e finale
|
EgtSetMachiningParam( MCH_MP.LOCOMPLEN, dLoCompLength)
|
||||||
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dAllStart - dAccStart)
|
|
||||||
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dAllEnd - dAccEnd)
|
|
||||||
-- imposto angolo 3° asse rot
|
-- imposto angolo 3° asse rot
|
||||||
local sBlockedAxis = EgtIf( bMaximizeVerticalDepth, 'parallel', 'perpendicular')
|
local sBlockedAxis = EgtIf( bMaximizeVerticalDepth, 'parallel', 'perpendicular')
|
||||||
EgtSetMachiningParam( MCH_MP.BLOCKEDAXIS, BL.GetBlockedAxis( sCutting, sBlockedAxis, b3Raw, vtN, vtOrthO))
|
EgtSetMachiningParam( MCH_MP.BLOCKEDAXIS, BL.GetBlockedAxis( sCutting, sBlockedAxis, b3Raw, vtN, vtOrthO))
|
||||||
-- eventuali note
|
-- eventuali note
|
||||||
|
if ( sLeadInOutType == 'PerpendicularOutraw') then
|
||||||
|
sNotes = EgtSetValInNotes( sNotes, 'OutRaw', 3)
|
||||||
|
end
|
||||||
if sNotes and #sNotes > 0 then EgtSetMachiningParam( MCH_MP.USERNOTES, sNotes) end
|
if sNotes and #sNotes > 0 then EgtSetMachiningParam( MCH_MP.USERNOTES, sNotes) end
|
||||||
-- eseguo
|
-- eseguo
|
||||||
if not ML.ApplyMachining( true, false) then
|
if not ML.ApplyMachining( true, false) then
|
||||||
@@ -609,9 +700,9 @@ function FacesBySaw.MakeTwo( Proc, nPhase, nRawId, nPartId, dOvmHead, sCutType,
|
|||||||
local bConvex = ( dAngT > 0)
|
local bConvex = ( dAngT > 0)
|
||||||
-- verifico non siano orientate troppo verso il basso e molto sbandate (oltre 10 deg), oppure in testa o in coda e non troppo distanti dal grezzo esterno
|
-- verifico non siano orientate troppo verso il basso e molto sbandate (oltre 10 deg), oppure in testa o in coda e non troppo distanti dal grezzo esterno
|
||||||
local bFaceOk = {}
|
local bFaceOk = {}
|
||||||
bFaceOk[1] = ( vtN[1]:getZ() >= BD.NZ_MINB or abs( vtN[1]:getY()) < 0.174 or ( Proc.AffectedFaces.Left ~= Proc.AffectedFaces.Right and Proc.Face[1].Elevation < dMaxDepth - 10 * GEO.EPS_SMALL))
|
bFaceOk[1] = ( vtN[1]:getZ() >= ( BD.CUT_VZ_MIN or BD.NZ_MINB) or abs( vtN[1]:getY()) < 0.174 or ( Proc.AffectedFaces.Left ~= Proc.AffectedFaces.Right and Proc.Face[1].Elevation < dMaxDepth - 10 * GEO.EPS_SMALL))
|
||||||
bFaceOk[2] = ( vtN[2]:getZ() >= BD.NZ_MINB or abs( vtN[2]:getY()) < 0.174 or ( Proc.AffectedFaces.Left ~= Proc.AffectedFaces.Right and Proc.Face[2].Elevation < dMaxDepth - 10 * GEO.EPS_SMALL))
|
bFaceOk[2] = ( vtN[2]:getZ() >= ( BD.CUT_VZ_MIN or BD.NZ_MINB) or abs( vtN[2]:getY()) < 0.174 or ( Proc.AffectedFaces.Left ~= Proc.AffectedFaces.Right and Proc.Face[2].Elevation < dMaxDepth - 10 * GEO.EPS_SMALL))
|
||||||
if not bDownHead and ( not bFaceOk[1] or not bFaceOk[2]) then
|
if not bDownHead and not bFaceOk[1] and not bFaceOk[2] then
|
||||||
local sErr = 'Error : TwoFacesBySaw from bottom impossible'
|
local sErr = 'Error : TwoFacesBySaw from bottom impossible'
|
||||||
EgtOutLog( sErr)
|
EgtOutLog( sErr)
|
||||||
return false, sErr
|
return false, sErr
|
||||||
|
|||||||
+67
-46
@@ -25,11 +25,14 @@ EgtOutLog( ' MachiningLib started', 1)
|
|||||||
|
|
||||||
-- Dati
|
-- Dati
|
||||||
local BD = require( 'BeamData')
|
local BD = require( 'BeamData')
|
||||||
local Cuttings = require( 'CutData')
|
-- librerie lavorazioni caricate con pcall perchè potrebbero non esserci
|
||||||
local Millings = require( 'MillingData')
|
local Cuttings, Millings, Pocketings, Sawings, Drillings, Probing
|
||||||
local Pocketings = require( 'PocketingData')
|
if pcall( require, 'CutData') then Cuttings = require( 'CutData') end
|
||||||
local Sawings = require( 'SawingData')
|
if pcall( require, 'MillingData') then Millings = require( 'MillingData') end
|
||||||
local Drillings = require( 'DrillData')
|
if pcall( require, 'PocketingData') then Pocketings = require( 'PocketingData') end
|
||||||
|
if pcall( require, 'SawingData') then Sawings = require( 'SawingData') end
|
||||||
|
if pcall( require, 'DrillData') then Drillings = require( 'DrillData') end
|
||||||
|
if pcall( require, 'ProbingData') then Probing = require( 'ProbingData') end
|
||||||
|
|
||||||
-- tipo di teste macchina
|
-- tipo di teste macchina
|
||||||
local ONE_HEAD = 1 -- una testa (Fast, One, Turn1T)
|
local ONE_HEAD = 1 -- una testa (Fast, One, Turn1T)
|
||||||
@@ -77,7 +80,7 @@ end
|
|||||||
-- setta ultimi testa e utensile utilizzati se compatibili con ottimizzazione testa
|
-- setta ultimi testa e utensile utilizzati se compatibili con ottimizzazione testa
|
||||||
local function ConfirmNextMachining()
|
local function ConfirmNextMachining()
|
||||||
-- utensile corrente
|
-- utensile corrente
|
||||||
local sToolUuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
local sToolUuid = EgtGetMachiningParam( MCH_MP.TUUID)
|
||||||
local sToolName = EgtTdbGetToolFromUUID( sToolUuid or '')
|
local sToolName = EgtTdbGetToolFromUUID( sToolUuid or '')
|
||||||
EgtTdbSetCurrTool( sToolName or '')
|
EgtTdbSetCurrTool( sToolName or '')
|
||||||
-- testa dell'utensile corrente
|
-- testa dell'utensile corrente
|
||||||
@@ -170,7 +173,7 @@ function VerifyTool( Machining, MachiningType, Params, bH2)
|
|||||||
return VerifyDrillPocket( Machining, Params.Diam, Params.Depth, bH2)
|
return VerifyDrillPocket( Machining, Params.Diam, Params.Depth, bH2)
|
||||||
end
|
end
|
||||||
elseif MachiningType == MCH_MY.SAWING then
|
elseif MachiningType == MCH_MY.SAWING then
|
||||||
return true, { H2 = bH2}
|
return ( not Params.Depth or Machining.Tool.MaxMat > Params.Depth - GEO.EPS_SMALL), { H2 = bH2}
|
||||||
elseif MachiningType == MCH_MY.MILLING then
|
elseif MachiningType == MCH_MY.MILLING then
|
||||||
return VerifyMill( Machining, Params.Depth, Params.TuuidMstr, Params.MaxDiam, Params.MaxTotLen, bH2)
|
return VerifyMill( Machining, Params.Depth, Params.TuuidMstr, Params.MaxDiam, Params.MaxTotLen, bH2)
|
||||||
elseif MachiningType == MCH_MY.POCKETING then
|
elseif MachiningType == MCH_MY.POCKETING then
|
||||||
@@ -184,18 +187,32 @@ end
|
|||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
function GetMachinings( MachiningType, sType)
|
function GetMachinings( MachiningType, sType)
|
||||||
local Machinings
|
local Machinings = {}
|
||||||
-- leggo le lavorazioni disponibili
|
-- leggo le lavorazioni disponibili
|
||||||
if MachiningType == MCH_MY.DRILLING then
|
if MachiningType == MCH_MY.DRILLING then
|
||||||
Machinings = Drillings
|
if Drillings and type( Drillings) == "table" then
|
||||||
|
Machinings = Drillings
|
||||||
|
end
|
||||||
elseif MachiningType == MCH_MY.SAWING then
|
elseif MachiningType == MCH_MY.SAWING then
|
||||||
Machinings = Cuttings
|
if Cuttings and type( Cuttings) == "table" then
|
||||||
|
Machinings = Cuttings
|
||||||
|
end
|
||||||
elseif MachiningType == MCH_MY.MILLING then
|
elseif MachiningType == MCH_MY.MILLING then
|
||||||
Machinings = Millings
|
if Millings and type( Millings) == "table" then
|
||||||
|
Machinings = Millings
|
||||||
|
end
|
||||||
elseif MachiningType == MCH_MY.POCKETING then
|
elseif MachiningType == MCH_MY.POCKETING then
|
||||||
Machinings = Pocketings
|
if Pocketings and type( Pocketings) == "table" then
|
||||||
|
Machinings = Pocketings
|
||||||
|
end
|
||||||
elseif MachiningType == MCH_MY.MORTISING then
|
elseif MachiningType == MCH_MY.MORTISING then
|
||||||
Machinings = Sawings
|
if Sawings and type( Sawings) == "table" then
|
||||||
|
Machinings = Sawings
|
||||||
|
end
|
||||||
|
elseif MachiningType == MCH_MY.PROBING then
|
||||||
|
if Probing and type( Probing) == "table" then
|
||||||
|
Machinings = Probing
|
||||||
|
end
|
||||||
end
|
end
|
||||||
-- scrivo i parametri utensile nella lavorazione
|
-- scrivo i parametri utensile nella lavorazione
|
||||||
local validMachinings = {}
|
local validMachinings = {}
|
||||||
@@ -208,27 +225,30 @@ function GetMachinings( MachiningType, sType)
|
|||||||
if Machining.Tool.Name then
|
if Machining.Tool.Name then
|
||||||
if EgtTdbSetCurrTool( Machining.Tool.Name) then
|
if EgtTdbSetCurrTool( Machining.Tool.Name) then
|
||||||
table.insert( validMachinings, Machining)
|
table.insert( validMachinings, Machining)
|
||||||
if ( MachiningType == MCH_MY.MILLING) or ( MachiningType == MCH_MY.POCKETING) or ( MachiningType == MCH_MY.DRILLING and EgtStartsWith( sType, 'Pocket')) then
|
-- se non è tastatura, recupero dati utensile
|
||||||
Machining.Tool.MaxMat = EgtTdbGetCurrToolMaxDepth()
|
if MachiningType ~= MCH_MY.PROBING then
|
||||||
else
|
if ( MachiningType == MCH_MY.MILLING) or ( MachiningType == MCH_MY.POCKETING) or ( MachiningType == MCH_MY.DRILLING and EgtStartsWith( sType, 'Pocket')) then
|
||||||
Machining.Tool.MaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT)
|
Machining.Tool.MaxMat = EgtTdbGetCurrToolMaxDepth()
|
||||||
end
|
else
|
||||||
if MachiningType == MCH_MY.DRILLING then
|
Machining.Tool.MaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT)
|
||||||
if EgtStartsWith( Machining.Type, 'Drill') then
|
|
||||||
Machining.SubType = 'Drill'
|
|
||||||
elseif EgtStartsWith( Machining.Type, 'AngleDrill') then
|
|
||||||
Machining.SubType = 'AngleDrill'
|
|
||||||
elseif EgtStartsWith( Machining.Type, 'Pocket') then
|
|
||||||
Machining.SubType = 'DrillPocket'
|
|
||||||
elseif EgtStartsWith( Machining.Type, 'Predrill') then
|
|
||||||
Machining.SubType = 'Predrill'
|
|
||||||
end
|
end
|
||||||
|
if MachiningType == MCH_MY.DRILLING then
|
||||||
|
if EgtStartsWith( Machining.Type, 'Drill') then
|
||||||
|
Machining.SubType = 'Drill'
|
||||||
|
elseif EgtStartsWith( Machining.Type, 'AngleDrill') then
|
||||||
|
Machining.SubType = 'AngleDrill'
|
||||||
|
elseif EgtStartsWith( Machining.Type, 'Pocket') then
|
||||||
|
Machining.SubType = 'DrillPocket'
|
||||||
|
elseif EgtStartsWith( Machining.Type, 'Predrill') then
|
||||||
|
Machining.SubType = 'Predrill'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
Machining.Tool.Diameter = EgtTdbGetCurrToolParam( MCH_TP.DIAM)
|
||||||
|
Machining.Tool.Length = EgtTdbGetCurrToolParam( MCH_TP.LEN)
|
||||||
|
Machining.Tool.TotalLength = EgtTdbGetCurrToolParam( MCH_TP.TOTLEN)
|
||||||
|
Machining.Tool.ToolHolderDiameter = EgtTdbGetCurrToolThDiam()
|
||||||
|
Machining.Tool.ToolHolderLength = EgtTdbGetCurrToolThLength() or 72
|
||||||
end
|
end
|
||||||
Machining.Tool.Diameter = EgtTdbGetCurrToolParam( MCH_TP.DIAM)
|
|
||||||
Machining.Tool.Length = EgtTdbGetCurrToolParam( MCH_TP.LEN)
|
|
||||||
Machining.Tool.TotalLength = EgtTdbGetCurrToolParam( MCH_TP.TOTLEN)
|
|
||||||
Machining.Tool.ToolHolderDiameter = EgtTdbGetCurrToolThDiam()
|
|
||||||
Machining.Tool.ToolHolderLength = EgtTdbGetCurrToolThLength() or 72
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -311,6 +331,7 @@ end
|
|||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
local function FindMachining( MachiningType, sType, Params, bTopHead, bDownHead, bExcludeH2, bExcludeH3, sSortingCriterion)
|
local function FindMachining( MachiningType, sType, Params, bTopHead, bDownHead, bExcludeH2, bExcludeH3, sSortingCriterion)
|
||||||
|
local bOptimizeHeads = ( not sSortingCriterion or sSortingCriterion == '')
|
||||||
if bTopHead == nil and bDownHead == nil then
|
if bTopHead == nil and bDownHead == nil then
|
||||||
bTopHead = true
|
bTopHead = true
|
||||||
bDownHead = false
|
bDownHead = false
|
||||||
@@ -342,21 +363,21 @@ local function FindMachining( MachiningType, sType, Params, bTopHead, bDownHead,
|
|||||||
local ForStart = 1
|
local ForStart = 1
|
||||||
local ForEnd = #Machinings
|
local ForEnd = #Machinings
|
||||||
local ForStep = 1
|
local ForStep = 1
|
||||||
-- le forature vanno scorse dal diametro maggiore al minore
|
-- le forature vanno scorse dal diametro maggiore al minore, a meno che non sia stato passato un ordinamento specifico
|
||||||
if MachiningType == MCH_MY.DRILLING then
|
if MachiningType == MCH_MY.DRILLING and ( not sSortingCriterion or sSortingCriterion == '') then
|
||||||
ForStart = #Machinings
|
ForStart = #Machinings
|
||||||
ForEnd = 1
|
ForEnd = 1
|
||||||
ForStep = -1
|
ForStep = -1
|
||||||
end
|
end
|
||||||
if ( BEAM and BEAM.BW) or MachineHeadType == ONE_HEAD or MachineHeadType == TWO_EQUAL_HEADS or ( MachineHeadType == TWO_UP_DOWN_HEADS and not bDownHead) then
|
if bOptimizeHeads or MachineHeadType == ONE_HEAD or MachineHeadType == TWO_EQUAL_HEADS or ( MachineHeadType == TWO_UP_DOWN_HEADS and not bDownHead) then
|
||||||
_, sType = EgtEndsWith( sType, '_H2')
|
_, sType = EgtEndsWith( sType, '_H2')
|
||||||
elseif not ( BEAM and BEAM.BW) and MachineHeadType == TWO_UP_DOWN_HEADS and not bTopHead and bDownHead then
|
elseif not bOptimizeHeads and MachineHeadType == TWO_UP_DOWN_HEADS and not bTopHead and bDownHead then
|
||||||
if not EgtEndsWith( sType, '_H2') then
|
if not EgtEndsWith( sType, '_H2') then
|
||||||
sType = sType .. '_H2'
|
sType = sType .. '_H2'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local MachineHeadUse = MachineHeadType
|
local MachineHeadUse = MachineHeadType
|
||||||
if not ( BEAM and BEAM.BW) and MachineHeadUse == TWO_EQUAL_HEADS then
|
if not bOptimizeHeads and MachineHeadUse == TWO_EQUAL_HEADS then
|
||||||
MachineHeadUse = ONE_HEAD
|
MachineHeadUse = ONE_HEAD
|
||||||
end
|
end
|
||||||
if MachineHeadUse == TWO_UP_DOWN_HEADS and bTopHead and bDownHead then
|
if MachineHeadUse == TWO_UP_DOWN_HEADS and bTopHead and bDownHead then
|
||||||
@@ -368,7 +389,7 @@ local function FindMachining( MachiningType, sType, Params, bTopHead, bDownHead,
|
|||||||
for i = ForStart, ForEnd, ForStep do
|
for i = ForStart, ForEnd, ForStep do
|
||||||
local Machining = Machinings[i]
|
local Machining = Machinings[i]
|
||||||
local sMachiningType = Machining.Type
|
local sMachiningType = Machining.Type
|
||||||
if ( BEAM and BEAM.BW) or MachineHeadUse == TWO_EQUAL_HEADS then
|
if bOptimizeHeads or MachineHeadUse == TWO_EQUAL_HEADS then
|
||||||
_, sMachiningType = EgtEndsWith( Machining.Type, '_H2')
|
_, sMachiningType = EgtEndsWith( Machining.Type, '_H2')
|
||||||
end
|
end
|
||||||
-- recupero dati utensile
|
-- recupero dati utensile
|
||||||
@@ -444,18 +465,18 @@ local function FindMachining( MachiningType, sType, Params, bTopHead, bDownHead,
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
local bH2, sOrigType = EgtEndsWith( sType, '_H2')
|
local bH2, sOrigType = EgtEndsWith( sType, '_H2')
|
||||||
if ( not BEAM or not BEAM.BW) and MachineHeadType == TWO_UP_DOWN_HEADS and bH2 and bTopHead then
|
if not bOptimizeHeads and MachineHeadType == TWO_UP_DOWN_HEADS and bH2 and bTopHead then
|
||||||
return FindMachining( MachiningType, sOrigType, Params, true, false)
|
return FindMachining( MachiningType, sOrigType, Params, true, false)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
function MachiningLib.FindCutting( sType, bTopHead, bDownHead)
|
function MachiningLib.FindCutting( sType, bTopHead, bDownHead, dDepth, sSortingCriterion)
|
||||||
return FindMachining( MCH_MY.SAWING, sType, nil, bTopHead, bDownHead)
|
return FindMachining( MCH_MY.SAWING, sType, { Depth = dDepth}, bTopHead, bDownHead, nil, nil, sSortingCriterion)
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
function MachiningLib.FindDrilling( dDiam, dDepth, bTopHead, bDownHead, bExcludeH2, bAngleTransmission, bIsPredrill)
|
function MachiningLib.FindDrilling( dDiam, dDepth, bTopHead, bDownHead, bExcludeH2, bAngleTransmission, bIsPredrill, bExcludeH3, sSortingCriterion)
|
||||||
local MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5, sTypeMach
|
local MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5, sTypeMach
|
||||||
-- se il foro è un predrill, cerco solo punte abilitate al Predrill
|
-- se il foro è un predrill, cerco solo punte abilitate al Predrill
|
||||||
if bIsPredrill then
|
if bIsPredrill then
|
||||||
@@ -463,9 +484,9 @@ function MachiningLib.FindDrilling( dDiam, dDepth, bTopHead, bDownHead, bExclude
|
|||||||
else
|
else
|
||||||
sTypeMach = EgtIf( bAngleTransmission, 'Drill_AT', 'Drill')
|
sTypeMach = EgtIf( bAngleTransmission, 'Drill_AT', 'Drill')
|
||||||
end
|
end
|
||||||
MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5 = FindMachining( MCH_MY.DRILLING, sTypeMach, { Diam = dDiam, Depth = dDepth}, bTopHead, bDownHead, bExcludeH2)
|
MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5 = FindMachining( MCH_MY.DRILLING, sTypeMach, { Diam = dDiam, Depth = dDepth}, bTopHead, bDownHead, bExcludeH2, bExcludeH3, sSortingCriterion)
|
||||||
if ( not MachiningName or MachiningName == '') then
|
if ( not MachiningName or MachiningName == '') then
|
||||||
MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5 = FindMachining( MCH_MY.DRILLING, EgtIf( bAngleTransmission, 'Pocket_AT', 'Pocket'), { Diam = dDiam, Depth = dDepth}, bTopHead, bDownHead)
|
MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5 = FindMachining( MCH_MY.DRILLING, EgtIf( bAngleTransmission, 'Pocket_AT', 'Pocket'), { Diam = dDiam, Depth = dDepth}, bTopHead, bDownHead, bExcludeH2, bExcludeH3, sSortingCriterion)
|
||||||
end
|
end
|
||||||
if MachiningName and MachiningName ~= '' then
|
if MachiningName and MachiningName ~= '' then
|
||||||
return MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5
|
return MachiningName, MachiningType, Param1, Param2, Param3, Param4, Param5
|
||||||
@@ -481,8 +502,8 @@ function MachiningLib.FindAngleDrilling( dDiam, dDepth, bTopHead, bDownHead)
|
|||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
function MachiningLib.FindMilling( sType, dDepth, sTuuidMstr, dMaxDiam, dMaxTotLen, bTopHead, bDownHead, bExcludeH2, bExcludeH3)
|
function MachiningLib.FindMilling( sType, dDepth, sTuuidMstr, dMaxDiam, dMaxTotLen, bTopHead, bDownHead, bExcludeH2, bExcludeH3, sSortingCriterion)
|
||||||
return FindMachining( MCH_MY.MILLING, sType, { Depth = dDepth, TuuidMstr = sTuuidMstr, MaxDiam = dMaxDiam, MaxTotLen = dMaxTotLen}, bTopHead, bDownHead, bExcludeH2, bExcludeH3)
|
return FindMachining( MCH_MY.MILLING, sType, { Depth = dDepth, TuuidMstr = sTuuidMstr, MaxDiam = dMaxDiam, MaxTotLen = dMaxTotLen}, bTopHead, bDownHead, bExcludeH2, bExcludeH3, sSortingCriterion)
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
|
|||||||
+54
-17
@@ -46,7 +46,14 @@ local ML = require( 'MachiningLib')
|
|||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- Riconoscimento della feature
|
-- Riconoscimento della feature
|
||||||
function ProcessCut.Identify( Proc)
|
function ProcessCut.Identify( Proc)
|
||||||
return ( ( Proc.Grp == 1 or Proc.Grp == 2) and Proc.Prc == 10)
|
-- se richiesto si forza fresatura
|
||||||
|
Proc.bForceMill = ( ( ( Proc.Grp == 1 or Proc.Grp == 2) and Proc.Prc == 10) and ( ( EgtGetInfo( Proc.Id, 'Q07', 'd') or 0) == 1))
|
||||||
|
|
||||||
|
if Proc.bForceMill then
|
||||||
|
return false
|
||||||
|
else
|
||||||
|
return ( ( Proc.Grp == 1 or Proc.Grp == 2) and Proc.Prc == 10)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
@@ -85,7 +92,7 @@ function ProcessCut.Classify( Proc, b3Raw)
|
|||||||
-- calcolo l'ingombro orizzontale della faccia
|
-- calcolo l'ingombro orizzontale della faccia
|
||||||
local _, DimH, DimV = BL.GetFaceHvRefDim( Proc.Id, 0)
|
local _, DimH, DimV = BL.GetFaceHvRefDim( Proc.Id, 0)
|
||||||
-- confronto questo ingombro con il doppio della massima dimensione del DiceCut (impossibile lavorare sotto da sopra se più di 2 tagli oppure se tipo PF, taglio inclinato in Y e non taglio singolo orizzontale)
|
-- confronto questo ingombro con il doppio della massima dimensione del DiceCut (impossibile lavorare sotto da sopra se più di 2 tagli oppure se tipo PF, taglio inclinato in Y e non taglio singolo orizzontale)
|
||||||
if DimH > 2 * BD.MAX_DIM_DICE or ( BD.C_SIMM and abs( vtN:getY()) > 0.1 and dMaxMat < DimH + BD.CUT_EXTRA) then
|
if DimH > 2 * BD.MAX_DIM_DICE or ( BD.C_SIMM and ( abs( vtN:getY()) > 0.1) and dMaxMat < DimH + BD.CUT_EXTRA) then
|
||||||
return true, true
|
return true, true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -254,7 +261,8 @@ end
|
|||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- Applicazione della lavorazione con testa da sopra
|
-- Applicazione della lavorazione con testa da sopra
|
||||||
local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom, bCustDiceCut, bForced, b3Raw, sNotes, nLimitingSurf)
|
local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom, bCustDiceCut, bForced, b3Raw, sNotes, nLimitingSurf, sLeadInOutType)
|
||||||
|
local sWarn
|
||||||
-- ingombro del grezzo
|
-- ingombro del grezzo
|
||||||
b3Raw = b3Raw or EgtGetRawPartBBox( nRawId)
|
b3Raw = b3Raw or EgtGetRawPartBBox( nRawId)
|
||||||
-- ingombro del pezzo
|
-- ingombro del pezzo
|
||||||
@@ -265,9 +273,9 @@ local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, b
|
|||||||
local dNzLimDwnUp = BL.GetNzLimDownUp( b3Raw, vtN)
|
local dNzLimDwnUp = BL.GetNzLimDownUp( b3Raw, vtN)
|
||||||
local bDownCut = ( vtN:getZ() <= dNzLimDwnUp)
|
local bDownCut = ( vtN:getZ() <= dNzLimDwnUp)
|
||||||
if bFromBottom == nil then
|
if bFromBottom == nil then
|
||||||
bFromBottom = ( vtN:getZ() > 0.25 and b3Solid:getDimX() < BD.LEN_SHORT_PART and not Proc.AdvTail and vtN:getX() < 0 and abs( vtN:getY()) < 0.259)
|
bFromBottom = ( vtN:getZ() > 0.25 and ( b3Solid:getDimX() < BD.LEN_SHORT_PART and BL.IsSplittedPartPhase( nPhase)) and not Proc.AdvTail and vtN:getX() < 0 and abs( vtN:getY()) < 0.259)
|
||||||
end
|
end
|
||||||
local dMinFeatureLengthForLongCut = 590.000
|
local dMinFeatureLengthForLongCut = EgtIf( BD.C_SIMM, 590, 400)
|
||||||
-- verifico se da considerare taglio lungo ( non da sotto, inclinato non più di 30deg, largo come la trave e abbastanza lungo)
|
-- verifico se da considerare taglio lungo ( non da sotto, inclinato non più di 30deg, largo come la trave e abbastanza lungo)
|
||||||
local bLongCut = ( not bDownCut and vtN:getZ() > 0.865 and
|
local bLongCut = ( not bDownCut and vtN:getZ() > 0.865 and
|
||||||
Proc.Box:getDimY() > b3Solid:getDimY() - 10 * GEO.EPS_SMALL and
|
Proc.Box:getDimY() > b3Solid:getDimY() - 10 * GEO.EPS_SMALL and
|
||||||
@@ -366,10 +374,19 @@ local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, b
|
|||||||
end
|
end
|
||||||
-- verifico se necessari tagli supplementari o se presente superficie limitante
|
-- verifico se necessari tagli supplementari o se presente superficie limitante
|
||||||
EgtOutLog( string.format( 'MaxDepth=%.1f MaxVertDepth=%.1f CutH=%.1f CutV=%.1f', dMaxDepth, dMaxVertDepth, dCutH, dCutV), 3)
|
EgtOutLog( string.format( 'MaxDepth=%.1f MaxVertDepth=%.1f CutH=%.1f CutV=%.1f', dMaxDepth, dMaxVertDepth, dCutH, dCutV), 3)
|
||||||
|
-- se lungo, una faccia e rivolto sul retro verso l'alto si forzano i cubetti per evitare di rovinare il pezzo successivo
|
||||||
|
local bForceDicing = ( Proc.Fct == 1 and Proc.AffectedFaces.Left and bLongCut and vtN:getZ() > 10 * GEO.EPS_SMALL and vtN:getY() < 10 * GEO.EPS_SMALL)
|
||||||
local vCuts = {}
|
local vCuts = {}
|
||||||
if not Proc.AdvTail and ( dCutH > dMaxDepth - BD.CUT_EXTRA - 3 * BD.COLL_SIC or dCutV > dMaxVertDepth - BD.CUT_EXTRA - 3 * BD.COLL_SIC) then
|
local dDicingOffsetP
|
||||||
|
local dDicingOffsetO
|
||||||
|
if ( ( not Proc.AdvTail) or bForceDicing) and ( dCutH > dMaxDepth - BD.CUT_EXTRA - 3 * BD.COLL_SIC or dCutV > dMaxVertDepth - BD.CUT_EXTRA - 3 * BD.COLL_SIC) then
|
||||||
local ptExtra, vtExtra
|
local ptExtra, vtExtra
|
||||||
local bAutoCalcSurf = true
|
local bAutoCalcSurf = true
|
||||||
|
if Proc.AdvTail then
|
||||||
|
-- do avviso che la lama può sbordare nel pezzo successivo
|
||||||
|
sWarn = 'Warning : Cut machining can damage next piece'
|
||||||
|
EgtOutLog( sWarn .. ' (process ' .. tostring( Proc.Id) .. ')')
|
||||||
|
end
|
||||||
if bFillAreaPiece or bFillTail then
|
if bFillAreaPiece or bFillTail then
|
||||||
local ptMiddle = ( b3Solid:getMin() + b3Solid:getMax()) / 2
|
local ptMiddle = ( b3Solid:getMin() + b3Solid:getMax()) / 2
|
||||||
ptExtra = Point3d( b3Solid:getMin():getX() + 5*GEO.EPS_SMALL, ptMiddle:getY(), ptMiddle:getZ())
|
ptExtra = Point3d( b3Solid:getMin():getX() + 5*GEO.EPS_SMALL, ptMiddle:getY(), ptMiddle:getZ())
|
||||||
@@ -408,11 +425,11 @@ local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, b
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- se il taglio è più spesso della lama abilito il dicing, altrimenti no
|
-- se il taglio è più spesso della lama abilito il dicing, altrimenti no
|
||||||
if dMaxElev > dSawThick then
|
if ( dMaxElev > dSawThick) or bForceDicing then
|
||||||
vCuts = DC.GetDice( nAddGrpId, EgtIf( bForced, b3Raw, b3Solid), ptC, vtN, bAutoCalcSurf, ptExtra, vtExtra, dMaxVertDepth - BD.CUT_EXTRA, dNewDiceDim)
|
vCuts, dDicingOffsetP = DC.GetDice( nAddGrpId, EgtIf( bForced, b3Raw, b3Solid), ptC, vtN, bAutoCalcSurf, ptExtra, vtExtra, dMaxVertDepth - BD.CUT_EXTRA, dNewDiceDim)
|
||||||
-- se taglio sborda in coda e non è stato inserito nessun taglio a cubetti, lo rilancio con le dimensioni customizzate
|
-- se taglio sborda in coda e non è stato inserito nessun taglio a cubetti, lo rilancio con le dimensioni customizzate
|
||||||
if ( bFillTail or bCustDiceCut) and #vCuts == 0 then
|
if ( bFillTail or bCustDiceCut) and #vCuts == 0 then
|
||||||
vCuts = DC.GetDice( nAddGrpId, b3Solid, ptC, vtN, bAutoCalcSurf, ptExtra, vtExtra, dMaxVertDepth - BD.CUT_EXTRA, Proc.Box:getDimY())
|
vCuts, dDicingOffsetP = DC.GetDice( nAddGrpId, b3Solid, ptC, vtN, bAutoCalcSurf, ptExtra, vtExtra, dMaxVertDepth - BD.CUT_EXTRA, Proc.Box:getDimY())
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -581,7 +598,17 @@ local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, b
|
|||||||
if ( i % 2 == 0) and ( Proc.Fct == 1) and bNoPerpCuts then
|
if ( i % 2 == 0) and ( Proc.Fct == 1) and bNoPerpCuts then
|
||||||
vtOrthoOAlternative = - vtOrthoO
|
vtOrthoOAlternative = - vtOrthoO
|
||||||
end
|
end
|
||||||
local bOk, sErr = Fbs.MakeOne( vCuts[i][j], 0, sCutting, dSawDiam, vtOrthoO, dVzLimDwnUp, dExtraCut, BD.CUT_SIC, 0, 0, 0, sNotes, b3Raw, nil, nil, bSpecialTangentLeadInOut, nil, vtOrthoOAlternative)
|
local sLeadInOutTypeFbs = 'Calculated'
|
||||||
|
if ( ( i % 2) ~= 0) then
|
||||||
|
if ( sLeadInOutType == 'Tangent') then
|
||||||
|
sLeadInOutTypeFbs = 'Tangent'
|
||||||
|
elseif ( sLeadInOutType == 'Perpendicular') then
|
||||||
|
sLeadInOutTypeFbs = 'Perpendicular'
|
||||||
|
elseif ( sLeadInOutType == 'PerpendicularOutraw') then
|
||||||
|
sLeadInOutTypeFbs = 'PerpendicularOutraw'
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local bOk, sErr = Fbs.MakeOne( vCuts[i][j], 0, sCutting, dSawDiam, vtOrthoO, dVzLimDwnUp, dExtraCut, BD.CUT_SIC, 0, 0, 0, sNotes, b3Raw, nil, nil, bSpecialTangentLeadInOut, sLeadInOutTypeFbs, vtOrthoOAlternative, dDicingOffsetP)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -600,7 +627,8 @@ local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, b
|
|||||||
local vtOrthoO
|
local vtOrthoO
|
||||||
if bFromBottom and dCutV < dMaxDepth - BD.CUT_EXTRA and vtN:getZ() > 0 then
|
if bFromBottom and dCutV < dMaxDepth - BD.CUT_EXTRA and vtN:getZ() > 0 then
|
||||||
vtOrthoO = -Z_AX()
|
vtOrthoO = -Z_AX()
|
||||||
elseif bHorizCut and ( not bVertCutOk or b3Solid:getDimX() > BD.LEN_SHORT_PART or Proc.AdvTail or ( vtN:getX() > 0 and vtN:getZ() <= 0.708) or ( abs( vtN:getY()) < 0.1 and vtN:getZ() <= 0)) then
|
elseif ( bHorizCut and not bVertCutOk) and
|
||||||
|
( not bVertCutOk or b3Solid:getDimX() > BD.LEN_SHORT_PART or Proc.AdvTail or ( vtN:getX() > 0 and vtN:getZ() <= 0.708) or ( abs( vtN:getY()) < 0.1 and vtN:getZ() <= 0)) then
|
||||||
vtOrthoO = Z_AX()
|
vtOrthoO = Z_AX()
|
||||||
elseif b3Solid:getDimX() < BD.LEN_SHORT_PART and not Proc.AdvTail and abs( vtN:getY()) > 0.259 and
|
elseif b3Solid:getDimX() < BD.LEN_SHORT_PART and not Proc.AdvTail and abs( vtN:getY()) > 0.259 and
|
||||||
vtN:getZ() > -0.174 and abs( vtN:getY()) > abs( vtN:getZ()) and dCutH < dMaxDepth + 10 * GEO.EPS_SMALL then
|
vtN:getZ() > -0.174 and abs( vtN:getY()) > abs( vtN:getZ()) and dCutH < dMaxDepth + 10 * GEO.EPS_SMALL then
|
||||||
@@ -633,7 +661,7 @@ local function MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, b
|
|||||||
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0, sCutting, dSawDiam, vtOrthoO, dVzLimDwnUp, dCutExtra, BD.CUT_SIC, 0, 0, 0, nil, b3Raw)
|
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0, sCutting, dSawDiam, vtOrthoO, dVzLimDwnUp, dCutExtra, BD.CUT_SIC, 0, 0, 0, nil, b3Raw)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
return true
|
return true, sWarn
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
@@ -821,7 +849,7 @@ end
|
|||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- Applicazione della lavorazione
|
-- Applicazione della lavorazione
|
||||||
function ProcessCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom, bCustDiceCut, bForced, b3Raw, sNotes, dOvmTail, bUpdateIng, nLimitingSurf)
|
function ProcessCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom, bCustDiceCut, bForced, b3Raw, sNotes, dOvmTail, bUpdateIng, nLimitingSurf, sLeadInOutType)
|
||||||
-- sovramateriale di coda
|
-- sovramateriale di coda
|
||||||
dOvmTail = dOvmTail or BD.OVM_MID
|
dOvmTail = dOvmTail or BD.OVM_MID
|
||||||
-- ingombro del grezzo
|
-- ingombro del grezzo
|
||||||
@@ -858,22 +886,31 @@ function ProcessCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom,
|
|||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
local bNoDicing = false
|
local bNoDicing = false
|
||||||
|
local sWarn
|
||||||
-- se taglio con testa da sopra
|
-- se taglio con testa da sopra
|
||||||
if not bDownHead and not bDownTurn then
|
if not bDownHead and not bDownTurn then
|
||||||
local bOk, sErr, bNoDicing2 = MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom, bCustDiceCut, bForced, b3Raw, sNotes, nLimitingSurf)
|
local bOk, sErr, bNoDicing2 = MakeFromTop( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom, bCustDiceCut, bForced, b3Raw, sNotes, nLimitingSurf, sLeadInOutType)
|
||||||
bNoDicing = bNoDicing2
|
bNoDicing = bNoDicing2
|
||||||
if not bOk then return false, sErr end
|
if not bOk then
|
||||||
|
return false, sErr
|
||||||
|
else
|
||||||
|
sWarn = sErr
|
||||||
|
end
|
||||||
-- altrimenti taglio con testa da sotto
|
-- altrimenti taglio con testa da sotto
|
||||||
else
|
else
|
||||||
local bOk, sErr = MakeFromDown( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead)
|
local bOk, sErr = MakeFromDown( sCutting, Proc, nPhase, nRawId, nPartId, dOvmHead)
|
||||||
if not bOk then return false, sErr end
|
if not bOk then
|
||||||
|
return false, sErr
|
||||||
|
else
|
||||||
|
sWarn = sErr
|
||||||
|
end
|
||||||
end
|
end
|
||||||
-- Aggiornamento ingombro (se vero taglio o richiesto)
|
-- Aggiornamento ingombro (se vero taglio o richiesto)
|
||||||
-- Se lascio il cordolo (bNoDicing) non aggiorno il grezzo perchè lo scarto rimane attaccato
|
-- Se lascio il cordolo (bNoDicing) non aggiorno il grezzo perchè lo scarto rimane attaccato
|
||||||
if ( ProcessCut.Identify( Proc) or bUpdateIng) and not bNoDicing then
|
if ( ProcessCut.Identify( Proc) or bUpdateIng) and not bNoDicing then
|
||||||
UpdateEncumbrance( Proc, vtN, dOvmHead, nRawId, b3Solid, b3Raw)
|
UpdateEncumbrance( Proc, vtN, dOvmHead, nRawId, b3Solid, b3Raw)
|
||||||
end
|
end
|
||||||
return true
|
return true, sWarn
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
|
|||||||
@@ -475,13 +475,36 @@ function ProcessDoubleCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
-- dati delle facce
|
-- dati delle facce
|
||||||
local ptC = {}
|
local ptC = {}
|
||||||
local vtN = {}
|
local vtN = {}
|
||||||
ptC[1], vtN[1] = EgtSurfTmFacetCenter( Proc.Id, 0, GDB_ID.ROOT)
|
local idFirstFace, idSecondFace
|
||||||
ptC[2], vtN[2] = EgtSurfTmFacetCenter( Proc.Id, 1, GDB_ID.ROOT)
|
|
||||||
|
-- se ci sono più di due face (caso insolito), si prendono le facce più grandi
|
||||||
|
if Proc.Fct > 2 then
|
||||||
|
local Area = {}
|
||||||
|
-- si prendono le due più grandi, potrebbero essercene più di due
|
||||||
|
for i = 1, Proc.Fct do
|
||||||
|
local _, dL, dW = EgtSurfTmFacetMinAreaRectangle( Proc.Id, i - 1)
|
||||||
|
table.insert( Area, { nIndex = i-1, dArea = dL*dW})
|
||||||
|
end
|
||||||
|
-- ordina 'Area' in ordine decrescente
|
||||||
|
table.sort( Area, function( A, B)
|
||||||
|
return A.dArea > B.dArea
|
||||||
|
end
|
||||||
|
)
|
||||||
|
idFirstFace = Area[1].nIndex
|
||||||
|
idSecondFace = Area[2].nIndex
|
||||||
|
else
|
||||||
|
idFirstFace = 0
|
||||||
|
idSecondFace = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
ptC[1], vtN[1] = EgtSurfTmFacetCenter( Proc.Id, idFirstFace, GDB_ID.ROOT)
|
||||||
|
ptC[2], vtN[2] = EgtSurfTmFacetCenter( Proc.Id, idSecondFace, GDB_ID.ROOT)
|
||||||
|
|
||||||
-- normale media per capire se taglio di testa o di coda
|
-- normale media per capire se taglio di testa o di coda
|
||||||
local vtNm = ( vtN[1] + vtN[2]) ; vtNm:normalize()
|
local vtNm = ( vtN[1] + vtN[2]) ; vtNm:normalize()
|
||||||
local bHead = ( vtNm:getX() > 0)
|
local bHead = ( vtNm:getX() > 0)
|
||||||
-- angolo diedro per stabilire se taglio convesso
|
-- angolo diedro per stabilire se taglio convesso
|
||||||
local bAdj, ptP1, ptP2, dAng = EgtSurfTmFacetsContact( Proc.Id, 0, 1, GDB_ID.ROOT)
|
local bAdj, ptP1, ptP2, dAng = EgtSurfTmFacetsContact( Proc.Id, idFirstFace, idSecondFace, GDB_ID.ROOT)
|
||||||
local bConvex = true
|
local bConvex = true
|
||||||
local bOnY = true
|
local bOnY = true
|
||||||
local ptPs = ( ptC[1] + ptC[2]) / 2
|
local ptPs = ( ptC[1] + ptC[2]) / 2
|
||||||
@@ -492,8 +515,8 @@ function ProcessDoubleCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
bConvex = ( dAng > 0)
|
bConvex = ( dAng > 0)
|
||||||
end
|
end
|
||||||
-- determino quale faccia è più grande
|
-- determino quale faccia è più grande
|
||||||
local _, dB1, dH1 = EgtSurfTmFacetMinAreaRectangle( Proc.Id, 0)
|
local _, dB1, dH1 = EgtSurfTmFacetMinAreaRectangle( Proc.Id, idFirstFace)
|
||||||
local _, dB2, dH2 = EgtSurfTmFacetMinAreaRectangle( Proc.Id, 1)
|
local _, dB2, dH2 = EgtSurfTmFacetMinAreaRectangle( Proc.Id, idSecondFace)
|
||||||
local nBigInd = EgtIf( dB1 * dH1 >= dB2 * dH2, 1, 2)
|
local nBigInd = EgtIf( dB1 * dH1 >= dB2 * dH2, 1, 2)
|
||||||
local nSmaInd = 3 - nBigInd
|
local nSmaInd = 3 - nBigInd
|
||||||
-- inserimento smussi
|
-- inserimento smussi
|
||||||
@@ -560,8 +583,8 @@ function ProcessDoubleCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
dMaxDepth = EgtTdbGetCurrToolMaxDepth() or dMaxDepth
|
dMaxDepth = EgtTdbGetCurrToolMaxDepth() or dMaxDepth
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
local _, _, dDimV1 = BL.GetFaceHvRefDim( Proc.Id, 0, b3Raw)
|
local _, _, dDimV1 = BL.GetFaceHvRefDim( Proc.Id, idFirstFace, b3Raw)
|
||||||
local _, _, dDimV2 = BL.GetFaceHvRefDim( Proc.Id, 1, b3Raw)
|
local _, _, dDimV2 = BL.GetFaceHvRefDim( Proc.Id, idSecondFace, b3Raw)
|
||||||
local bFace1TooLongForBlade, bFace2TooLongForBlade = ( dDimV1 >= dMaxDepth), ( dDimV2 >= dMaxDepth)
|
local bFace1TooLongForBlade, bFace2TooLongForBlade = ( dDimV1 >= dMaxDepth), ( dDimV2 >= dMaxDepth)
|
||||||
local dFace1Ang, dFace2Ang = vtN[1]:getZ(), vtN[2]:getZ()
|
local dFace1Ang, dFace2Ang = vtN[1]:getZ(), vtN[2]:getZ()
|
||||||
if bFace1TooLongForBlade and dFace1Ang < ( BD.CUT_VZ_MIN or -0.484) or bFace2TooLongForBlade and dFace2Ang < ( BD.CUT_VZ_MIN or -0.484) then
|
if bFace1TooLongForBlade and dFace1Ang < ( BD.CUT_VZ_MIN or -0.484) or bFace2TooLongForBlade and dFace2Ang < ( BD.CUT_VZ_MIN or -0.484) then
|
||||||
|
|||||||
@@ -1190,14 +1190,14 @@ local function Make2Faces( Proc, nPhase, nRawId, nPartId, dOvmHead, b3Raw, b3Sol
|
|||||||
return MakeByBlade( Proc, nPhase, nRawId, nPartId, dOvmHead, b3Raw, b3Solid)
|
return MakeByBlade( Proc, nPhase, nRawId, nPartId, dOvmHead, b3Raw, b3Solid)
|
||||||
-- altrimenti provo con il truciolatore
|
-- altrimenti provo con il truciolatore
|
||||||
else
|
else
|
||||||
|
local sName = 'Mill_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
-- se non ho la lavorazione esco
|
-- se non ho la lavorazione esco
|
||||||
if not sMilling then
|
if not sMilling then
|
||||||
local sErr = 'Error, machining or tool not found ' .. sName .. '-' .. sMilling
|
local sErr = 'Error, machining or tool not found ' .. sName
|
||||||
EgtOutLog( sErr)
|
EgtOutLog( sErr)
|
||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
-- inserisco la lavorazione di fresatura
|
-- inserisco la lavorazione di fresatura
|
||||||
local sName = 'Mill_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
|
||||||
local nMchFId = EgtAddMachining( sName, sMilling)
|
local nMchFId = EgtAddMachining( sName, sMilling)
|
||||||
if not nMchFId then
|
if not nMchFId then
|
||||||
local sErr = 'Error adding machining ' .. sName .. '-' .. sMilling
|
local sErr = 'Error adding machining ' .. sName .. '-' .. sMilling
|
||||||
|
|||||||
@@ -209,7 +209,8 @@ function ProcessDrill.AddPredrillFromDrillProc( Proc)
|
|||||||
PredrillProc.MainId = Proc.MainId
|
PredrillProc.MainId = Proc.MainId
|
||||||
PredrillProc.IsPredrill = true
|
PredrillProc.IsPredrill = true
|
||||||
PredrillProc.IsPredrillOf = Proc.Id
|
PredrillProc.IsPredrillOf = Proc.Id
|
||||||
|
-- recupero l'elenco delle facce della parte interessate dalla feature
|
||||||
|
PredrillProc.AffectedFaces = BL.GetProcessAffectedFaces( PredrillProc)
|
||||||
return true, PredrillProc
|
return true, PredrillProc
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -250,8 +251,13 @@ function ProcessDrill.Classify( Proc, b3Raw, sDownOrSideOrStd)
|
|||||||
-- se ci sono delle dipendenze da altre feature da rispettare
|
-- se ci sono delle dipendenze da altre feature da rispettare
|
||||||
if sDownOrSideOrStd then
|
if sDownOrSideOrStd then
|
||||||
if sDownOrSideOrStd == 'DOWN' then
|
if sDownOrSideOrStd == 'DOWN' then
|
||||||
if vtExtr:getZ() < - BD.DRILL_VZ_MIN then
|
-- se foro fatto in doppio entrambe le forature (valore assoluto) devono essere sopra al valore limite, se foro singolo deve essere sopra al valore limite se ribaltato
|
||||||
Proc.Down = true
|
if ( abs( Proc.Flg) == 2 and ( abs( vtExtr:getZ()) < - BD.DRILL_VZ_MIN) or ( abs( Proc.Flg) ~= 2 and vtExtr:getZ() < - BD.DRILL_VZ_MIN)) then
|
||||||
|
-- in doppio non cambio di fase al foro perchè devo garantire il lato master su H1
|
||||||
|
if not( Proc.Double) or Proc.Double == 0 then
|
||||||
|
Proc.Down = true
|
||||||
|
Proc.Side = false
|
||||||
|
end
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -383,6 +389,25 @@ function ProcessDrill.Make( Proc, nPhase, nRawId, nPartId)
|
|||||||
-- primo gruppo di controlli con lunghezza utensile pari a metà foro se passante
|
-- primo gruppo di controlli con lunghezza utensile pari a metà foro se passante
|
||||||
-- recupero la lavorazione
|
-- recupero la lavorazione
|
||||||
local sDrilling, sType, dMaxDepth, dMaxToolLength, dToolDiam, dDiamTh, dToolFreeLen = ML.FindDrilling( dDiam, dCheckDepth, bDrillUp, bDrillDown, bExcludeH2, bDrillAngTrasm, Proc.IsPredrill)
|
local sDrilling, sType, dMaxDepth, dMaxToolLength, dToolDiam, dDiamTh, dToolFreeLen = ML.FindDrilling( dDiam, dCheckDepth, bDrillUp, bDrillDown, bExcludeH2, bDrillAngTrasm, Proc.IsPredrill)
|
||||||
|
|
||||||
|
if sDrilling then
|
||||||
|
-- Determino la faccia di inizio del foro e dati correlati
|
||||||
|
local nFac, CosB, vFaces = GetHoleStartData( ptCen, vtExtr, b3Solid)
|
||||||
|
-- Calcolo acciorciamento affondamento utile per evitare collisione portautensile con faccia
|
||||||
|
local TgA = CosB / sqrt( 1 - CosB * CosB)
|
||||||
|
local dSubL = ( dDiamTh / 2 + ( Proc.Diam - dToolDiam) / 2 + 4) * TgA
|
||||||
|
-- Per fori molto inclinati ( < 30 gradi) si usa la testa della macchina per l'accorciamento. Fast esclusa
|
||||||
|
if BD.C_SIMM and CosB > 0.866 then
|
||||||
|
dSubL = ( 190 / 2 + ( Proc.Diam - dToolDiam) / 2 + 4) * TgA - 116
|
||||||
|
end
|
||||||
|
local dMaxDepthOri = dMaxDepth
|
||||||
|
dMaxDepth = min( dMaxDepth, max( dToolFreeLen - dSubL, 0))
|
||||||
|
-- se utensile scelto non arriva in fondo, cerco il più lungo
|
||||||
|
if dMaxDepth < GEO.EPS_SMALL * 10 then
|
||||||
|
sDrilling, sType, dMaxDepth, dMaxToolLength, dToolDiam, dDiamTh, dToolFreeLen = ML.FindDrilling( dDiam, dCheckDepth, bDrillUp, bDrillDown, bExcludeH2, bDrillAngTrasm, Proc.IsPredrill, nil, 'Longest')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
if not sDrilling and dCheckDepth then
|
if not sDrilling and dCheckDepth then
|
||||||
sDrilling, sType, dMaxDepth, dMaxToolLength, dToolDiam, dDiamTh, dToolFreeLen = ML.FindDrilling( dDiam, 0, bDrillUp, bDrillDown, bExcludeH2, bDrillAngTrasm, Proc.IsPredrill)
|
sDrilling, sType, dMaxDepth, dMaxToolLength, dToolDiam, dDiamTh, dToolFreeLen = ML.FindDrilling( dDiam, 0, bDrillUp, bDrillDown, bExcludeH2, bDrillAngTrasm, Proc.IsPredrill)
|
||||||
if sDrilling then dCheckDepth = nil end
|
if sDrilling then dCheckDepth = nil end
|
||||||
@@ -477,16 +502,28 @@ function ProcessDrill.Make( Proc, nPhase, nRawId, nPartId)
|
|||||||
EgtOutLog( sErr)
|
EgtOutLog( sErr)
|
||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
|
-- eventuale inversione foro in base al lato di lavoro e al lato testa dell'utensile scelto
|
||||||
|
-- se non già richiesta inversione e foro quasi orizzontale (15deg) passante
|
||||||
|
if not bToInvert and Proc.Flg == 1 and bOpen and abs( vtExtr:getZ()) < 0.259 and abs( vtExtr:getY()) > 0.966 then
|
||||||
|
local Tool = BL.GetToolFromMachining( sDrilling)
|
||||||
|
-- lato testa e lato di lavoro devono corrispondere
|
||||||
|
if ( ( Tool.PreferredSide.bFront == true) and vtExtr:getY() > 10 * GEO.EPS_SMALL)
|
||||||
|
or ( ( Tool.PreferredSide.bBack == true) and vtExtr:getY() < - 10 * GEO.EPS_SMALL) then
|
||||||
|
ptCen = ptCen - vtExtr * dLen
|
||||||
|
vtExtr = - vtExtr
|
||||||
|
bToInvert = true
|
||||||
|
end
|
||||||
|
end
|
||||||
-- Determino la faccia di inizio del foro e dati correlati
|
-- Determino la faccia di inizio del foro e dati correlati
|
||||||
local nFac, CosB, vFaces = GetHoleStartData( ptCen, vtExtr, b3Solid)
|
nFac, CosB, vFaces = GetHoleStartData( ptCen, vtExtr, b3Solid)
|
||||||
-- Calcolo acciorciamento affondamento utile per evitare collisione portautensile con faccia
|
-- Calcolo acciorciamento affondamento utile per evitare collisione portautensile con faccia
|
||||||
local TgA = CosB / sqrt( 1 - CosB * CosB)
|
TgA = CosB / sqrt( 1 - CosB * CosB)
|
||||||
local dSubL = ( dDiamTh / 2 + ( Proc.Diam - dToolDiam) / 2 + 4) * TgA
|
dSubL = ( dDiamTh / 2 + ( Proc.Diam - dToolDiam) / 2 + 4) * TgA
|
||||||
-- Per fori molto inclinati ( < 30 gradi) si usa la testa della macchina per l'accorciamento. Fast esclusa
|
-- Per fori molto inclinati ( < 30 gradi) si usa la testa della macchina per l'accorciamento. Fast esclusa
|
||||||
if BD.C_SIMM and CosB > 0.866 then
|
if BD.C_SIMM and CosB > 0.866 then
|
||||||
dSubL = ( 190 / 2 + ( Proc.Diam - dToolDiam) / 2 + 4) * TgA - 116
|
dSubL = ( 190 / 2 + ( Proc.Diam - dToolDiam) / 2 + 4) * TgA - 116
|
||||||
end
|
end
|
||||||
local dMaxDepthOri = dMaxDepth
|
dMaxDepthOri = dMaxDepth
|
||||||
dMaxDepth = min( dMaxDepth, max( dToolFreeLen - dSubL, 0))
|
dMaxDepth = min( dMaxDepth, max( dToolFreeLen - dSubL, 0))
|
||||||
-- Verifico inclinazione foro nei limiti
|
-- Verifico inclinazione foro nei limiti
|
||||||
local bTryDrill = EgtIf( dMaxDepth > 0, ( CosB < BD.DRILL_VX_MAX), false)
|
local bTryDrill = EgtIf( dMaxDepth > 0, ( CosB < BD.DRILL_VX_MAX), false)
|
||||||
@@ -509,7 +546,7 @@ function ProcessDrill.Make( Proc, nPhase, nRawId, nPartId)
|
|||||||
if bIntersectionOk then
|
if bIntersectionOk then
|
||||||
local dHoleToCutDistance = vDistance[1]
|
local dHoleToCutDistance = vDistance[1]
|
||||||
-- se il taglio accorcia realmente il foro
|
-- se il taglio accorcia realmente il foro
|
||||||
if dHoleToCutDistance > 10 * GEO.EPS_SMALL and dHoleToCutDistance < dLen then
|
if ( dHoleToCutDistance > 10 * GEO.EPS_SMALL or Proc.AffectedFaces.Right) and dHoleToCutDistance < dLen then
|
||||||
dMaxDepth = dMaxDepthOri
|
dMaxDepth = dMaxDepthOri
|
||||||
dMaxElev = dLen - dHoleToCutDistance
|
dMaxElev = dLen - dHoleToCutDistance
|
||||||
bTryDrill = true
|
bTryDrill = true
|
||||||
@@ -560,6 +597,8 @@ function ProcessDrill.Make( Proc, nPhase, nRawId, nPartId)
|
|||||||
local nSCC = MCH_SCC.NONE
|
local nSCC = MCH_SCC.NONE
|
||||||
if bDrillAngTrasm then
|
if bDrillAngTrasm then
|
||||||
nSCC = MCH_SCC.ADIR_NEAR
|
nSCC = MCH_SCC.ADIR_NEAR
|
||||||
|
elseif BD.TURN == 2 then
|
||||||
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
elseif not BD.C_SIMM and not BD.TURN then
|
elseif not BD.C_SIMM and not BD.TURN then
|
||||||
nSCC = MCH_SCC.ADIR_YM
|
nSCC = MCH_SCC.ADIR_YM
|
||||||
if AreSameVectorApprox( vtExtr, Z_AX()) then
|
if AreSameVectorApprox( vtExtr, Z_AX()) then
|
||||||
@@ -599,6 +638,16 @@ function ProcessDrill.Make( Proc, nPhase, nRawId, nPartId)
|
|||||||
end
|
end
|
||||||
-- se lavorazione in doppio
|
-- se lavorazione in doppio
|
||||||
if Proc.Double and Proc.Double > 0 then
|
if Proc.Double and Proc.Double > 0 then
|
||||||
|
-- calcolo gli step reali
|
||||||
|
local dStep = EgtGetMachiningParam( MCH_MP.STEP)
|
||||||
|
local nNumStep = ceil( dDepth/dStep)
|
||||||
|
local dRealStep = dDepth / nNumStep
|
||||||
|
-- Se foro passante e nel penultimo step le punte si trovano più vicine del minimo ( MinDistX1X2 + Puntina centraggio H1 + puntina centraggio H2) ricalcolo facendo uno step in meno
|
||||||
|
if bOpen and ( nNumStep > 1) and ( ( dLen / 2) - ( dRealStep * (nNumStep - 1))) * 2 < ( 40 + 10 + 10) then
|
||||||
|
dRealStep = ceil( dDepth / (nNumStep - 1))
|
||||||
|
EgtSetMachiningParam( MCH_MP.STEP, dRealStep)
|
||||||
|
sMyWarn ='Warning in drill-double : step changed to ' .. tostring(dRealStep) .. 'mm'
|
||||||
|
end
|
||||||
sUserNotes = EgtSetValInNotes( sUserNotes, 'DOUBLE', Proc.Double)
|
sUserNotes = EgtSetValInNotes( sUserNotes, 'DOUBLE', Proc.Double)
|
||||||
if Proc.Double ~= Proc.PrevDouble then
|
if Proc.Double ~= Proc.PrevDouble then
|
||||||
sUserNotes = EgtSetValInNotes( sUserNotes, 'StartZmax', 2)
|
sUserNotes = EgtSetValInNotes( sUserNotes, 'StartZmax', 2)
|
||||||
|
|||||||
+240
-97
@@ -20,6 +20,7 @@ local ProcessDtMortise = {}
|
|||||||
require( 'EgtBase')
|
require( 'EgtBase')
|
||||||
local BL = require( 'BeamLib')
|
local BL = require( 'BeamLib')
|
||||||
local Cut = require( 'ProcessCut')
|
local Cut = require( 'ProcessCut')
|
||||||
|
local Probe = require( 'ProcessProbing')
|
||||||
|
|
||||||
EgtOutLog( ' ProcessDtMortise started', 1)
|
EgtOutLog( ' ProcessDtMortise started', 1)
|
||||||
|
|
||||||
@@ -103,7 +104,7 @@ function ProcessDtMortise.GetCutPlane( Proc)
|
|||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
local function CalcTopPath( nProcId, AuxId, nAddGrpId, dAltMort, dSideAng, b3Solid)
|
local function CalcPathAtHeight( nProcId, AuxId, nAddGrpId, dHeight, dSideAng, b3Solid)
|
||||||
-- copio la curva di base
|
-- copio la curva di base
|
||||||
local NewAuxId = EgtCopyGlob( AuxId, nAddGrpId)
|
local NewAuxId = EgtCopyGlob( AuxId, nAddGrpId)
|
||||||
if not NewAuxId then return end
|
if not NewAuxId then return end
|
||||||
@@ -111,16 +112,16 @@ local function CalcTopPath( nProcId, AuxId, nAddGrpId, dAltMort, dSideAng, b3Sol
|
|||||||
EgtAddCurveCompoLineTg( NewAuxId, 100, false)
|
EgtAddCurveCompoLineTg( NewAuxId, 100, false)
|
||||||
EgtAddCurveCompoLineTg( NewAuxId, 100, true)
|
EgtAddCurveCompoLineTg( NewAuxId, 100, true)
|
||||||
EgtMergeCurvesInCurveCompo( NewAuxId)
|
EgtMergeCurvesInCurveCompo( NewAuxId)
|
||||||
-- eseguo traslazione e offset per portarla sul top
|
local dOffset = dHeight * tan( dSideAng)
|
||||||
local vtMove = EgtCurveExtrusion( AuxId, GDB_RT.GLOB) * ( dAltMort - 10 * GEO.EPS_SMALL)
|
|
||||||
EgtMove( NewAuxId, vtMove, GDB_RT.GLOB)
|
|
||||||
local dOffset = dAltMort * tan( dSideAng)
|
|
||||||
if not EgtOffsetCurve( NewAuxId, dOffset) then return end
|
if not EgtOffsetCurve( NewAuxId, dOffset) then return end
|
||||||
-- la limito entro la trave
|
-- la limito entro la trave
|
||||||
local refBox = Frame3d( b3Solid:getMin())
|
local refBox = Frame3d( b3Solid:getMin())
|
||||||
local vtBoxDiag = b3Solid:getMax() - b3Solid:getMin()
|
local vtBoxDiag = b3Solid:getMax() - b3Solid:getMin()
|
||||||
local nCount
|
local nCount
|
||||||
NewAuxId, nCount = EgtTrimFlatCurveWithBox( NewAuxId, refBox, vtBoxDiag, true, true, GDB_RT.GLOB)
|
NewAuxId, nCount = EgtTrimFlatCurveWithBox( NewAuxId, refBox, vtBoxDiag, true, true, GDB_RT.GLOB)
|
||||||
|
-- eseguo traslazione e offset per portarla sul top
|
||||||
|
local vtMove = EgtCurveExtrusion( AuxId, GDB_RT.GLOB) * ( dHeight - 10 * GEO.EPS_SMALL)
|
||||||
|
EgtMove( NewAuxId, vtMove, GDB_RT.GLOB)
|
||||||
-- se divisa in più parti, le unisco congiungendole con segmenti
|
-- se divisa in più parti, le unisco congiungendole con segmenti
|
||||||
if nCount > 1 then
|
if nCount > 1 then
|
||||||
if EgtGetType( NewAuxId) ~= GDB_TY.CRV_COMPO then
|
if EgtGetType( NewAuxId) ~= GDB_TY.CRV_COMPO then
|
||||||
@@ -136,6 +137,23 @@ local function CalcTopPath( nProcId, AuxId, nAddGrpId, dAltMort, dSideAng, b3Sol
|
|||||||
return NewAuxId
|
return NewAuxId
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
local function GetVerticalSteps( dMachiningDepth, dStep )
|
||||||
|
local MachiningSteps = {}
|
||||||
|
MachiningSteps.StepLength = 0
|
||||||
|
|
||||||
|
if dMachiningDepth <= 0 then
|
||||||
|
MachiningSteps.Count = 0
|
||||||
|
return MachiningSteps
|
||||||
|
end
|
||||||
|
|
||||||
|
MachiningSteps.Count = ceil( (dMachiningDepth - 10 * GEO.EPS_SMALL) / dStep )
|
||||||
|
|
||||||
|
MachiningSteps.StepLength = dMachiningDepth / MachiningSteps.Count
|
||||||
|
|
||||||
|
return MachiningSteps
|
||||||
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- verifica che il box includa il punto in XY
|
-- verifica che il box includa il punto in XY
|
||||||
function EnclosesPoint( b3Box, ptP)
|
function EnclosesPoint( b3Box, ptP)
|
||||||
@@ -154,6 +172,8 @@ end
|
|||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- Applicazione della lavorazione
|
-- Applicazione della lavorazione
|
||||||
function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
||||||
|
local sWarn
|
||||||
|
bMakeAntiSplitPath = true
|
||||||
-- ingombro del pezzo
|
-- ingombro del pezzo
|
||||||
local b3Solid = EgtGetBBoxGlob( EgtGetFirstNameInGroup( nPartId, 'Box') or GDB_ID.NULL, GDB_BB.STANDARD)
|
local b3Solid = EgtGetBBoxGlob( EgtGetFirstNameInGroup( nPartId, 'Box') or GDB_ID.NULL, GDB_BB.STANDARD)
|
||||||
if not b3Solid then
|
if not b3Solid then
|
||||||
@@ -273,7 +293,9 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
local dToolDiam = 100
|
local dToolDiam = 100
|
||||||
local dMaxMat = 30
|
local dMaxMat = 30
|
||||||
local dSideAng = 0
|
local dSideAng = 0
|
||||||
|
local sHeadTool = 'H1'
|
||||||
local bCW = true
|
local bCW = true
|
||||||
|
local bMillOnAggregate = sMchExt == '_AT'
|
||||||
if EgtMdbSetCurrMachining( sMilling) then
|
if EgtMdbSetCurrMachining( sMilling) then
|
||||||
local sTuuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
local sTuuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
||||||
if EgtTdbSetCurrTool( EgtTdbGetToolFromUUID( sTuuid) or '') then
|
if EgtTdbSetCurrTool( EgtTdbGetToolFromUUID( sTuuid) or '') then
|
||||||
@@ -281,16 +303,66 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
dToolDiam = max( dToolDiam, 10)
|
dToolDiam = max( dToolDiam, 10)
|
||||||
dMaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT) or dMaxMat
|
dMaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT) or dMaxMat
|
||||||
dSideAng = EgtTdbGetCurrToolParam( MCH_TP.SIDEANG) or dSideAng
|
dSideAng = EgtTdbGetCurrToolParam( MCH_TP.SIDEANG) or dSideAng
|
||||||
|
sHeadTool = EgtTdbGetCurrToolParam( MCH_TP.HEAD)
|
||||||
local dSpeed = EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) or 0
|
local dSpeed = EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) or 0
|
||||||
bCW = ( dSpeed >= 0)
|
bCW = ( dSpeed >= 0)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- verifico che la profondità non superi il massimo materiale dell'utensile
|
local bMultipleZPasses = false
|
||||||
|
-- se necessario, cerco un utensile più lungo
|
||||||
if dAltMort > dMaxMat + 10 * GEO.EPS_SMALL then
|
if dAltMort > dMaxMat + 10 * GEO.EPS_SMALL then
|
||||||
local sErr = 'Error : DtMortise Depth bigger than Tool Cutting edge'
|
-- recupero la lavorazione : prima ricerca per sola tipologia
|
||||||
EgtOutLog( sErr)
|
sMilling = ML.FindMilling( sMillType..sMchExt, nil, nil, nil, nil, bMillUp, bMillDown, bExcludeH2, nil, 'Longest')
|
||||||
return false, sErr
|
if not sMilling and bMillUp then
|
||||||
|
sMilling = ML.FindMilling( sMillType, nil, nil, nil, nil, bMillUp, bMillDown, bExcludeH2, nil, 'Longest')
|
||||||
|
end
|
||||||
|
if not sMilling then
|
||||||
|
local sErr = 'Milling not found in library : Error on DtMortise ' .. tostring( Proc.Id)
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- recupero la lavorazione : seconda ricerca con tipologia e diametro massimo
|
||||||
|
sMilling = ML.FindMilling( sMillType..sMchExt, nil, nil, 2 * dMinRad, nil, bMillUp, bMillDown, bExcludeH2, nil, 'Longest')
|
||||||
|
if not sMilling and bMillUp then
|
||||||
|
sMilling = ML.FindMilling( sMillType, nil, nil, 2 * dMinRad, nil, bMillUp, bMillDown, bExcludeH2, nil, 'Longest')
|
||||||
|
sMchExt = ''
|
||||||
|
end
|
||||||
|
if not sMilling then
|
||||||
|
local sErr = 'Radius too small : Error on DtMortise ' .. tostring( Proc.Id)
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
if not sMilling then
|
||||||
|
local sErr = 'Error : DtMortise Depth bigger than Tool Cutting edge'
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- riassegno dati utensile
|
||||||
|
dToolDiam = 100
|
||||||
|
dMaxMat = 30
|
||||||
|
dSideAng = 0
|
||||||
|
bCW = true
|
||||||
|
bMillOnAggregate = sMchExt == '_AT'
|
||||||
|
if EgtMdbSetCurrMachining( sMilling) then
|
||||||
|
local sTuuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
||||||
|
if EgtTdbSetCurrTool( EgtTdbGetToolFromUUID( sTuuid) or '') then
|
||||||
|
dToolDiam = EgtTdbGetCurrToolParam( MCH_TP.DIAM) or dToolDiam
|
||||||
|
dToolDiam = max( dToolDiam, 10)
|
||||||
|
dMaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT) or dMaxMat
|
||||||
|
dSideAng = EgtTdbGetCurrToolParam( MCH_TP.SIDEANG) or dSideAng
|
||||||
|
local dSpeed = EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) or 0
|
||||||
|
bCW = ( dSpeed >= 0)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
bMultipleZPasses = true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- tastatura se richiesta
|
||||||
|
local Info = { vtProbe = vtExtr, ptProbe = ptBC, sType = 'DTMortise', sHead = sHeadTool}
|
||||||
|
local bProbeExecuted, sErr = Probe.Make( Proc, nPartId, Info)
|
||||||
|
|
||||||
-- se con tasca, la lavoro (mai in doppio)
|
-- se con tasca, la lavoro (mai in doppio)
|
||||||
if bPocket then
|
if bPocket then
|
||||||
-- recupero il contorno della tasca (seconda curva ausiliaria)
|
-- recupero il contorno della tasca (seconda curva ausiliaria)
|
||||||
@@ -345,11 +417,20 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
end
|
end
|
||||||
-- eventuale calcolo SCC
|
-- eventuale calcolo SCC
|
||||||
local nSCC
|
local nSCC
|
||||||
if BD.TURN and not bPocket then
|
if BD.TURN then
|
||||||
if abs( vtAx:getY()) > abs( vtAx:getZ()) then
|
if not bPocket then
|
||||||
nSCC = EgtIf( vtAx:getY() > 0, MCH_SCC.ADIR_YP, MCH_SCC.ADIR_YM)
|
if abs( vtAx:getY()) > abs( vtAx:getZ()) then
|
||||||
else
|
nSCC = EgtIf( vtAx:getY() > 0, MCH_SCC.ADIR_YP, MCH_SCC.ADIR_YM)
|
||||||
nSCC = EgtIf( vtAx:getZ() > 0, MCH_SCC.ADIR_ZP, MCH_SCC.ADIR_ZM)
|
else
|
||||||
|
nSCC = EgtIf( vtAx:getZ() > 0, MCH_SCC.ADIR_ZP, MCH_SCC.ADIR_ZM)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- se aggregato e rivolto verso Z-, si accede da lato aperto
|
||||||
|
elseif bMillOnAggregate and AreSameVectorApprox( vtExtr, -Z_AX()) then
|
||||||
|
if Proc.AffectedFaces.Back then
|
||||||
|
nSCC = MCH_SCC.ADIR_YP
|
||||||
|
elseif Proc.AffectedFaces.Front then
|
||||||
|
nSCC = MCH_SCC.ADIR_YM
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- flag di mirror precedente aggiornabile localmente
|
-- flag di mirror precedente aggiornabile localmente
|
||||||
@@ -364,93 +445,101 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
-- calcolo il percorso top mortise
|
-- calcolo il percorso top mortise
|
||||||
local nAuxId1 = CalcTopPath( Proc.Id, AuxId, nAddGrpId, dAltMort, dSideAng, b3Solid)
|
local nAuxId1 = CalcPathAtHeight( Proc.Id, AuxId, nAddGrpId, dAltMort, dSideAng, b3Solid)
|
||||||
-- se esiste il percorso
|
-- se esiste il percorso
|
||||||
if nAuxId1 then
|
if nAuxId1 then
|
||||||
-- creo percorso sulla parte alta della mortasa
|
if EgtCurveIsFlat( nAuxId1) then
|
||||||
local dToolRadDelta = dAltMort * tan( dSideAng)
|
-- creo percorso sulla parte alta della mortasa
|
||||||
local dTopDiam = dToolDiam + 2 * dToolRadDelta
|
local dToolRadDelta = dAltMort * tan( dSideAng)
|
||||||
-- recupero punto iniziale e finale del percorso
|
local dTopDiam = dToolDiam + 2 * dToolRadDelta
|
||||||
local ptStart = EgtSP( nAuxId1, GDB_RT.GLOB)
|
-- recupero punto iniziale e finale del percorso
|
||||||
local ptEnd = EgtEP( nAuxId1, GDB_RT.GLOB)
|
local ptStart = EgtSP( nAuxId1, GDB_RT.GLOB)
|
||||||
if ptStart and ptEnd then
|
local ptEnd = EgtEP( nAuxId1, GDB_RT.GLOB)
|
||||||
local nId1
|
if ptStart and ptEnd then
|
||||||
-- se richiesti due segmenti di linea
|
local nId1
|
||||||
if not bMakeAsByArc then
|
-- se richiesti due segmenti di linea
|
||||||
-- determino il punto comune dei due segmenti
|
if not bMakeAsByArc then
|
||||||
local vtDelta = ( ptEnd - ptStart) / 4
|
-- determino il punto comune dei due segmenti
|
||||||
vtDelta:rotate( vtExtr, -90)
|
local vtDelta = ( ptEnd - ptStart) / 4
|
||||||
local ptMid = ( ptStart + ptEnd) / 2 + vtDelta
|
vtDelta:rotate( vtExtr, -90)
|
||||||
-- creo la spezzata formata dai due segmenti
|
local ptMid = ( ptStart + ptEnd) / 2 + vtDelta
|
||||||
nId1 = EgtCurveCompoFromPoints( nAddGrpId, { ptStart, ptMid, ptEnd}, GDB_RT.GLOB)
|
-- creo la spezzata formata dai due segmenti
|
||||||
-- altrimenti richiesto arco
|
nId1 = EgtCurveCompoFromPoints( nAddGrpId, { ptStart, ptMid, ptEnd}, GDB_RT.GLOB)
|
||||||
|
-- altrimenti richiesto arco
|
||||||
|
else
|
||||||
|
-- direzione del segmento
|
||||||
|
local vtDir = ptEnd - ptStart ;
|
||||||
|
local dLen = vtDir:len()
|
||||||
|
vtDir:normalize()
|
||||||
|
-- direzioni tangenti iniziale e finale
|
||||||
|
local vtStart = EgtSV( nAuxId1, GDB_RT.GLOB)
|
||||||
|
local vtEnd = EgtEV( nAuxId1, GDB_RT.GLOB)
|
||||||
|
-- angoli
|
||||||
|
local dAngStart = acos( vtStart * vtDir)
|
||||||
|
local dAngEnd = acos( vtEnd * vtDir)
|
||||||
|
local dMaxAng = min( 30, dAngStart, dAngEnd)
|
||||||
|
if dLen < dTopDiam then
|
||||||
|
dMaxAng = min( dMaxAng, asin( dLen / dTopDiam))
|
||||||
|
end
|
||||||
|
local vtTg = vtDir ; vtTg:rotate( vtExtr, -dMaxAng)
|
||||||
|
-- creo l'arco
|
||||||
|
nId1 = EgtArc2PV( nAddGrpId, ptStart, ptEnd, vtTg, GDB_RT.GLOB)
|
||||||
|
end
|
||||||
|
if not nId1 then
|
||||||
|
local sErr = 'Wrong geometry : Error on DtMortise '
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
EgtModifyCurveExtrusion( nId1, vtExtr, GDB_RT.GLOB)
|
||||||
|
-- inserisco la lavorazione di contornatura anti splint
|
||||||
|
local sNameF = 'DtMtAS_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
|
local nMchFId = EgtAddMachining( sNameF, sMilling)
|
||||||
|
if not nMchFId then
|
||||||
|
local sErr = 'Error adding machining ' .. sNameF .. '-' .. sMilling
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- aggiungo geometria
|
||||||
|
EgtSetMachiningGeometry( {{ nId1, -1}})
|
||||||
|
-- setto affondamento pari all'altezza della mortsasa
|
||||||
|
EgtSetMachiningParam( MCH_MP.DEPTH, dAltMort)
|
||||||
|
-- setto offset radiale con aggiunto un ulteriore allargamento di 1mm
|
||||||
|
EgtSetMachiningParam( MCH_MP.OFFSR, dToolRadDelta - 1)
|
||||||
|
-- antischeggia sempre con una passata
|
||||||
|
if bMultipleZPasses then
|
||||||
|
EgtSetMachiningParam( MCH_MP.STEP, 0)
|
||||||
|
end
|
||||||
|
-- sistemo il lato e la direzione di lavoro
|
||||||
|
EgtSetMachiningParam( MCH_MP.WORKSIDE, EgtIf( bCW, MCH_MILL_WS.LEFT, MCH_MILL_WS.RIGHT))
|
||||||
|
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( bCW, false, true))
|
||||||
|
-- se necessario, imposto SCC
|
||||||
|
if nSCC then
|
||||||
|
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
||||||
|
end
|
||||||
|
-- dichiaro non si generano sfridi per VMill
|
||||||
|
local sUserNotes = 'MaxElev='.. EgtNumToString( dAltMort, 1) .. '; VMRS=0;'
|
||||||
|
-- se lavorazione in doppio
|
||||||
|
if Proc.Double and Proc.Double > 0 then
|
||||||
|
sUserNotes = EgtSetValInNotes( sUserNotes, 'DOUBLE', Proc.Double)
|
||||||
|
if Proc.Double ~= nMyPrevDouble then
|
||||||
|
nMyPrevDouble = Proc.Double
|
||||||
|
sUserNotes = EgtSetValInNotes( sUserNotes, 'StartZmax', 2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
EgtSetMachiningParam( MCH_MP.USERNOTES, sUserNotes)
|
||||||
|
-- eseguo
|
||||||
|
if not ML.ApplyMachining( true, false) then
|
||||||
|
local _, sErr = EgtGetLastMachMgrError()
|
||||||
|
EgtSetOperationMode( nMchFId, false)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
else
|
else
|
||||||
-- direzione del segmento
|
local sErr = 'Wrong geometry : Error on DtMortise ' .. tostring( Proc.Id)
|
||||||
local vtDir = ptEnd - ptStart ;
|
|
||||||
local dLen = vtDir:len()
|
|
||||||
vtDir:normalize()
|
|
||||||
-- direzioni tangenti iniziale e finale
|
|
||||||
local vtStart = EgtSV( nAuxId1, GDB_RT.GLOB)
|
|
||||||
local vtEnd = EgtEV( nAuxId1, GDB_RT.GLOB)
|
|
||||||
-- angoli
|
|
||||||
local dAngStart = acos( vtStart * vtDir)
|
|
||||||
local dAngEnd = acos( vtEnd * vtDir)
|
|
||||||
local dMaxAng = min( 30, dAngStart, dAngEnd)
|
|
||||||
if dLen < dTopDiam then
|
|
||||||
dMaxAng = min( dMaxAng, asin( dLen / dTopDiam))
|
|
||||||
end
|
|
||||||
local vtTg = vtDir ; vtTg:rotate( vtExtr, -dMaxAng)
|
|
||||||
-- creo l'arco
|
|
||||||
nId1 = EgtArc2PV( nAddGrpId, ptStart, ptEnd, vtTg, GDB_RT.GLOB)
|
|
||||||
end
|
|
||||||
if not nId1 then
|
|
||||||
local sErr = 'Wrong geometry : Error on DtMortise '
|
|
||||||
EgtOutLog( sErr)
|
EgtOutLog( sErr)
|
||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
EgtModifyCurveExtrusion( nId1, vtExtr, GDB_RT.GLOB)
|
|
||||||
-- inserisco la lavorazione di contornatura anti splint
|
|
||||||
local sNameF = 'DtMtAS_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
|
||||||
local nMchFId = EgtAddMachining( sNameF, sMilling)
|
|
||||||
if not nMchFId then
|
|
||||||
local sErr = 'Error adding machining ' .. sNameF .. '-' .. sMilling
|
|
||||||
EgtOutLog( sErr)
|
|
||||||
return false, sErr
|
|
||||||
end
|
|
||||||
-- aggiungo geometria
|
|
||||||
EgtSetMachiningGeometry( {{ nId1, -1}})
|
|
||||||
-- setto affondamento pari all'altezza della mortsasa
|
|
||||||
EgtSetMachiningParam( MCH_MP.DEPTH, dAltMort)
|
|
||||||
-- setto offset radiale con aggiunto un ulteriore allargamento di 1mm
|
|
||||||
EgtSetMachiningParam( MCH_MP.OFFSR, dToolRadDelta - 1)
|
|
||||||
-- sistemo il lato e la direzione di lavoro
|
|
||||||
EgtSetMachiningParam( MCH_MP.WORKSIDE, EgtIf( bCW, MCH_MILL_WS.LEFT, MCH_MILL_WS.RIGHT))
|
|
||||||
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( bCW, false, true))
|
|
||||||
-- se necessario, imposto SCC
|
|
||||||
if nSCC then
|
|
||||||
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
|
||||||
end
|
|
||||||
-- dichiaro non si generano sfridi per VMill
|
|
||||||
local sUserNotes = 'MaxElev='.. EgtNumToString( dAltMort, 1) .. '; VMRS=0;'
|
|
||||||
-- se lavorazione in doppio
|
|
||||||
if Proc.Double and Proc.Double > 0 then
|
|
||||||
sUserNotes = EgtSetValInNotes( sUserNotes, 'DOUBLE', Proc.Double)
|
|
||||||
if Proc.Double ~= nMyPrevDouble then
|
|
||||||
nMyPrevDouble = Proc.Double
|
|
||||||
sUserNotes = EgtSetValInNotes( sUserNotes, 'StartZmax', 2)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
EgtSetMachiningParam( MCH_MP.USERNOTES, sUserNotes)
|
|
||||||
-- eseguo
|
|
||||||
if not ML.ApplyMachining( true, false) then
|
|
||||||
local _, sErr = EgtGetLastMachMgrError()
|
|
||||||
EgtSetOperationMode( nMchFId, false)
|
|
||||||
return false, sErr
|
|
||||||
end
|
|
||||||
else
|
else
|
||||||
local sErr = 'Wrong geometry : Error on DtMortise ' .. tostring( Proc.Id)
|
sWarn = 'Warning : skipped DoveTail mortise antisplint'
|
||||||
EgtOutLog( sErr)
|
|
||||||
return false, sErr
|
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
local sErr = 'Wrong geometry : Error on DtMortise ' .. tostring( Proc.Id)
|
local sErr = 'Wrong geometry : Error on DtMortise ' .. tostring( Proc.Id)
|
||||||
@@ -466,6 +555,23 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
local nPass = ceil( dDist / ( 1.9 * dToolDiam))
|
local nPass = ceil( dDist / ( 1.9 * dToolDiam))
|
||||||
local dStep = 0
|
local dStep = 0
|
||||||
if nPass > 1 then dStep = max( ( dDist - 2 * dToolDiam) / ( 2 * nPass - 2), 0.25 * dToolDiam) end
|
if nPass > 1 then dStep = max( ( dDist - 2 * dToolDiam) / ( 2 * nPass - 2), 0.25 * dToolDiam) end
|
||||||
|
|
||||||
|
local dVerticalStep = 0
|
||||||
|
if bMultipleZPasses then
|
||||||
|
local dToolVerticalStep = 0
|
||||||
|
if EgtMdbSetCurrMachining( sMilling) then
|
||||||
|
dToolVerticalStep = EgtMdbGetCurrMachiningParam( MCH_MP.STEP) or 0
|
||||||
|
end
|
||||||
|
if dToolVerticalStep < 10 * GEO.EPS_SMALL then
|
||||||
|
dToolVerticalStep = dMaxMat / 3
|
||||||
|
else
|
||||||
|
dToolVerticalStep = min( dToolVerticalStep, dMaxMat / 3)
|
||||||
|
end
|
||||||
|
local VerticalSteps = GetVerticalSteps( dAltMort, dToolVerticalStep)
|
||||||
|
dVerticalStep = VerticalSteps.StepLength
|
||||||
|
nPass = VerticalSteps.Count
|
||||||
|
end
|
||||||
|
|
||||||
for i = nPass, 1, -1 do
|
for i = nPass, 1, -1 do
|
||||||
-- inserisco la lavorazione di contornatura
|
-- inserisco la lavorazione di contornatura
|
||||||
local sNameF = 'DtMt_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id)) .. '_' .. tostring( nPass)
|
local sNameF = 'DtMt_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id)) .. '_' .. tostring( nPass)
|
||||||
@@ -476,10 +582,39 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
-- aggiungo geometria
|
-- aggiungo geometria
|
||||||
EgtSetMachiningGeometry( {{ AuxId, -1}})
|
local GeomId = AuxId
|
||||||
|
if ( i > 1) and bMultipleZPasses then
|
||||||
|
local dCurrentHeight = dAltMort - ( ( nPass - i + 1) * dVerticalStep)
|
||||||
|
-- recupero gruppo per geometria addizionale
|
||||||
|
local nAddGrpId = BL.GetAddGroup( nPartId)
|
||||||
|
if not nAddGrpId then
|
||||||
|
local sErr = 'Error : missing AddGroup'
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
local b3MortiseNoPocket = EgtGetBBoxGlob( AuxId, GDB_BB.STANDARD)
|
||||||
|
GeomId = CalcPathAtHeight( Proc.Id, AuxId, nAddGrpId, dCurrentHeight, dSideAng, b3MortiseNoPocket)
|
||||||
|
if not GeomId then
|
||||||
|
local sErr = 'Wrong geometry : Error on DtMortise ' .. tostring( Proc.Id)
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
end
|
||||||
|
EgtSetMachiningGeometry( {{ GeomId, -1}})
|
||||||
-- imposto offset
|
-- imposto offset
|
||||||
local dOffs = ( i - 1) * dStep
|
local dOffs = ( i - 1) * dStep
|
||||||
|
if bMultipleZPasses then
|
||||||
|
if i > 1 then
|
||||||
|
dOffs = 1
|
||||||
|
else
|
||||||
|
dOffs = 0
|
||||||
|
end
|
||||||
|
end
|
||||||
EgtSetMachiningParam( MCH_MP.OFFSR, dOffs)
|
EgtSetMachiningParam( MCH_MP.OFFSR, dOffs)
|
||||||
|
-- in caso di passate in Z già calcolate lo step deve essere nullo per garantire passate singole
|
||||||
|
if bMultipleZPasses then
|
||||||
|
EgtSetMachiningParam( MCH_MP.STEP, 0)
|
||||||
|
end
|
||||||
-- sistemo il lato e la direzione di lavoro
|
-- sistemo il lato e la direzione di lavoro
|
||||||
EgtSetMachiningParam( MCH_MP.WORKSIDE, EgtIf( bCW, MCH_MILL_WS.LEFT, MCH_MILL_WS.RIGHT))
|
EgtSetMachiningParam( MCH_MP.WORKSIDE, EgtIf( bCW, MCH_MILL_WS.LEFT, MCH_MILL_WS.RIGHT))
|
||||||
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( bCW, false, true))
|
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( bCW, false, true))
|
||||||
@@ -516,7 +651,11 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
||||||
end
|
end
|
||||||
-- dichiaro massima elevazione e assenza sfridi per VMill
|
-- dichiaro massima elevazione e assenza sfridi per VMill
|
||||||
local sUserNotes = EgtSetVal( 'MaxElev', EgtNumToString( dMaxMat - 0.1, 1)) .. ';' .. EgtSetVal( 'VMRS', 0) .. ';'
|
local dMaxElev = dMaxMat
|
||||||
|
if bMultipleZPasses then
|
||||||
|
dMaxElev = dVerticalStep
|
||||||
|
end
|
||||||
|
local sUserNotes = EgtSetVal( 'MaxElev', EgtNumToString( dMaxElev - 0.1, 1)) .. ';' .. EgtSetVal( 'VMRS', 0) .. ';'
|
||||||
-- in presenza di pocket dichiaro che non sto entrando e uscendo nel grezzo
|
-- in presenza di pocket dichiaro che non sto entrando e uscendo nel grezzo
|
||||||
if bPocket then
|
if bPocket then
|
||||||
sUserNotes = EgtSetValInNotes( sUserNotes, 'OutRaw', 3)
|
sUserNotes = EgtSetValInNotes( sUserNotes, 'OutRaw', 3)
|
||||||
@@ -529,6 +668,10 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
sUserNotes = EgtSetValInNotes( sUserNotes, 'StartZmax', 2)
|
sUserNotes = EgtSetValInNotes( sUserNotes, 'StartZmax', 2)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
-- se c'è stata tastatura, si disattiva sull'ultima lavorazione
|
||||||
|
if bProbeExecuted and i == 1 then
|
||||||
|
sUserNotes = EgtSetValInNotes( sUserNotes, 'END-PROBE', true)
|
||||||
|
end
|
||||||
EgtSetMachiningParam( MCH_MP.USERNOTES, sUserNotes)
|
EgtSetMachiningParam( MCH_MP.USERNOTES, sUserNotes)
|
||||||
-- eseguo
|
-- eseguo
|
||||||
if not ML.ApplyMachining( true, false) then
|
if not ML.ApplyMachining( true, false) then
|
||||||
@@ -537,7 +680,7 @@ function ProcessDtMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return true
|
return true, sWarn
|
||||||
end
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
|
|||||||
+144
-11
@@ -46,9 +46,9 @@ local function VerifyOrientation( Proc, vtN, b3Raw)
|
|||||||
-- se macchina Fast, pezzo stretto e inclinazione laterale non eccessiva, accetto fino a -27deg
|
-- se macchina Fast, pezzo stretto e inclinazione laterale non eccessiva, accetto fino a -27deg
|
||||||
elseif ( not BD.C_SIMM) and abs( vtN:getY()) < 0.5 and b3Raw:getDimY() < 150.1 then
|
elseif ( not BD.C_SIMM) and abs( vtN:getY()) < 0.5 and b3Raw:getDimY() < 150.1 then
|
||||||
return ( vtN:getZ() >= -0.454)
|
return ( vtN:getZ() >= -0.454)
|
||||||
-- altrimenti accetto fino a -21deg
|
-- altrimenti accetto fino a -23.5deg
|
||||||
else
|
else
|
||||||
return ( vtN:getZ() >= -0.359)
|
return ( vtN:getZ() >= -0.399)
|
||||||
end
|
end
|
||||||
-- se trave medio-bassa
|
-- se trave medio-bassa
|
||||||
elseif b3Raw:getDimZ() < 281 then
|
elseif b3Raw:getDimZ() < 281 then
|
||||||
@@ -64,14 +64,14 @@ local function VerifyOrientation( Proc, vtN, b3Raw)
|
|||||||
-- se tenone praticamente in asse, accetto fino a -22 deg
|
-- se tenone praticamente in asse, accetto fino a -22 deg
|
||||||
if abs( vtN:getY()) < 0.088 then
|
if abs( vtN:getY()) < 0.088 then
|
||||||
return ( vtN:getZ() >= -0.375)
|
return ( vtN:getZ() >= -0.375)
|
||||||
-- altrimenti, accetto fino a -10 deg
|
-- altrimenti, accetto fino a -12.5 deg
|
||||||
else
|
else
|
||||||
return ( vtN:getZ() >= -0.174)
|
return ( vtN:getZ() >= -0.216)
|
||||||
end
|
end
|
||||||
-- altrimenti
|
-- altrimenti
|
||||||
else
|
else
|
||||||
-- accetto fino a -5deg
|
-- accetto fino a -12.5 deg
|
||||||
return ( vtN:getZ() >= -0.088)
|
return ( vtN:getZ() >= -0.216)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -209,7 +209,20 @@ function ProcessDtTenon.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
local CutProc = { Id = AddId, Grp = Proc.Grp, Prc = Proc.Prc, Box = Proc.Box, Fct = Proc.Fct, Flg = Proc.Flg,
|
local CutProc = { Id = AddId, Grp = Proc.Grp, Prc = Proc.Prc, Box = Proc.Box, Fct = Proc.Fct, Flg = Proc.Flg,
|
||||||
Head = Proc.Head, Tail = Proc.Tail, CutId = Proc.CutId, TaskId = Proc.TaskId, PartId = Proc.PartId}
|
Head = Proc.Head, Tail = Proc.Tail, CutId = Proc.CutId, TaskId = Proc.TaskId, PartId = Proc.PartId}
|
||||||
CutProc.AffectedFaces = BL.GetProcessAffectedFaces( CutProc)
|
CutProc.AffectedFaces = BL.GetProcessAffectedFaces( CutProc)
|
||||||
local bFromBottom = ( b3Solid:getDimX() < BD.LEN_SHORT_PART and vtExtr:getZ() > 0.25)
|
|
||||||
|
-- se esiste grezzo successivo non serve tagliare dal basso
|
||||||
|
local bFromBottom
|
||||||
|
local dTotalLength = 0
|
||||||
|
local nNextRawId = EgtGetNextRawPart( nRawId)
|
||||||
|
while nNextRawId do
|
||||||
|
dTotalLength = dTotalLength + EgtGetRawPartBBox( nNextRawId):getDimX()
|
||||||
|
nNextRawId = EgtGetNextRawPart( nNextRawId)
|
||||||
|
end
|
||||||
|
if dTotalLength > BD.MinRaw and not Proc.Tail then
|
||||||
|
bFromBottom = false
|
||||||
|
else
|
||||||
|
bFromBottom = ( b3Solid:getDimX() < BD.LEN_SHORT_PART and vtExtr:getZ() > 0.25)
|
||||||
|
end
|
||||||
local bOk, sErr = Cut.Make( CutProc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom)
|
local bOk, sErr = Cut.Make( CutProc, nPhase, nRawId, nPartId, dOvmHead, bFromBottom)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
@@ -236,11 +249,32 @@ function ProcessDtTenon.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
bCW = ( dSpeed >= 0)
|
bCW = ( dSpeed >= 0)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- verifico che l'altezza non superi il massimo materiale dell'utensile
|
-- se necessario, cerco un utensile più lungo
|
||||||
if dDtTenH > dMaxMat + 10 * GEO.EPS_SMALL then
|
if dDtTenH > dMaxMat + 10 * GEO.EPS_SMALL then
|
||||||
local sErr = 'Error : DtTenon Height bigger than Tool Cutting edge'
|
sMilling = ML.FindMilling( sMillType .. EgtIf( bMillDown and not bMillUp, '_H2', ''), nil, nil, nil, nil, bMillUp, bMillDown, nil, nil, 'Longest')
|
||||||
EgtOutLog( sErr)
|
if not sMilling then
|
||||||
return false, sErr
|
local sErr = 'Error : milling not found in library'
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
if not sMilling then
|
||||||
|
local sErr = 'Error : DtTenon Height bigger than Tool Cutting edge'
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- riassegno dati utensile
|
||||||
|
dTDiam = 50
|
||||||
|
dMaxMat = 30
|
||||||
|
bCW = true
|
||||||
|
if EgtMdbSetCurrMachining( sMilling) then
|
||||||
|
local sTuuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
||||||
|
if EgtTdbSetCurrTool( EgtTdbGetToolFromUUID( sTuuid) or '') then
|
||||||
|
dTDiam = EgtTdbGetCurrToolParam( MCH_TP.DIAM) or dTDiam
|
||||||
|
dMaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT) or dMaxMat
|
||||||
|
local dSpeed = EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) or 0
|
||||||
|
bCW = ( dSpeed >= 0)
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
-- calcolo distanza massima della curva dal punto più lontano della base tenone Dt (facet 0)
|
-- calcolo distanza massima della curva dal punto più lontano della base tenone Dt (facet 0)
|
||||||
local dMaxDist
|
local dMaxDist
|
||||||
@@ -331,6 +365,105 @@ function ProcessDtTenon.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
BL.UpdateTCING( nRawId, dOffs)
|
BL.UpdateTCING( nRawId, dOffs)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- si controllano le ultime 5 facce della feature
|
||||||
|
local nIndFace = -1
|
||||||
|
for i = 1, 5 do
|
||||||
|
if abs( vtExtr * EgtSurfTmFacetNormVersor( Proc.Id, Proc.Fct-i, GDB_ID.ROOT)) < GEO.EPS_ANG_SMALL then
|
||||||
|
nIndFace = Proc.Fct-i
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- controllo se serve passaggio di finitura in caso il tenone non cominci dal bordo della trave (P14 > 0)
|
||||||
|
if nIndFace > 0 then
|
||||||
|
-- verifico se almeno uno dei punti iniziale e finale della curva giace in uno dei piani limite del pezzo, quindi se è un lato aperto
|
||||||
|
local bOpen = false
|
||||||
|
local ptIni = EgtSP( AuxId, GDB_RT.GLOB)
|
||||||
|
local ptFin = EgtEP( AuxId, GDB_RT.GLOB)
|
||||||
|
if ( abs( ptIni:getX() - b3Solid:getMax():getX()) < 100 * GEO.EPS_SMALL or abs( ptFin:getX() - b3Solid:getMax():getX()) < 100 * GEO.EPS_SMALL) or
|
||||||
|
( abs( ptIni:getX() - b3Solid:getMin():getX()) < 100 * GEO.EPS_SMALL or abs( ptFin:getX() - b3Solid:getMin():getX()) < 100 * GEO.EPS_SMALL) or
|
||||||
|
( abs( ptIni:getY() - b3Solid:getMax():getY()) < 100 * GEO.EPS_SMALL or abs( ptFin:getY() - b3Solid:getMax():getY()) < 100 * GEO.EPS_SMALL) or
|
||||||
|
( abs( ptIni:getY() - b3Solid:getMin():getY()) < 100 * GEO.EPS_SMALL or abs( ptFin:getY() - b3Solid:getMin():getY()) < 100 * GEO.EPS_SMALL) or
|
||||||
|
( abs( ptIni:getZ() - b3Solid:getMax():getZ()) < 100 * GEO.EPS_SMALL or abs( ptFin:getZ() - b3Solid:getMax():getZ()) < 100 * GEO.EPS_SMALL) or
|
||||||
|
( abs( ptIni:getZ() - b3Solid:getMin():getZ()) < 100 * GEO.EPS_SMALL or abs( ptFin:getZ() - b3Solid:getMin():getZ()) < 100 * GEO.EPS_SMALL) then
|
||||||
|
bOpen = true
|
||||||
|
end
|
||||||
|
-- se entrambi i punti non sono sul limite pezzo
|
||||||
|
if not bOpen then
|
||||||
|
-- recupero la lavorazione
|
||||||
|
sMillType = 'Tenon'
|
||||||
|
sMilling = ML.FindMilling( sMillType .. EgtIf( bMillDown and not bMillUp, '_H2', ''), nil, nil, nil, nil, bMillUp, bMillDown)
|
||||||
|
if not sMilling then
|
||||||
|
local sErr = 'Error : milling to finish the tenon not found in library'
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- recupero i dati dell'utensile
|
||||||
|
if EgtMdbSetCurrMachining( sMilling) then
|
||||||
|
local sTuuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
||||||
|
if EgtTdbSetCurrTool( EgtTdbGetToolFromUUID( sTuuid) or '') then
|
||||||
|
dTDiam = EgtTdbGetCurrToolParam( MCH_TP.DIAM) or dTDiam
|
||||||
|
dMaxMat = EgtTdbGetCurrToolParam( MCH_TP.MAXMAT) or dMaxMat
|
||||||
|
local dSpeed = EgtMdbGetCurrMachiningParam( MCH_MP.SPEED) or 0
|
||||||
|
bCW = ( dSpeed >= 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- inserisco la passata finale della lavorazione
|
||||||
|
local sNameF = 'TenF_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
|
local nMchFId = EgtAddMachining( sNameF, sMilling)
|
||||||
|
if not nMchFId then
|
||||||
|
local sErr = 'Error adding machining ' .. sNameF .. '-' .. sMilling
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- aggiungo geometria
|
||||||
|
EgtSetMachiningGeometry( {{ Proc.Id, nIndFace}})
|
||||||
|
-- sistemo i parametri
|
||||||
|
EgtSetMachiningParam( MCH_MP.DEPTH_STR, 'TH')
|
||||||
|
-- sistemo il lato e la direzione di lavoro
|
||||||
|
EgtSetMachiningParam( MCH_MP.WORKSIDE, EgtIf( bCW, MCH_MILL_WS.LEFT, MCH_MILL_WS.RIGHT))
|
||||||
|
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( bCW, true, false))
|
||||||
|
EgtSetMachiningParam( MCH_MP.LITANG, 0.7 * dTDiam)
|
||||||
|
EgtSetMachiningParam( MCH_MP.LIPERP, 20)
|
||||||
|
EgtSetMachiningParam( MCH_MP.LOTANG, 0.7 * dTDiam)
|
||||||
|
EgtSetMachiningParam( MCH_MP.LOPERP, 20)
|
||||||
|
|
||||||
|
local nFaceUse
|
||||||
|
if vtExtr:getX() > -GEO.EPS_SMALL then
|
||||||
|
nFaceUse = MCH_MILL_FU.PARAL_LEFT
|
||||||
|
else
|
||||||
|
nFaceUse = MCH_MILL_FU.PARAL_RIGHT
|
||||||
|
end
|
||||||
|
EgtSetMachiningParam( MCH_MP.FACEUSE, nFaceUse)
|
||||||
|
|
||||||
|
-- imposto elevazione
|
||||||
|
local sUserNotes = EgtSetVal( 'MaxElev', EgtNumToString( dDtTenH, 1)) .. ';'
|
||||||
|
EgtSetMachiningParam( MCH_MP.USERNOTES, sUserNotes)
|
||||||
|
|
||||||
|
-- imposto posizione braccio porta testa
|
||||||
|
local nSCC = MCH_SCC.NONE
|
||||||
|
if BD.TURN then
|
||||||
|
if abs( vtAx:getY()) > abs( vtAx:getZ()) then
|
||||||
|
nSCC = EgtIf( vtAx:getY() > 0, MCH_SCC.ADIR_YP, MCH_SCC.ADIR_YM)
|
||||||
|
else
|
||||||
|
nSCC = EgtIf( vtAx:getZ() > 0, MCH_SCC.ADIR_ZP, MCH_SCC.ADIR_ZM)
|
||||||
|
end
|
||||||
|
elseif not BD.C_SIMM then
|
||||||
|
nSCC = MCH_SCC.ADIR_YM
|
||||||
|
if abs( vtExtr:getY()) > 0.088 then
|
||||||
|
nSCC = EgtIf( vtExtr:getX() < GEO.EPS_SMALL, MCH_SCC.ADIR_XM, MCH_SCC.ADIR_XP)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
||||||
|
-- eseguo
|
||||||
|
if not ML.ApplyMachining( true, false) then
|
||||||
|
local _, sErr = EgtGetLastMachMgrError()
|
||||||
|
EgtSetOperationMode( nMchFId, false)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -31,6 +31,9 @@ local Q_DEPTH_CHAMFER = 'Q02' -- d
|
|||||||
local Q_OVERMAT_FOR_FINISH = 'Q03' -- d
|
local Q_OVERMAT_FOR_FINISH = 'Q03' -- d
|
||||||
local Q_ONLY_CHAMFER = 'Q00' -- i
|
local Q_ONLY_CHAMFER = 'Q00' -- i
|
||||||
local Q_RADIAL_OFFSET = 'Q06' -- d, valido solo per pocket
|
local Q_RADIAL_OFFSET = 'Q06' -- d, valido solo per pocket
|
||||||
|
local Q_IGNORE_LASER_PROBLEMS = 'Q07'
|
||||||
|
local Q_FORCE_CLAMPABLE_AREA = 'Q08'
|
||||||
|
local Q_INVERT_LAST_PATH = 'Q09'
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- Riconoscimento della feature
|
-- Riconoscimento della feature
|
||||||
@@ -99,6 +102,8 @@ end
|
|||||||
function ProcessFreeContour.Classify( Proc, b3Raw)
|
function ProcessFreeContour.Classify( Proc, b3Raw)
|
||||||
-- verifico se di tipo pocket
|
-- verifico se di tipo pocket
|
||||||
local bPocket = ( EgtGetInfo( Proc.Id, 'PCKT', 'i') == 1)
|
local bPocket = ( EgtGetInfo( Proc.Id, 'PCKT', 'i') == 1)
|
||||||
|
-- verifico se forzata esecuzione anche se di testa e ribaltata o ruotata (lettura laser)
|
||||||
|
local bDownSideOnHeadOk = ( EgtGetInfo( Proc.Id, Q_IGNORE_LASER_PROBLEMS, 'd') or 0) == 1
|
||||||
-- recupero la curva associata
|
-- recupero la curva associata
|
||||||
local AuxId = EgtGetInfo( Proc.Id, 'AUXID', 'i')
|
local AuxId = EgtGetInfo( Proc.Id, 'AUXID', 'i')
|
||||||
if not AuxId then return false end
|
if not AuxId then return false end
|
||||||
@@ -107,23 +112,23 @@ function ProcessFreeContour.Classify( Proc, b3Raw)
|
|||||||
-- se tasca
|
-- se tasca
|
||||||
if bPocket then
|
if bPocket then
|
||||||
local bDown = ( vtN:getZ() < - 0.5)
|
local bDown = ( vtN:getZ() < - 0.5)
|
||||||
return true, bDown, false
|
return true, bDown, false, bDownSideOnHeadOk
|
||||||
-- se altrimenti profilo orizzontale
|
-- se altrimenti profilo orizzontale
|
||||||
elseif abs( vtN:getZ()) < 0.5 then
|
elseif abs( vtN:getZ()) < 0.5 then
|
||||||
return true, false, false
|
return true, false, false, bDownSideOnHeadOk
|
||||||
-- se altrimenti profilo verticale che non interessa tutta la sezione
|
-- se altrimenti profilo verticale che non interessa tutta la sezione
|
||||||
elseif Proc.Box:getDimZ() < 0.9 * b3Raw:getDimZ() then
|
elseif Proc.Box:getDimZ() < 0.9 * b3Raw:getDimZ() then
|
||||||
local bDown = ( vtN:getZ() < - 0.5)
|
local bDown = ( vtN:getZ() < - 0.5)
|
||||||
return true, bDown, false
|
return true, bDown, false, bDownSideOnHeadOk
|
||||||
-- altrimenti è profilo verticale che interessa tutta la sezione
|
-- altrimenti è profilo verticale che interessa tutta la sezione
|
||||||
else
|
else
|
||||||
-- recupero la massima capacità di lavoro dell'utensile da utilizzare
|
-- recupero la massima capacità di lavoro dell'utensile da utilizzare
|
||||||
local sMilling, dMaxDepth = ML.FindMilling( 'FreeContour')
|
local sMilling, dMaxDepth = ML.FindMilling( 'FreeContour')
|
||||||
if not sMilling then dMaxDepth = 0 end
|
if not sMilling then dMaxDepth = 0 end
|
||||||
if Proc.Box:getDimZ() > dMaxDepth and BD.ROT90 then
|
if Proc.Box:getDimZ() > dMaxDepth and BD.ROT90 then
|
||||||
return true, false, true
|
return true, false, true, bDownSideOnHeadOk
|
||||||
else
|
else
|
||||||
return true, false, false
|
return true, false, false, bDownSideOnHeadOk
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -466,7 +471,9 @@ local function MakeByMill( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
end
|
end
|
||||||
-- posizione braccio porta testa
|
-- posizione braccio porta testa
|
||||||
local nSCC = MCH_SCC.NONE
|
local nSCC = MCH_SCC.NONE
|
||||||
if not BD.C_SIMM then
|
if BD.TURN == 2 then
|
||||||
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
|
elseif not BD.C_SIMM then
|
||||||
if Proc.Head then
|
if Proc.Head then
|
||||||
nSCC = MCH_SCC.ADIR_XP
|
nSCC = MCH_SCC.ADIR_XP
|
||||||
elseif Proc.Tail then
|
elseif Proc.Tail then
|
||||||
@@ -534,7 +541,9 @@ local function MakeByMill( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
end
|
end
|
||||||
-- posizione braccio porta testa
|
-- posizione braccio porta testa
|
||||||
local nSCC = MCH_SCC.NONE
|
local nSCC = MCH_SCC.NONE
|
||||||
if not BD.C_SIMM then
|
if BD.TURN == 2 then
|
||||||
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
|
elseif not BD.C_SIMM then
|
||||||
if Proc.Head then
|
if Proc.Head then
|
||||||
nSCC = MCH_SCC.ADIR_XP
|
nSCC = MCH_SCC.ADIR_XP
|
||||||
elseif Proc.Tail then
|
elseif Proc.Tail then
|
||||||
@@ -584,6 +593,8 @@ local function MakeByMill( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
-- eventuale inversione ultimo segmento
|
||||||
|
local bInvertLastPath = ( ( EgtGetInfo( Proc.Id, Q_INVERT_LAST_PATH, 'd') or 0) == 1)
|
||||||
-- eseguo
|
-- eseguo
|
||||||
for i = 1, nStep do
|
for i = 1, nStep do
|
||||||
for j = 1, nDouble do
|
for j = 1, nDouble do
|
||||||
@@ -626,38 +637,71 @@ local function MakeByMill( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
-- aggiungo geometria
|
-- aggiungo geometria
|
||||||
EgtSetMachiningGeometry( {{ AuxId, -1}})
|
EgtSetMachiningGeometry( {{ AuxId, -1}})
|
||||||
-- eventuale accorciamento di testa
|
-- eventuale accorciamento di testa
|
||||||
|
local dStartAddLen, dEndAddLen, dWorkSide, bToolInvert, bInvert
|
||||||
if ( j == 1 and i > 1) or ( j == 2 and i < nStep) then
|
if ( j == 1 and i > 1) or ( j == 2 and i < nStep) then
|
||||||
local dStartAddLen = EgtIf( j == 1, - ( i - 1) * dStep, - ( nStep - i) * dStep)
|
dStartAddLen = EgtIf( j == 1, - ( i - 1) * dStep, - ( nStep - i) * dStep)
|
||||||
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dStartAddLen)
|
|
||||||
else
|
else
|
||||||
EgtSetMachiningParam( MCH_MP.STARTADDLEN, EgtIf( j == 1, dStartAddSpec, dEndAddSpec))
|
dStartAddLen = EgtIf( j == 1, dStartAddSpec, dEndAddSpec)
|
||||||
end
|
end
|
||||||
-- eventuale accorciamento di coda
|
-- eventuale accorciamento di coda
|
||||||
if ( j == 1 and i < nStep) or ( j == 2 and i > 1) then
|
if ( j == 1 and i < nStep) or ( j == 2 and i > 1) then
|
||||||
local dEndAddLen = EgtIf( j == 1, - ( nStep - i) * dStep, - ( i - 1) * dStep)
|
dEndAddLen = EgtIf( j == 1, - ( nStep - i) * dStep, - ( i - 1) * dStep)
|
||||||
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dEndAddLen)
|
|
||||||
else
|
else
|
||||||
EgtSetMachiningParam( MCH_MP.ENDADDLEN, EgtIf( j == 1, dEndAddSpec, dStartAddSpec))
|
dEndAddLen = EgtIf( j == 1, dEndAddSpec, dStartAddSpec)
|
||||||
end
|
end
|
||||||
-- se estrusione da sotto, inverto direzione fresa
|
-- se estrusione da sotto, inverto direzione fresa
|
||||||
if ( j == 1 and bToolInv) or ( j == 2 and not bToolInv) then
|
if ( j == 1 and bToolInv) or ( j == 2 and not bToolInv) then
|
||||||
EgtSetMachiningParam( MCH_MP.TOOLINVERT, true)
|
bToolInvert = true
|
||||||
|
else
|
||||||
|
bToolInvert = false
|
||||||
end
|
end
|
||||||
-- se seconda passata, inverto direzione di lavoro
|
-- se seconda passata, inverto direzione di lavoro
|
||||||
if j == 2 then
|
if j == 2 then
|
||||||
EgtSetMachiningParam( MCH_MP.INVERT, true)
|
bInvert = true
|
||||||
|
else
|
||||||
|
bInvert = false
|
||||||
end
|
end
|
||||||
|
|
||||||
-- assegno lato di lavoro
|
-- assegno lato di lavoro
|
||||||
if Proc.Grp == 0 then
|
if Proc.Grp == 0 then
|
||||||
EgtSetMachiningParam( MCH_MP.WORKSIDE, MCH_MILL_WS.CENTER)
|
dWorkSide = MCH_MILL_WS.CENTER
|
||||||
elseif ( Proc.Grp == 3 and not bToolInv) or ( Proc.Grp == 4 and bToolInv) or ( Proc.Grp == 1 and bToolInv) or ( Proc.Grp == 2 and bToolInv) then
|
elseif ( Proc.Grp == 3 and not bToolInv) or ( Proc.Grp == 4 and bToolInv) or ( Proc.Grp == 1 and bToolInv) or ( Proc.Grp == 2 and bToolInv) then
|
||||||
EgtSetMachiningParam( MCH_MP.WORKSIDE, MCH_MILL_WS.LEFT)
|
dWorkSide = MCH_MILL_WS.LEFT
|
||||||
elseif ( Proc.Grp == 3 and bToolInv) or ( Proc.Grp == 4 and not bToolInv) or ( Proc.Grp == 1 and not bToolInv) or ( Proc.Grp == 2 and not bToolInv) then
|
elseif ( Proc.Grp == 3 and bToolInv) or ( Proc.Grp == 4 and not bToolInv) or ( Proc.Grp == 1 and not bToolInv) or ( Proc.Grp == 2 and not bToolInv) then
|
||||||
EgtSetMachiningParam( MCH_MP.WORKSIDE, MCH_MILL_WS.RIGHT)
|
dWorkSide = MCH_MILL_WS.RIGHT
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- se ultimo step da invertire
|
||||||
|
if i == nStep and bInvertLastPath then
|
||||||
|
-- se profilo orizzontale
|
||||||
|
if abs( vtExtr:getZ()) < 10 * GEO.EPS_SMALL then
|
||||||
|
dStartAddLen, dEndAddLen = dEndAddLen, dStartAddLen
|
||||||
|
bInvert = not( bInvert)
|
||||||
|
bToolInvert = not( bToolInvert)
|
||||||
|
else
|
||||||
|
dStartAddLen, dEndAddLen = dEndAddLen, dStartAddLen
|
||||||
|
bInvert = not( bInvert)
|
||||||
|
if dWorkSide == MCH_MILL_WS.LEFT then
|
||||||
|
dWorkSide = MCH_MILL_WS.RIGHT
|
||||||
|
elseif dWorkSide == MCH_MILL_WS.RIGHT then
|
||||||
|
dWorkSide = MCH_MILL_WS.LEFT
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- setto i valori
|
||||||
|
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dStartAddLen)
|
||||||
|
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dEndAddLen)
|
||||||
|
EgtSetMachiningParam( MCH_MP.TOOLINVERT, bToolInvert)
|
||||||
|
EgtSetMachiningParam( MCH_MP.INVERT, bInvert)
|
||||||
|
EgtSetMachiningParam( MCH_MP.WORKSIDE, dWorkSide)
|
||||||
|
|
||||||
|
|
||||||
-- posizione braccio porta testa
|
-- posizione braccio porta testa
|
||||||
local nSCC = MCH_SCC.NONE
|
local nSCC = MCH_SCC.NONE
|
||||||
if not BD.C_SIMM then
|
if BD.TURN == 2 then
|
||||||
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
|
elseif not BD.C_SIMM then
|
||||||
if Proc.Head then
|
if Proc.Head then
|
||||||
nSCC = MCH_SCC.ADIR_XP
|
nSCC = MCH_SCC.ADIR_XP
|
||||||
elseif Proc.Tail then
|
elseif Proc.Tail then
|
||||||
@@ -713,7 +757,13 @@ local function MakeByMill( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
-- eventuale segnalazione ingombro di testa o coda
|
-- eventuale segnalazione ingombro di testa o coda
|
||||||
local dMinHIng = min( 0.5 * BD.VICE_MINH, 0.5 * b3Raw:getDimZ())
|
local dMinHIng = min( 0.5 * BD.VICE_MINH, 0.5 * b3Raw:getDimZ())
|
||||||
local dMinZ = max( BD.MIN_HEIGHT, 0.35 * b3Raw:getDimZ())
|
local dMinZ = max( BD.MIN_HEIGHT, 0.35 * b3Raw:getDimZ())
|
||||||
if Proc.Box:getDimZ() > 0.75 * b3Raw:getDimZ() and Proc.Box:getMin():getZ() < b3Raw:getMin():getZ() + dMinZ then
|
local bRawPartHas90Rotation = ( ( EgtGetInfo( nRawId, 'ROTATE90', 'd') or 0) == 1)
|
||||||
|
-- eventuale forzatura area feature pinzabile
|
||||||
|
local bForceClampableArea = ( ( EgtGetInfo( Proc.Id, Q_FORCE_CLAMPABLE_AREA, 'd') or 0) == 1)
|
||||||
|
-- se la feature è passante top/down oppure se è passante e si ruota di 90deg considero sempre non pinzabile; in alternativa si valuta in base all'ingombro
|
||||||
|
if not bForceClampableArea and ( ( Proc.Box:getDimZ() > 0.75 * b3Raw:getDimZ() and Proc.Box:getMin():getZ() < b3Raw:getMin():getZ() + dMinZ) or
|
||||||
|
( Proc.AffectedFaces.Top and Proc.AffectedFaces.Bottom and ( AreSameOrOppositeVectorApprox( vtExtr, Z_AX()))) or
|
||||||
|
( Proc.AffectedFaces.Front and Proc.AffectedFaces.Back and bRawPartHas90Rotation)) then
|
||||||
if Proc.Head then
|
if Proc.Head then
|
||||||
local dOffs = b3Raw:getMax():getX() - dOvmHead - Proc.Box:getMin():getX()
|
local dOffs = b3Raw:getMax():getX() - dOvmHead - Proc.Box:getMin():getX()
|
||||||
BL.UpdateHCING( nRawId, dOffs)
|
BL.UpdateHCING( nRawId, dOffs)
|
||||||
@@ -722,6 +772,7 @@ local function MakeByMill( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
BL.UpdateTCING( nRawId, dOffs)
|
BL.UpdateTCING( nRawId, dOffs)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return true, sWarn
|
return true, sWarn
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -781,7 +832,9 @@ local function MakeByPocket( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
EgtSetMachiningParam( MCH_MP.OFFSR, dExtra)
|
EgtSetMachiningParam( MCH_MP.OFFSR, dExtra)
|
||||||
-- posizione braccio porta testa
|
-- posizione braccio porta testa
|
||||||
local nSCC = MCH_SCC.NONE
|
local nSCC = MCH_SCC.NONE
|
||||||
if not BD.C_SIMM then
|
if BD.TURN == 2 then
|
||||||
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
|
elseif not BD.C_SIMM then
|
||||||
if Proc.Head then
|
if Proc.Head then
|
||||||
nSCC = MCH_SCC.ADIR_XP
|
nSCC = MCH_SCC.ADIR_XP
|
||||||
elseif Proc.Tail then
|
elseif Proc.Tail then
|
||||||
|
|||||||
+30
-17
@@ -161,7 +161,7 @@ end
|
|||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- tagli verticali aggiuntivi
|
-- tagli verticali aggiuntivi
|
||||||
local function AddVerticalPreCuts( Proc, sCutting, dCutXOffset, b3Raw)
|
local function AddVerticalPreCuts( Proc, sCutting, dCutXOffset, b3Raw, dOffsetBetweenCuts)
|
||||||
local nVerticalCuts = ceil( Proc.Face[1].WidthTrimmed / ( BD.MAX_LEN_DICE)) - 1
|
local nVerticalCuts = ceil( Proc.Face[1].WidthTrimmed / ( BD.MAX_LEN_DICE)) - 1
|
||||||
local dVerticalSliceHeight = Proc.Face[1].WidthTrimmed / ( nVerticalCuts + 1)
|
local dVerticalSliceHeight = Proc.Face[1].WidthTrimmed / ( nVerticalCuts + 1)
|
||||||
-- recupero il diametro dell'utensile
|
-- recupero il diametro dell'utensile
|
||||||
@@ -177,8 +177,8 @@ local function AddVerticalPreCuts( Proc, sCutting, dCutXOffset, b3Raw)
|
|||||||
for j = nVerticalCuts, 1, -1 do
|
for j = nVerticalCuts, 1, -1 do
|
||||||
local nFaceUse = MCH_MILL_FU.PARAL_FRONT
|
local nFaceUse = MCH_MILL_FU.PARAL_FRONT
|
||||||
local dVerticalCutOffset = dVerticalSliceHeight * -j
|
local dVerticalCutOffset = dVerticalSliceHeight * -j
|
||||||
local bForceTangentLeadInOut = BD.PRESS_ROLLER
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
bOk, sErr = Fbs.MakeOne( Proc.Id, 0, sCutting, dSawDiam, nFaceUse, nil, -0.1 -dCutXOffset, BD.CUT_SIC, dVerticalCutOffset, 0, 0, '', b3Raw, nil, nil, nil, bForceTangentLeadInOut)
|
bOk, sErr = Fbs.MakeOne( Proc.Id, 0, sCutting, dSawDiam, nFaceUse, nil, -0.1 -dCutXOffset, BD.CUT_SIC, dVerticalCutOffset, 0, 0, '', b3Raw, nil, nil, nil, sLeadInOutType, nil, dOffsetBetweenCuts)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -240,8 +240,8 @@ local function MakeStandardCuts( Proc, b3Raw, nCuts, dOffsetBetweenCuts, HeadCut
|
|||||||
for j = nHorizontalCuts, 1, -1 do
|
for j = nHorizontalCuts, 1, -1 do
|
||||||
local nFaceUse = MCH_MILL_FU.PARAL_DOWN
|
local nFaceUse = MCH_MILL_FU.PARAL_DOWN
|
||||||
local dHorizontalCutOffset = dHorizontalSliceHeight * -j
|
local dHorizontalCutOffset = dHorizontalSliceHeight * -j
|
||||||
local bForceTangentLeadInOut = BD.PRESS_ROLLER
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0, Cutting1Data.sCutting, Cutting1Data.dSawDiam, nFaceUse, nil, -0.1 -dCutXOffset, BD.CUT_SIC, dHorizontalCutOffset, 0, 0, '', b3Raw, nil, nil, nil, bForceTangentLeadInOut)
|
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0, Cutting1Data.sCutting, Cutting1Data.dSawDiam, nFaceUse, nil, -0.1 -dCutXOffset, BD.CUT_SIC, dHorizontalCutOffset, 0, 0, '', b3Raw, nil, nil, nil, sLeadInOutType, nil, dOffsetBetweenCuts)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
-- se necessario taglio verticale doppio, eseguo l'opposto
|
-- se necessario taglio verticale doppio, eseguo l'opposto
|
||||||
@@ -284,7 +284,7 @@ local function MakeStandardCuts( Proc, b3Raw, nCuts, dOffsetBetweenCuts, HeadCut
|
|||||||
local dCutOffset = ( i - 1) * dOffsetBetweenCuts
|
local dCutOffset = ( i - 1) * dOffsetBetweenCuts
|
||||||
-- se trave larga effettuo tagli verticali aggiuntivi
|
-- se trave larga effettuo tagli verticali aggiuntivi
|
||||||
if HeadCutType.bNeedVerticalAddedCuts then
|
if HeadCutType.bNeedVerticalAddedCuts then
|
||||||
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw)
|
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw, dOffsetBetweenCuts)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
if i == 1 and HeadCutType.sType =='Precut' then
|
if i == 1 and HeadCutType.sType =='Precut' then
|
||||||
@@ -340,7 +340,7 @@ local function MakeStandardCuts( Proc, b3Raw, nCuts, dOffsetBetweenCuts, HeadCut
|
|||||||
end
|
end
|
||||||
-- se trave larga effettuo tagli verticali aggiuntivi
|
-- se trave larga effettuo tagli verticali aggiuntivi
|
||||||
if HeadCutType.bNeedVerticalAddedCuts then
|
if HeadCutType.bNeedVerticalAddedCuts then
|
||||||
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw)
|
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw, dOffsetBetweenCuts)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0, Cutting1Data.sCutting, Cutting1Data.dSawDiam, MCH_MILL_FU.ORTHO_DOWN, dVzLimDwnUp, dCutExtra, BD.CUT_SIC, dCutOffset, dAccStart, 0, '', b3Raw)
|
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0, Cutting1Data.sCutting, Cutting1Data.dSawDiam, MCH_MILL_FU.ORTHO_DOWN, dVzLimDwnUp, dCutExtra, BD.CUT_SIC, dCutOffset, dAccStart, 0, '', b3Raw)
|
||||||
@@ -365,7 +365,15 @@ function ProcessHeadCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, bNeedHCut
|
|||||||
-- eventuali informazioni sul tipo di finitura
|
-- eventuali informazioni sul tipo di finitura
|
||||||
local nQ05 = EgtGetInfo( nOriId or GDB_ID.NULL, 'Q05', 'i') or 0
|
local nQ05 = EgtGetInfo( nOriId or GDB_ID.NULL, 'Q05', 'i') or 0
|
||||||
-- recupero la lavorazione
|
-- recupero la lavorazione
|
||||||
local sCutting = ML.FindCutting( 'HeadSide')
|
-- TODO questa parte andrà cambiata quando si gestiranno i volumi liberi in cui girare da mlse
|
||||||
|
local dMinWidthForBigBlade = 300
|
||||||
|
local dMaxHeightForBigBlade = 300
|
||||||
|
local sCutting
|
||||||
|
if b3Raw:getDimY() > dMinWidthForBigBlade and b3Raw:getDimZ() < dMaxHeightForBigBlade then
|
||||||
|
sCutting = ML.FindCutting( 'HeadSide', nil, nil, nil, 'Longest')
|
||||||
|
else
|
||||||
|
sCutting = ML.FindCutting( 'HeadSide')
|
||||||
|
end
|
||||||
if not sCutting then
|
if not sCutting then
|
||||||
local sErr = 'Error : cutting not found in library'
|
local sErr = 'Error : cutting not found in library'
|
||||||
EgtOutLog( sErr)
|
EgtOutLog( sErr)
|
||||||
@@ -398,17 +406,23 @@ function ProcessHeadCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, bNeedHCut
|
|||||||
dSawThick2 = EgtTdbGetCurrToolParam( MCH_TP.THICK) or dSawThick2
|
dSawThick2 = EgtTdbGetCurrToolParam( MCH_TP.THICK) or dSawThick2
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
-- determino se lo spessore del materiale da rimuovere è eccessivo e quindi vanno fatti più tagli con offset
|
||||||
|
local nCuts = max( ceil( dOvmHead / (( BD.MAX_LEN_SCRAP_START or BD.MAX_LEN_SCRAP) + 0.5)), 1)
|
||||||
|
local dOffsL = dOvmHead / nCuts
|
||||||
-- caratteristiche taglio
|
-- caratteristiche taglio
|
||||||
local dDimYRef = EgtIf( b3Raw:getDimZ() < BD.MIN_DIM_HBEAM + 10 * GEO.EPS_SMALL, dMaxDepth, abs( BD.MAX_DIM_HTCUT_HBEAM))
|
local dDimYRef = EgtIf( b3Raw:getDimZ() < BD.MIN_DIM_HBEAM + 10 * GEO.EPS_SMALL, dMaxDepth, abs( BD.MAX_DIM_HTCUT_HBEAM))
|
||||||
local bBigSectionCut = ( b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL) and
|
local bBigSectionCut = ( b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL) and
|
||||||
( b3Raw:getDimZ() > EgtIf( BD.TURN, 2 * dMaxVertDepth, dMaxVertDepth + dMaxDepth2) - 2 * BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
( b3Raw:getDimZ() > EgtIf( BD.TURN, 2 * dMaxVertDepth, dMaxVertDepth + dMaxDepth2) - 2 * BD.CUT_EXTRA + 10 * GEO.EPS_SMALL)
|
||||||
local bHorizCut = ( ( b3Raw:getDimY() > b3Raw:getDimZ() + 10 * GEO.EPS_SMALL or BD.TURN) and b3Raw:getDimZ() < dMaxVertDepth - BD.CUT_EXTRA)
|
local bHorizCut = ( ( b3Raw:getDimY() > b3Raw:getDimZ() + 10 * GEO.EPS_SMALL or BD.TURN) and b3Raw:getDimZ() < dMaxVertDepth - BD.CUT_EXTRA)
|
||||||
local bDoubleHorizCut = ( ( BD.DOWN_HEAD or BD.TURN) and not bHorizCut and b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
local bDoubleHorizCut = ( ( BD.DOWN_HEAD or BD.TURN) and not bHorizCut and b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
||||||
local bDoubleCut = ( not bHorizCut and not bDoubleHorizCut and b3Raw:getDimY() > dDimYRef - BD.CUT_EXTRA + 10 * GEO.EPS_SMALL)
|
local bDoubleCut = ( not bHorizCut and not bDoubleHorizCut and b3Raw:getDimY() > dDimYRef - BD.CUT_EXTRA + 10 * GEO.EPS_SMALL) and
|
||||||
|
( b3Raw:getDimY() < 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
||||||
-- verifico necessità di tagli aggiuntivi orizzontali o verticali
|
-- verifico necessità di tagli aggiuntivi orizzontali o verticali
|
||||||
local dMinOvmHeadForAddeddCuts = 10.123
|
local dMinOvmHeadForAddeddCuts = 10.123
|
||||||
local bNeedVerticalAddedCuts = ( Proc.Face[1].WidthTrimmed > BD.MAX_LEN_DICE) and ( dOvmHead > dMinOvmHeadForAddeddCuts - 10 * GEO.EPS_SMALL)
|
local bNeedVerticalAddedCuts = ( Proc.Face[1].WidthTrimmed > BD.MAX_LEN_DICE) and ( dOvmHead > dMinOvmHeadForAddeddCuts - 10 * GEO.EPS_SMALL)
|
||||||
local bNeedHorizontalAddedCuts = ( Proc.Face[1].HeightTrimmed > ( BD.MIN_HEIGHT_ADDED_CUTS or BD.MAX_LEN_DICE)) and not bBigSectionCut and ( dOvmHead > dMinOvmHeadForAddeddCuts - 10 * GEO.EPS_SMALL)
|
local bNeedHorizontalAddedCuts = ( Proc.Face[1].HeightTrimmed > ( BD.MIN_HEIGHT_ADDED_CUTS or BD.MAX_LEN_DICE)) and
|
||||||
|
not bBigSectionCut and ( dOvmHead > dMinOvmHeadForAddeddCuts - 10 * GEO.EPS_SMALL) and
|
||||||
|
dOffsL < BD.MAX_DIM_DICE
|
||||||
-- dati lavorazioni sopra e sotto
|
-- dati lavorazioni sopra e sotto
|
||||||
local Cutting1Data = { sCutting = sCutting, dSawDiam = dSawDiam, dMaxDepth = dMaxDepth, dSawThick = dSawThick, dMaxVertDepth = dMaxVertDepth}
|
local Cutting1Data = { sCutting = sCutting, dSawDiam = dSawDiam, dMaxDepth = dMaxDepth, dSawThick = dSawThick, dMaxVertDepth = dMaxVertDepth}
|
||||||
local Cutting2Data = { sCutting = sCutting2, dSawDiam = dSawDiam2, dMaxDepth = dMaxDepth2, dSawThick = dSawThick2}
|
local Cutting2Data = { sCutting = sCutting2, dSawDiam = dSawDiam2, dMaxDepth = dMaxDepth2, dSawThick = dSawThick2}
|
||||||
@@ -420,9 +434,6 @@ function ProcessHeadCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, bNeedHCut
|
|||||||
if not bNeedHCut and AreSameVectorApprox( vtN, X_AX()) and abs( ptC:getX() - b3Raw:getMax():getX()) < 10 * GEO.EPS_SMALL then
|
if not bNeedHCut and AreSameVectorApprox( vtN, X_AX()) and abs( ptC:getX() - b3Raw:getMax():getX()) < 10 * GEO.EPS_SMALL then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
-- determino se lo spessore del materiale da rimuovere è eccessivo e quindi vanno fatti più tagli con offset
|
|
||||||
local nCuts = max( ceil( dOvmHead / (( BD.MAX_LEN_SCRAP_START or BD.MAX_LEN_SCRAP) + 0.5)), 1)
|
|
||||||
local dOffsL = dOvmHead / nCuts
|
|
||||||
-- se taglio per sezioni alte e larghe
|
-- se taglio per sezioni alte e larghe
|
||||||
if bBigSectionCut then
|
if bBigSectionCut then
|
||||||
if dOvmHead > 0 then
|
if dOvmHead > 0 then
|
||||||
@@ -487,14 +498,16 @@ function ProcessHeadCut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, bNeedHCut
|
|||||||
if AreSameVectorApprox( X_AX(), vtNLimitingSurf) then EgtInvertSurf( nLimitingSurf) end
|
if AreSameVectorApprox( X_AX(), vtNLimitingSurf) then EgtInvertSurf( nLimitingSurf) end
|
||||||
end
|
end
|
||||||
-- tagli verticali
|
-- tagli verticali
|
||||||
bOk, sErr = AddVerticalPreCuts( AddProc, sCutting, 0, b3Raw)
|
bOk, sErr = AddVerticalPreCuts( AddProc, sCutting, 0, b3Raw, dOffsL)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
-- tagli a cubetti con eventuale superficie limitante
|
-- tagli a cubetti con eventuale superficie limitante
|
||||||
bOk, sErr = Cut.Make( AddProc, nPhase, nRawId, nPartId, dOvmHead, nil, false, true, nil, nil, nil, nil, nLimitingSurf)
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
|
bOk, sErr = Cut.Make( AddProc, nPhase, nRawId, nPartId, dOvmHead, nil, false, true, nil, nil, nil, nil, nLimitingSurf, sLeadInOutType)
|
||||||
end
|
end
|
||||||
-- tagli aggiuntivi non necessari
|
-- tagli aggiuntivi non necessari
|
||||||
else
|
else
|
||||||
bOk, sErr = Cut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, nil, false, true)
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
|
bOk, sErr = Cut.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, nil, false, true, nil, nil, nil, nil, nil, sLeadInOutType)
|
||||||
end
|
end
|
||||||
return bOk, sErr
|
return bOk, sErr
|
||||||
end
|
end
|
||||||
|
|||||||
+430
-156
File diff suppressed because it is too large
Load Diff
@@ -286,9 +286,11 @@ local function CalcBladeUse( bUseBlade, bDown_Head, nSide, vtN1, vtN2, bConvex,
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if ( vtN1 and vtN1:getZ() >= EgtIf( dCustomAngle, dCustomAngle, -0.5)) and ( not vtN2 or vtN2:getZ() >= -0.5) then
|
--if ( vtN1 and vtN1:getZ() >= EgtIf( dCustomAngle, dCustomAngle, -0.5)) and ( not vtN2 or vtN2:getZ() >= -0.5) then
|
||||||
bCanUseBlade = true
|
-- bCanUseBlade = true
|
||||||
end
|
--end
|
||||||
|
-- viene abilitata sempre lama da sotto
|
||||||
|
bCanUseBlade = true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -423,12 +425,22 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
-- analisi del taglio
|
-- analisi del taglio
|
||||||
local vOrd = {}
|
local vOrd = {}
|
||||||
local vFaceUse = {}
|
local vFaceUse = {}
|
||||||
|
local bIsMachDownUp = false
|
||||||
if nSide == 1 or ( nSide == -1 and ( BD.DOWN_HEAD or BD.TURN)) then
|
if nSide == 1 or ( nSide == -1 and ( BD.DOWN_HEAD or BD.TURN)) then
|
||||||
vOrd = EgtIf( ptC[1]:getY() < ptRef:getY(), { 1, 2}, { 2, 1})
|
vOrd = EgtIf( ptC[1]:getY() < ptRef:getY(), { 1, 2}, { 2, 1})
|
||||||
vFaceUse = { BL.GetNearestOrthoOpposite( ptC[1] - ptM), BL.GetNearestOrthoOpposite( ptC[2] - ptM)}
|
vFaceUse = { BL.GetNearestOrthoOpposite( ptC[1] - ptM), BL.GetNearestOrthoOpposite( ptC[2] - ptM)}
|
||||||
elseif nSide == -1 then
|
elseif nSide == -1 then
|
||||||
vOrd = EgtIf( ptC[1]:getY() < ptRef:getY(), { 1, 2}, { 2, 1})
|
vOrd = EgtIf( ptC[1]:getY() < ptRef:getY(), { 1, 2}, { 2, 1})
|
||||||
vFaceUse = { BL.GetNearestParalOpposite( ptC[1] - ptM), BL.GetNearestParalOpposite( ptC[2] - ptM)}
|
local vtFaceUse1, vtFaceUse2
|
||||||
|
if bCanUseBlade and not BD.DOWN_HEAD then
|
||||||
|
bIsMachDownUp = true
|
||||||
|
vtFaceUse1 = BL.GetOrtupOpposite( BL.GetNearestOrthoOpposite( ptC[1] - ptM))
|
||||||
|
vtFaceUse2 = BL.GetOrtupOpposite( BL.GetNearestOrthoOpposite( ptC[2] - ptM))
|
||||||
|
else
|
||||||
|
vtFaceUse1 = BL.GetNearestParalOpposite( ptC[1] - ptM)
|
||||||
|
vtFaceUse2 = BL.GetNearestParalOpposite( ptC[2] - ptM)
|
||||||
|
end
|
||||||
|
vFaceUse = { vtFaceUse1, vtFaceUse2}
|
||||||
else
|
else
|
||||||
local bFront = ( ( vtN[1]:getY() + vtN[2]:getY()) < 0)
|
local bFront = ( ( vtN[1]:getY() + vtN[2]:getY()) < 0)
|
||||||
if bFront then
|
if bFront then
|
||||||
@@ -442,6 +454,7 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
local vWidth = {}
|
local vWidth = {}
|
||||||
_, _, vWidth[1] = BL.GetFaceHvRefDim( Proc.Id, tFaceLong[1])
|
_, _, vWidth[1] = BL.GetFaceHvRefDim( Proc.Id, tFaceLong[1])
|
||||||
_, _, vWidth[2] = BL.GetFaceHvRefDim( Proc.Id, tFaceLong[2])
|
_, _, vWidth[2] = BL.GetFaceHvRefDim( Proc.Id, tFaceLong[2])
|
||||||
|
local vElevation = { vWidth[2], vWidth[1]}
|
||||||
|
|
||||||
-- Se da sopra o ( da tutte i lati con testa da sotto) e taglio di lama e lunghezza facce maggiore del parametro lunghezza minima
|
-- Se da sopra o ( da tutte i lati con testa da sotto) e taglio di lama e lunghezza facce maggiore del parametro lunghezza minima
|
||||||
if ( bCanUseUnderBlade or bCanUseBlade) and bUseBlade and Proc.Box:getDimX() > dLimMinPiece - 1 then
|
if ( bCanUseUnderBlade or bCanUseBlade) and bUseBlade and Proc.Box:getDimX() > dLimMinPiece - 1 then
|
||||||
@@ -850,7 +863,7 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
-- imposto la direzione di lavoro per avere scarico del truciolo ottimale
|
-- imposto la direzione di lavoro per avere scarico del truciolo ottimale
|
||||||
local nWorkSide, bInvert
|
local nWorkSide, bInvert
|
||||||
if ( not bIsTopBladeCurrent and abs( nSide) ~= 0) or ( bCanUseBlade and bCanUseUnderBlade and nSide == -1) then
|
if ( not bIsTopBladeCurrent and abs( nSide) ~= 0) or ( bCanUseBlade and bCanUseUnderBlade and nSide == -1) then
|
||||||
if bIsCurrentBladeCCW then
|
if bIsCurrentBladeCCW and not bIsMachDownUp then
|
||||||
nWorkSide = MCH_MILL_WS.LEFT
|
nWorkSide = MCH_MILL_WS.LEFT
|
||||||
bInvert = true
|
bInvert = true
|
||||||
dSal, dEal = dEal, dSal
|
dSal, dEal = dEal, dSal
|
||||||
@@ -859,7 +872,7 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
bInvert = false
|
bInvert = false
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if bIsCurrentBladeCCW then
|
if bIsCurrentBladeCCW and not bIsMachDownUp then
|
||||||
nWorkSide = MCH_MILL_WS.LEFT
|
nWorkSide = MCH_MILL_WS.LEFT
|
||||||
bInvert = false
|
bInvert = false
|
||||||
else
|
else
|
||||||
@@ -1066,6 +1079,11 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
if nSide == -1 and BD.DOWN_HEAD then
|
if nSide == -1 and BD.DOWN_HEAD then
|
||||||
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dEal)
|
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dEal)
|
||||||
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dSal)
|
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dSal)
|
||||||
|
elseif nSide == -1 and not BD.DOWN_HEAD and bIsMachDownUp then
|
||||||
|
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( EgtGetMachiningParam( MCH_MP.INVERT), false, true))
|
||||||
|
dOffset = 5
|
||||||
|
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dEal)
|
||||||
|
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dSal)
|
||||||
else
|
else
|
||||||
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dSal)
|
EgtSetMachiningParam( MCH_MP.STARTADDLEN, dSal)
|
||||||
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dEal)
|
EgtSetMachiningParam( MCH_MP.ENDADDLEN, dEal)
|
||||||
@@ -1262,10 +1280,10 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
nFin = 1
|
nFin = 1
|
||||||
else
|
else
|
||||||
if vtN[vOrd[1]]:getZ() >= vtN[vOrd[2]]:getZ() then
|
if vtN[vOrd[1]]:getZ() >= vtN[vOrd[2]]:getZ() then
|
||||||
if vtN[vOrd[2]]:getZ() < dLimitAngle then
|
if vtN[vOrd[1]]:getZ() < dLimitAngle then
|
||||||
nFin = 1
|
|
||||||
else
|
|
||||||
nIni = 2
|
nIni = 2
|
||||||
|
else
|
||||||
|
nFin = 1
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if vtN[vOrd[1]]:getZ() < dLimitAngle then
|
if vtN[vOrd[1]]:getZ() < dLimitAngle then
|
||||||
@@ -1288,6 +1306,7 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
end
|
end
|
||||||
-- ciclo sulle parti
|
-- ciclo sulle parti
|
||||||
local nM = 0
|
local nM = 0
|
||||||
|
local bInverted = false
|
||||||
for j = 1, nC do
|
for j = 1, nC do
|
||||||
-- su entrambe le facce
|
-- su entrambe le facce
|
||||||
for i = nIni, nFin do
|
for i = nIni, nFin do
|
||||||
@@ -1311,8 +1330,11 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
if nSide == 1 or nSide == -1 then
|
if nSide == 1 or nSide == -1 then
|
||||||
local bFromYM = (( vtN[vOrd[i]]:getY() < 0 and bConvex) or ( vtN[vOrd[i]]:getY() > 0 and not bConvex))
|
local bFromYM = (( vtN[vOrd[i]]:getY() < 0 and bConvex) or ( vtN[vOrd[i]]:getY() > 0 and not bConvex))
|
||||||
nSCC = EgtIf( bFromYM, MCH_SCC.ADIR_YM, MCH_SCC.ADIR_YP)
|
nSCC = EgtIf( bFromYM, MCH_SCC.ADIR_YM, MCH_SCC.ADIR_YP)
|
||||||
|
if BD.TURN == 2 and not bFromYM then
|
||||||
|
nSCC = EgtIf( nSide == -1, MCH_SCC.ADIR_ZM, MCH_SCC.ADIR_ZP)
|
||||||
|
end
|
||||||
else
|
else
|
||||||
local bFromZM = (( vtN[vOrd[i]]:getZ() < 0 and bConvex) or ( vtN[vOrd[i]]:getZ() > 0 and not bConvex))
|
local bFromZM = (( vtN[vOrd[i]]:getZ() < 10 * GEO.EPS_ANG_SMALL and bConvex) or ( vtN[vOrd[i]]:getZ() > - 10 * GEO.EPS_ANG_SMALL and not bConvex))
|
||||||
nSCC = EgtIf( bFromZM, MCH_SCC.ADIR_ZM, MCH_SCC.ADIR_ZP)
|
nSCC = EgtIf( bFromZM, MCH_SCC.ADIR_ZM, MCH_SCC.ADIR_ZP)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@@ -1325,6 +1347,23 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
local dStep = 0
|
local dStep = 0
|
||||||
local dAgg = EgtIf( bConvex, 2 * BD.CUT_EXTRA, BD.CUT_EXTRA)
|
local dAgg = EgtIf( bConvex, 2 * BD.CUT_EXTRA, BD.CUT_EXTRA)
|
||||||
local dLargh = vWidth[vOrd[i]]
|
local dLargh = vWidth[vOrd[i]]
|
||||||
|
-- controllo se lavorazione completa
|
||||||
|
local dMachDepth = vElevation[vOrd[i]]
|
||||||
|
if dMachDepth > dMaxDepth - 10 * GEO.EPS_ANG_SMALL then
|
||||||
|
-- verifico se posso lavorare la faccia 2
|
||||||
|
local nOtherFace = EgtIf( i == 1, 2, 1)
|
||||||
|
if Proc.Fct == 2 and j == 1 and vtN[vOrd[nOtherFace]]:getZ() > dLimitAngle and vWidth[vOrd[i]] < dMaxDepth then
|
||||||
|
vOrd[1], vOrd[2] = vOrd[2], vOrd[1]
|
||||||
|
dLargh = vWidth[vOrd[i]]
|
||||||
|
dSal, dEal = dEal, dSal
|
||||||
|
bInverted = true
|
||||||
|
else
|
||||||
|
sWarn = 'Warning : elevation bigger than max tool depth'
|
||||||
|
EgtOutLog( sWarn)
|
||||||
|
end
|
||||||
|
elseif bInverted then
|
||||||
|
dSal, dEal = dEal, dSal
|
||||||
|
end
|
||||||
if not bSide and dLargh > 0.8 * dToolDiam then
|
if not bSide and dLargh > 0.8 * dToolDiam then
|
||||||
nO = ceil( dLargh / ( 0.6 * dToolDiam))
|
nO = ceil( dLargh / ( 0.6 * dToolDiam))
|
||||||
if nO > 1 then
|
if nO > 1 then
|
||||||
@@ -1358,7 +1397,7 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
--EgtSetMachiningParam( MCH_MP.FACEUSE, EgtIf( bSide, BL.GetParallelOpposite( vFaceUse[vOrd[i]]), vFaceUse[vOrd[i]]))
|
--EgtSetMachiningParam( MCH_MP.FACEUSE, EgtIf( bSide, BL.GetParallelOpposite( vFaceUse[vOrd[i]]), vFaceUse[vOrd[i]]))
|
||||||
EgtSetMachiningParam( MCH_MP.FACEUSE, EgtIf( bSide, MCH_MILL_FU.PARAL_DOWN, vFaceUse[vOrd[i]]))
|
EgtSetMachiningParam( MCH_MP.FACEUSE, EgtIf( bSide, MCH_MILL_FU.PARAL_DOWN, vFaceUse[vOrd[i]]))
|
||||||
-- imposto lato di lavoro e inversione
|
-- imposto lato di lavoro e inversione
|
||||||
EgtSetMachiningParam( MCH_MP.WORKSIDE, MCH_MILL_WS.LEFT)
|
EgtSetMachiningParam( MCH_MP.WORKSIDE, EgtIf( bIsMachDownUp, MCH_MILL_WS.RIGHT, MCH_MILL_WS.LEFT))
|
||||||
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( bSide, true, false))
|
EgtSetMachiningParam( MCH_MP.INVERT, EgtIf( bSide, true, false))
|
||||||
-- imposto offset radiale (nullo se concavo o di lato)
|
-- imposto offset radiale (nullo se concavo o di lato)
|
||||||
local dOffsR = EgtIf( k < nO, ( nO - k) * dStep, EgtIf( bConvex, - BD.CUT_EXTRA, 0))
|
local dOffsR = EgtIf( k < nO, ( nO - k) * dStep, EgtIf( bConvex, - BD.CUT_EXTRA, 0))
|
||||||
@@ -1393,7 +1432,7 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if not Proc.MoveAfterSplit and not bEndFixed and not bConvex then
|
if not Proc.bMoveAfterSplit and not bConvex and Proc.AffectedFaces.Left then
|
||||||
-- recupero gruppo per geometria addizionale
|
-- recupero gruppo per geometria addizionale
|
||||||
local nAddGrpId = BL.GetAddGroup( nPartId)
|
local nAddGrpId = BL.GetAddGroup( nPartId)
|
||||||
if not nAddGrpId then
|
if not nAddGrpId then
|
||||||
@@ -1402,7 +1441,8 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
local AddId = EgtCopyGlob( Proc.Id, nAddGrpId) or GDB_ID.NULL
|
local AddId = EgtCopyGlob( Proc.Id, nAddGrpId) or GDB_ID.NULL
|
||||||
local AddProc = { Id = AddId, Grp = 0, Prc = 12, Box = Proc.Box, Fct = Proc.Fct, Flg = Proc.Flg, PartId = Proc.PartId, bMoveAfterSplit = true}
|
local AddProc = { Id = AddId, Grp = 0, Prc = 12, Box = Proc.Box, Fct = Proc.Fct, Flg = Proc.Flg,
|
||||||
|
PartId = Proc.PartId, TaskId = Proc.TaskId, CutId = Proc.CutId, bMoveAfterSplit = true}
|
||||||
Topology.Classify( AddProc, b3Raw)
|
Topology.Classify( AddProc, b3Raw)
|
||||||
table.insert( AddedIds, AddProc)
|
table.insert( AddedIds, AddProc)
|
||||||
end
|
end
|
||||||
@@ -1793,7 +1833,7 @@ function ProcessLong2Cut.Make( Proc, nPhase, nRawId, nPartId, bForcedBladeMaster
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- imposto lato di lavoro e inversione
|
-- imposto lato di lavoro e inversione
|
||||||
EgtSetMachiningParam( MCH_MP.WORKSIDE, MCH_MILL_WS.LEFT)
|
EgtSetMachiningParam( MCH_MP.WORKSIDE, EgtIf( bIsMachDownUp, MCH_MILL_WS.RIGHT, MCH_MILL_WS.LEFT))
|
||||||
EgtSetMachiningParam( MCH_MP.INVERT, true)
|
EgtSetMachiningParam( MCH_MP.INVERT, true)
|
||||||
-- calcolo la componente dNz non in base alla classificazione della feature (sopra, sotto, fianchi) ma alla componente maggiore
|
-- calcolo la componente dNz non in base alla classificazione della feature (sopra, sotto, fianchi) ma alla componente maggiore
|
||||||
-- local dNz = EgtIf( nSide == 0, vtN[vOrd[i]]:getY(), vtN[vOrd[i]]:getZ())
|
-- local dNz = EgtIf( nSide == 0, vtN[vOrd[i]]:getY(), vtN[vOrd[i]]:getZ())
|
||||||
|
|||||||
@@ -352,6 +352,69 @@ function ProcessMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
if not bModif and not bOpenBtm then
|
if not bModif and not bOpenBtm then
|
||||||
BL.SetOpenSide( AuxId, b3Solid)
|
BL.SetOpenSide( AuxId, b3Solid)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- recupero il raggio minimo della mortasa
|
||||||
|
local dMaxDiam = 1000
|
||||||
|
local nSt, nEnd = EgtCurveDomain( AuxId)
|
||||||
|
for i = nSt, nEnd - 1 do
|
||||||
|
local dRad = EgtCurveCompoRadius( AuxId, i)
|
||||||
|
-- se è un raggio, setto ed esco subito. Tutti i raggi sono uguali nella mortasa
|
||||||
|
if dRad > 0 then
|
||||||
|
dMaxDiam = dRad * 2
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- caso speciale feature trimmata diversamente in/out: si ricostruisce la curva non trimmata
|
||||||
|
-- recupero gruppo per geometria addizionale
|
||||||
|
local nAddGrpId = BL.GetAddGroup( nPartId)
|
||||||
|
if not nAddGrpId then
|
||||||
|
local sErr = 'Error : missing AddGroup'
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- estrazione loop trimesh: se 1 contorno ha il fondo, se due contorni è passante.
|
||||||
|
-- se passante si deve discriminare se i due contorni sono uguali (passante standard, trimmata allo stesso modo in/out) oppure se un contorno è diverso dall'altro (e quindi non è trimmata in egual modo in/out)
|
||||||
|
-- se più di 2 contorni si rimane nel caso standard
|
||||||
|
local idCurve1, nIdCount = EgtExtractSurfTmLoops( Proc.Id, nAddGrpId)
|
||||||
|
if nIdCount == 2 then
|
||||||
|
local idCurve2 = idCurve1 + 1
|
||||||
|
local dCurveLength1 = EgtCurveLength( idCurve1)
|
||||||
|
local dCurveLength2 = EgtCurveLength( idCurve2)
|
||||||
|
if abs( dCurveLength1 - dCurveLength2) > 100 * GEO.EPS_SMALL then
|
||||||
|
-- riferimento curva ausiliaria
|
||||||
|
local frAuxId = Frame3d( EgtGP( AuxId, GDB_RT.GLOB), vtExtr)
|
||||||
|
-- box dei due contorni nel riferimento della faccia di fondo
|
||||||
|
local b3Curve1 = EgtGetBBoxRef( idCurve1, GDB_BB.STANDARD, frAuxId)
|
||||||
|
local b3Curve2 = EgtGetBBoxRef( idCurve2, GDB_BB.STANDARD, frAuxId)
|
||||||
|
-- per creare la curva non trimmata si creerà un piano di intersezione con la trimesh appena sopra al contorno più vicino a AuxId, ossia a ptOffset
|
||||||
|
local ptOffset = b3Curve1:getMax()
|
||||||
|
if b3Curve1:getMin():getZ() > b3Curve2:getMin():getZ() + 10 * GEO.EPS_SMALL then
|
||||||
|
ptOffset = b3Curve2:getMax()
|
||||||
|
end
|
||||||
|
-- ptOffset si sposta appena sopra per garantire l'intersezione
|
||||||
|
ptOffset = ptOffset + Vector3d( 0, 0, 100 * GEO.EPS_SMALL)
|
||||||
|
local ptOffsetGlob = Point3d( ptOffset)
|
||||||
|
ptOffsetGlob:toGlob( frAuxId)
|
||||||
|
EgtErase( { idCurve1, idCurve2} )
|
||||||
|
-- intersezione piano a ptOffset con la trimesh: si ottiene la curva originale non trimmata
|
||||||
|
local nFirstId, nPnt, nCrv, nSrf = EgtPlaneSurfTmInters( ptOffsetGlob, frAuxId:getVersZ(), Proc.Id, nAddGrpId, GDB_RT.GLOB)
|
||||||
|
if nPnt == 0 and nCrv == 1 and nSrf == 0 then
|
||||||
|
EgtCloseCurveCompo( nFirstId)
|
||||||
|
local vtMove = -frAuxId:getVersZ() * ptOffset:getZ()
|
||||||
|
EgtMove( nFirstId, vtMove, GDB_RT.GLOB)
|
||||||
|
EgtErase( AuxId)
|
||||||
|
EgtChangeId( nFirstId, AuxId)
|
||||||
|
else
|
||||||
|
if nFirstId then
|
||||||
|
for nId = nFirstId, nFirstId + nPnt + nCrv + nSrf - 1 do
|
||||||
|
EgtErase( nId)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
if bOpenBtm then
|
if bOpenBtm then
|
||||||
-- creo superficie chiusa
|
-- creo superficie chiusa
|
||||||
local nFlat = EgtSurfTmByFlatContour( EgtGetParent( AuxId), AuxId, 0.05)
|
local nFlat = EgtSurfTmByFlatContour( EgtGetParent( AuxId), AuxId, 0.05)
|
||||||
@@ -435,6 +498,10 @@ function ProcessMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
end
|
end
|
||||||
-- determino larghezza della mortasa
|
-- determino larghezza della mortasa
|
||||||
if dL < dW then dL, dW = dW, dL end
|
if dL < dW then dL, dW = dW, dL end
|
||||||
|
|
||||||
|
-- si prende il minimo tra larghezza mortasa e il raggio minimo impostato da parametro
|
||||||
|
dMaxDiam = min( dW, dMaxDiam)
|
||||||
|
|
||||||
-- abilitazione lavorazione da sotto
|
-- abilitazione lavorazione da sotto
|
||||||
local bPockUp = ( BD.DOWN_HEAD and vtExtr:getZ() > -0.259)
|
local bPockUp = ( BD.DOWN_HEAD and vtExtr:getZ() > -0.259)
|
||||||
local bPockDown = ( BD.DOWN_HEAD and vtExtr:getZ() < 0.174)
|
local bPockDown = ( BD.DOWN_HEAD and vtExtr:getZ() < 0.174)
|
||||||
@@ -513,16 +580,16 @@ function ProcessMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
end
|
end
|
||||||
local sPocketing
|
local sPocketing
|
||||||
if Proc.Prc ~= 53 then
|
if Proc.Prc ~= 53 then
|
||||||
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dW, dMorH, nil, sPockType..sMchExt, bPockDown, bExcludeH2)
|
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dMaxDiam, dMorH, nil, sPockType..sMchExt, bPockDown, bExcludeH2)
|
||||||
if not sPocketing and bPockUp then
|
if not sPocketing and bPockUp then
|
||||||
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dW, dMorH, nil, sPockType..sMchExt, _, bExcludeH2)
|
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dMaxDiam, dMorH, nil, sPockType..sMchExt, _, bExcludeH2)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if not sPocketing then
|
if not sPocketing then
|
||||||
sPockType = 'Pocket'
|
sPockType = 'Pocket'
|
||||||
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dW, dMorH, nil, sPockType..sMchExt, bPockDown, bExcludeH2)
|
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dMaxDiam, dMorH, nil, sPockType..sMchExt, bPockDown, bExcludeH2)
|
||||||
if not sPocketing and bPockUp then
|
if not sPocketing and bPockUp then
|
||||||
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dW, dMorH, nil, sPockType..sMchExt, _, bExcludeH2)
|
sPocketing = ProcessMortise.VerifyMortiseOrPocket( Proc, dMaxDiam, dMorH, nil, sPockType..sMchExt, _, bExcludeH2)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if not sPocketing then
|
if not sPocketing then
|
||||||
@@ -543,6 +610,7 @@ function ProcessMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
bCW = ( dSpeed >= 0)
|
bCW = ( dSpeed >= 0)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- inserisco la lavorazione di svuotatura
|
-- inserisco la lavorazione di svuotatura
|
||||||
local sName = 'Mort_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
local sName = 'Mort_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
local nMchFId = EgtAddMachining( sName, sPocketing)
|
local nMchFId = EgtAddMachining( sName, sPocketing)
|
||||||
@@ -562,6 +630,11 @@ function ProcessMortise.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
EgtSetMachiningParam( MCH_MP.SUBTYPE, MCH_POCK_SUB.SPIRALIN)
|
EgtSetMachiningParam( MCH_MP.SUBTYPE, MCH_POCK_SUB.SPIRALIN)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- se diametro utensile esattamente uguale a larghezza tasca, e tasca tonda, si setta un offset radiale negativo
|
||||||
|
if Proc.Fct > 6 and abs( dMillDiam - dW) < 100 * GEO.EPS_SMALL then
|
||||||
|
EgtSetMachiningParam( MCH_MP.OFFSR, - 50 * GEO.EPS_SMALL)
|
||||||
|
end
|
||||||
|
|
||||||
-- aggiungo geometria
|
-- aggiungo geometria
|
||||||
EgtSetMachiningGeometry( {{ AuxId, -1}})
|
EgtSetMachiningGeometry( {{ AuxId, -1}})
|
||||||
-- sistemo la direzione di lavoro
|
-- sistemo la direzione di lavoro
|
||||||
|
|||||||
@@ -0,0 +1,103 @@
|
|||||||
|
-- ProcessSplit.lua by Egaltech s.r.l. 2025/06/20
|
||||||
|
-- Gestione tastatura
|
||||||
|
|
||||||
|
-- Tabella per definizione modulo
|
||||||
|
local ProcessProbing = {}
|
||||||
|
|
||||||
|
-- Include
|
||||||
|
require( 'EgtBase')
|
||||||
|
local BL = require( 'BeamLib')
|
||||||
|
|
||||||
|
-- Dati
|
||||||
|
local ML = require( 'MachiningLib')
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
local function GetProbingMachining( Machinings, sHead)
|
||||||
|
local sProbeMachining, sHeadTool
|
||||||
|
|
||||||
|
-- TODO questa associazione "testa utensile"-"testa tastatore" dovrebbe essere spostata nella macchina.
|
||||||
|
-- Non è detto che se testa utensile inizia con "H2" allora bisogna prendere lavorazione con "_H2"
|
||||||
|
|
||||||
|
-- se la testa utilizzata dalla lavorazione inizia con H2, dovrebbe essere la seconda testa
|
||||||
|
if EgtStartsWith( sHead, 'H2') then
|
||||||
|
sHeadTool = '_H2'
|
||||||
|
else
|
||||||
|
sHeadTool = '_H1'
|
||||||
|
end
|
||||||
|
|
||||||
|
for i = 1, #Machinings do
|
||||||
|
if EgtEndsWith( Machinings[i].Name, sHeadTool) then
|
||||||
|
sProbeMachining = Machinings[i]
|
||||||
|
return sProbeMachining
|
||||||
|
end
|
||||||
|
end
|
||||||
|
sProbeMachining = Machinings[1]
|
||||||
|
return sProbeMachining
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
local function MoveProbePointToRawFaces( ptProbe, vtProbe, nPartId)
|
||||||
|
local b3BoxPart = EgtGetBBoxGlob( EgtGetFirstNameInGroup( nPartId, 'Box') or GDB_ID.NULL, GDB_BB.STANDARD)
|
||||||
|
-- si porta linea di tastatura su grezzo
|
||||||
|
if AreSameVectorApprox( vtProbe, Z_AX()) then
|
||||||
|
ptProbe[3] = b3BoxPart:getMax():getZ()
|
||||||
|
elseif AreSameVectorApprox( vtProbe, -Z_AX()) then
|
||||||
|
ptProbe[3] = b3BoxPart:getMin():getZ()
|
||||||
|
elseif AreSameVectorApprox( vtProbe, Y_AX()) then
|
||||||
|
ptProbe[2] = b3BoxPart:getMax():getY()
|
||||||
|
elseif AreSameVectorApprox( vtProbe, -Y_AX()) then
|
||||||
|
ptProbe[2] = b3BoxPart:getMin():getY()
|
||||||
|
end
|
||||||
|
return ptProbe
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
-- Applicazione della lavorazione
|
||||||
|
function ProcessProbing.Make( Proc, nPartId, Info)
|
||||||
|
local bOk, sErr
|
||||||
|
|
||||||
|
-- per eseguire tastatura servono tutti i dati, altriemnti impossibile
|
||||||
|
if Info.vtProbe and Info.ptProbe and Info.sType then
|
||||||
|
Info.ptProbe = MoveProbePointToRawFaces( Info.ptProbe, Info.vtProbe, nPartId)
|
||||||
|
-- recupero gruppo per geometria addizionale
|
||||||
|
local nAddGrpId = BL.GetAddGroup( nPartId)
|
||||||
|
local nIdLine = EgtLinePVL( nAddGrpId, Info.ptProbe, Info.vtProbe, 10, GDB_RT.GLOB) -- TODO lunghezza da portare fuori come parametro
|
||||||
|
local Machinings = GetMachinings( MCH_MY.PROBING, Info.sType)
|
||||||
|
-- se c'è almeno una lavorazione, allora devo fare tastatura
|
||||||
|
if Machinings and #Machinings > 0 then
|
||||||
|
local sProbing = GetProbingMachining( Machinings, Info.sHead)
|
||||||
|
-- se c'è la linea e la lavorazione, applico
|
||||||
|
if sProbing and nIdLine then
|
||||||
|
local sName = 'DtMtProbe_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
|
local nMchFId = EgtAddMachining( sName, sProbing.Name)
|
||||||
|
-- si inverte la direzione della linea, deve essere entrante, oppostaa vettore estrusione
|
||||||
|
EgtInvertCurve( nIdLine)
|
||||||
|
-- aggiungo geometria
|
||||||
|
EgtSetMachiningGeometry( {{ nIdLine, -1}})
|
||||||
|
|
||||||
|
-- eseguo
|
||||||
|
if not ML.ApplyMachining( true, false) then
|
||||||
|
local _, sErr = EgtGetLastMachMgrError()
|
||||||
|
EgtSetOperationMode( nMchFId, false)
|
||||||
|
return false, sErr
|
||||||
|
else
|
||||||
|
bOk = true
|
||||||
|
end
|
||||||
|
else
|
||||||
|
bOk = false
|
||||||
|
sErr = 'Error on probing'
|
||||||
|
end
|
||||||
|
-- altrimenti tastatura non richiesta, esco
|
||||||
|
else
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
else
|
||||||
|
bOk = false
|
||||||
|
sErr = 'Error on probing'
|
||||||
|
end
|
||||||
|
|
||||||
|
return bOk, sErr
|
||||||
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
return ProcessProbing
|
||||||
@@ -206,6 +206,36 @@ local function VerifyCham( Proc, AuxId, nRawId, bMakeVertCham, sDephtCham, sOnly
|
|||||||
return nChamfer, dDepth, sMilling, sMilling2
|
return nChamfer, dDepth, sMilling, sMilling2
|
||||||
end
|
end
|
||||||
|
|
||||||
|
---------------------------------------------------------------------
|
||||||
|
function VerifyOtherMillCanFinish( dDepthProfile, nSide)
|
||||||
|
local dToolMaxDepthFinish
|
||||||
|
-- abilitazione lavorazione da sotto
|
||||||
|
local sMillType = 'Prof_end'
|
||||||
|
local sMillingFinish, _, _, _ = ML.FindMilling( sMillType, nil, nil, nil, nil, true, nil, nil, nil)
|
||||||
|
if not sMillingFinish then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
-- Recupero i dati dell'utensile
|
||||||
|
if EgtMdbSetCurrMachining( sMillingFinish) then
|
||||||
|
local sTuuid = EgtMdbGetCurrMachiningParam( MCH_MP.TUUID)
|
||||||
|
if EgtTdbSetCurrTool( EgtTdbGetToolFromUUID( sTuuid)) then
|
||||||
|
dToolMaxDepthFinish = EgtTdbGetCurrToolMaxDepth()
|
||||||
|
end
|
||||||
|
else
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
local bDouble = ( dDepthProfile + BD.CUT_EXTRA > dToolMaxDepthFinish)
|
||||||
|
-- se lavorazione in doppio richiesta, si verifica se richiesta testa sotto
|
||||||
|
if bDouble and nSide == 0 then
|
||||||
|
return false -- TODO macchine con BD.DOWN_HEAD potrebbero lavorare in doppio in questo caso!
|
||||||
|
end
|
||||||
|
|
||||||
|
if not bDouble or ( dDepthProfile + BD.MILL_OVERLAP < dToolMaxDepthFinish * 2) then
|
||||||
|
return true, sMillingFinish, bDouble
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- Applicazione della lavorazione
|
-- Applicazione della lavorazione
|
||||||
function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
||||||
@@ -468,6 +498,11 @@ function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- se configurata fresa di finitura
|
||||||
|
local bUseOtherMillOnFinish, sFinishMilling, bDoubleFinishMill = VerifyOtherMillCanFinish( dProfDepth, nSide)
|
||||||
|
|
||||||
-- se il chamfer non è esclusivo continuo con le altre lavorazioni
|
-- se il chamfer non è esclusivo continuo con le altre lavorazioni
|
||||||
if nChamfer < 2 then
|
if nChamfer < 2 then
|
||||||
-- verifico se necessario lavorare in doppio
|
-- verifico se necessario lavorare in doppio
|
||||||
@@ -537,10 +572,6 @@ function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
EgtSetMachiningParam( MCH_MP.OFFSR, ( dOriOffset + dOffsetPar))
|
EgtSetMachiningParam( MCH_MP.OFFSR, ( dOriOffset + dOffsetPar))
|
||||||
bFinish = true
|
bFinish = true
|
||||||
end
|
end
|
||||||
-- se parametro sovramateriale è maggiore di 0 lo aggiungo al sovramateriale precedente
|
|
||||||
if dOffsetPar > 0 then
|
|
||||||
EgtSetMachiningParam( MCH_MP.OFFSR, ( dOriOffset + dOffsetPar))
|
|
||||||
end
|
|
||||||
-- eseguo
|
-- eseguo
|
||||||
if not ML.ApplyMachining( true, false) then
|
if not ML.ApplyMachining( true, false) then
|
||||||
local _, sErr = EgtGetLastMachMgrError()
|
local _, sErr = EgtGetLastMachMgrError()
|
||||||
@@ -567,7 +598,7 @@ function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
nMchId = nMch2Id
|
nMchId = nMch2Id
|
||||||
end
|
end
|
||||||
-- se abilitata, aggiungo lavorazione di finitura
|
-- se abilitata, aggiungo lavorazione di finitura
|
||||||
if bFinish then
|
if bFinish and not bUseOtherMillOnFinish then
|
||||||
-- inserisco la lavorazione
|
-- inserisco la lavorazione
|
||||||
local sNewName = 'ProfB_Fin_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
local sNewName = 'ProfB_Fin_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
local nMch2Id = EgtCopyMachining( sNewName, EgtGetName( nMchId))
|
local nMch2Id = EgtCopyMachining( sNewName, EgtGetName( nMchId))
|
||||||
@@ -639,7 +670,13 @@ function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
EgtSetMachiningParam( MCH_MP.DEPTH, dDepth)
|
EgtSetMachiningParam( MCH_MP.DEPTH, dDepth)
|
||||||
end
|
end
|
||||||
-- posizione braccio porta testa
|
-- posizione braccio porta testa
|
||||||
EgtSetMachiningParam( MCH_MP.SCC, EgtIf( bHead, MCH_SCC.ADIR_XP, MCH_SCC.ADIR_XM))
|
local nSCC = MCH_SCC.ADIR_NONE
|
||||||
|
if BD.TURN == 2 then
|
||||||
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
|
else
|
||||||
|
nSCC = EgtIf( bHead, MCH_SCC.ADIR_XP, MCH_SCC.ADIR_XM)
|
||||||
|
end
|
||||||
|
EgtSetMachiningParam( MCH_MP.SCC, nSCC)
|
||||||
-- variabili per gestione direzione percorso e per gestione lavorazione di finitura opzionale
|
-- variabili per gestione direzione percorso e per gestione lavorazione di finitura opzionale
|
||||||
local ptSP, ptEp
|
local ptSP, ptEp
|
||||||
local bFinish
|
local bFinish
|
||||||
@@ -676,7 +713,7 @@ function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
nMchId = nMch2Id
|
nMchId = nMch2Id
|
||||||
end
|
end
|
||||||
-- se abilitata, aggiungo lavorazione di finitura
|
-- se abilitata, aggiungo lavorazione di finitura
|
||||||
if bFinish then
|
if bFinish and not bUseOtherMillOnFinish then
|
||||||
-- inserisco la lavorazione
|
-- inserisco la lavorazione
|
||||||
local sNewName = 'Prof_Fin_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
local sNewName = 'Prof_Fin_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
local nMch2Id = EgtCopyMachining( sNewName, EgtGetName( nMchId))
|
local nMch2Id = EgtCopyMachining( sNewName, EgtGetName( nMchId))
|
||||||
@@ -732,6 +769,46 @@ function ProcessProfCamb.Make( Proc, nPhase, nRawId, nPartId, dCurrOvmH)
|
|||||||
return false, sErr
|
return false, sErr
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
-- se finitura con fresa piccola
|
||||||
|
if bFinish and bUseOtherMillOnFinish then
|
||||||
|
local sDepthFinishMill = EgtIf( bDoubleFinishMill, ( dProfDepth+ BD.MILL_OVERLAP ) / 2, dProfDepth + BD.CUT_EXTRA)
|
||||||
|
local sMachName = 'Fin_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
|
nMchId = EgtAddMachining( sMachName, sFinishMilling)
|
||||||
|
if not nMchId then
|
||||||
|
local sErr = 'Error adding machining ' .. sMachName .. '-' .. sFinishMilling
|
||||||
|
EgtOutLog( sErr)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
-- aggiungo geometria
|
||||||
|
EgtSetMachiningGeometry( {{ AuxId, -1}})
|
||||||
|
|
||||||
|
-- imposto l'affondamento
|
||||||
|
EgtSetMachiningParam( MCH_MP.DEPTH, sDepthFinishMill)
|
||||||
|
-- posizione braccio porta testa
|
||||||
|
EgtSetMachiningParam( MCH_MP.SCC, EgtIf( bHead, MCH_SCC.ADIR_XP, MCH_SCC.ADIR_XM))
|
||||||
|
-- eseguo
|
||||||
|
if not ML.ApplyMachining( true, false) then
|
||||||
|
local _, sErr = EgtGetLastMachMgrError()
|
||||||
|
EgtSetOperationMode( nMchId, false)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
|
||||||
|
if bDoubleFinishMill then
|
||||||
|
local sNewName = 'FinB_' .. ( EgtGetName( Proc.Id) or tostring( Proc.Id))
|
||||||
|
local nMch2Id = EgtCopyMachining( sNewName, EgtGetName( nMchId))
|
||||||
|
-- ottengo l'inversione e setto il contrario
|
||||||
|
local bInvertMode = EgtGetMachiningParam( MCH_MP.INVERT)
|
||||||
|
EgtSetMachiningParam( MCH_MP.INVERT, not bInvertMode)
|
||||||
|
EgtSetMachiningParam( MCH_MP.TOOLINVERT, true)
|
||||||
|
|
||||||
|
-- eseguo
|
||||||
|
if not ML.ApplyMachining( true, false) then
|
||||||
|
local _, sErr = EgtGetLastMachMgrError()
|
||||||
|
EgtSetOperationMode( nMchId, false)
|
||||||
|
return false, sErr
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
-- aggiorno ingombro testa o coda per presa
|
-- aggiorno ingombro testa o coda per presa
|
||||||
if nSide ~= 1 then -- se feature di fianco o da sotto
|
if nSide ~= 1 then -- se feature di fianco o da sotto
|
||||||
|
|||||||
@@ -50,6 +50,7 @@ end
|
|||||||
-- Applicazione della lavorazione
|
-- Applicazione della lavorazione
|
||||||
function ProcessRidgeLap.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
function ProcessRidgeLap.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
||||||
local nForceUseBladeOnNotContinueFace = EgtGetInfo( Proc.Id, 'Q04', 'i') or 0
|
local nForceUseBladeOnNotContinueFace = EgtGetInfo( Proc.Id, 'Q04', 'i') or 0
|
||||||
|
local bUseMill = ( EgtGetInfo( Proc.Id, 'Q05', 'i') or 0) == 1
|
||||||
-- recupero l'ingombro del grezzo di appartenenza
|
-- recupero l'ingombro del grezzo di appartenenza
|
||||||
local b3Raw = EgtGetRawPartBBox( nRawId)
|
local b3Raw = EgtGetRawPartBBox( nRawId)
|
||||||
-- ingombro del pezzo
|
-- ingombro del pezzo
|
||||||
@@ -139,6 +140,9 @@ function ProcessRidgeLap.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
if BL.IsCutNeeded( CutProc, b3Raw, dOvmHead) then
|
if BL.IsCutNeeded( CutProc, b3Raw, dOvmHead) then
|
||||||
local bOk, sErr = Cut.Make( CutProc, nPhase, nRawId, nPartId, dOvmHead, false)
|
local bOk, sErr = Cut.Make( CutProc, nPhase, nRawId, nPartId, dOvmHead, false)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
|
elseif bUseMill then
|
||||||
|
Proc.bForceMill = true
|
||||||
|
return LapJoint.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
||||||
elseif nForceUseBladeOnNotContinueFace > 0 then
|
elseif nForceUseBladeOnNotContinueFace > 0 then
|
||||||
EgtSurfTmRemoveFacet( Proc.Id, vFaceOrd[1] - 1)
|
EgtSurfTmRemoveFacet( Proc.Id, vFaceOrd[1] - 1)
|
||||||
Proc.Fct = Proc.Fct - 1
|
Proc.Fct = Proc.Fct - 1
|
||||||
@@ -169,18 +173,18 @@ function ProcessRidgeLap.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
end
|
end
|
||||||
-- calcolo riferimenti per facce inclinate
|
-- calcolo riferimenti per facce inclinate
|
||||||
local vtRef = Vector3d( vtN[vFaceOrd[3]])
|
local vtRef = Vector3d( vtN[vFaceOrd[3]])
|
||||||
local vtRef2 = EgtIf( bHead, X_AX(), -X_AX())
|
local vtRef2 = Vector3d( vtN[vFaceOrd[2]])
|
||||||
-- eseguo
|
-- eseguo
|
||||||
for i = 1, #vCuts do
|
for i = 1, #vCuts do
|
||||||
local nOrthoOpposite
|
local vtOrtho
|
||||||
if i % 2 == 1 then
|
if i % 2 == 1 then
|
||||||
nOrthoOpposite = BL.GetNearestOrthoOpposite( vtRef)
|
vtOrtho = vtRef
|
||||||
else
|
else
|
||||||
nOrthoOpposite = BL.GetNearestOrthoOpposite( vtRef2)
|
vtOrtho = vtRef2
|
||||||
end
|
end
|
||||||
-- lavoro la faccia
|
-- lavoro la faccia
|
||||||
for j = 1, #vCuts[i] do
|
for j = 1, #vCuts[i] do
|
||||||
local bOk, sErr = Fbs.MakeOne( vCuts[i][j], 0, sCutting, dSawDiam, nOrthoOpposite, dVzLimDwnUp, 0, BD.CUT_SIC, 0, 0, 0, nil, b3Raw)
|
local bOk, sErr = Fbs.MakeOne( vCuts[i][j], 0, sCutting, dSawDiam, vtOrtho, dVzLimDwnUp, 0, BD.CUT_SIC, 0, 0, 0, nil, b3Raw)
|
||||||
if not bOk then
|
if not bOk then
|
||||||
return bOk, sErr
|
return bOk, sErr
|
||||||
end
|
end
|
||||||
@@ -209,7 +213,12 @@ function ProcessRidgeLap.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
local b3Fac1 = EgtSurfTmGetFacetBBoxGlob( Proc.Id, vFaceOrd[1] - 1, GDB_BB.STANDARD)
|
local b3Fac1 = EgtSurfTmGetFacetBBoxGlob( Proc.Id, vFaceOrd[1] - 1, GDB_BB.STANDARD)
|
||||||
if b3Fac1 then dHCI = b3Raw:getMax():getX() - dOvmHead - b3Fac1:getMin():getX() end
|
if b3Fac1 then dHCI = b3Raw:getMax():getX() - dOvmHead - b3Fac1:getMin():getX() end
|
||||||
else
|
else
|
||||||
dHCI = b3Raw:getMax():getX() - dOvmHead - Proc.Box:getMin():getX()
|
-- se feature inclinata, si va oltre ingombro del box. Si considera metà dell'ingombro della faccia inclinata
|
||||||
|
if vtN[vFaceOrd[2]] and vtN[vFaceOrd[2]]:getZ() > 0 then
|
||||||
|
dHCI = b3Raw:getMax():getX() - dOvmHead - Proc.Box:getMin():getX() - ( vtN[vFaceOrd[2]]:getZ() * b3Raw:getDimZ())
|
||||||
|
else
|
||||||
|
dHCI = b3Raw:getMax():getX() - dOvmHead - Proc.Box:getMin():getX()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
BL.UpdateHCING( nRawId, dHCI)
|
BL.UpdateHCING( nRawId, dHCI)
|
||||||
elseif Proc.Tail then
|
elseif Proc.Tail then
|
||||||
@@ -218,7 +227,12 @@ function ProcessRidgeLap.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
local b3Fac1 = EgtSurfTmGetFacetBBoxGlob( Proc.Id, vFaceOrd[1] - 1, GDB_BB.STANDARD)
|
local b3Fac1 = EgtSurfTmGetFacetBBoxGlob( Proc.Id, vFaceOrd[1] - 1, GDB_BB.STANDARD)
|
||||||
if b3Fac1 then dTCI = b3Fac1:getMax():getX() - b3Solid:getMin():getX() end
|
if b3Fac1 then dTCI = b3Fac1:getMax():getX() - b3Solid:getMin():getX() end
|
||||||
else
|
else
|
||||||
dTCI = Proc.Box:getMax():getX() - b3Solid:getMin():getX()
|
-- se feature inclinata, si va oltre ingombro del box. Si considera metà dell'ingombro della faccia inclinata
|
||||||
|
if vtN[vFaceOrd[2]] and vtN[vFaceOrd[2]]:getZ() > 0 then
|
||||||
|
dTCI = Proc.Box:getMax():getX() - b3Solid:getMin():getX() - ( vtN[vFaceOrd[2]]:getZ() * b3Raw:getDimZ())
|
||||||
|
else
|
||||||
|
dTCI = Proc.Box:getMax():getX() - b3Solid:getMin():getX()
|
||||||
|
end
|
||||||
end
|
end
|
||||||
BL.UpdateTCING( nRawId, dTCI)
|
BL.UpdateTCING( nRawId, dTCI)
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -239,6 +239,8 @@ function ProcessRoundArch.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
elseif AreSameOrOppositeVectorApprox( vtExtr, Z_AX()) then
|
elseif AreSameOrOppositeVectorApprox( vtExtr, Z_AX()) then
|
||||||
nSCC = MCH_SCC.ADIR_YP
|
nSCC = MCH_SCC.ADIR_YP
|
||||||
end
|
end
|
||||||
|
elseif BD.TURN == 2 then
|
||||||
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
elseif BD.TURN then
|
elseif BD.TURN then
|
||||||
if vtN:getZ() > 0.707 then
|
if vtN:getZ() > 0.707 then
|
||||||
nSCC = MCH_SCC.ADIR_ZP
|
nSCC = MCH_SCC.ADIR_ZP
|
||||||
|
|||||||
@@ -196,28 +196,53 @@ local function ApplyDiceCut( vFaceOrd, nGoodFace1, nGoodFace4, nAddGrpId, b3Soli
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local dDiceFaceMaxH = 0
|
-- se non ho intersezione con la faccia tappo posso fare il taglio sul fianco
|
||||||
local dDiceFaceMinH = GEO.INFINITO
|
if not nGoodFace1 or nGoodFace1 == 0 then
|
||||||
if ( i % 2) == 0 then
|
-- controllo per eseguire solo un taglio ottimizzato
|
||||||
for cont = 1, #vCuts[i] do
|
local bExecJustOneCut = false
|
||||||
local _, dDiceFaceH, dDiceFaceV = BL.GetFaceHvRefDim( vCuts[i][cont], 0)
|
local dDiceFaceDim = GEO.INFINITO
|
||||||
dDiceFaceMaxH = max( dDiceFaceMaxH, dDiceFaceH)
|
if ( i % 2) == 0 then
|
||||||
-- calcolo lato orizzontale minore ipotizzando sia un trapezio
|
for cont = 1, #vCuts[i] do
|
||||||
local dDiceFaceH2 = ( 2 * EgtSurfArea( vCuts[i][cont]) ) / dDiceFaceV - dDiceFaceH
|
local _, dDiceFaceH, dDiceFaceV = BL.GetFaceHvRefDim( vCuts[i][cont], 0)
|
||||||
dDiceFaceMinH = min( dDiceFaceMinH, dDiceFaceH2)
|
-- se feature verso Z, si ammette anche lavorazione in doppio
|
||||||
|
if AreSameVectorApprox( vtRef, Z_AX()) then
|
||||||
|
if dMaxDepth * 2 > dDiceFaceH + BD.CUT_EXTRA then
|
||||||
|
bExecJustOneCut = true
|
||||||
|
dDiceFaceDim = dDiceFaceH
|
||||||
|
break
|
||||||
|
end
|
||||||
|
elseif AreSameVectorApprox( vtRef, Y_AX()) or AreSameVectorApprox( vtRef, -Y_AX()) then
|
||||||
|
if dMaxDepth > dDiceFaceV + BD.CUT_EXTRA then
|
||||||
|
bExecJustOneCut = true
|
||||||
|
dDiceFaceDim = dDiceFaceV
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
-- se c'è intersezione non ci deve essere ExtraCut
|
||||||
|
else
|
||||||
|
dExtraCut = 0
|
||||||
end
|
end
|
||||||
-- se si può fare, faccio unico taglio parallelo
|
-- se si può fare, faccio unico taglio parallelo
|
||||||
if ( i % 2) == 0 and ( dMaxDepth > dDiceFaceMaxH - 0.5 * dDiceFaceMinH + BD.CUT_EXTRA_MIN) then
|
if bExecJustOneCut then
|
||||||
local bDoubleCut = false
|
local bDoubleCut = false
|
||||||
local dCutExtra = BD.CUT_EXTRA
|
local dCutExtra = BD.CUT_EXTRA
|
||||||
if dMaxDepth < dDiceFaceMaxH + BD.CUT_EXTRA then
|
if dMaxDepth < dDiceFaceDim then
|
||||||
bDoubleCut = true
|
bDoubleCut = true
|
||||||
dCutExtra = - 0.5 * dDiceFaceMinH + BD.CUT_EXTRA_MIN
|
|
||||||
end
|
end
|
||||||
local nSurfToCut = EgtSurfTmBySewing( nAddGrpId, vCuts[i], false)
|
local nSurfToCut = EgtSurfTmBySewing( nAddGrpId, vCuts[i], false)
|
||||||
local nFaceUseCut1, nFaceUseCut2 = MCH_MILL_FU.ORTHO_BACK, MCH_MILL_FU.ORTHO_FRONT
|
|
||||||
if Proc.Tail then
|
local nFaceUseCut1, nFaceUseCut2
|
||||||
|
-- se feature rivolta verso alto setto direzione taglio davanti e dietro
|
||||||
|
if AreSameVectorApprox( vtRef, Z_AX()) then
|
||||||
|
nFaceUseCut1, nFaceUseCut2 = MCH_MILL_FU.ORTHO_BACK, MCH_MILL_FU.ORTHO_FRONT
|
||||||
|
-- altrimenti taglio da sopra
|
||||||
|
else
|
||||||
|
nFaceUseCut2 = MCH_MILL_FU.ORTHO_DOWN
|
||||||
|
end
|
||||||
|
|
||||||
|
if Proc.Tail and AreSameVectorApprox( vtRef, Z_AX()) then
|
||||||
nFaceUseCut1, nFaceUseCut2 = nFaceUseCut2, nFaceUseCut1
|
nFaceUseCut1, nFaceUseCut2 = nFaceUseCut2, nFaceUseCut1
|
||||||
end
|
end
|
||||||
if bDoubleCut then
|
if bDoubleCut then
|
||||||
@@ -424,7 +449,7 @@ function ProcessScarfJoint.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, dOvmTa
|
|||||||
if not nGoodFace1 or nGoodFace1 == 0 then
|
if not nGoodFace1 or nGoodFace1 == 0 then
|
||||||
-- inserisco la lavorazione
|
-- inserisco la lavorazione
|
||||||
local vtRef2 = EgtIf( abs(vtRef:getZ()) < GEO.EPS_SMALL, Z_AX(), EgtIf( bHead, Y_AX(), -Y_AX()))
|
local vtRef2 = EgtIf( abs(vtRef:getZ()) < GEO.EPS_SMALL, Z_AX(), EgtIf( bHead, Y_AX(), -Y_AX()))
|
||||||
bOkd, sErrD = Fbs.MakeOne( nFace4, nGoodFace4 - 1, sCutting, dSawDiam, vtRef2, nil, 0, BD.CUT_SIC, 0, 0, 0, nil, b3Raw)
|
bOkd, sErrD = Fbs.MakeOne( nFace4, nGoodFace4 - 1, sCutting, dSawDiam, vtRef2, nil, BD.CUT_EXTRA, BD.CUT_SIC, 0, 0, 0, nil, b3Raw)
|
||||||
if not bOkd then return bOkd, sErrD end
|
if not bOkd then return bOkd, sErrD end
|
||||||
-- lavoro la faccia opposta (definita dal parametro P11)
|
-- lavoro la faccia opposta (definita dal parametro P11)
|
||||||
if vFaceOrd[3] ~= 0 then
|
if vFaceOrd[3] ~= 0 then
|
||||||
@@ -503,10 +528,20 @@ function ProcessScarfJoint.Make( Proc, nPhase, nRawId, nPartId, dOvmHead, dOvmTa
|
|||||||
else
|
else
|
||||||
dDiamMax = EgtIf( abs( frMor:getVersX():getY()) < abs( frMor:getVersY():getY()), dL, dW)
|
dDiamMax = EgtIf( abs( frMor:getVersX():getY()) < abs( frMor:getVersY():getY()), dL, dW)
|
||||||
end
|
end
|
||||||
-- determino la distanza tra le due facce inclinate
|
-- determino la distanza tra le due facce inclinate per determinare elevazione
|
||||||
local dDistFaces
|
local dDistFaces
|
||||||
if vFaceOrd[4] ~= 0 then
|
if vFaceOrd[4] ~= 0 then
|
||||||
dDistFaces = abs((ptC[vFaceOrd[2]]-ptC[vFaceOrd[4]])*vtN[vFaceOrd[2]])
|
local nElevationFace1 = 0
|
||||||
|
-- controllo estensione faccia 1
|
||||||
|
if vFaceOrd[1] ~= 0 then
|
||||||
|
frMor, dL, dW = EgtSurfTmFacetMinAreaRectangle( Proc.Id, vFaceOrd[1]-1, GDB_ID.ROOT)
|
||||||
|
if abs(vtRef:getY()) > 0.866 then
|
||||||
|
nElevationFace1 = EgtIf( abs( frMor:getVersX():getZ()) < abs( frMor:getVersY():getY()), dL, dW)
|
||||||
|
else
|
||||||
|
nElevationFace1 = EgtIf( abs( frMor:getVersX():getY()) < abs( frMor:getVersY():getY()), dL, dW)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
dDistFaces = max( abs((ptC[vFaceOrd[2]]-ptC[vFaceOrd[4]])*vtN[vFaceOrd[2]]), nElevationFace1)
|
||||||
end
|
end
|
||||||
-- recupero la lavorazione. considerando l dimensione del lato e l'affondamento
|
-- recupero la lavorazione. considerando l dimensione del lato e l'affondamento
|
||||||
local sPocketing
|
local sPocketing
|
||||||
|
|||||||
+29
-15
@@ -336,7 +336,7 @@ end
|
|||||||
|
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- tagli verticali aggiuntivi
|
-- tagli verticali aggiuntivi
|
||||||
local function AddVerticalPreCuts( Proc, sCutting, dCutXOffset, b3Raw, sNotes)
|
local function AddVerticalPreCuts( Proc, sCutting, dCutXOffset, b3Raw, sNotes, dOffsetBetweenCuts)
|
||||||
local nVerticalCuts = ceil( Proc.Face[1].WidthTrimmed / ( BD.MAX_LEN_DICE)) - 1
|
local nVerticalCuts = ceil( Proc.Face[1].WidthTrimmed / ( BD.MAX_LEN_DICE)) - 1
|
||||||
local dVerticalSliceHeight = Proc.Face[1].WidthTrimmed / ( nVerticalCuts + 1)
|
local dVerticalSliceHeight = Proc.Face[1].WidthTrimmed / ( nVerticalCuts + 1)
|
||||||
-- recupero il diametro dell'utensile
|
-- recupero il diametro dell'utensile
|
||||||
@@ -352,8 +352,8 @@ local function AddVerticalPreCuts( Proc, sCutting, dCutXOffset, b3Raw, sNotes)
|
|||||||
for j = nVerticalCuts, 1, -1 do
|
for j = nVerticalCuts, 1, -1 do
|
||||||
local nFaceUse = MCH_MILL_FU.PARAL_FRONT
|
local nFaceUse = MCH_MILL_FU.PARAL_FRONT
|
||||||
local dVerticalCutOffset = dVerticalSliceHeight * -j
|
local dVerticalCutOffset = dVerticalSliceHeight * -j
|
||||||
local bForceTangentLeadInOut = BD.PRESS_ROLLER
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
bOk, sErr = Fbs.MakeOne( Proc.Id, 0, sCutting, dSawDiam, nFaceUse, nil, -0.1 -dCutXOffset, BD.CUT_SIC, dVerticalCutOffset, 0, 0, sNotes, b3Raw, nil, nil, nil, bForceTangentLeadInOut)
|
bOk, sErr = Fbs.MakeOne( Proc.Id, 0, sCutting, dSawDiam, nFaceUse, nil, -0.1 -dCutXOffset, BD.CUT_SIC, dVerticalCutOffset, 0, 0, sNotes, b3Raw, nil, nil, nil, sLeadInOutType, nil, dOffsetBetweenCuts)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -374,7 +374,7 @@ local function MakeStandardCuts( Proc, b3Raw, nCuts, dOffsetBetweenCuts, TailCut
|
|||||||
local dCutExtra = 0
|
local dCutExtra = 0
|
||||||
local dAccStart = 0
|
local dAccStart = 0
|
||||||
local dAccEnd = 0
|
local dAccEnd = 0
|
||||||
if TailCutType.bBigSectionCut and BD.C_SIMM then
|
if TailCutType.bBigSectionCut and BD.C_SIMM and b3Raw:getDimZ() > BD.MIN_DIM_HBEAM + 10 * GEO.EPS_SMALL then
|
||||||
-- qui arrivano sezioni molto grandi su macchine tipo PF con materiale da asportare inferiore allo spessore lama
|
-- qui arrivano sezioni molto grandi su macchine tipo PF con materiale da asportare inferiore allo spessore lama
|
||||||
local dSawRad = Cutting1Data.dSawDiam / 2
|
local dSawRad = Cutting1Data.dSawDiam / 2
|
||||||
dCutExtra = - ( b3Raw:getDimY() - dSawRad)
|
dCutExtra = - ( b3Raw:getDimY() - dSawRad)
|
||||||
@@ -422,8 +422,8 @@ local function MakeStandardCuts( Proc, b3Raw, nCuts, dOffsetBetweenCuts, TailCut
|
|||||||
for j = nHorizontalCuts, 1, -1 do
|
for j = nHorizontalCuts, 1, -1 do
|
||||||
local nFaceUse = MCH_MILL_FU.PARAL_DOWN
|
local nFaceUse = MCH_MILL_FU.PARAL_DOWN
|
||||||
local dHorizontalCutOffset = dHorizontalSliceHeight * -j
|
local dHorizontalCutOffset = dHorizontalSliceHeight * -j
|
||||||
local bForceTangentLeadInOut = BD.PRESS_ROLLER
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0 , Cutting1Data.sCutting, Cutting1Data.dSawDiam, nFaceUse, nil, -0.1 - dCutXOffset, BD.CUT_SIC, dHorizontalCutOffset, 0, 0, 'Precut;', b3Raw, nil, nil, nil, bForceTangentLeadInOut)
|
local bOk, sErr = Fbs.MakeOne( Proc.Id, 0 , Cutting1Data.sCutting, Cutting1Data.dSawDiam, nFaceUse, nil, -0.1 - dCutXOffset, BD.CUT_SIC, dHorizontalCutOffset, 0, 0, 'Precut;', b3Raw, nil, nil, nil, sLeadInOutType, nil, dOffsetBetweenCuts)
|
||||||
if not bOk then return false, sErr end
|
if not bOk then return false, sErr end
|
||||||
end
|
end
|
||||||
-- se necessario taglio verticale doppio, eseguo l'opposto
|
-- se necessario taglio verticale doppio, eseguo l'opposto
|
||||||
@@ -472,7 +472,7 @@ local function MakeStandardCuts( Proc, b3Raw, nCuts, dOffsetBetweenCuts, TailCut
|
|||||||
-- se trave larga effettuo tagli verticali aggiuntivi
|
-- se trave larga effettuo tagli verticali aggiuntivi
|
||||||
if TailCutType.bNeedVerticalAddedCuts then
|
if TailCutType.bNeedVerticalAddedCuts then
|
||||||
local sSpecNotes = EgtIf( TailCutType.bSplit, 'Presplit;', 'Precut;')
|
local sSpecNotes = EgtIf( TailCutType.bSplit, 'Presplit;', 'Precut;')
|
||||||
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw, sSpecNotes)
|
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw, sSpecNotes, dOffsetBetweenCuts)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
if i == 1 and TailCutType.sType =='Precut' then
|
if i == 1 and TailCutType.sType =='Precut' then
|
||||||
@@ -541,7 +541,7 @@ local function MakeStandardCuts( Proc, b3Raw, nCuts, dOffsetBetweenCuts, TailCut
|
|||||||
-- se trave larga effettuo tagli verticali aggiuntivi
|
-- se trave larga effettuo tagli verticali aggiuntivi
|
||||||
if TailCutType.bNeedVerticalAddedCuts then
|
if TailCutType.bNeedVerticalAddedCuts then
|
||||||
local sSpecNotes = EgtIf( TailCutType.bSplit, 'Presplit;', 'Precut;')
|
local sSpecNotes = EgtIf( TailCutType.bSplit, 'Presplit;', 'Precut;')
|
||||||
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw, sSpecNotes)
|
local bOk, sErr = AddVerticalPreCuts( Proc, Cutting1Data.sCutting, dCutOffset, b3Raw, sSpecNotes, dOffsetBetweenCuts)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
end
|
end
|
||||||
local sNotes
|
local sNotes
|
||||||
@@ -573,7 +573,15 @@ function ProcessSplit.Make( Proc, nPhase, nRawId, nPartId, nOrd, sDownOrSideOrSt
|
|||||||
if not bOkc then return bOkc, sErrC end
|
if not bOkc then return bOkc, sErrC end
|
||||||
end
|
end
|
||||||
-- recupero la lavorazione
|
-- recupero la lavorazione
|
||||||
local sCutting = ML.FindCutting( 'TailSide')
|
-- TODO questa parte andrà cambiata quando si gestiranno i volumi liberi in cui girare da mlse
|
||||||
|
local dMinWidthForBigBlade = 300
|
||||||
|
local dMaxHeightForBigBlade = 300
|
||||||
|
local sCutting
|
||||||
|
if b3Raw:getDimY() > dMinWidthForBigBlade and b3Raw:getDimZ() < dMaxHeightForBigBlade then
|
||||||
|
sCutting = ML.FindCutting( 'TailSide', nil, nil, nil, 'Longest')
|
||||||
|
else
|
||||||
|
sCutting = ML.FindCutting( 'TailSide')
|
||||||
|
end
|
||||||
if not sCutting then
|
if not sCutting then
|
||||||
local sErr = 'Error on process ' .. tostring( Proc.Id) .. ' cutting not found in library'
|
local sErr = 'Error on process ' .. tostring( Proc.Id) .. ' cutting not found in library'
|
||||||
EgtOutLog( sErr)
|
EgtOutLog( sErr)
|
||||||
@@ -623,10 +631,11 @@ function ProcessSplit.Make( Proc, nPhase, nRawId, nPartId, nOrd, sDownOrSideOrSt
|
|||||||
-- caratteristiche taglio
|
-- caratteristiche taglio
|
||||||
local dDimYRef = EgtIf( b3Raw:getDimZ() < BD.MIN_DIM_HBEAM + 10 * GEO.EPS_SMALL, dSawMaxDepth, abs( BD.MAX_DIM_HTCUT_HBEAM))
|
local dDimYRef = EgtIf( b3Raw:getDimZ() < BD.MIN_DIM_HBEAM + 10 * GEO.EPS_SMALL, dSawMaxDepth, abs( BD.MAX_DIM_HTCUT_HBEAM))
|
||||||
local bBigSectionCut = ( b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL) and
|
local bBigSectionCut = ( b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL) and
|
||||||
( b3Raw:getDimZ() > EgtIf( BD.TURN, 2 * dMaxVertDepth, dMaxVertDepth + dSawMaxDepth2) - 2 * BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
( b3Raw:getDimZ() > EgtIf( BD.TURN, 2 * dMaxVertDepth, dMaxVertDepth + dSawMaxDepth2) - 2 * BD.CUT_EXTRA + 10 * GEO.EPS_SMALL)
|
||||||
local bHorizCut = ( ( b3Raw:getDimY() > b3Raw:getDimZ() + 10 * GEO.EPS_SMALL or BD.TURN) and ( b3Raw:getDimZ() < dMaxVertDepth - BD.CUT_EXTRA))
|
local bHorizCut = ( ( b3Raw:getDimY() > b3Raw:getDimZ() + 10 * GEO.EPS_SMALL or BD.TURN) and ( b3Raw:getDimZ() < dMaxVertDepth - BD.CUT_EXTRA))
|
||||||
local bDoubleHorizCut = ( ( BD.DOWN_HEAD or BD.TURN) and not bHorizCut and b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
local bDoubleHorizCut = ( ( BD.DOWN_HEAD or BD.TURN) and not bHorizCut and b3Raw:getDimY() > 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
||||||
local bDoubleCut = ( not bHorizCut and not bDoubleHorizCut and b3Raw:getDimY() > dDimYRef - BD.CUT_EXTRA + 10 * GEO.EPS_SMALL)
|
local bDoubleCut = ( not bHorizCut and not bDoubleHorizCut and b3Raw:getDimY() > dDimYRef - BD.CUT_EXTRA + 10 * GEO.EPS_SMALL) and
|
||||||
|
( b3Raw:getDimY() < 2 * dDimYRef - BD.CUT_EXTRA_MIN + 10 * GEO.EPS_SMALL)
|
||||||
-- dati geometrici del taglio
|
-- dati geometrici del taglio
|
||||||
local ptC, vtN = EgtSurfTmFacetCenter( Proc.Id, 0, GDB_ID.ROOT)
|
local ptC, vtN = EgtSurfTmFacetCenter( Proc.Id, 0, GDB_ID.ROOT)
|
||||||
-- separazione solo se esiste grezzo successivo con pezzi o scaricabile
|
-- separazione solo se esiste grezzo successivo con pezzi o scaricabile
|
||||||
@@ -652,7 +661,10 @@ function ProcessSplit.Make( Proc, nPhase, nRawId, nPartId, nOrd, sDownOrSideOrSt
|
|||||||
-- determino la necessità di tagli aggiuntivi
|
-- determino la necessità di tagli aggiuntivi
|
||||||
local dMinTailScrapForAdditionalCuts = 10.123
|
local dMinTailScrapForAdditionalCuts = 10.123
|
||||||
local bNeedVerticalAddedCuts = not bSplit and ( Proc.Face[1].WidthTrimmed > BD.MAX_LEN_DICE) and ( dLenEndRaw > dMinTailScrapForAdditionalCuts - 10 * GEO.EPS_SMALL)
|
local bNeedVerticalAddedCuts = not bSplit and ( Proc.Face[1].WidthTrimmed > BD.MAX_LEN_DICE) and ( dLenEndRaw > dMinTailScrapForAdditionalCuts - 10 * GEO.EPS_SMALL)
|
||||||
local bNeedHorizontalAddedCuts = not bSplit and ( Proc.Face[1].HeightTrimmed > ( BD.MIN_HEIGHT_ADDED_CUTS or BD.MAX_LEN_DICE)) and not bBigSectionCut and ( dLenEndRaw > dMinTailScrapForAdditionalCuts - 10 * GEO.EPS_SMALL)
|
local bNeedHorizontalAddedCuts = not bSplit and not bBigSectionCut and
|
||||||
|
( Proc.Face[1].HeightTrimmed > ( BD.MIN_HEIGHT_ADDED_CUTS or BD.MAX_LEN_DICE)) and
|
||||||
|
( dLenEndRaw > dMinTailScrapForAdditionalCuts - 10 * GEO.EPS_SMALL) and
|
||||||
|
dOffsL < BD.MAX_DIM_DICE
|
||||||
-- dati lavorazioni sopra e sotto
|
-- dati lavorazioni sopra e sotto
|
||||||
local Cutting1Data = { sCutting = sCutting, dSawDiam = dSawDiam, dMaxDepth = dSawMaxDepth, dSawThick = dSawThick, dMaxVertDepth = dMaxVertDepth}
|
local Cutting1Data = { sCutting = sCutting, dSawDiam = dSawDiam, dMaxDepth = dSawMaxDepth, dSawThick = dSawThick, dMaxVertDepth = dMaxVertDepth}
|
||||||
local Cutting2Data = { sCutting = sCutting2, dSawDiam = dSawDiam2, dMaxDepth = dSawMaxDepth2, dSawThick = dSawThick2}
|
local Cutting2Data = { sCutting = sCutting2, dSawDiam = dSawDiam2, dMaxDepth = dSawMaxDepth2, dSawThick = dSawThick2}
|
||||||
@@ -759,14 +771,16 @@ function ProcessSplit.Make( Proc, nPhase, nRawId, nPartId, nOrd, sDownOrSideOrSt
|
|||||||
if AreOppositeVectorApprox( X_AX(), vtNLimitingSurf) then EgtInvertSurf( nLimitingSurf) end
|
if AreOppositeVectorApprox( X_AX(), vtNLimitingSurf) then EgtInvertSurf( nLimitingSurf) end
|
||||||
end
|
end
|
||||||
-- tagli verticali
|
-- tagli verticali
|
||||||
bOk, sErr = AddVerticalPreCuts( AddProc, sCutting, 0, b3Raw, sNotes)
|
bOk, sErr = AddVerticalPreCuts( AddProc, sCutting, 0, b3Raw, sNotes, dOffsL)
|
||||||
if not bOk then return bOk, sErr end
|
if not bOk then return bOk, sErr end
|
||||||
-- tagli a cubetti con eventuale superficie limitante
|
-- tagli a cubetti con eventuale superficie limitante
|
||||||
bOk, sErr = Cut.Make( AddProc, nNewPhase, nRawId, nPartId, dMaxElev, nil, false, true, b3Raw, sNotes, dCurrOvmT, nil, nLimitingSurf)
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
|
bOk, sErr = Cut.Make( AddProc, nNewPhase, nRawId, nPartId, dMaxElev, nil, false, true, b3Raw, sNotes, dCurrOvmT, nil, nLimitingSurf, sLeadInOutType)
|
||||||
end
|
end
|
||||||
-- tagli aggiuntivi non necessari
|
-- tagli aggiuntivi non necessari
|
||||||
else
|
else
|
||||||
bOk, sErr = Cut.Make( Proc, nNewPhase, nRawId, nPartId, dMaxElev, nil, false, true, b3Raw, sNotes, dCurrOvmT)
|
local sLeadInOutType = 'PerpendicularOutraw'
|
||||||
|
bOk, sErr = Cut.Make( Proc, nNewPhase, nRawId, nPartId, dMaxElev, nil, false, true, b3Raw, sNotes, dCurrOvmT, nil, nil, sLeadInOutType)
|
||||||
end
|
end
|
||||||
if sNotesFinal then
|
if sNotesFinal then
|
||||||
EgtSetMachiningParam( MCH_MP.USERNOTES, sNotesFinal)
|
EgtSetMachiningParam( MCH_MP.USERNOTES, sNotesFinal)
|
||||||
|
|||||||
@@ -13,6 +13,7 @@ local Fbs = require( 'FacesBySaw')
|
|||||||
local DC = require( 'DiceCut')
|
local DC = require( 'DiceCut')
|
||||||
local Cut = require( 'ProcessCut')
|
local Cut = require( 'ProcessCut')
|
||||||
local Topology = require( 'FeatureTopology')
|
local Topology = require( 'FeatureTopology')
|
||||||
|
local LapJoint = require( 'ProcessLapJoint')
|
||||||
|
|
||||||
EgtOutLog( ' ProcessStepJointNotch started', 1)
|
EgtOutLog( ' ProcessStepJointNotch started', 1)
|
||||||
|
|
||||||
@@ -49,7 +50,7 @@ function ProcessStepJointNotch.Classify( Proc)
|
|||||||
-- numero delle facce
|
-- numero delle facce
|
||||||
local nFacetCnt = EgtSurfTmFacetCount( Proc.Id)
|
local nFacetCnt = EgtSurfTmFacetCount( Proc.Id)
|
||||||
-- gestisco solo 2 o 4 facce
|
-- gestisco solo 2 o 4 facce
|
||||||
if nFacetCnt ~= 2 and nFacetCnt ~= 4 and nFacetCnt ~= 6 and nFacetCnt ~= 8 then
|
if nFacetCnt ~= 2 and nFacetCnt ~= 3 and nFacetCnt ~= 4 and nFacetCnt ~= 6 and nFacetCnt ~= 8 then
|
||||||
return false, false
|
return false, false
|
||||||
end
|
end
|
||||||
-- verifico le normali delle facce
|
-- verifico le normali delle facce
|
||||||
@@ -132,7 +133,12 @@ local function MakePocket( Proc, nPartId, ptPs, vtN, nFaceRef, nDiffWidth, sMchF
|
|||||||
-- calcolo il diametro utensile
|
-- calcolo il diametro utensile
|
||||||
local dDiamTool
|
local dDiamTool
|
||||||
if nUseRoughTool == 1 then
|
if nUseRoughTool == 1 then
|
||||||
dDiamTool = max( 80, min( tBHx[nFaceRef][1], tBHx[nFaceRef][2]))
|
-- se feature passante prendo utensile più grande possibile
|
||||||
|
if ( Proc.AffectedFaces.Top and Proc.AffectedFaces.Bottom) or ( Proc.AffectedFaces.Front and Proc.AffectedFaces.Back) then
|
||||||
|
dDiamTool = nil
|
||||||
|
else
|
||||||
|
dDiamTool = max( 80, min( tBHx[nFaceRef][1], tBHx[nFaceRef][2]))
|
||||||
|
end
|
||||||
else
|
else
|
||||||
-- se non uso truciolatore prendo il valore dalle dimensioni minime delle facce
|
-- se non uso truciolatore prendo il valore dalle dimensioni minime delle facce
|
||||||
dDiamTool = min( tBHx[nFaceRef][1], tBHx[nFaceRef][2])
|
dDiamTool = min( tBHx[nFaceRef][1], tBHx[nFaceRef][2])
|
||||||
@@ -283,8 +289,8 @@ local function MachineByMill( Proc, nPhase, nRawId, nPartId, b3Solid, ptC, vtN,
|
|||||||
-- setto a 0 eventuali offset
|
-- setto a 0 eventuali offset
|
||||||
EgtSetMachiningParam( MCH_MP.OFFSR, 0)
|
EgtSetMachiningParam( MCH_MP.OFFSR, 0)
|
||||||
-- applico gli allungamenti o accorciamenti considerando che la lavorazione è invertita
|
-- applico gli allungamenti o accorciamenti considerando che la lavorazione è invertita
|
||||||
EgtSetMachiningParam( MCH_MP.STARTADDLEN, EgtIf( bOpenStart, dTDiam / 2, - dTDiam / 2))
|
EgtSetMachiningParam( MCH_MP.STARTADDLEN, EgtIf( bOpenStart, dTDiam / 2 + 10, - dTDiam / 2))
|
||||||
EgtSetMachiningParam( MCH_MP.ENDADDLEN, EgtIf( bOpenEnd, dTDiam / 2, - dTDiam / 2))
|
EgtSetMachiningParam( MCH_MP.ENDADDLEN, EgtIf( bOpenEnd, dTDiam / 2 + 10, - dTDiam / 2))
|
||||||
-- attacchi e uscite lineari con parte tg nulla
|
-- attacchi e uscite lineari con parte tg nulla
|
||||||
EgtSetMachiningParam( MCH_MP.LEADINTYPE, MCH_MILL_LI.LINEAR)
|
EgtSetMachiningParam( MCH_MP.LEADINTYPE, MCH_MILL_LI.LINEAR)
|
||||||
EgtSetMachiningParam( MCH_MP.LITANG, 0)
|
EgtSetMachiningParam( MCH_MP.LITANG, 0)
|
||||||
@@ -578,6 +584,9 @@ end
|
|||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
-- Applicazione della lavorazione
|
-- Applicazione della lavorazione
|
||||||
function ProcessStepJointNotch.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
function ProcessStepJointNotch.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
||||||
|
if Proc.Fct == 3 then
|
||||||
|
return LapJoint.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
||||||
|
end
|
||||||
-- esecuzione eventuale smusso
|
-- esecuzione eventuale smusso
|
||||||
-- ottengo anche il flag che indica che la feature è larga come la trave
|
-- ottengo anche il flag che indica che la feature è larga come la trave
|
||||||
local bOkc, sErrC, nDiffWidth = MakeChamfer( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
local bOkc, sErrC, nDiffWidth = MakeChamfer( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
||||||
|
|||||||
@@ -321,9 +321,9 @@ function ProcessTenon.Make( Proc, nPhase, nRawId, nPartId, dOvmHead)
|
|||||||
-- se contorno aperto, cambio parametri di attacco/uscita
|
-- se contorno aperto, cambio parametri di attacco/uscita
|
||||||
if not bClosed then
|
if not bClosed then
|
||||||
EgtSetMachiningParam( MCH_MP.LITANG, 0.7 * dMillDiam)
|
EgtSetMachiningParam( MCH_MP.LITANG, 0.7 * dMillDiam)
|
||||||
EgtSetMachiningParam( MCH_MP.LIPERP, 0)
|
EgtSetMachiningParam( MCH_MP.LIPERP, 20)
|
||||||
EgtSetMachiningParam( MCH_MP.LOTANG, 0.7 * dMillDiam)
|
EgtSetMachiningParam( MCH_MP.LOTANG, 0.7 * dMillDiam)
|
||||||
EgtSetMachiningParam( MCH_MP.LOPERP, 0)
|
EgtSetMachiningParam( MCH_MP.LOPERP, 20)
|
||||||
end
|
end
|
||||||
-- imposto posizione braccio porta testa
|
-- imposto posizione braccio porta testa
|
||||||
local nSCC = MCH_SCC.NONE
|
local nSCC = MCH_SCC.NONE
|
||||||
|
|||||||
+188
@@ -1,5 +1,193 @@
|
|||||||
==== Beam Update Log ====
|
==== Beam Update Log ====
|
||||||
|
|
||||||
|
Versione 2.7j2 (30/10/2025)
|
||||||
|
- Fixed : in DoubleCut gestito il caso in cui si ha una terza faccia piccola da non lavorare
|
||||||
|
|
||||||
|
Versione 2.7j1 (28/10/2025)
|
||||||
|
- Modif : migliorato ordinamento feature
|
||||||
|
- Modif : in mortasa si considera ora il raggio minimo impostato da parametro P
|
||||||
|
- Modif : migliorie in tenone a coda di rondine
|
||||||
|
- Fixed : in mortasa corretto percorso errato in caso di diametro utensile uguale a larghezza tasca
|
||||||
|
- Fixed : in profilo cambered (103) gestito correttamente inverti in lavorazione
|
||||||
|
|
||||||
|
Versione 2.7i2 (30/09/2025)
|
||||||
|
- Modif : migliorie a mortasa e tenone a coda di rondine
|
||||||
|
- Modif : migliorie a LongDoubleCut
|
||||||
|
- Modif : migliorie ai tagli
|
||||||
|
|
||||||
|
Versione 2.7i1 (03/09/2025)
|
||||||
|
- Added : in Tenone a coda di rondine aggiunto passaggio di finitura in caso di P14 > 0
|
||||||
|
- Modif : in LapJoint migliorata la scelta lama in caso di due facce e altre piccole correzioni
|
||||||
|
|
||||||
|
Versione 2.7h3 (26/08/2025)
|
||||||
|
- Added : in LapJoint, se possibile, si ricalcola l'elevazione in caso di feature troncanti testa/coda
|
||||||
|
- Modif : eventuali feature troncanti testa/coda sono fatte sempre subito dopo i rispettivi tagli di testa/coda
|
||||||
|
|
||||||
|
Versione 2.7h2 (19/08/2025)
|
||||||
|
- Modif : migliorata ottimizzazione teste
|
||||||
|
- Modif : migliorate forature in doppio
|
||||||
|
- Modif : in LapJoint migliorate lavorazioni lama + sega a catena
|
||||||
|
- Modif : in LapJoint migliorata spezzatura per feature lunghe rispetto al pezzo
|
||||||
|
- Modif : in LapJoint tipo BirdsMouth migliorata lavorazione faccia inclinata
|
||||||
|
- Modif : in StepJointNotch, se 3 facce si riconduce a LapJoint
|
||||||
|
|
||||||
|
Versione 2.7h1 (05/08/2025)
|
||||||
|
- Fixed : in Mortise migliorata la lavorazione in caso di feature trimmata
|
||||||
|
- Modif : in LapJoint, riduzione massimo materiale lama per lavorazioni antischeggia di lama con direzione verticale
|
||||||
|
- Modif : in LapJoint migliorie alla lavorazione tipo BlockHaus
|
||||||
|
- Modif : nei profili si usa il tipo lavorazione Prof_end per la finitura
|
||||||
|
|
||||||
|
Versione 2.7g5 (14/07/2025)
|
||||||
|
- Fixed : in tagli di testa e coda corretti attacchi
|
||||||
|
|
||||||
|
Versione 2.7g4 (11/07/2025)
|
||||||
|
- Fixed : in LapJoint 2 facce correzione nella scelta lama da sotto
|
||||||
|
|
||||||
|
Versione 2.7g3 (11/07/2025)
|
||||||
|
- Fixed : in RidgeLap corretta scelta del lato da lavorare
|
||||||
|
|
||||||
|
Versione 2.7g2 (10/07/2025)
|
||||||
|
- Fixed : in LapJoint correzione per caso in cui la sega a catena lavorava la tasca in modo errato
|
||||||
|
|
||||||
|
Versione 2.7g1 (08/07/2025)
|
||||||
|
- Added : in LapJoint, aggiunti smussi anche se lavorazione con truciolatore
|
||||||
|
- Added : per profilo caudato aggiunta finitura con fresa piccola
|
||||||
|
- Added : gestione tastatura
|
||||||
|
- Modif : nei tagli di testa e coda, compresi quelli di spezzatura, la lama evita di arretrare se non necessario
|
||||||
|
- Modif : in LongDoubleCut migliorie varie
|
||||||
|
- Modif : in RidgeLap migliorie varie
|
||||||
|
- Modif : nelle forature che attraversano un taglio ora si considera la profondità già lavorata
|
||||||
|
- Fixed : in LongDoubleCut corretta lavorazione aggiunta erroneamente dopo separazione
|
||||||
|
|
||||||
|
Versione 2.7f3 (19/06/2025)
|
||||||
|
- Modif : in StepJointNotch corretta distanza attacco in/out
|
||||||
|
|
||||||
|
Versione 2.7f2 (18/06/2025)
|
||||||
|
- Modif : in LongDoubleCut aggiunto messaggio feature non completa se utensile non arriva sul fondo
|
||||||
|
- Modif : in StepJointNotch, se si forza truciolatore, si prende utensile più grande
|
||||||
|
- Fixed : in LapJoint, piccola correzione calcolo sovrapposizione trimesh per svuotatura
|
||||||
|
- Fixed : in LapJoint, per sovrapposizione in spezzatura, corretto caso tipo Tunnel
|
||||||
|
|
||||||
|
Versione 2.7f1 (03/06/2025)
|
||||||
|
- Modif : in tenone coda di rondine modificato angolo limite tenone per lavorazione in sottosquadro
|
||||||
|
- Modif : migliorie per lavorazioni su aggregato
|
||||||
|
|
||||||
|
Versione 2.7e2 (23/05/2025)
|
||||||
|
- Modif : in tagli di lama migliorie alla scelta del lato da lavorare
|
||||||
|
- Modif : in mortasa coda di rondine migliorati i percorsi
|
||||||
|
- Modif : in tenone coda di rondine migliorate le lavorazioni da sotto
|
||||||
|
- Fixed : in Scarf Joint correzione alla scelta faccia da lavorare
|
||||||
|
|
||||||
|
Versione 2.7e1 (05/05/2025)
|
||||||
|
- Modif : in LapJoint se tunnel verticale lavorato solo da sopra e l'utensile non arriva, si restituisce warning
|
||||||
|
- Fixed : in taglio di separazione si riduce percorso di taglio solo se il pezzo è effettivamente alto
|
||||||
|
- Fixed : in foratura corretto caso in cui non si sceglieva l'utensile più lungo disponibile
|
||||||
|
- Fixed : In BatchProcess (Ts7) corretta generazione in caso di progetto senza ricalcolo
|
||||||
|
|
||||||
|
Versione 2.7d3 (22/04/2025)
|
||||||
|
- Fixed : in LapJoint corretta gestione errata Q04
|
||||||
|
|
||||||
|
Versione 2.7d2 (17/04/2025)
|
||||||
|
- Added : in scanalatura aggiunta Q03 per forzare fresa
|
||||||
|
- Modif : in slot con lama + sega a catena abilitata lavorazione da sotto per macchine con testa sopra
|
||||||
|
- Modif : nei tagli modifche in caso di tagli di coda anticipati
|
||||||
|
- Modif : in lavorazioni tipo tacca ma 3 facce migliorata la scelta faccia
|
||||||
|
|
||||||
|
Versione 2.7d1 (04/04/2025)
|
||||||
|
- Fixed : in PreDrill piccola correzione
|
||||||
|
- Fixed : nei tagli varie correzioni
|
||||||
|
- Fixed : in HeadCut e Split corretto calcolo lunghezza extra di taglio
|
||||||
|
|
||||||
|
Versione 2.7c2 (24/03/2025)
|
||||||
|
- Fixed : in BatchProcess (Ts7) riabilitata modifica barra erroneamente rimossa
|
||||||
|
|
||||||
|
Versione 2.7c1 (17/03/2025)
|
||||||
|
- Modif : in HeadCut e Split, per decidere se fare doppio taglio verticale, si controlla anche il massimo possibile e non solo il minimo
|
||||||
|
- Modif : in LapJoint migliorato controllo per decidere se feature di coda
|
||||||
|
- Modif : nei tagli, se taglio rivolto verso il basso e non possibile tagliare di fianco, si fa in fase ribaltata
|
||||||
|
- Fixed : in BatchProcess (Ts7) corretta restituzione stato feature erroneamente segnalata verde
|
||||||
|
- Fixed : corretta restituzione stato feature lavorata in doppio
|
||||||
|
|
||||||
|
Versione 2.7b3 (03/03/2025)
|
||||||
|
- Modif : in forature passanti orizzontali fatte da un solo lato, si inverte il lato di lavoro in base all'utensile scelto
|
||||||
|
- Modif : in LapJoint in lavorazione tipo BH permessa U passante non parallela agli assi principali; attacchi migliorati
|
||||||
|
- Modif : in LapJoint le feature di coda con pezzo lungo vengono spostate sempre dopo separazione
|
||||||
|
- Fixed : in macchine tipo Turn piccoli miglioramenti ai tagli di lama
|
||||||
|
|
||||||
|
Versione 2.7b2 (05/02/2025)
|
||||||
|
- Modif : si consentono DrillPocket in doppio solo se foro non passante
|
||||||
|
|
||||||
|
Versione 2.7b1 (04/02/2025)
|
||||||
|
- Modif : in tagli di testa e coda l'utilizzo delle lame grandi (es: 1000 su 15003TMAX) è limitato ai pezzi più bassi di 300 mm e più larghi di 300 mm
|
||||||
|
|
||||||
|
Versione 2.7a2 (23/01/2025)
|
||||||
|
- Added : in RidgeLap aggiunta Q05 per usare la fresa tipo LapJoint
|
||||||
|
- Fixed : in BatchProcess (Ts7) piccola correzione
|
||||||
|
- Fixed : in ScarfJoint, in caso di taglio dal lato, aggiunta estensione oltre il bordo
|
||||||
|
|
||||||
|
Versione 2.7a1 (21/01/2025)
|
||||||
|
- Added : in FreeContour aggiunta Q09 per inversione ultima lavorazione
|
||||||
|
- Modif : in Cut, si taglia dal basso solo se il pezzo piccolo è già staccato dalla barra
|
||||||
|
- Modif : in BatchProcess (Ts7) aggiunta scrittura id progetto e produzione in Btm
|
||||||
|
|
||||||
|
Versione 2.6l2 (07/01/2025)
|
||||||
|
- Added : in LapJoint abiitata SideMillAsBlade anche da sotto e varie migliorie
|
||||||
|
- Modif : in LapJoint L030 aggiunto Q03=4 per lavorare con fresa evitando tasche aperte testa/coda
|
||||||
|
- Modif : in LapJoint modifiche per gestione fresa a disco su aggregato
|
||||||
|
- Modif : in fresature con lama o simili aggiunta la possibilità di invertire il senso di percorrenza calcolato in automatico
|
||||||
|
- Modif : migliorie all'ordinamento
|
||||||
|
- Fixed : in LapJoint la Q per forzare lavorazione di lato funziona solo se la feature è aperta davnti o dietro
|
||||||
|
|
||||||
|
Versione 2.6l1 (11/12/2024)
|
||||||
|
- Added : aggiunta gestione slot e tagli di lama con lame molto grandi
|
||||||
|
- Modif : in lama + motosega aggiunta gestione slot aperte con lato obliquo
|
||||||
|
- Modif : modificata retrazione per tenoni aperti
|
||||||
|
|
||||||
|
Versione 2.6k2 (28/11/2024)
|
||||||
|
- Modif : nei tagli migliorati i casi in cui si inverte l'SCC per facilitare la caduta del legno
|
||||||
|
- Modif : nei tagli migliorato controllo rimozione del primo cubetto molto piccolo
|
||||||
|
- Modif : nei tagli migliorati i casi con bilinea
|
||||||
|
- Fixed : in lapjoint corretto un caso in cui si sbagliava a calcolare la dimensione della tasca
|
||||||
|
|
||||||
|
Versione 2.6k1 (15/11/2024)
|
||||||
|
- Modif : in macchine tipo Fast lunghezza minima feature per considerare taglio lungo portata a 400 mm
|
||||||
|
- Modif : in tacche si applica svuotatura anche nel caso di elevazione non raggiunta
|
||||||
|
- Modif : in forature in doppio, se necessario, si aumenta lo step per evitare collisione tra le punte durante lavorazione
|
||||||
|
- Fixed : in L010 correzione in utilizzo Q07 (forzatura frese)
|
||||||
|
- Fixed : in coda di rondine corretto bug che causava un blocco anomalo del programma
|
||||||
|
|
||||||
|
Versione 2.6j4 (06/11/2024)
|
||||||
|
- Fixed : corretto caso in cui i fori passanti fatti con due teste finiviano nella rotazione sbagliata, provocando un errore di chariot collision
|
||||||
|
|
||||||
|
Versione 2.6j3 (18/10/2024)
|
||||||
|
- Modif : nei tagli orizzontali si inverte SCC per evitare problemi di cubetti incastrati
|
||||||
|
- Modif : modifiche in ordinamento fori che intersecano tenoni
|
||||||
|
- Fixed : corretto caso con fori sul tenone spostati in coda nella fase errata
|
||||||
|
|
||||||
|
Versione 2.6j2 (17/10/2024)
|
||||||
|
- Fixed : in forature con precedenza corretto caso in cui il foro veniva ripetuto in rotazioni diverse
|
||||||
|
|
||||||
|
Versione 2.6j1 (10/10/2024)
|
||||||
|
- Modif : se la macchina è tipo BlockHaus, i LapJoint vengono fatti prima del taglio di separazione
|
||||||
|
- Modif : se tenone di coda è attraversato da foro allora anche il foro sarà di coda
|
||||||
|
- Modif : migliorato ordinamento per tenoni con foro secante
|
||||||
|
- Modif : in FreeContour migliorato pinzaggio
|
||||||
|
- Modif : in LapJoint miglioramenti vari alla lavorazione delle facce oblique
|
||||||
|
- Modif : In RidgeLap l'ingombro testa coda considera inclinazione feature per pinzaggio
|
||||||
|
- Added : in FreeContour aggiunta Q08 per forzare come pinzabile l'area della feature e Q07 per ignorare possibili problemi di lettura laser
|
||||||
|
- Added : in tagli aggiunta Q07 per forzare uso fresa
|
||||||
|
|
||||||
|
Versione 2.6i3 (08/10/2024)
|
||||||
|
- Modif : In RidgeLap, ingombro testa coda considera inclinazione feature per pinzaggio.
|
||||||
|
|
||||||
|
Versione 2.6i2 (13/09/2024)
|
||||||
|
- Modif : in FacesBySaw si invertono gli accorciamenti solo se l'inversione del percorso non è forzata dall'esterno; adeguati HeadCut e Split
|
||||||
|
- Modif : in nesting correzione in lettura array per cambio dll di lettura
|
||||||
|
- Modif : in BatchProcess e New, in caso sia richiesta generazione senza check, verifico prima che il file log specifico non contenga errori: se sì, forzo il check
|
||||||
|
- Modif : in FacesBySaw per settare il FaceUse si usa il versore nelle UserNotes
|
||||||
|
- Modif : in HeadCut, Split modifiche ai tagli aggiuntivi orizzontali e verticali; disattivati attacchi tangenziali per tagli aggiuntivi verticali in PF1250
|
||||||
|
- Fixed : in ProcessDrill In GetData corretta gestione modifica diametro foro
|
||||||
|
|
||||||
Versione 2.6i1 (09/09/2024)
|
Versione 2.6i1 (09/09/2024)
|
||||||
- Added : refactoring e modifiche a HeadCut e Split per introduzione pretagli a zero sul grezzo, per evitare problemi con pezzi non lunghi quanto ci si aspetta
|
- Added : refactoring e modifiche a HeadCut e Split per introduzione pretagli a zero sul grezzo, per evitare problemi con pezzi non lunghi quanto ci si aspetta
|
||||||
- Added : in Mark, gestita la lavorazione del testo
|
- Added : in Mark, gestita la lavorazione del testo
|
||||||
|
|||||||
+2
-2
@@ -2,5 +2,5 @@
|
|||||||
-- Gestione della versione di Beam
|
-- Gestione della versione di Beam
|
||||||
|
|
||||||
NAME = 'Beam'
|
NAME = 'Beam'
|
||||||
VERSION = '2.6i1'
|
VERSION = '2.7j2'
|
||||||
MIN_EXE = '2.6e5'
|
MIN_EXE = '2.7f2'
|
||||||
|
|||||||
Reference in New Issue
Block a user