I'm trying to build a Google map application but keep receiving this in my LogCat. I have all the permissions and meta-data set in my manifest, but am still dumbfounded by this error. Have looked everywhere on SO for this specific error but found nothing relating to com.google.android.gms.checkin
A little bit about my structural hierarchy. MainActivity extends ActionBarActivity with three tabs underneath actionbar. Each tab has it's own fragment. On the gMapFragment I create a GPSTrack object from my GPSTrack class which extends Service and implements LocationListener.
The problem is that when I start the application I get this message:
I have all my libraries imported properly and I even added the google-play-services.jar into my libs folder. I also installed Google Play Services APKs through CMD onto my emulator.
Furthermore the LocationManager lm = = (LocationManager) mContext.getSystemService(LOCATION_SERVICE); in my GPSTrack class always returns null.
Why is this and how can I fix these issues? Would appreciate an explanation along with solution too, I want to understand what's going on here.
==============
Code:
gMapFragment.java
public class gMapFragment extends SupportMapFragment {
private final String TAG = "gMapFragment";
private GoogleMap mMap;
protected SupportMapFragment mapFrag;
private Context mContext = getActivity();
private static View view;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
if (view != null) {
ViewGroup parent = (ViewGroup) view.getParent();
if (parent != null) {
parent.removeView(view);
}
}
try {
super.onCreateView(inflater, container, savedInstanceState);
view = inflater.inflate(R.layout.fragment_map, container, false);
setupGoogleMap();
} catch (Exception e) {
/*
* Map already there , just return as view
*/
}
return view;
}
private void setupGoogleMap() {
mapFrag = (SupportMapFragment) getFragmentManager().findFragmentById(
R.id.mapView);
if (mapFrag == null) {
FragmentManager fragManager = getFragmentManager();
FragmentTransaction fragTransaction = fragManager
.beginTransaction();
mapFrag = SupportMapFragment.newInstance();
fragTransaction.replace(R.id.mapView, mapFrag).commit();
}
if (mapFrag != null) {
mMap = mapFrag.getMap();
if (mMap != null) {
setupMap();
mMap.setOnMapClickListener(new OnMapClickListener() {
@Override
public void onMapClick(LatLng point) {
// TODO your click stuff on map
}
});
}
}
}
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
Log.d("Attach", "on attach");
}
@Override
public void onDetach() {
super.onDetach();
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
public void onResume() {
super.onResume();
}
@Override
public void onPause() {
super.onPause();
}
@Override
public void onDestroy() {
super.onDestroy();
}
private void setupMap() {
GPSTrack gps = new GPSTrack(mContext);
// Enable MyLocation layer of google map
mMap.setMyLocationEnabled(true);
Log.d(TAG, "MyLocation enabled");
// Set Map type
mMap.setMapType(GoogleMap.MAP_TYPE_NORMAL);
// Grab current location
**ERROR HERE/Returns Null** Location location = gps.getLocation();
Log.d(TAG, "Grabbing location...");
if (location != null) {
Log.d(TAG, "location != null");
// Grab Latitude and Longitude
double latitude = location.getLatitude();
double longitude = location.getLongitude();
Log.d(TAG, "Getting lat, long..");
// Initialize LatLng object
LatLng latLng = new LatLng(latitude, longitude);
Log.d(TAG, "LatLng initialized");
// Show current location on google map
mMap.moveCamera(CameraUpdateFactory.newLatLng(latLng));
// Zoom in on google map
mMap.animateCamera(CameraUpdateFactory.zoomTo(20));
mMap.addMarker(new MarkerOptions().position(
new LatLng(latitude, longitude)).title("You are here."));
} else {
gps.showSettingsAlert();
}
}
}
GPSTrack.java
public class GPSTrack extends Service implements LocationListener{
private final Context mContext;
private boolean isGPSEnabled = false;
//See if network is connected to internet
private boolean isNetworkEnabled = false;
//See if you can grab the location
private boolean canGetLocation = false;
protected Location location = null;
protected double latitude;
protected double longitude;
private static final long MINIMUM_DISTANCE_CHANGE_FOR_UPDATES = 10; //10 Meters
private static final long MINIMUM_TIME_CHANGE_FOR_UPDATES = 1000 * 60 * 1; //1 minute
protected LocationManager locationManager;
public GPSTrack(Context context) {
this.mContext = context;
getLocation();
}
public Location getLocation() {
try {
//Setup locationManager for controlling location services
**ERROR HERE/Return Null** locationManager = (LocationManager) mContext.getSystemService(LOCATION_SERVICE);
//See if GPS is enabled
isGPSEnabled = locationManager.isProviderEnabled(LocationManager.GPS_PROVIDER);
//See if Network is connected to the internet or carrier service
isNetworkEnabled = locationManager.isProviderEnabled(LocationManager.NETWORK_PROVIDER);
if (!isGPSEnabled && !isNetworkEnabled) {
Toast.makeText(getApplicationContext(), "No Network Provider Available", Toast.LENGTH_SHORT).show();
} else {
this.canGetLocation = true;
if (isNetworkEnabled) {
locationManager.requestLocationUpdates(
LocationManager.NETWORK_PROVIDER,
MINIMUM_TIME_CHANGE_FOR_UPDATES,
MINIMUM_DISTANCE_CHANGE_FOR_UPDATES,
this);
Log.d("GPS", "GPS Enabled");
if (locationManager != null) {
location = locationManager.getLastKnownLocation(LocationManager.GPS_PROVIDER);
if (location != null) {
latitude = location.getLatitude();
longitude = location.getLongitude();
}
}
}
}
} catch (Exception e) {
e.printStackTrace();
}
return location;
}
public void stopUsingGPS() {
if (locationManager != null) {
locationManager.removeUpdates(GPSTrack.this);
}
}
public double getLatitude() {
if (location != null) {
latitude = location.getLatitude();
}
return latitude;
}
public double getLongitude() {
if (location != null) {
longitude = location.getLongitude();
}
return longitude;
}
public boolean canGetLocation() {
return this.canGetLocation;
}
public void showSettingsAlert() {
AlertDialog.Builder alertDialog = new AlertDialog.Builder(mContext);
//AlertDialog title
alertDialog.setTitle("GPS Settings");
//AlertDialog message
alertDialog.setMessage("GPS is not enabled. Do you want to go to Settings?");
alertDialog.setPositiveButton("Settings", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
Intent i = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
mContext.startActivity(i);
}
});
alertDialog.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
dialog.cancel();
}
});
alertDialog.show();
}
@Override
public void onLocationChanged(Location location) {
// TODO Auto-generated method stub
}
@Override
public void onStatusChanged(String provider, int status, Bundle extras) {
// TODO Auto-generated method stub
}
@Override
public void onProviderEnabled(String provider) {
// TODO Auto-generated method stub
}
@Override
public void onProviderDisabled(String provider) {
// TODO Auto-generated method stub
}
@Override
public IBinder onBind(Intent intent) {
// TODO Auto-generated method stub
return null;
}
}
logcat
06-08 22:35:03.441: E/AndroidRuntime(1370): FATAL EXCEPTION: main
06-08 22:35:03.441: E/AndroidRuntime(1370): Process: com.google.android.gms, PID: 1370
06-08 22:35:03.441: E/AndroidRuntime(1370): java.lang.RuntimeException: Unable to start service com.google.android.gms.checkin.CheckinService@b1094e48 with Intent { cmp=com.google.android.gms/.checkin.CheckinService }: java.lang.SecurityException: attempting to read gservices without permission: Neither user 10053 nor current process has com.google.android.providers.gsf.permission.READ_GSERVICES.
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2719)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.app.ActivityThread.access$2100(ActivityThread.java:135)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1293)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.os.Handler.dispatchMessage(Handler.java:102)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.os.Looper.loop(Looper.java:136)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.app.ActivityThread.main(ActivityThread.java:5017)
06-08 22:35:03.441: E/AndroidRuntime(1370): at java.lang.reflect.Method.invokeNative(Native Method)
06-08 22:35:03.441: E/AndroidRuntime(1370): at java.lang.reflect.Method.invoke(Method.java:515)
06-08 22:35:03.441: E/AndroidRuntime(1370): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
06-08 22:35:03.441: E/AndroidRuntime(1370): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
06-08 22:35:03.441: E/AndroidRuntime(1370): at dalvik.system.NativeStart.main(Native Method)
06-08 22:35:03.441: E/AndroidRuntime(1370): Caused by: java.lang.SecurityException: attempting to read gservices without permission: Neither user 10053 nor current process has com.google.android.providers.gsf.permission.READ_GSERVICES.
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.app.ContextImpl.enforce(ContextImpl.java:1685)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.app.ContextImpl.enforceCallingOrSelfPermission(ContextImpl.java:1714)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.content.ContextWrapper.enforceCallingOrSelfPermission(ContextWrapper.java:572)
06-08 22:35:03.441: E/AndroidRuntime(1370): at imq.c(SourceFile:107)
06-08 22:35:03.441: E/AndroidRuntime(1370): at imq.a(SourceFile:121)
06-08 22:35:03.441: E/AndroidRuntime(1370): at imq.a(SourceFile:227)
06-08 22:35:03.441: E/AndroidRuntime(1370): at bwq.c(SourceFile:166)
06-08 22:35:03.441: E/AndroidRuntime(1370): at com.google.android.gms.checkin.CheckinService.a(SourceFile:237)
06-08 22:35:03.441: E/AndroidRuntime(1370): at com.google.android.gms.checkin.CheckinService.onStartCommand(SourceFile:211)
06-08 22:35:03.441: E/AndroidRuntime(1370): at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2702)
AndroidManifest
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.app"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="14"
android:targetSdkVersion="19" />
<uses-permission android:name="com.curio.permission.MAPS_RECEIVE" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES" />
<uses-permission android:name="android.permission.ACCESS_MOCK_LOCATION" />
<uses-feature
android:name="android.hardware.camera"
android:required="true" />
<uses-feature
android:glEsVersion="0x00020000"
android:required="true" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.app.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<meta-data
android:name="com.google.android.gms.version"
android:value="@integer/google_play_services_version" />
<meta-data
android:name="com.google.android.maps.v2.API_KEY"
android:value="AI........................" />
</application>