1

更新:一个 UI 错误阻止我导入 google-play-services_lib。我必须立即单击 SDK 列表下方才能滚动查看库框。有关更多信息,请参阅已接受答案中的图像

我正在使用 Android IDE 获取 Hello World 地图应用程序,我将其命名为 Intactless2。这些文件都正确命名,/libs 中的 android-support-v4.jar,我有一个有效的 API 密钥等。

我按照 Google 的 Android 地图指南,逐字复制和粘贴 Java 和 activity_main.xml:

https://developers.google.com/maps/documentation/android/start#getting_the_google_maps_android_api_v2

我正确地将那里的所有内容添加到我的清单中。我在<meta-data android:name="com.google.android.gms.version"... 的值不正确时遇到错误,因此我将 version.xml 文件中的整数硬编码为android:value="4030500". 否则我的清单是不变的。

对于收到的错误消息,我尝试了 Google 热门搜索中的所有解决方案,但它仍然无法运行。通常,这表明我没有想到可能与 Google Play 服务无关的特殊错误,但我完全按照 Google 指南的建议重建了它,并重新修改了这些帖子中的所有建议,但仍然无法使用 Google播放服务。

我正在运行 4.4 模拟器,而 4.4 是我的项目将构建的最低版本。我尝试了以下方法以在我的应用程序中使用 google-play-services/google-play-services_lib:

1) 为 Google Play Services 制作了一个 Eclipse 项目并将其添加到我的项目中。右键单击我的项目 -> 属性 -> Java 构建路径 -> 项目添加 -> google-play-services_lib。a) 在 Order & Export 中选中 google-play-services_lib b) 在 Order and Export 中未选中 oogle-play-services_lib 2) 复制粘贴的 google-play-services、google-play-services_lib 和 google-play-services.properties我的 Android SDK 目录到我项目中的 /libs 目录。

1) Properties -> Android -> Target Build Path -> Android 4.4 2) Properties -> Android -> Target Build Path -> Google APIs(“Android 4.4”正下方的那个)

这是很多组合,包括 StackOverflow 上的人们建议的解决方案。

此外,如果我在<uses-library android:name="com.google.android.gms.maps" />清单中添加(或按照某些指南的建议删除 gms),我会收到以下 LogCat 错误:

11-13 00:57:18.890: E/PackageManager(938): Package com.example.intactless2 requires unavailable shared library com.google.android.gms.maps; failing!

将 google-play-services/google-play-services_lib 作为 Eclipse 项目导入:

google-play-services_lib Eclipse 项目截图:http: //postimg.org/image/ukbqjk9lp/

Package Explorer 中我的 hello world Maps 项目的屏幕截图:http: //postimg.org/image/589t2137h/

控制台输出:

...
[2013-11-12 21:57:13 - Intactless2] Installing Intactless2.apk...
[2013-11-12 21:57:19 - Intactless2] Installation error: INSTALL_FAILED_MISSING_SHARED_LIBRARY
[2013-11-12 21:57:19 - Intactless2] Please check logcat output for more details.
[2013-11-12 21:57:19 - Intactless2] Launch canceled!

日志猫:

11-13 01:03:44.870: E/AndroidRuntime(1886): FATAL EXCEPTION: main
11-13 01:03:44.870: E/AndroidRuntime(1886): Process: com.example.intactless2, PID: 1886
11-13 01:03:44.870: E/AndroidRuntime(1886): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.intactless2/com.example.intactless2.MainActivity}: android.view.InflateException: Binary XML file line #2: Error inflating class fragment
11-13 01:03:44.870: E/AndroidRuntime(1886):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2176)
11-13 01:03:44.870: E/AndroidRuntime(1886):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226)
11-13 01:03:44.870: E/AndroidRuntime(1886):     at android.app.ActivityThread.access$700(ActivityThread.java:135)
...

将 google-play-services.jar、google-play-services_lib.jar 和 google-play-services.jar.properties 直接放入我项目的 /libs 目录

Package Explorer 中我的 hello world Maps 项目的屏幕截图:http: //postimg.org/image/l68z4crl7/

控制台输出:

...
[2013-11-12 22:15:20 - Intactless2] Uploading Intactless2.apk onto device 'emulator-5554'
[2013-11-12 22:15:20 - Intactless2] Installing Intactless2.apk...
[2013-11-12 22:15:37 - Intactless2] Success!
[2013-11-12 22:15:37 - Intactless2] Starting activity com.example.intactless2.MainActivity on device emulator-5554
[2013-11-12 22:15:41 - Intactless2] ActivityManager: Starting: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] cmp=com.example.intactless2/.MainActivity }

日志猫:

11-13 01:15:43.990: E/AndroidRuntime(1959): FATAL EXCEPTION: main
11-13 01:15:43.990: E/AndroidRuntime(1959): Process: com.example.intactless2, PID: 1959
11-13 01:15:43.990: E/AndroidRuntime(1959): java.lang.NoClassDefFoundError: com.google.android.gms.R$styleable
11-13 01:15:43.990: E/AndroidRuntime(1959):     at com.google.android.gms.maps.GoogleMapOptions.createFromAttributes(Unknown Source)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at com.google.android.gms.maps.MapFragment.onInflate(Unknown Source)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at android.app.Activity.onCreateView(Activity.java:4784)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:689)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at android.view.LayoutInflater.inflate(LayoutInflater.java:469)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at android.view.LayoutInflater.inflate(LayoutInflater.java:397)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at android.view.LayoutInflater.inflate(LayoutInflater.java:353)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:290)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at android.app.Activity.setContentView(Activity.java:1928)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at com.example.intactless2.MainActivity.onCreate(MainActivity.java:11)
11-13 01:15:43.990: E/AndroidRuntime(1959):     at android.app.Activity.performCreate(Activity.java:5243)

先感谢您!任何帮助表示赞赏。:)

4

2 回答 2

0

我认为你的 XML 文件中有错误,因为在 log-cat 中你得到了

 Binary XML file line #2: Error inflating class fragment first you try to rectify it
于 2013-11-13T06:56:08.587 回答
0

您提到您使用的是 4.4 模拟器 - 您需要使用Google APIs (Google Inc.) - API Level 19模拟器来测试 Google Play 服务。

于 2013-11-13T06:50:27.253 回答