if (keyWord != null) { BaiduNaviInitHelper.setCanSpeak(false); BaiduNaviManagerFactory.getRouteGuideManager().deleteViaNodes(); // 过滤并删除包含关键字的数据 boolean removed = routeList.removeIf(node -> node.get(0).getName().contains(keyWord)); if (removed) { List<BNRoutePlanNode> list = new ArrayList<>(); for (List<BNRoutePlanNode> planNodeList : routeList) { //planNodeList获取0是因为list中只有一条数据 list.add(planNodeList.get(0)); } BaiduNaviManagerFactory.getRouteGuideManager().addViaNodes(list); BaiduNaviManagerFactory.getCommonSettingManager().setViaPointCount(4); showFullView(); isWayPoint = true; } else { speakWithoutFollowStep("抱歉,当前没有" + keyWord + "途经点"); } } 以上代码,有两个途经点,删除其中某个途经点,地图上还是显示的两个,代码逻辑帮我看看改一下
时间: 2024-02-14 15:07:45 浏览: 55
vue.js中过滤器的使用教程
根据您提供的代码逻辑,删除途经点后需要重新设置途经点并显示全览模式。可以尝试修改以下代码:
```
if (keyWord != null) {
BaiduNaviInitHelper.setCanSpeak(false);
BaiduNaviManagerFactory.getRouteGuideManager().deleteViaNodes();
// 过滤并删除包含关键字的数据
boolean removed = routeList.removeIf(node -> node.get(0).getName().contains(keyWord));
if (removed) {
List<BNRoutePlanNode> list = new ArrayList<>();
for (List<BNRoutePlanNode> planNodeList : routeList) {
list.add(planNodeList.get(0));
}
// 新增:重新设置途经点并显示全览模式
BaiduNaviManagerFactory.getRouteGuideManager().addViaNodes(list);
BaiduNaviManagerFactory.getCommonSettingManager().setViaPointCount(list.size());
showFullView();
isWayPoint = true;
} else {
speakWithoutFollowStep("抱歉,当前没有" + keyWord + "途经点");
}
}
```
修改后的代码中,新增了设置途经点并显示全览模式的代码。具体来说,我们在重新设置途经点时,使用`list`列表中的元素数量来设置途经点数量,然后调用`showFullView()`方法显示全览模式。同时,我们也将`isWayPoint`变量设置为`true`,表示当前已经设置了途经点。
阅读全文