更新:一个 UI 错误阻止我导入 google-play-services_lib。我必须立即单击 SDK 列表下方才能滚动查看库框。有关更多信息,请参阅已接受答案中的图像。
我正在使用 Android IDE 获取 Hello World 地图应用程序,我将其命名为 Intactless2。这些文件都正确命名,/libs 中的 android-support-v4.jar,我有一个有效的 API 密钥等。
我按照 Google 的 Android 地图指南,逐字复制和粘贴 Java 和 activity_main.xml:
我正确地将那里的所有内容添加到我的清单中。我在<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)
先感谢您!任何帮助表示赞赏。:)