Android 我的位置管理器使我的应用程序崩溃了?

Android 我的位置管理器使我的应用程序崩溃了?,android,google-maps,android-fragments,android-location,Android,Google Maps,Android Fragments,Android Location,我是android的新手,在LocationManager方面遇到了麻烦。 我试着对几乎所有的事情发表评论,应用程序显示了一个地图。这意味着我已经从google api获得了一个密钥,其他任何东西都可以使用。 然后我想知道我现在的位置 我试图取消这些注释 LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE); 我从我的设备上收到强制关闭消息 这是我的活动 i

我是android的新手,在LocationManager方面遇到了麻烦。
我试着对几乎所有的事情发表评论,应用程序显示了一个地图。这意味着我已经从google api获得了一个密钥,其他任何东西都可以使用。
然后我想知道我现在的位置

我试图取消这些注释

LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
我从我的设备上收到强制关闭消息

这是我的活动

 import android.content.Context;
 import android.location.Criteria;
 import android.location.Location;
 import android.location.LocationManager;

 import android.os.Bundle;
 import android.support.v4.app.FragmentActivity;

 import com.google.android.gms.maps.CameraUpdateFactory;
 import com.google.android.gms.maps.GoogleMap;
 import com.google.android.gms.maps.model.LatLng;


 public class MainActivity extends FragmentActivity {
  private GoogleMap mMap;
  LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
  public Criteria criteria = new Criteria();
  public String provider = locationManager.getBestProvider(criteria,true);
  public Location myLocation = locationManager.getLastKnownLocation(provider);
  public Double latid = myLocation.getLatitude();
  public Double longi = myLocation.getLongitude();
  public LatLng Coba = new LatLng(latid,longi);
  protected Context context;


    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        mMap.setMyLocationEnabled(true);
        mMap.animateCamera(CameraUpdateFactory.newLatLngZoom(Coba, 16));

        }    
}
Logcat

12-28 16:01:38.830:E/Launcher(268):setWindow不透明() 12-28 16:01:42.630:E/UinboxLogger(3310):[UinboxReceiver]onReceive()>>Context is>android.app。ReceiverRestrictedContext@40523808 12-28 16:01:44.010:E/AndroidRuntime(3337):致命异常:主 12-28 16:01:44.010:E/AndroidRuntime(3337):java.lang.RuntimeException:无法实例化活动组件信息{com.example.hellomap/com.example.hellomap.MainActivity}:java.lang.IllegalStateException:onCreate()之前的活动无法使用系统服务 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1573) 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1667) 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.ActivityThread.access$1500(ActivityThread.java:117) 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.ActivityThread$H.handleMessage(ActivityThread.java:935) 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.os.Handler.dispatchMessage(Handler.java:99)上 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.os.Looper.loop(Looper.java:130) 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.ActivityThread.main(ActivityThread.java:3687)上 12-28 16:01:44.010:E/AndroidRuntime(3337):位于java.lang.reflect.Method.Invokenactive(本机方法) 12-28 16:01:44.010:E/AndroidRuntime(3337):位于java.lang.reflect.Method.invoke(Method.java:507) 12-28 16:01:44.010:E/AndroidRuntime(3337):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) 12-28 16:01:44.010:E/AndroidRuntime(3337):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625) 12-28 16:01:44.010:E/AndroidRuntime(3337):在dalvik.system.NativeStart.main(本机方法) 12-28 16:01:44.010:E/AndroidRuntime(3337):原因:java.lang.IllegalStateException:onCreate()之前的活动无法使用系统服务 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.Activity.getSystemService(Activity.java:3536)上 12-28 16:01:44.010:E/AndroidRuntime(3337):位于com.example.hellomap.MainActivity。(MainActivity.java:30) 12-28 16:01:44.010:E/AndroidRuntime(3337):位于java.lang.Class.newInstanceImpl(本机方法) 12-28 16:01:44.010:E/AndroidRuntime(3337):位于java.lang.Class.newInstance(Class.java:1409) 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.Instrumentation.newActivity(Instrumentation.java:1021)上 12-28 16:01:44.010:E/AndroidRuntime(3337):在android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1565) 12-28 16:01:44.010:E/AndroidRuntime(3337):。。。还有11个 12-28 16:01:44.020:E/(171):Dumpstate>/data/log/Dumpstate\u app\u错误 12-28 16:01:49.609:E/Launcher(268):setWindow不透明() 12-28 16:01:49.679:E/Launcher(268):MTP-Launcher:媒体扫描尚未完成

在xml中使用

<fragment
        android:id="@+id/map"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_below="@id/crntlocation"
        class="com.google.android.gms.maps.SupportMapFragment" />
//创建条件对象以检索提供程序

Criteria criteria = new Criteria();
            String provider = locationManager.getBestProvider(criteria, true);
            Location location = locationManager.getLastKnownLocation(provider);

我想这是因为你想发起

      LocationManager locationManager = (LocationManager)
getSystemService(Context.LOCATION_SERVICE);
在调用onCreate方法之前

//在onCreate()中启动这些组件


您的mMap可以返回null,请使用Try&catch块。

请提供崩溃日志。发布日志猫和xml。。please@AbdullahShoaib:我试图在这里获取崩溃日志。@Abdullah Shoaib:12-28 15:51:46.400:E/AndroidRuntime(2900):java.lang.RuntimeException:无法实例化活动组件信息{com.example.hellomap/com.example.hellomap.MainActivity}:java.lang.IllegalStateException:系统服务对onCreate()之前的活动不可用它仍然显示一些错误,当我把它放在onCreate方法里面学习如何使用Logcat查找错误,请发布Logcat堆栈跟踪。
      LocationManager locationManager = (LocationManager)
getSystemService(Context.LOCATION_SERVICE);
 LocationManager locationManager = (LocationManager) getSystemService(Context.LOCATION_SERVICE);
  public String provider = locationManager.getBestProvider(criteria,true);
  public Location myLocation = locationManager.getLastKnownLocation(provider);
  public Double latid = myLocation.getLatitude();
  public Double longi = myLocation.getLongitude();
  public LatLng Coba = new LatLng(latid,longi);