// // AMapNaviBaseManager.h // AMapNaviKit // // Created by 刘博 on 16/1/12. // Copyright © 2016年 Amap. All rights reserved. // #import "AMapNaviCommonObj.h" NS_ASSUME_NONNULL_BEGIN @class CLLocation; @class AMapNaviInfo; @class AMapNaviRoute; @class AMapNaviLocation; @class AMapNaviStatisticsInfo; @class AMapNaviRouteGroup; ///注意:该类为导航控制器基类,请不要直接使用 @interface AMapNaviBaseManager : NSObject #pragma mark - Navi Mode ///当前导航模式,参考 AMapNaviMode . @property (nonatomic, readonly) AMapNaviMode naviMode; #pragma mark - Options ///是否在导航过程中让屏幕常亮,默认YES. @property (nonatomic, assign) BOOL screenAlwaysBright; ///指定定位是否会被系统自动暂停。默认为YES。 @property(nonatomic, assign) BOOL pausesLocationUpdatesAutomatically; ///是否允许后台定位.默认为NO(只在iOS 9.0及以后版本起作用).注意:设置为YES的时候必须保证 Background Modes 中的 Location updates 处于选中状态,否则会抛出异常. @property (nonatomic, assign) BOOL allowsBackgroundLocationUpdates; #pragma mark - External Location ///是否采用外部传入定位信息.注意:默认NO. @property (nonatomic, assign) BOOL enableExternalLocation; ///外部传入定位信息(enableExternalLocation为YES时有效).该方法坐标需使用WGS84坐标系. @property (nonatomic, copy) CLLocation *externalLocation; ///是否使用内置播放器进行导航播报, 如果为YES,就是由导航SDK来播报导航信息. 默认为NO. since 5.5.0 @property (nonatomic, assign) BOOL isUseInternalTTS; /** * @brief 设置外部传入定位的信息 * @param externalLocation 外部传入的定位信息 * @param isAMapCoordinate 外部传入的坐标是否采用高德坐标,YES表示采用高德坐标(GCJ02),NO表示使用WGS84坐标. */ - (void)setExternalLocation:(CLLocation *)externalLocation isAMapCoordinate:(BOOL)isAMapCoordinate; #pragma mark - 实时导航 & 模拟导航 /** * @brief 设置模拟导航的速度,默认60 * @param speed 模拟导航的速度(范围:[10,120]; 单位:km/h) */ - (void)setEmulatorNaviSpeed:(int)speed; /** * @brief 开始模拟导航. 注意:必须在路径规划成功的情况下,才能够开始模拟导航 * @return 是否成功 */ - (BOOL)startEmulatorNavi; /** * @brief 开始实时导航. 注意:必须在路径规划成功的情况下,才能够开始实时导航 * @return 是否成功 */ - (BOOL)startGPSNavi; /** * @brief 开始模拟导航. 注意:必须传入导航的路线组合routeGroup,才能够开始模拟导航. since 7.7.0 * @param routeGroup 本次导航需要传入的路线组合 * @return 是否成功 */ - (BOOL)startEmulatorNavi:(AMapNaviRouteGroup *)routeGroup; /** * @brief 开始实时导航. 注意:必须传入导航的路线组合routeGroup,才能够开始实时导航. since 7.7.0 * @param routeGroup 本次导航需要传入的路线组合 * @return 是否成功 */ - (BOOL)startGPSNavi:(AMapNaviRouteGroup *)routeGroup; /** * @brief 停止导航,包含实时导航和模拟导航 */ - (void)stopNavi; /** * @brief 暂停导航,包含实时导航和模拟导航 */ - (void)pauseNavi; /** * @brief 继续导航,包含实时导航和模拟导航 */ - (void)resumeNavi; #pragma mark - Manual /** * @brief 实时导航中手动触发一次信息播报. 注意:该接口仅支持驾车和步行,骑行不支持此功能. * @return 是否成功 */ - (BOOL)readNaviInfoManual; #pragma mark - Navi Guide /** * @brief 获取导航路线的路线详情列表 * @return 导航路线的路线详情列表,参考 AMapNaviGuide 类. */ - (nullable NSArray *)getNaviGuideList __attribute__((deprecated("已废弃,请使用 AMapNaviRoute 中的 guideGroups 替代 since 7.5.0"))); @end NS_ASSUME_NONNULL_END