//---------------------------------------------------------------------------- // EgalTech 2015-2015 //---------------------------------------------------------------------------- // File : DrillingData.h Data : 04.06.15 Versione : 1.6f1 // Contenuto : Dichiarazione della struct DrillingData e costanti associate. // // // // Modifiche : 04.06.15 DS Creazione modulo. // // //---------------------------------------------------------------------------- #pragma once #include "MachiningData.h" //---------------------------------------------------------------------------- struct DrillingData : public MachiningData { EgtUUID m_ToolUuid ; // identificativo universale dell'utensile std::string m_sToolName ; // nome dell'utensile std::string m_sInitAngs ; // angoli iniziali suggeriti (Nome1=val1,Nome2=val2) std::string m_sBlockedAxis ; // eventuale asse rotante bloccato (Nome=val) int m_nSolCh ; // criterio scelta soluzione (quando possibili molteplici) double m_dSpeed ; // velocità di rotazione (+ se CCW, - se CW) ( se 0 da utensile) double m_dFeed ; // velocità di lavorazione normale ( se 0 da utensile) double m_dStartFeed ; // velocità di lavorazione iniziale ( se 0 da utensile) double m_dEndFeed ; // velocità di lavorazione finale ( se 0 da utensile) double m_dTipFeed ; // velocità di lavorazione di sfondamento ( se 0 da utensile) bool m_bInvert ; // flag di inversione direzione lavorazione per fori aperti std::string m_sDepth ; // affondamento (espressione numerica) double m_dStartPos ; // quota di inizio lavorazione (sempre >= 0) double m_dStartSlowLen ; // lunghezza rallentamento iniziale double m_dEndSlowLen ; // lunghezza rallentamento finale double m_dThroughAddLen ; // lunghezza aggiuntiva di foratura se passante double m_dStep ; // passo di affondamento (0=nessun passo) double m_dReturnPos ; // quota di ritorno (+=fuori, -=dentro) int m_nSubType ; // 0=standard, 1=forature lungo curve std::string m_sOffset ; // offset (espressione numerica) (solo per tipo 1) std::string m_sOverlap ; // sovrapposizione (espressione numerica) (solo per tipo 1) double m_dStartAddLen ; // lunghezza addizionale da aggiungere all'inizio (solo per tipo 1) double m_dEndAddLen ; // lunghezza addizionale da aggiungere alla fine (solo per tipo 1) std::string m_sSysNotes ; // note interne std::string m_sUserNotes ; // note dell'utente DrillingData( void) : m_ToolUuid(), m_nSolCh( 0), m_dSpeed( 0), m_dFeed( 0), m_dStartFeed( 0), m_dEndFeed( 0), m_dTipFeed( 0), m_bInvert( false), m_dStartPos( 0), m_dStartSlowLen( 0), m_dEndSlowLen( 0), m_dThroughAddLen( 0), m_dStep( 0), m_dReturnPos( 0), m_nSubType(0), m_dStartAddLen(0), m_dEndAddLen( 0) {} DrillingData* Clone( void) const override ; bool CopyFrom( const MachiningData* pMdata) override ; bool SameAs(const MachiningData* pMdata) const override ; int GetType( void) const override { return MT_DRILLING ; } int GetSize( void) const override ; std::string GetTitle( void) const override ; bool FromString( const std::string& sString, int& nKey) override ; std::string ToString( int nKey) const override ; bool IsOptional( int nKey) const override ; bool SetParam( int nType, bool bVal) override ; bool SetParam( int nType, int nVal) override ; bool SetParam( int nType, double dVal) override ; bool SetParam( int nType, const std::string& sVal) override ; bool ResetTool( void) override ; bool GetParam( int nType, bool& bVal) const override ; bool GetParam( int nType, int& nVal) const override ; bool GetParam( int nType, double& dVal) const override ; bool GetParam( int nType, std::string& sVal) const override ; bool GetTool( const ToolsMgr* pToolsMgr, const ToolData*& pTdata) const override ; bool VerifyTool( const ToolsMgr* pToolsMgr, const std::string& sVal, const ToolData*& pTdata) const override ; bool VerifySolCh( int nVal) const ; } ; //---------------------------------------------------------------------------- inline const DrillingData* GetDrillingData( const MachiningData* pMdata) { return (dynamic_cast( pMdata)) ; } inline DrillingData* GetDrillingData( MachiningData* pMdata) { return (dynamic_cast( pMdata)) ; }