Я импортировал google_play_services_lib из дополнительных приложений Eclipse в свою Рабочую область. Я создал новый Android-проект и включил google_play_services_lib в качестве библиотеки. Мой проект имеет андроида-поддержка-v4.jar и Google-игра-services.jarGoogle Maps v2 для Android 10 не работает даже при использовании SupportMapFragment
Теперь мой файл манифеста:
<uses-sdk
android:minSdkVersion="9"
android:targetSdkVersion="16" />
<uses-permission android:name="android.permission.INTERNET" />
<!-- add for map2 -->
<permission
android:name="com.example.mapdemo.permission.MAPS_RECEIVE"
android:protectionLevel="signature" />
<meta-data
android:name="com.google.android.maps.v2.API_KEY"
android:value="MY API NUMBER" />
<uses-feature
android:glEsVersion="0x00020000"
android:required="true" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.phanism.gingerbreadmaps.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>
</application>
</manifest>
Мои activity_main:
package com.phanism.gingerbreadmaps;
import com.google.android.gms.maps.SupportMapFragment;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
public class MainActivity extends FragmentActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map);
mapFragment.getMap().setMyLocationEnabled(true);
}
}
И мой файл макета:
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/map"
android:name="com.phanism.MainActivity"
android:layout_width="match_parent"
android:layout_height="match_parent"
class="com.google.android.gms.maps.SupportMapFragment"/>
Когда я компилировать код выше, в эмуляторе, меня просят обновить Google Play Store. Когда я нажимаю OK, я получаю эту ошибку. На устройстве, я мое приложение рушится напрямую, и когда я смотрю на отладку, это ошибка, которую я получаю.
12-03 08:43:06.851: E/AndroidRuntime(620): FATAL EXCEPTION: main
12-03 08:43:06.851: E/AndroidRuntime(620): java.lang.NullPointerException
12-03 08:43:06.851: E/AndroidRuntime(620): at android.app.Instrumentation.execStartActivity(Instrumentation.java:1409)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.app.Activity.startActivityForResult(Activity.java:3351)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.app.Activity.startActivityForResult(Activity.java:3312)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.support.v4.app.FragmentActivity.startActivityForResult(FragmentActivity.java:824)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.app.Activity.startActivity(Activity.java:3522)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.app.Activity.startActivity(Activity.java:3490)
12-03 08:43:06.851: E/AndroidRuntime(620): at com.google.android.gms.dynamic.a$5.onClick(Unknown Source)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.view.View.performClick(View.java:4084)
12-3 08:43:06.851: E/AndroidRuntime(620): at android.view.View$PerformClick.run(View.java:16966)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.os.Handler.handleCallback(Handler.java:615)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.os.Handler.dispatchMessage(Handler.java:92)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.os.Looper.loop(Looper.java:137)
12-03 08:43:06.851: E/AndroidRuntime(620): at android.app.ActivityThread.main(ActivityThread.java:4745)
12-03 08:43:06.851: E/AndroidRuntime(620): at java.lang.reflect.Method.invokeNative(Native Method)
12-03 08:43:06.851: E/AndroidRuntime(620): at java.lang.reflect.Method.invoke(Method.java:511)
12-03 08:43:06.851: E/AndroidRuntime(620): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
12-03 08:43:06.851: E/AndroidRuntime(620): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
12-03 08:43:06.851: E/AndroidRuntime(620): at dalvik.system.NativeStart.main(Native Method)
Может ли кто-нибудь указать мне, что я делаю неправильно.
проверить эту ссылку http://www.androidhive.info/2013/08/android-working-with-google-maps-v2/ –
Как указано в одном ответе, вам не хватает, чтобы установить Версию Google Play Services в вашем манифесте, но было бы замечательно, если бы вы могли опубликовать свой полный логарифм исключения. Благодаря! – fasteque