gpt4 book ai didi

android - MapFragment 错误 - CameraUpdateFactory 未初始化

转载 作者:行者123 更新时间:2023-11-29 01:56:24 31 4
gpt4 key购买 nike

尝试为手机创建 ListFragment --> MapFragment Activity 。 MapFragment代码如下:

public class MapFragment extends SupportMapFragment {
private GoogleMap mMap;

@Override
public void onCreate(Bundle bundle){
super.onCreate(bundle);

try {
MapsInitializer.initialize(this.getActivity());
} catch (GooglePlayServicesNotAvailableException e){
e.printStackTrace();
}

setRetainInstance(true);
}

@Override
public void onActivityCreated(Bundle savedInstanceState){
super.onActivityCreated(savedInstanceState);
if(getMap() != null){
Log.v(TAG, "Map ready for use!");
mMap = getMap();
}
}

@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
View root = super.onCreateView(inflater, container, savedInstanceState);
return root;
}

public void animateTo(double lat, double lng){
Log.d(TAG, "mMap animating...");
LatLng mCurrentPosition = new LatLng(lat, lng);
mMap.animateCamera(CameraUpdateFactory.newLatLngZoom(mCurrentPosition, 16));
}
}

但我得到以下错误---

02-15 17:12:53.232: E/AndroidRuntime(6913): FATAL EXCEPTION: main
02-15 17:12:53.232: E/AndroidRuntime(6913): java.lang.NullPointerException: CameraUpdateFactory is not initialized
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.google.android.gms.internal.at.a(Unknown Source)
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.google.android.gms.maps.CameraUpdateFactory.J(Unknown Source)
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.google.android.gms.maps.CameraUpdateFactory.newLatLngZoom(Unknown Source)
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.test.app.MapFragment.animateTo(MapFragment.java:113)
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.test.app.MapActivity.onListItemClick(MapActivity.java:270)
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.test.app.SimpleListFragment.onListItemClick(SimpleListFragment.java:65)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.support.v4.app.ListFragment$2.onItemClick(ListFragment.java:58)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.widget.AdapterView.performItemClick(AdapterView.java:298)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.widget.AbsListView.performItemClick(AbsListView.java:1100)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.widget.AbsListView$PerformClick.run(AbsListView.java:2749)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.widget.AbsListView$1.run(AbsListView.java:3423)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.os.Handler.handleCallback(Handler.java:725)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.os.Handler.dispatchMessage(Handler.java:92)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.os.Looper.loop(Looper.java:137)
02-15 17:12:53.232: E/AndroidRuntime(6913): at android.app.ActivityThread.main(ActivityThread.java:5039)
02-15 17:12:53.232: E/AndroidRuntime(6913): at java.lang.reflect.Method.invokeNative(Native Method)
02-15 17:12:53.232: E/AndroidRuntime(6913): at java.lang.reflect.Method.invoke(Method.java:511)
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
02-15 17:12:53.232: E/AndroidRuntime(6913): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
02-15 17:12:53.232: E/AndroidRuntime(6913): at dalvik.system.NativeStart.main(Native Method)

我认为调用 MapInitializer 可以解决问题,但似乎并没有成功。跟调用getMap()方法的时机有关系吗?

最佳答案

更改了此处的实现。使用了一个新的布局,它在 FrameLayout 中同时具有 listFragment 和 MapFragment 的 fragment 类。然后通过它们的 FragmentId 找到这些,然后使用显示/隐藏结合添加到返回堆栈以使 map /列表显示给用户。我不确定使用显示/隐藏的两组 fragment 会产生什么开销,但似乎在 Nexus4 上工作得很好 :)

此处提供代码: https://github.com/codedawg82/AndroidFragments/

关于android - MapFragment 错误 - CameraUpdateFactory 未初始化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14904277/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com