Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to use multiple MapActivities/MapViews per Android application/process

I have written one MapActivity class that is able to display a set of places as well as single places. On startup, the application creates an instance of this MapActivity and displays multiple places. If the user clicks on a certain place, then a new Activity is launched that shows the details of the selected place. This activity has a menu item that allows the user to view the place on a map - this causes that a new instance of the MapActivity is created, except that now only this single place is displayed.

The problem now is that if the user navigates back to the first MapActivity (the one that shows multiple places) the tiles won't be loaded anymore + sometimes OutOfMemoryErrors are encountered.

According to the Android JavaDocs, it is only possible to have one MapActivity per process. However, I don't want to define my MapActivity as a singleInstance/singleTask, since the user should always be able to navigate back to the first MapActivity that shows multiple places.

I have seen that the Google Places app (which has come with Google Map 4.4) for Android uses multiple MapActivity instances. How is this possible? And how can I achieve it in my application?

like image 413
stacky Avatar asked Jul 31 '10 19:07

stacky


4 Answers

According to the Android JavaDocs, it is only possible to have one MapActivity per class

It's not one map view per class, it's per process.

It's known that you might experience some issues when using multiple mapviews in one process. Usually this is the case (your app running in one process) if you don't configure anything specific. You could though use the android:process attribute in your manifest to assign to your acitivites:

<activity android:name=".activity.directory.MapView1" android:process=":MapView1">

<activity android:name=".activity.directory.MapView2" android:process=":MapView2">

This way you have the activities running in separate processes, which works well if you don't use any shared static variables across activities.

Also see the discussion on the bug in the android bug tracker:

http://code.google.com/p/android/issues/detail?id=3756

like image 140
Mathias Conradt Avatar answered Nov 12 '22 03:11

Mathias Conradt


You can have more than one MapActivity per process as long as only one is running at a time. Each MapActivity can have only one MapView assigned to it. You can show different maps by reusing the same MapView in the same MapActivity. You can reuse a MapView by declaring it as a static class variable, removing it from the view that it was currently added to when you are done displaying it, giving it new GPS coordinates and adding it to the next view. When you are finished with that MapActivity finish it and then you can open a new MapActivity. This works, I do in my app.

like image 25
Danny Remington - OMS Avatar answered Nov 12 '22 01:11

Danny Remington - OMS


Another simple solution: just override onDestroy method of all of your MapActivities to prevent closing resources, e.g.:

    @Override
    protected void onDestroy() {
        super.onStop();
    }

We should invoke onStop here to prevent RuntimeException thrown. Yes, that's a hack but it works.

like image 2
Flavio Avatar answered Nov 12 '22 03:11

Flavio


Update:

The Google Maps Android API v2 has support for Fragments. This means that you can easily display multiple maps like you would any other fragment.

See the documentation and read more about the new MapFragment class.

like image 1
Chris Broadfoot Avatar answered Nov 12 '22 03:11

Chris Broadfoot