我正在尝试将新的Google Maps Android API v2集成到使用Android支持库的应用程序中。
我经历了许多迭代,尝试着使它正常工作,但最终放弃了并认为我应该在这里提问。
我去了API控制台,创建了一个项目,启用了适用于Android的Google Maps API v2,在清单上粘贴了所需的调试KEY。没有身份验证问题或其他任何问题。我非常确定我做得对。
在我的项目的libs
文件夹中,我通过项目右键单击->Android->Add Support Library...添加了android-support-v4.jar
。在Eclipse中,我执行了File->Import->Android->Existing Android Code Into Workspace,并导入了最新的(rev 3)android-sdk/google/google_play_services/libproject/google-play-services_lib。然后我将其作为依赖库添加到我的项目中(项目右键单击->Properties->Android->在底部添加它作为库依赖项)。
在我的清单中,我有:
<manifest xmlns:android="http://schemas.android.com/apk/res/android" ...>
<permission
android:name="myapp.permission.MAPS_RECEIVE"
android:protectionLevel="signature"/>
<All the uses-permission required like INTERNET, ACCESS_NETWORK_STATE, WRITE_EXTERNAL_STORAGE, FINE AND COARSE LOCATION, etc>
<uses-permission android:name="myapp.permission.MAPS_RECEIVE"/>
<uses-feature android:glEsVersion="0x00020000" android:required="true"/>
<application ...>
...
<uses-library android:name="com.google.android.maps" />
<meta-data android:name="com.google.android.maps.v2.API_KEY" android:value="AI..."/>
</application>
在我的mainview.xml文件中,我有:
<fragment
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/map"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
class="com.google.android.gms.maps.SupportMapFragment" />
现在在MainView.java中我有以下代码:
import android.support.v4.app.Fragment;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentManager;
import android.support.v4.app.FragmentTransaction;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
public class MainView extends FragmentActivity ... {
private GoogleMap mMap;
@Override
protected void onResume() {
...
Fragment fragment = getSupportFragmentManager().findFragmentById(R.id.map);
SupportMapFragment mapFragment = (SupportMapFragment)fragment;
mMap = mapFragment.getMap();
//PROBLEM: mMap is null here even though mapFragment is not
}
}
接着我想我可能需要初始化碎片,所以在设置内容视图后,我在我的onCreate
中添加了以下代码:
//Fragments
FragmentManager manager = getSupportFragmentManager();
FragmentTransaction transaction = manager.beginTransaction();
transaction.add(R.id.map, SupportMapFragment.newInstance());
transaction.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN);
transaction.commit();
我说,也许不是SupportMapFragment
引起了问题,而是我应该引用实际的片段,在我的onResume
中这样做:
Fragment fragment = getSupportFragmentManager().findFragmentById(R.id.map);
SupportMapFragment mapFragment = (SupportMapFragment)fragment;
//Fragments
FragmentManager manager = getSupportFragmentManager();
FragmentTransaction transaction = manager.beginTransaction();
transaction.add(R.id.map, mapFragment);
transaction.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN);
transaction.commit();
mMap = mapFragment.getMap();
mMap
在这之后又变成了 null。
然后我发现有一个 MapsInitializer
类,所以我觉得可能应该先调用那个。
于是我在上面的代码中获取片段之前添加了以下代码:
try {
MapsInitializer.initialize(this);
} catch (GooglePlayServicesNotAvailableException e) {
e.printStackTrace();
}
使用Logcat时报告了警告(第313行是MapsInitializer.initialize(this)
):
com.google.android.gms.common.GooglePlayServicesNotAvailableException
at com.google.android.gms.internal.n.c(Unknown Source)
at com.google.android.gms.internal.n.a(Unknown Source)
at com.google.android.gms.maps.MapsInitializer.initialize(Unknown Source)
at myapp.activities.MainView.inflateSelectedViewAndSetData(MainView.java:313)
at myapp.activities.MainView.onClick(MainView.java:642)
at android.view.View.performClick(View.java:3153)
at android.view.View$PerformClick.run(View.java:12148)
at android.os.Handler.handleCallback(Handler.java:587)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:152)
at android.app.ActivityThread.main(ActivityThread.java:4615)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:491)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:841)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:599)
at dalvik.system.NativeStart.main(Native Method)
尝试期间,Logcat会报告以下警告:
Google Play services out of date. Requires 2010100 but found 1013
这可能是罪魁祸首,但我没有找到解决方案。
现在我已经束手无策了。我阅读了几个线程这里,这里,这里 ,但是没有一个建议解决了问题。在后者中,他们建议不包括项目依赖关系,只包括jar文件。嗯,使用google-play-services.jar
从google-play-services_lib/libs
文件夹或从该项目导出我的自己的jar文件都不起作用。
顺便说一句,我正在实际设备上运行(2.3.5和带有3.2的平板电脑),而不是模拟器。
非常感谢任何帮助。 :)
更新:
qubit提供了以下解决方案。
至于导出库依赖项,不必处理它的一个巧妙方法(在处理存储库时很痛苦)是使用FatJar并导出google_play_services_lib
项目(我没有创建本地副本,因为当它更新时我不想重新导入),并将输出fat jar文件作为另一个jar文件包含在您的项目中。
注意:在选择要包含在fat jar中的jar文件时,我必须排除annotations.jar
文件,因为它已经被预先包含并且会导致重复错误。
现在,我只需将google_play_services_rev_3.jar
包含在我的项目的libs
文件夹中,就可以开始了。