2013-02-17 2 views
0

Я пытаюсь загрузить googlemaps из mapview в свой код.Не удалось запустить mapview из активности

В настоящий момент, как только действие пытается загрузить, производится следующая ошибка, как показано ниже в LogCat.

Я не вижу ничего очевидного в своем коде, я не импортировал никаких дополнительных JAR-файлов в качестве учебника im, используя dosent, заявив, что они требуются на этом простом этапе.

Надеюсь, некоторые из них могут увидеть, где я собираюсь неправильно .:

Ошибка из LogCat:

02-17 19:47:01.889: E/AndroidRuntime(300): FATAL EXCEPTION: main 
02-17 19:47:01.889: E/AndroidRuntime(300): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.mapdb/com.example.mapdb.GoogleMapsActivity}: java.lang.ClassNotFoundException: com.example.mapdb.GoogleMapsActivity in loader dalvik.system.PathClassLoader[/system/framework/com.google.android.maps.jar:/data/app/com.example.mapdb-2.apk] 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.app.ActivityThread.access$2300(ActivityThread.java:125) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.os.Handler.dispatchMessage(Handler.java:99) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.os.Looper.loop(Looper.java:123) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.app.ActivityThread.main(ActivityThread.java:4627) 
02-17 19:47:01.889: E/AndroidRuntime(300): at java.lang.reflect.Method.invokeNative(Native Method) 
02-17 19:47:01.889: E/AndroidRuntime(300): at java.lang.reflect.Method.invoke(Method.java:521) 
02-17 19:47:01.889: E/AndroidRuntime(300): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
02-17 19:47:01.889: E/AndroidRuntime(300): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
02-17 19:47:01.889: E/AndroidRuntime(300): at dalvik.system.NativeStart.main(Native Method) 
02-17 19:47:01.889: E/AndroidRuntime(300): Caused by: java.lang.ClassNotFoundException: com.example.mapdb.GoogleMapsActivity in loader dalvik.system.PathClassLoader[/system/framework/com.google.android.maps.jar:/data/app/com.example.mapdb-2.apk] 
02-17 19:47:01.889: E/AndroidRuntime(300): at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243) 
02-17 19:47:01.889: E/AndroidRuntime(300): at java.lang.ClassLoader.loadClass(ClassLoader.java:573) 
02-17 19:47:01.889: E/AndroidRuntime(300): at java.lang.ClassLoader.loadClass(ClassLoader.java:532) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.app.Instrumentation.newActivity(Instrumentation.java:1021) 
02-17 19:47:01.889: E/AndroidRuntime(300): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577) 
02-17 19:47:01.889: E/AndroidRuntime(300): ... 11 more 

Manifest:

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
package="com.example.mapdb" 
android:versionCode="1" 
android:versionName="1.0" > 

<uses-sdk android:minSdkVersion="8" /> 

<uses-permission android:name="android.permission.INTERNET"/> 

<application 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" > 
    <activity 
     android:name=".GoogleMapsActivity" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 

      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 
    <uses-library android:name="com.google.android.maps" /> 
</application> 
</manifest> 

Основной класс активность:

package com.example.mapdb; 

import android.os.Bundle; 
import com.google.android.maps.MapActivity; 
import com.google.android.maps.MapView; 

public class MainActivity extends MapActivity { 

@Override 
public void onCreate(Bundle savedInstanceState) { 

    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 

    //fetch the map view from the layout 
    MapView mapView = (MapView) findViewById(R.id.mapview); 

    //make available zoom controls 
    mapView.setBuiltInZoomControls(true); 
} 

@Override 
protected boolean isRouteDisplayed() { 

    return false; 

} 
} 

activi ty_main.xml расположение:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 
android:orientation="vertical" > 

    <com.google.android.maps.MapView 
    android:id="@+id/mapview" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:apiKey="0xxxxxxxxxxxxxxxxxxxxg" 
    android:clickable="true" /> 
</LinearLayout> 
+0

Ваш APIkey был обесценен с декабря 2012 года. Вы должны реализовать новый метод с помощью API Карт Google v2. Пожалуйста, прочтите [этот официальный документ] (https://developers.google.com/maps/documentation/android/v1/). – BBonDoo

ответ

2

В коде Java, у вас есть:

public class MainActivity extends MapActivity 

В манифесте, у вас есть:

<activity 
    android:name=".GoogleMapsActivity" 

MainActivity не GoogleMapsActivity. Пожалуйста, синхронизируйте эти два значения, переименовав класс или отредактировав манифест.

+0

CommonsWare большое спасибо за вашу помощь снова. Я только что заметил это сам, проверяя, чтобы это произошло сейчас, но я уверен, что это так! – user1352057

+0

И это было. Я переименовал деятельность в манифесте в правильную «основную активность». еще раз спасибо – user1352057

Смежные вопросы