使用HERE API取得我的位置时出现问题(Wifi)[更新]

时间:2019-01-16 11:27:22

标签: android here-api

我在平板电脑上安装了HERE测试产品(这是一台旧版Android 5.1平板电脑,没有GPS或蜂窝数据,只有Wifi上网),并且可以很好地(大约)使用Wifi定位我的位置。

所以我试图在我的应用程序中对其进行编程。

下载了HERE API,获得了我应用名称的免费增值许可,并在清单中输入以下行:

<meta-data
    android:name="com.here.android.maps.appid"
    android:value="itkC4uIay69MTXXXXXXX" />
<meta-data
    android:name="com.here.android.maps.apptoken"
    android:value="NdT8laoCmRysyh8XXXXXXX" />

在我的版本中包含了HERE-sdk,我的代码也可以正常编译。

我的MainActivity.onCreate()中有代码[我已添加代码以按照下面的HERE支持的建议来初始化地图引擎]:

    MapEngine.getInstance().init(this, new OnEngineInitListener() {
        @Override
        public void onEngineInitializationCompleted(Error error) {
            if (error == Error.NONE) {
                Logger.i(Tags.POSITION, "correctly started map engine");
                PositioningManager pm = PositioningManager.getInstance();
                PositioningManager.LocationStatus  ls = pm.getLocationStatus(PositioningManager.LocationMethod.GPS_NETWORK);
                if (ls ==  PositioningManager.LocationStatus.AVAILABLE) {
                    Logger.i(Tags.POSITION, "Positioning is available");
                } else {
                    Logger.w(Tags.POSITION, "Positioning not available right now " + ls.toString());
                }
                pm.start(PositioningManager.LocationMethod.GPS_NETWORK);
            } else {
                Logger.i(Tags.POSITION, "Problem setting up map engine: " + error);
            }
        }
    });

然后,我每分钟在计时器上运行一次代码以检查我的当前位置:

        GeoPosition pos = PositioningManager.getInstance().getPosition();
        if (pos == null) {
            Log.w("Positioning", "GeoPosition is Null");
        } else {
            GeoCoordinate coord = pos.getCoordinate();
            Logger.i("Positioning", "Location: Latitude = " + coord.getLatitude() + ", Longitude = " + coord.getLongitude());
            Logger.i("Positioning", "Accuracy = " + pos.getLatitudeAccuracy() + ", " + pos.getLongitudeAccuracy());
        }

当我跑步时,我会得到这样的日志:

2019-01-27 11:49:31.960 30112-30112/com.company.app I/: [main] INFO  Positioning: correctly started map engine
2019-01-27 11:49:31.961 30112-30112/com.company.app W: [main] WARN  Positioning: Positioning not available right now OUT_OF_SERVICE

然后,每分钟一次

2019-01-27 11:50:30.850 30112-30343/com.company.app W/: [Timer-2] WARN  Positioning: GeoPosition is Null

在平板电脑的“设置”中,尽管显示“最近没有应用请求位置”,但“位置”已打开“

日志中没有错误或警告,所有权限均在清单中请求

[EDIT]最糟糕的是我的简单测试应用程序(在下面的评论中提到),在我添加了MapEngine的初始化之后,现在可以使用了。要回答HERE的问题,我现在真的对使用地图不感兴趣,我只想获取当前的经度和纬度以帮助丢失平板电脑。

有人知道我在做什么错吗?

1 个答案:

答案 0 :(得分:1)

我有几个问题要问,关于这个问题的答案将帮助我们了解问题所在。

  1. 您要显示地图还是仅使用PositioningManager?
  2. 如果仅使用PositionManager,是否首先初始化MapEngine?

如果您不使用地图,则必须执行类似的操作,因为PositionManager不会初始化MapEngine本身。

ApplicationContext context = new ApplicationContext(getApplicationContext());
MapEngine.getInstance().init(context, new OnEngineInitListener() {

  @Override
  public void onEngineInitializationCompleted(OnEngineInitListener.Error error) {
    if (error == OnEngineInitListener.Error.NONE) {

    } else {

    }
  }
});

更新:github上还有另一个测试应用程序可能非常有用,没有使用地图,而是使用了位置管理器。希望这可以帮助! https://github.com/heremaps/here-android-sdk-examples/tree/master/speed-limit-watcher