我有一个使用谷歌地图Android v2 API的应用程序。我已经添加了google-play-services_lib库项目到我的工作空间,并从我的应用程序项目中添加了对它的引用,按照这些页面上的说明:

http://developer.android.com/google/play-services/setup.html。 https://developers.google.com/maps/documentation/android/start

一切似乎都很正常:应用程序显示地图和覆盖默认标记。所以我很确定我已经正确地设置了谷歌播放服务和谷歌地图API。

然而,我在ADT LogCat窗口中看到这条消息每当地图视图初始化(在第二代Nexus 7上):

The Google Play services resources were not found. Check your project configuration to ensure that the resources are included.

消息级别是Error,标记是GooglePlayServicesUtil。

这似乎是良性的,因为我的应用程序运行良好。但是我能做些什么来解决问题呢?


进一步的信息:每次“谷歌播放服务资源未找到”消息出现在LogCat中,它前面是这些消息,这是警告和标记ResourceType:

getEntry failing because entryIndex 906 is beyond type entryCount 3

Failure getting entry for 0x7f0b038a (t=10 e=906) in package 0 (error -2147483647)

FWIW,当我搜索项目时,我找不到常量0x7f0b038a,包括gen/R.java文件。

我检查了生成的.apk的内容,它包括了google-play-services_lib/res目录下的所有资源。


另一个更新:添加ActionBarSherlock和更新targetSdkVersion在我的清单从8到17,我现在看到另一个错误在LogCat输出:

Could not find class 'maps.af.k', referenced from method 'maps.ag.an.a'

关于这个问题的更多细节可以在这里找到:谷歌地图在Android上工作正常,但我仍然得到一个错误“无法找到类的Maps . I。K ',引用自方法maps.z.ag.a"

这款应用似乎又一次运行良好。也许忽略这些“错误”是安全的?


当前回答

我已经反编译谷歌播放服务修订版14库。我认为com.google.android.gms.common.GooglePlayServicesUtil.class有一个bug。前面提到的字符串只出现在一个地方:

public static int isGooglePlayServicesAvailable(Context context) {
    PackageManager localPackageManager = context.getPackageManager();
    try {
        Resources localResources = context.getResources();
        localResources.getString(R.string.common_google_play_services_unknown_issue);
    } catch (Throwable localThrowable1) {
        Log.e("GooglePlayServicesUtil", "The Google Play services resources were not found. "
                + "Check your project configuration to ensure that the resources are included.");
    }
....

在com.google.android.gms.common包中没有R.class。

有一个导入com.google.android.gms.R.string;,但没有使用string。什么,所以我猜这是错误-应该有导入com.google.android.gms.R;。

尽管如此,isGooglePlayServicesAvailable方法仍能正常工作(除了记录该警告),但该类中还有其他方法,它们使用未导入的R.class,因此可能会出现其他一些错误。虽然横幅在我的应用程序工作得很好…

其他回答

我也有同样的问题。我也试图寻找解决方案,但在我没有找到任何解决方案后,我试图重新启动我的移动设备(Android设备),它解决了这个问题。

请试一试!为了安全起见,重新启动您的移动设备和Eclipse,并检查它是否正常工作。

我相信这是当前谷歌Play Services库的一个bug,修订版15,因为底层原因似乎是由于未能读取资源文件造成的:

W/ResourceType(25122):请求资源0x7f0c000d失败,因为它很复杂 E/GooglePlayServicesUtil(25122): The谷歌Play services resources were not found。检查您的项目配置,以确保资源包括在内。

谷歌Play Services库似乎试图读取资源文件,并在资源加载失败时显示此错误消息的通用catch-all。这与kreker设法从库反编译的内容相对应,并将解释日志消息。

在与其他开发者合作时,我也遇到了同样的问题。如果我从我的ADT运行项目,它工作得很好,但从他们的不是。

答案是把他们的SHA-1密钥和包名放在谷歌API控制台和我的控制台中。我们是三个开发人员,所以我们需要输入三个SHA-1密钥。

我希望它能给你一些启发……

我也有同样的问题。在谷歌api控制台中,你应该检查该应用程序只有一个键生成。我有一个延伸,我将我的代码从一台PC迁移到下一台等(它变得混乱),并为我的一个项目有多个键。在API控制台页面上,旧的键都被列为非活动键,但由于某种原因导致了冲突。在完全删除它们之后,我再次运行它,它工作了。

至于我,我已经通过下一种方式解决了这个问题-正如developer.android.com所说,在添加google-play-services_lib之后,你应该添加<meta-data android:name="com.google.android.gms.version" android: value = " / google_play_services_version " / > 在你的清单,但在新的SDK,你总是会得到一个错误:

错误:没有找到与给定名称匹配的资源(at 'value'与value' @integer/ google_play_services_version”)。

为了解决这个错误,许多人建议使用原始值4030500,而不是@integer/google_play_services_version,但这只适用于谷歌服务版本13。

如果你使用任何旧版本或版本的Froyo(像我),你应该在它里面放另一个值。要知道你应该放什么值,只需打开谷歌播放服务清单,并复制粘贴一个version_code值。Froyo服务是3265130。添加这个后,我已经停止得到这个错误,我已经开始在我的应用程序中接收坐标。