-1

Я пытаюсь работать с Google Maps API V2 в моем проекте Android, проблема в том, что когда я использую карту, которую я получил из макета, я получаю исключение NullPointerException. Я часами смотрел в Интернете, но ничего не мог найти. Мне жаль, если это уже было задано.google maps v2 фрагмент nullpointer

Вот макет, содержащий фрагмент:

<?xml version="1.0" encoding="utf-8"?> 

<fragment xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/map" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    class="com.google.android.gms.maps.MapFragment" /> 

Вот мой MainActivity:

public class MainActivity extends Activity { 

private GoogleMap map; 

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


    map = ((MapFragment) getFragmentManager().findFragmentById(R.id.map)) 
      .getMap(); 

    Log.d("MAP",map.toString());} 

Дело "ToString", чтобы уменьшить проблему. Не имеет никакого смысла, я знаю, но он должен работать. Вот файл манифеста:

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

<uses-sdk 
    android:minSdkVersion="11" 
    android:targetSdkVersion="17" /> 

<uses-feature 
    android:glEsVersion="0x00020000" 
    android:required="true" /> 
<uses-feature android:name="android.hardware.camera" /> 
<uses-feature android:name="android.hardware.camera.autofocus" /> 

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

<permission 
    android:name="com.example.testgooglemapsv2.permission.MAPS_RECEIVE" 
    android:protectionLevel="signature" /> 

<uses-permission android:name="com.example.testgooglemapsv2.permission.MAPS_RECEIVE" /> 
<uses-permission android:name="android.permission.INTERNET" /> 
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" /> 
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" /> 
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" /> 
<uses-permission android:name="android.permission.DISABLE_KEYGUARD" /> 

<application 
    android:allowBackup="true" 
    android:configChanges="orientation|keyboardHidden" 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" 
    android:theme="@style/AppTheme" > 
    <uses-library android:name="com.google.android.maps" /> 

    <activity 
     android:name="com.example.testgooglemapsv2.MainActivity" 
     android:label="@string/app_name" > 
     <intent-filter> 
      <action android:name="android.intent.action.MAIN" /> 

      <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 

    <meta-data 
     android:name="com.google.android.maps.v2.API_KEY" 
     android:value="AIzaSyB5tu4v6-jG1eiCKoSxEm_GfSZzAZt73k8" /> 

    <activity 
     android:name="com.example.testgooglemapsv2.CameraActivity" 
     android:label="@string/title_activity_camera" > 
    </activity> 
</application> 

</manifest> 

Вот лог-файл:

> 04-11 23:31:03.715: E/AndroidRuntime(4209): FATAL EXCEPTION: main 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): 
> java.lang.RuntimeException: Unable to start activity 
> ComponentInfo{com.example.testgooglemapsv2/com.example.testgooglemapsv2.MainActivity}: 
> java.lang.NullPointerException 04-11 23:31:03.715: 
> E/AndroidRuntime(4209): at 
> android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2180) 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): at 
> android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230) 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): at 
> android.app.ActivityThread.access$600(ActivityThread.java:141) 04-11 
> 23:31:03.715: E/AndroidRuntime(4209):  at 
> android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234) 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): at 
> android.os.Handler.dispatchMessage(Handler.java:99) 04-11 
> 23:31:03.715: E/AndroidRuntime(4209):  at 
> android.os.Looper.loop(Looper.java:137) 04-11 23:31:03.715: 
> E/AndroidRuntime(4209): at 
> android.app.ActivityThread.main(ActivityThread.java:5041) 04-11 
> 23:31:03.715: E/AndroidRuntime(4209):  at 
> java.lang.reflect.Method.invokeNative(Native Method) 04-11 
> 23:31:03.715: E/AndroidRuntime(4209):  at 
> java.lang.reflect.Method.invoke(Method.java:511) 04-11 23:31:03.715: 
> E/AndroidRuntime(4209): at 
> com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793) 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): at 
> com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560) 04-11 
> 23:31:03.715: E/AndroidRuntime(4209):  at 
> dalvik.system.NativeStart.main(Native Method) 04-11 23:31:03.715: 
> E/AndroidRuntime(4209): Caused by: java.lang.NullPointerException 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): at 
> com.example.testgooglemapsv2.MainActivity.onCreate(MainActivity.java:99) 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): at 
> android.app.Activity.performCreate(Activity.java:5104) 04-11 
> 23:31:03.715: E/AndroidRuntime(4209):  at 
> android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1080) 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): at 
> android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2144) 
> 04-11 23:31:03.715: E/AndroidRuntime(4209): ... 11 more 04-11 
> 23:31:03.724: D/dalvikvm(4209): GC_CONCURRENT freed 206K, 12% free 
> 2625K/2956K, paused 70ms+76ms, total 190ms 04-11 23:36:03.855: 
> I/Process(4209): Sending signal. PID: 4209 SIG: 9 

Извините еще раз, если это, кажется, легкий вопрос, но поверьте мне, я пытался. Спасибо.

+0

шоу StackTrace ... –

+0

((MapFragment) getFragmentManager() findFragmentById (R.id.map).) Whate это результат для этой линии? Вы найдете FragmentMap? – Pauland

+0

Я после этого учебника: http://www.vogella.com/articles/AndroidGoogleMaps/article.html Описание findFragmentById является: << общественного аннотация Фрагмент findFragmentById (интермедиат идентификатор) Добавлено в уровне API 11 Находит фрагмент, который был идентифицирован данным идентификатором либо при надувании из XML, либо в качестве идентификатора контейнера при добавлении в транзакции. Сначала выполняется поиск фрагментов, которые в настоящее время добавляются к активности менеджера; если такой фрагмент не найден, все поисковые фрагменты, находящиеся в обратном стеке, связанные с этим идентификатором, выполняются. >> – Pivoine

ответ

-3

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

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

    F = (MapFragment) getFragmentManager().findFragmentById(R.id.map); 
    map = F.getMap(); 
    while(map==null){ 

    } 
    if(map!=null) 
     Log.d("MAP",map.toString()); 
     } 

И это отлично работает :)

+2

ЭТО - принятый ответ? он не решает проблему и ее один из худших хаков, которые вы могли бы себе представить в ui-thread. – datayeah