//---------------------------------------------------------------------------- // EgalTech 2014-2014 //---------------------------------------------------------------------------- // File : API_Exchange.cpp Data : 20.09.14 Versione : 1.5i4 // Contenuto : Funzioni import/export per API. // // // // Modifiche : 20.09.14 DS Creazione modulo. // // //---------------------------------------------------------------------------- //--------------------------- Include ---------------------------------------- #include "stdafx.h" #include "API.h" #include "API_Macro.h" #include "DllExchange.h" #include "/EgtDev/Include/EInAPI.h" #include "/EgtDev/Include/EExImportStl.h" #include "/EgtDev/Include/EExImportDxf.h" #include "/EgtDev/Include/EExImportCnc.h" #include "/EgtDev/Include/EExExportStl.h" #include "/EgtDev/Include/EExExportDxf.h" #include "/EgtDev/Include/EGnStringUtils.h" #include "/EgtDev/Include/EGnStringConverter.h" #include "/EgtDev/Include/EgtPointerOwner.h" using namespace std ; //----------------------------------------------------------------------------- int __stdcall EgtGetFileType( const wchar_t* wsFilePath) { return EgtGetFileType( wstrztoA( wsFilePath)) ; } //----------------------------------------------------------------------------- int EgtGetFileType( const string& sFilePath) { // divido in nome e direttorio string sFileDir, sFileName ; SplitLast( sFilePath, "\\", sFileDir, sFileName) ; // recupero l'estensione string sFileTitle, sFileExt ; SplitLast( sFileName, ".", sFileTitle, sFileExt) ; ToUpper( sFileExt) ; if ( sFileExt == "NGE") return 1 ; else if ( sFileExt == "NFE") return 2 ; else if ( sFileExt == "DXF") return 11 ; else if ( sFileExt == "STL") return 12 ; else if ( sFileExt == "CNC") return 13 ; else if ( sFileExt == "TSC") return 101 ; else if ( sFileExt == "LUA") return 102 ; else { // emetto info string sInfo = "File type (" + sFileExt + ") not recognized" ; LOG_INFO( GetLogger(), sInfo.c_str()) return 0 ; } } //----------------------------------------------------------------------------- BOOL __stdcall EgtImportDxf( const wchar_t* wsFilePath, double dScaleFactor) { return ( EgtImportDxf( wstrztoA( wsFilePath), dScaleFactor) ? TRUE : FALSE) ; } //----------------------------------------------------------------------------- bool EgtImportDxf( const string& sFilePath, double dScaleFactor) { GseContext* pGseCtx = GetCurrGseContext() ; VERIFY_CTX_GEOMDB( pGseCtx, false) bool bOk = true ; // importo il file DXF // aggiungo un gruppo pezzo int nPartId = pGseCtx->m_pGeomDB->AddGroup( GDB_ID_NULL, GDB_ID_ROOT, Frame3d()) ; // preparo l'importatore PtrOwner pImpDxf( MyCreateImportDxf()) ; bOk = bOk && ! IsNull( pImpDxf) ; // eseguo l'importazione bOk = bOk && pImpDxf->Import( sFilePath, pGseCtx->m_pGeomDB, nPartId, dScaleFactor) ; // aggiorno stato file corrente pGseCtx->m_sFilePath = sFilePath ; pGseCtx->m_bModified = true ; // se richiesto, salvo il comando Lua equivalente if ( IsCmdLog()) { string sLuaPath = sFilePath ; ReplaceString( sLuaPath, "\\", "\\\\") ; string sLua = "EgtImportDxf('" + sLuaPath + "'," + ToString( dScaleFactor) + ")" + " -- Ok=" + ToString( bOk) ; LOG_INFO( GetCmdLogger(), sLua.c_str()) ; } // restituisco il risultato return bOk ; } //----------------------------------------------------------------------------- BOOL __stdcall EgtImportStl( const wchar_t* wsFilePath, double dScaleFactor) { return ( EgtImportStl( wstrztoA( wsFilePath), dScaleFactor) ? TRUE : FALSE) ; } //----------------------------------------------------------------------------- bool EgtImportStl( const string& sFilePath, double dScaleFactor) { GseContext* pGseCtx = GetCurrGseContext() ; VERIFY_CTX_GEOMDB( pGseCtx, false) bool bOk = true ; // importo il file STL // aggiungo un gruppo pezzo e un gruppo layer int nPartId = pGseCtx->m_pGeomDB->AddGroup( GDB_ID_NULL, GDB_ID_ROOT, Frame3d()) ; int nLayerId = pGseCtx->m_pGeomDB->AddGroup( GDB_ID_NULL, nPartId, Frame3d()) ; // preparo l'importatore PtrOwner pImpStl( MyCreateImportStl()) ; bOk = bOk && ! IsNull( pImpStl) ; // eseguo l'importazione bOk = bOk && pImpStl->Import( sFilePath, pGseCtx->m_pGeomDB, nLayerId, dScaleFactor) ; // aggiorno stato file corrente pGseCtx->m_sFilePath = sFilePath ; pGseCtx->m_bModified = true ; // se richiesto, salvo il comando Lua equivalente if ( IsCmdLog()) { string sLuaPath = sFilePath ; ReplaceString( sLuaPath, "\\", "\\\\") ; string sLua = "EgtImportStl('" + sLuaPath + "'," + ToString( dScaleFactor) + ")" + " -- Ok=" + ToString( bOk) ; LOG_INFO( GetCmdLogger(), sLua.c_str()) ; } // restituisco il risultato return bOk ; } //----------------------------------------------------------------------------- BOOL __stdcall EgtImportCnc( const wchar_t* wsFilePath) { return ( EgtImportCnc( wstrztoA( wsFilePath)) ? TRUE : FALSE) ; } //----------------------------------------------------------------------------- bool EgtImportCnc( const string& sFilePath) { GseContext* pGseCtx = GetCurrGseContext() ; VERIFY_CTX_GEOMDB( pGseCtx, false) bool bOk = true ; // importo il file CNC // aggiungo un gruppo pezzo int nPartId = pGseCtx->m_pGeomDB->AddGroup( GDB_ID_NULL, GDB_ID_ROOT, Frame3d()) ; // preparo l'importatore PtrOwner pImpCnc( MyCreateImportCnc()) ; bOk = bOk && ! IsNull( pImpCnc) ; // eseguo l'importazione bOk = bOk && pImpCnc->Import( sFilePath, pGseCtx->m_pGeomDB, nPartId) ; // aggiorno stato file corrente pGseCtx->m_sFilePath = sFilePath ; pGseCtx->m_bModified = true ; // se richiesto, salvo il comando Lua equivalente if ( IsCmdLog()) { string sLuaPath = sFilePath ; ReplaceString( sLuaPath, "\\", "\\\\") ; string sLua = "EgtImportCnc('" + sLuaPath + "')" + " -- Ok=" + ToString( bOk) ; LOG_INFO( GetCmdLogger(), sLua.c_str()) ; } // restituisco il risultato return bOk ; } //----------------------------------------------------------------------------- BOOL __stdcall EgtExportDxf( int nId, const wchar_t* wsFilePath) { return ( EgtExportDxf( nId, wstrztoA( wsFilePath)) ? TRUE : FALSE) ; } //----------------------------------------------------------------------------- bool EgtExportDxf( int nId, const string& sFilePath) { IGeomDB* pGeomDB = GetCurrGeomDB() ; VERIFY_GEOMDB( pGeomDB, false) bool bOk = true ; // esporto il file DXF // preparo l'esportatore PtrOwner pExpDxf( MyCreateExportDxf()) ; bOk = bOk && ! IsNull( pExpDxf) ; // eseguo l'esportazione bOk = bOk && pExpDxf->Export( pGeomDB, nId, sFilePath) ; // se richiesto, salvo il comando Lua equivalente if ( IsCmdLog()) { string sLuaPath = sFilePath ; ReplaceString( sLuaPath, "\\", "\\\\") ; string sLua = "EgtExportDxf(" + ToString( nId) + ",'" + sLuaPath + "')" + " -- Ok=" + ToString( bOk) ; LOG_INFO( GetCmdLogger(), sLua.c_str()) ; } // restituisco il risultato return bOk ; } //----------------------------------------------------------------------------- BOOL __stdcall EgtExportStl( int nId, const wchar_t* wsFilePath) { return ( EgtExportStl( nId, wstrztoA( wsFilePath)) ? TRUE : FALSE) ; } //----------------------------------------------------------------------------- bool EgtExportStl( int nId, const string& sFilePath) { IGeomDB* pGeomDB = GetCurrGeomDB() ; VERIFY_GEOMDB( pGeomDB, false) bool bOk = true ; // esporto il file STL // preparo l'esportatore PtrOwner pExpStl( MyCreateExportStl()) ; bOk = bOk && ! IsNull( pExpStl) ; // eseguo l'esportazione bOk = bOk && pExpStl->Export( pGeomDB, nId, sFilePath) ; // se richiesto, salvo il comando Lua equivalente if ( IsCmdLog()) { string sLuaPath = sFilePath ; ReplaceString( sLuaPath, "\\", "\\\\") ; string sLua = "EgtExportStl(" + ToString( nId) + ",'" + sLuaPath + "')" + " -- Ok=" + ToString( bOk) ; LOG_INFO( GetCmdLogger(), sLua.c_str()) ; } // restituisco il risultato return bOk ; }