感谢您抽出时间阅读此内容。
大约一个月前(08/29/14),我在 Google Play 商店发布了一个应用程序,使用相同数量的标记,这并不是问题。然而,本周我注意到,当我打开我的应用程序时,在我的 Galaxy S5 上加载 400 个标记到地图上需要大约 10-20 秒钟,并且在默认地图标记图标的中心有一个小圆圈。在此之前,地图加载少于一秒钟。我没有更新或更改我的应用程序。我猜测 Google 更新了 Google 地图 API,而这种变化使得加载标记变得更慢了?有其他人遇到过类似情况吗?有其他人对此有信息吗?
我的应用程序可以免费在 Play 商店上下载。如果您想查看它加载缓慢的情况,可以搜索“NYS Canal Guide”。
这种方法在地图片段的 onCreateView() 中调用,此时地图已经初始化:
private void addExistingMarkersToMap(){
log("Adding existing markers to the map. poiAdapter size = " + poiAdapter.getCount());
Marker marker;
MarkerOptions markerOptions;
for(MapMarker mapMarker : poiAdapter){
if(markersNotFilteredOut(mapMarker)){
markerOptions = mapMarker.getMarkerOptions();
if(markerOptions != null && mapMarker != null){
marker = mMap.addMarker(markerOptions);
mapMarker.setMarker(marker);
}
}
}
}
这是MapMarker类上的getMarkerOptions()方法:
public MarkerOptions getMarkerOptions() {
return new MarkerOptions()
.title(name)
.position(new LatLng(lat, lng))
.snippet(bodyOfWater + ", mile " + mile)
.icon(BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_BLUE));
}
完整的源代码在这里:github.com/olearyj234/NYS-Canal-Guide
编辑:
** 具体而言,唯一缓慢的部分是在初始化地图时加载标记(因此也是从一个导航选项卡切换回地图选项卡时)。当移动地图或执行其他操作时,它不会缓慢。
这里有一些日志:
当屏幕冻结几秒钟(5-15)因为正在加载标记时,这个日志会非常快速地产生。位图ID将继续递增一,当标记正在加载时,它会产生大约400个这样的日志。这表明它必须是与在屏幕上加载标记位图相关的问题。我正在使用默认的标记位图。
10-01 15:45:07.222: D/skia(32108): GFXPNG PNG bitmap created width:16 height:32 bitmap id is 414
当应用程序完成将所有标记加载到地图上时,将生成此日志。
10-01 15:51:09.402: I/Choreographer(8353): Skipped 1130 frames! The application may be doing too much work on its main thread.
当应用程序完成将所有标记加载到地图上时,此日志将出现14次。
10-01 15:59:13.882: I/dalvikvm-heap(8353): Grow heap (frag case) to 40.668MB for 4194320-byte allocation
编辑2:
我刚刚检查了一下某些代码行所需的时间。我使用了System.currentTimeMillis();
以获取时间。在方法addExistingMarkersToMap()
中,这是需要长时间运行的行:marker = mMap.addMarker(markerOptions);
当添加所有400个标记时,每个标记平均需要54毫秒。最短时间为34毫秒,最长时间为114毫秒。
如果您认为还有其他信息需要提供,请在评论中告诉我。 谢谢!
BitmapDescriptor
,添加标记的速度仍然很慢。 - eliocs