更新: UI 错误阻止我导入 google-play-services_lib。我必须单击 SDK 列表正下方才能滚动查看“库”框。请参阅the image in the accepted answer了解更多信息。
我正在使用 Android IDE 来获取 Hello World map 应用程序,我将其命名为 Intactless2。这些文件的命名都正确,android-support-v4.jar 在/libs 中,我有一个有效的 API key ,等等。
我遵循 Google 的 Android map 指南,逐字复制并粘贴 Java 和 Activity_main.xml:
我正确地将所有内容添加到我的 list 中。我在 <meta-data android:name="com.google.android.gms.version"
上遇到错误... 的值不正确,因此我对 version.xml 文件中的整数进行了硬编码,使其为 android:value="4030500"
。否则我的 list 不会改变。
我针对收到的错误消息尝试了 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) 在订单和导出中检查 google-play-services_lib b) 取消选中 Order 和 Export 中的 oogle-play-services_lib 2) 将 google-play-services、google-play-services_lib 和 google-play-services.properties 从我的 Android SDK 目录复制粘贴到项目中的/libs 目录。
1) 属性 -> Android -> 目标构建路径 -> Android 4.4 2) 属性 -> Android -> 目标构建路径 -> Google API(“Android 4.4 正下方的那个”)
有很多组合,包括 StackOverflow 上的人们建议的解决方案。
此外,如果我添加 <uses-library android:name="com.google.android.gms.maps" />
(或按照某些指南的建议删除 gms)到我的 list ,我收到此 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 map 项目的屏幕截图: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 map 项目的屏幕截图: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.4 模拟器 - 您需要使用 Google API (Google Inc.) - API Level 19
模拟器来测试 Google Play 服务。
关于java - google-play-services 不会构建到 Eclipse 中的 Android Maps HelloWorld 项目中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19947061/