Android 谷歌地图 addMarker() 添加 400 个标记时非常慢
感谢您抽出宝贵时间阅读本文。
大约一个月前(08/29/14),我在Google Play商店发布了一个应用程序,对于相同数量的标记,这不是问题。本周,当我进入我的应用程序时,我注意到在我的Galaxy S5上将400个标记加载到地图大约需要10-20秒,并且在默认地图标记图标的中间有一个小圆圈。在此之前,地图在不到一秒钟的时间内加载。我没有更新或更改我的应用。我猜谷歌更新了谷歌地图API,而这一变化使得加载标记的速度要慢得多?这种情况发生在其他人身上吗?还有其他人有这方面的信息吗?
我的应用在 Play 商店中免费提供。您可以搜索NYS运河指南来找到它,如果你想看看它的加载速度有多慢。
初始化映射后,在映射片段的 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 继续递增 1,在加载标记时,它会生成大约 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:
我刚刚检查了某些代码行需要多长时间。我用是为了得到时间。在方法中,这是需要很长时间的一行:当添加所有400个标记时,每个标记平均需要54毫秒。最小时间为34毫秒,最大时间为114毫秒。System.currentTimeMillis();
addExistingMarkersToMap()
marker = mMap.addMarker(markerOptions);
如果您认为我应该提供更多信息,请在评论中告诉我。谢谢!