我已经尝试在此站点和其他一些站点中找到解决我的问题的方法,但没有运气。我在我的应用程序上设置了地图(谷歌地图 V2)。这张地图充满了标记(大约 450 个),每个标记都有一个来自可绘制文件的图标集。可绘制文件总共有 6 个,因此大约有 450 个标记重复 6 个可绘制文件(每个不同的图标指的是地图上的一个位置)。当我第一次启动地图时,没有任何问题,一切正常。但是,如果我返回上一个屏幕并再次启动地图,应用程序会因内存不足错误而崩溃。我认为问题是由于系统将所有位图保存在内存中,资源浪费令人难以置信,因为可绘制对象只有六个。
我尝试按照此处的建议将位图引用到应用程序上下文,但没有好的结果。有没有简单的方法来解决这个问题?
第 324 行:
if (IDTipologia.get(i).equals("1")) {
setLoghino(R.drawable.chieseluoghidiculto);
//iconcina = BitmapDescriptorFactory.defaultMarker(BitmapDescriptorFactory.HUE_AZURE);
Bitmap icon = BitmapFactory.decodeResource(getApplicationContext().getResources(),
R.drawable.markerchiese);
iconcina = BitmapDescriptorFactory.fromBitmap(icon);
}
以此类推,直到第 6 个可绘制对象。
日志猫:
E/AndroidRuntime(10990): FATAL EXCEPTION: main
E/AndroidRuntime(10990): java.lang.OutOfMemoryError
E/AndroidRuntime(10990): at android.graphics.Bitmap.nativeCreateFromParcel(Native Method)
E/AndroidRuntime(10990): at android.graphics.Bitmap.access$000(Bitmap.java:28)
E/AndroidRuntime(10990): at android.graphics.Bitmap$1.createFromParcel(Bitmap.java:1052)
E/AndroidRuntime(10990): at android.graphics.Bitmap$1.createFromParcel(Bitmap.java:1044)
E/AndroidRuntime(10990): at com.google.android.gms.maps.model.internal.IBitmapDescriptorFactoryDelegate$Stub.onTransact(IBitmapDescriptorFactoryDelegate.java:101)
E/AndroidRuntime(10990): at android.os.Binder.transact(Binder.java:297)
E/AndroidRuntime(10990): at com.google.android.gms.internal.h$a$a.a(Unknown Source)
E/AndroidRuntime(10990): at com.google.android.gms.maps.model.BitmapDescriptorFactory.fromBitmap(Unknown Source)
E/AndroidRuntime(10990): at it.eventitrapani.appaeventitp.ElencoMappaTutteCoseDaVedere.addMarkersToMap(ElencoMappaTutteCoseDaVedere.java:324)
E/AndroidRuntime(10990): at it.eventitrapani.appaeventitp.ElencoMappaTutteCoseDaVedere.setUpMap(ElencoMappaTutteCoseDaVedere.java:269)
E/AndroidRuntime(10990): at it.eventitrapani.appaeventitp.ElencoMappaTutteCoseDaVedere.setUpMapIfNeeded(ElencoMappaTutteCoseDaVedere.java:257)
E/AndroidRuntime(10990): at it.eventitrapani.appaeventitp.ElencoMappaTutteCoseDaVedere.onCreate(ElencoMappaTutteCoseDaVedere.java:208)
E/AndroidRuntime(10990): at android.app.Activity.performCreate(Activity.java:4470)
E/AndroidRuntime(10990): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1052)
E/AndroidRuntime(10990): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1931)
E/AndroidRuntime(10990): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1992)
E/AndroidRuntime(10990): at android.app.ActivityThread.access$600(ActivityThread.java:127)
E/AndroidRuntime(10990): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1158)
E/AndroidRuntime(10990): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(10990): at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(10990): at android.app.ActivityThread.main(ActivityThread.java:4511)
E/AndroidRuntime(10990): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(10990): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(10990): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:980)
E/AndroidRuntime(10990): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:747)
E/AndroidRuntime(10990): at dalvik.system.NativeStart.main(Native Method)