Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/179.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android开发:服务未注册:com.google.Android.gms.common.internal.bf_Android_Android Service_Google Play Services_Unbind_Mapfragment - Fatal编程技术网

Android开发:服务未注册:com.google.Android.gms.common.internal.bf

Android开发:服务未注册:com.google.Android.gms.common.internal.bf,android,android-service,google-play-services,unbind,mapfragment,Android,Android Service,Google Play Services,Unbind,Mapfragment,我正在使用“com.google.android.gms.maps.MapFragment”来显示嵌入片段中的地图。当我尝试关闭活动(或等待几秒钟)时,应用程序崩溃,出现以下错误: E/AndroidRuntime﹕ FATAL EXCEPTION: main java.lang.IllegalArgumentException: Service not registered: com.google.android.gms.common.internal.bf@5368ecf4

我正在使用“com.google.android.gms.maps.MapFragment”来显示嵌入片段中的地图。当我尝试关闭活动(或等待几秒钟)时,应用程序崩溃,出现以下错误:

E/AndroidRuntime﹕ FATAL EXCEPTION: main
    java.lang.IllegalArgumentException: Service not registered: com.google.android.gms.common.internal.bf@5368ecf4
            at android.app.LoadedApk.forgetServiceDispatcher(LoadedApk.java:921)
            at android.app.ContextImpl.unbindService(ContextImpl.java:1459)
            at android.content.ContextWrapper.unbindService(ContextWrapper.java:484)
            at com.google.android.gms.common.stats.c.a(SourceFile:145)
            at com.google.android.gms.common.internal.bc.handleMessage(SourceFile:208)
            at android.os.Handler.dispatchMessage(Handler.java:95)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:5041)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:511)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
            at dalvik.system.NativeStart.main(Native Method)
我甚至尝试用try/catch来启动map片段:

try {
            GoogleMapOptions options = new GoogleMapOptions();
            options.zoomControlsEnabled(true);

            mMapFragment = MapFragment.newInstance(options);
            FragmentTransaction fragmentTransaction =
                    getFragmentManager().beginTransaction();
            fragmentTransaction.add(R.id.map, mMapFragment);
            fragmentTransaction.commit();

            mMapFragment.getMapAsync(this);
        } catch (IllegalArgumentException e) {
            Log.e(application.DEBUG_STRING, "error: ", e);
        }

public void onMapReady(谷歌地图谷歌地图){
试一试{
如果(经度>0和纬度>0){
markers=newarraylist();
MarkerOptions驻车位置=新MarkerOptions()
.位置(新车床(纬度、经度))
.title(getString(R.string.positionOfCar));
谷歌地图。添加标记(停车位置);
标记。添加(驻车位置);
LatLngBounds.Builder=新的LatLngBounds.Builder();
用于(标记选项标记:标记){
include(marker.getPosition());
}
LatLngBounds bounds=builder.build();
int padding=10;//与贴图边缘的偏移量(以像素为单位)
CameraUpdate cu=CameraUpdateFactory.newLatLngBounds(边界、填充);
//谷歌地图。移动摄像机(cu);
//谷歌地图。动画美人鱼(cu);
moveCamera(CameraUpdateFactory.newLatLngZoom(bounds.getCenter(),10));
googleMap.moveCamera(CameraUpdateFactory.zoomTo(17));
Log.d(application.DEBUG_字符串,“zoom”+googleMap.getCameraPosition().zoom);
if(googleMap.getCameraPosition().zoom>=18){
googleMap.animateCamera(CameraUpdateFactory.zoomTo(17));
}
}
}捕获(IllegalArgumentException e){
Log.e(application.DEBUG_字符串,“error:”,e);
}
}

有人有办法解决这个问题吗?

Hi Evid。你找到原因了吗?有相同的问题。您可能希望尝试GoogleMapOptions=new GoogleMapOptions();选项。使用ViewLifecycleInFragment(true)方法引用
public void onMapReady(GoogleMap googleMap) {

        try {
            if (longitude > 0 && latitude > 0) {
                markers = new ArrayList<MarkerOptions>();

                MarkerOptions parkingPosition = new MarkerOptions()
                        .position(new LatLng(latitude, longitude))
                        .title(getString(R.string.positionOfCar));

                googleMap.addMarker(parkingPosition);
                markers.add(parkingPosition);

                LatLngBounds.Builder builder = new LatLngBounds.Builder();
                for (MarkerOptions marker : markers) {
                    builder.include(marker.getPosition());
                }
                LatLngBounds bounds = builder.build();

                int padding = 10; // offset from edges of the map in pixels
                CameraUpdate cu = CameraUpdateFactory.newLatLngBounds(bounds, padding);


//            googleMap.moveCamera(cu);
//            googleMap.animateCamera(cu);
                googleMap.moveCamera(CameraUpdateFactory.newLatLngZoom(bounds.getCenter(), 10));
                googleMap.moveCamera(CameraUpdateFactory.zoomTo(17));

                Log.d(application.DEBUG_STRING, "zoom " + googleMap.getCameraPosition().zoom);

                if (googleMap.getCameraPosition().zoom >= 18) {
                    googleMap.animateCamera(CameraUpdateFactory.zoomTo(17));
                }
            }
        } catch (IllegalArgumentException e) {
            Log.e(application.DEBUG_STRING, "error: ", e);
        }
    }