/////////////////////////////////////////////////////////////////////////////// // Copyright (C) 2002-2025, Open Design Alliance (the "Alliance"). // All rights reserved. // // This software and its documentation and related materials are owned by // the Alliance. The software may only be incorporated into application // programs owned by members of the Alliance, subject to a signed // Membership Agreement and Supplemental Software License Agreement with the // Alliance. The structure and organization of this software are the valuable // trade secrets of the Alliance and its suppliers. The software is also // protected by copyright law and international treaty provisions. Application // programs incorporating this software must include the following statement // with their copyright notices: // // This application incorporates Open Design Alliance software pursuant to a license // agreement with Open Design Alliance. // Open Design Alliance Copyright (C) 2002-2025 by Open Design Alliance. // All rights reserved. // // By use of this software, its documentation or related materials, you // acknowledge and accept the above terms. /////////////////////////////////////////////////////////////////////////////// #include "OdGeoMapPEModule.h" #include "RxDynamicModule.h" #include "DbGeoMap.h" #include "OdGeoMapTilesCache.h" #include "DbUserIO.h" #include "DbCommandContext.h" #define CMD_DEF_CLASS(CmdName, GroupName) \ extern void _##CmdName##_func(OdEdCommandContext* pCmdCtx);\ const OdString _##CmdName##_cmd::globalName() const { return OD_T(#CmdName); }\ const OdString _##CmdName##_cmd::groupName() const { return GroupName; } #define CMD_DEF(CmdName, GroupName) \ extern void _##CmdName##_func(OdEdCommandContext* pCmdCtx);\ const OdString _##CmdName##_cmd::globalName() const { return OD_T(#CmdName); }\ const OdString _##CmdName##_cmd::groupName() const { return GroupName; }\ void _##CmdName##_cmd::execute(OdEdCommandContext* pCmdCtx) { _##CmdName##_func(pCmdCtx); } #include "OdDbGeoMapPECmdDef.h" #undef CMD_DEF_CLASS #undef CMD_DEF void _GeoMapProviderSwitch_func(OdEdCommandContext* pCmdCtx) { OdSmartPtr pIO = pCmdCtx->userIO(); OdUInt32 nKeyword = pIO->getKeyword( L"Select Bing Maps or Azure Maps images provider for kAerial, kRoad, kHybrid OdDbGeoMap types [Bing/Azure] ", L"Bing Azure", 1 ); g_OdGeoMapTilesCache->UseBingOrAzureMaps(nKeyword == 0 ? true : false); } ODRX_DEFINE_DYNAMIC_MODULE(OdDbGeoMapPEModule); OdDbGeoMapPEModule::OdDbGeoMapPEModule() { } OdDbGeoMapPEModule::~OdDbGeoMapPEModule() { } void OdDbGeoMapPEModule::initApp() { m_pRxRasterServices = odrxDynamicLinker()->loadModule(RX_RASTER_SERVICES_APPNAME, false); m_pOdGeolocationObjModule = odrxDynamicLinker()->loadModule(OdGeolocationObjModuleName, false); m_pOdGeoDataModule = odrxDynamicLinker()->loadModule(OdGeoDataModuleName, false); OdDbGeoMapPEImpl::rxInit(); OdDbGeoMap::desc()->addX(OdDbGeoMapPE::desc(), &m_pGeoMapPE); OdDbGeoDataChunksPEImpl::rxInit(); OdDbGeoData::desc()->addX(OdDbGeoDataChunksPE::desc(), &m_pGeoDataChunksPE); g_OdGeoMapTilesCache = new OdGeoMapTilesCache; OdEdCommandStackPtr pCommands = odedRegCmds(); #define CMD_DEF(CmdName, GroupName) \ pCommands->addCommand(&m_##CmdName##_cmd); #include "OdDbGeoMapPECmdDef.h" #undef CMD_DEF } void OdDbGeoMapPEModule::uninitApp() { OdEdCommandStackPtr pCommands = odedRegCmds(); #define CMD_DEF(CmdName, GroupName) \ pCommands->removeCmd(GroupName, OD_T(#CmdName)); #include "OdDbGeoMapPECmdDef.h" #undef CMD_DEF if (NULL != g_OdGeoMapTilesCache) { delete g_OdGeoMapTilesCache; } OdDbGeoData::desc()->delX(OdDbGeoDataChunksPE::desc()); OdDbGeoDataChunksPEImpl::rxUninit(); OdDbGeoMap::desc()->delX(OdDbGeoMapPE::desc()); OdDbGeoMapPEImpl::rxUninit(); }