Leere GoogleMap auf einem echten Android 2.3-Gerät mit Google API (Lv. 17)

Frage Beschreibung, Bitte zuerst lesen

Ich versuche, meine einfache App zu erstellen, mit der der Standort des Benutzers auf Geräten von Android 2.3 bis Android 4.0+ angezeigt wird.Die Karte wird auf einem echten Android 2.3-Gerät nicht angezeigt.

Die App kann derzeit problemlos auf Android 4.0+-Geräten nach Belieben ausgeführt und Karten angezeigt werden.

Weil es Karten ohne Probleme auf Android 4.0 oder höher anzeigen kannIch gehe davon aus, dass das Problem nicht an den Einstellungen oder Berechtigungen von Google Maps V2 liegen sollte.

Wenn ich es jedoch auf Android 2.3-Geräten versuche, ist der Kartenbereich leer, wie im folgenden Screenshot dargestellt:

Die App verwendet ActionBarSherlock, Google Maps API v2 und SupportMapFragment. Build auf SDK 17 ausgerichtet, min. SDK 10.

Code-Auszug

Ich habe den Code eingefügt und getrimmt, um den einzigen zugehörigen Teil anzuzeigen. Bitte hinterlassen Sie einen Kommentar, wenn Sie etwas anderes benötigen.

activity_layout.xml

<fragment
    android:id="@+id/map"
    android:name="com.google.android.gms.maps.SupportMapFragment"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_margin="@dimen/incident_padding_right" />

Activity.java

import com.actionbarsherlock.app.SherlockFragmentActivity;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.GoogleMap.OnMarkerDragListener;
import com.google.android.gms.maps.SupportMapFragment;

public class Activity extends SherlockFragmentActivity{

private static GoogleMap map;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        this.setContentView(R.layout.activity_layout);

            ............

        //Set up map view
        map = ((SupportMapFragment)getSupportFragmentManager().findFragmentById(R.id.map)).getMap();

            ............

        OnMarkerDragListener markerDragListener = new OnMarkerDragListener() {

            @Override
            public void onMarkerDragStart(Marker marker) {
                // Called when the marker drag is started

            }

            @Override
            public void onMarkerDragEnd(Marker marker) {
                // Called when the marker is dropped down.
                coords[0] = marker.getPosition().latitude;
                coords[1] = marker.getPosition().longitude;
                RestoreUIwithSavedLocation(coords);
                Log.d(TAG, "Pin Dropped at: " + coords[0] + ", " + coords[1]);
            }

            @Override
            public void onMarkerDrag(Marker marker) {

            }
        };

        map.setOnMarkerDragListener(markerDragListener);
}

Der Logcat, wenn er auf einem echten Android 2.3-Gerät ausgeführt wird:

01-04 21:16:52.020: D/dalvikvm(19074): VFY: dead code 0x0014-0018 in Lcom/google/android/gms/common/GooglePlayServicesUtil;.b (Landroid/content/res/Resources;)Z
01-04 21:16:52.150: W/dalvikvm(19074): Unable to resolve superclass of Lmaps/p/s; (427)
01-04 21:16:52.150: W/dalvikvm(19074): Link of class 'Lmaps/p/s;' failed
01-04 21:16:52.150: W/dalvikvm(19074): Unable to resolve superclass of Lmaps/y/bo; (3820)
01-04 21:16:52.150: W/dalvikvm(19074): Link of class 'Lmaps/y/bo;' failed
01-04 21:16:52.150: W/dalvikvm(19074): Unable to resolve superclass of Lmaps/i/k; (4208)
01-04 21:16:52.150: W/dalvikvm(19074): Link of class 'Lmaps/i/k;' failed
01-04 21:16:52.150: E/dalvikvm(19074): Could not find class 'maps.i.k', referenced from method maps.z.ag.a
01-04 21:16:52.150: W/dalvikvm(19074): VFY: unable to resolve new-instance 3540 (Lmaps/i/k;) in Lmaps/z/ag;
01-04 21:16:52.150: D/dalvikvm(19074): VFY: replacing opcode 0x22 at 0x006d
01-04 21:16:52.160: D/dalvikvm(19074): VFY: dead code 0x006f-007f in Lmaps/z/ag;.a (Landroid/view/LayoutInflater;Lcom/google/android/gms/maps/GoogleMapOptions;ZLjava/lang/String;)Lmaps/z/ag;

Der Logcat, wenn er auf einem Emulator mit Google API Lv.10 ausgeführt wird

03-25 13:00:47.974: W/GooglePlayServicesUtil(751): Google Play services is missing.
03-25 13:00:47.992: W/GooglePlayServicesUtil(751): Google Play services is missing.
03-25 13:00:47.992: W/GooglePlayServicesUtil(751): Google Play services is missing.
03-25 13:00:48.002: W/GooglePlayServicesUtil(751): Google Play services is missing.
03-25 13:00:48.002: W/GooglePlayServicesUtil(751): Google Play services is missing.
03-25 13:00:48.022: W/GooglePlayServicesUtil(751): Google Play services is missing.
03-25 13:00:48.072: D/AndroidRuntime(751): Shutting down VM
03-25 13:00:48.072: W/dalvikvm(751): threadid=1: thread exiting with uncaught exception (group=0x40015560)
03-25 13:00:48.133: E/AndroidRuntime(751): FATAL EXCEPTION: main
03-25 13:00:48.133: E/AndroidRuntime(751): java.lang.RuntimeException: Unable to start activity ComponentInfo{Activity}: java.lang.NullPointerException
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.os.Handler.dispatchMessage(Handler.java:99)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.os.Looper.loop(Looper.java:130)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.app.ActivityThread.main(ActivityThread.java:3683)
03-25 13:00:48.133: E/AndroidRuntime(751):  at java.lang.reflect.Method.invokeNative(Native Method)
03-25 13:00:48.133: E/AndroidRuntime(751):  at java.lang.reflect.Method.invoke(Method.java:507)
03-25 13:00:48.133: E/AndroidRuntime(751):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-25 13:00:48.133: E/AndroidRuntime(751):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-25 13:00:48.133: E/AndroidRuntime(751):  at dalvik.system.NativeStart.main(Native Method)
03-25 13:00:48.133: E/AndroidRuntime(751): Caused by: java.lang.NullPointerException
03-25 13:00:48.133: E/AndroidRuntime(751):  at Activity.onCreate(Activity.java:250)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
03-25 13:00:48.133: E/AndroidRuntime(751):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
03-25 13:00:48.133: E/AndroidRuntime(751):  ... 11 more

Activity.onCreate(Activity.java:250) wird auf diese Zeile gezeigt:

map.setOnMarkerDragListener (markerDragListener);

Was ich versucht habe

Und es ist seltsam, wenn ich diese Zeile hinzufüge

<uses-library android:name="com.google.android.maps" />

zuAndroidManifest.xmlzeigt der Logcat nichts an (kein Fehler, keine Warnung) und die Karte ist noch leer. In einem Post steht jedoch, dass diese Zeile das Problem mit der leeren Karte gelöst hat:https://stackoverflow.com/questions/15595357/android-supportmapfragment-google-play-services-issue

In meinem ProjektAndroid Dependencies Ordner, ich habe diese*.jar Dateien:

actionbar-sherlock-4.2-library.jar
google-play-services_lib.jar
android-support-v4.jar
actionbarsherlock-plugin-maps-4.2.0.jar
google-play-services.jar

Aus einer Antwort vondieser Beitrag, Mir ist bekannt, dass Google Maps auf dem Emulator möglicherweise nicht ordnungsgemäß ausgeführt wird. Alles, was ich brauche, ist die Karte auf einem echten Android 2.3-Gerät anzuzeigen, was mir nicht gelungen ist.

Darüber hinaus habe ich auch diesen Post aufmerksam verfolgt und ihre Methode ausprobiert (falls zutreffend für meine Umstände), aber immer noch keine Freude an meinem Problem:

Google Map V2 Android-Kartenreferenzierung

Wie verwende ich Google Maps API v2 mit API Level 10?

Google MapFragment ist leer (weiß). Die Klasse 'maps.j.k' wurde nicht gefunden.

ActionBarSherlock mit dem neuen SupportMapFragment verwenden

Wenn Sie weitere Informationen benötigen, hinterlassen Sie bitte einen Kommentar und ich werde versuchen, sie hinzuzufügen.

Antworten auf die Frage(5)

Ihre Antwort auf die Frage