I'm really a newbie so I just watch tutorials. I'm having an issue about the location. I'm using a switch to go online/offline but when I pressed the switch, my app crashes.Here is the code
public class Welcome extends FragmentActivity implements OnMapReadyCallback,
GoogleApiClient.ConnectionCallbacks,
GoogleApiClient.OnConnectionFailedListener,
LocationListener{
private GoogleMap mMap;
//Play Services
private static final int MY_PERMISSION_REQUEST_CODE = 7000;
private static final int PLAY_SERVICE_RES_REQUEST = 7001;
private LocationRequest mLocationRequest;
private GoogleApiClient mGoogleApiClient;
private Location mLastLocation;
private static int UPDATE_INTERVAL = 5000;
private static int FASTEST_INTERVAL = 3000;
private static int DISPLACEMENT = 10;
DatabaseReference drivers;
GeoFire geoFire;
Marker mCurrent;
MaterialAnimatedSwitch location_switch;
SupportMapFragment mapFragment;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_welcome);
// Obtain the SupportMapFragment and get notified when the map is ready to be used.
mapFragment = (SupportMapFragment) getSupportFragmentManager()
.findFragmentById(R.id.map);
mapFragment.getMapAsync(this);
//Init View
location_switch = (MaterialAnimatedSwitch)findViewById(R.id.location_switch);
location_switch.setOnCheckedChangeListener(new MaterialAnimatedSwitch.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(boolean isOnline) {
if(isOnline)
{
StartLocationUpdates();
displayLocation();
Snackbar.make(mapFragment.getView(),"You are online",Snackbar.LENGTH_SHORT).show();
}
else
{
stopLocationUpdates();
mCurrent.remove();
Snackbar.make(mapFragment.getView(),"You are offline",Snackbar.LENGTH_SHORT).show();
}
}
});
//Geo fire
drivers = FirebaseDatabase.getInstance().getReference("Drivers");
geoFire = new GeoFire(drivers);
setUpLocation();
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
switch (requestCode)
{
case MY_PERMISSION_REQUEST_CODE:
if(grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED)
{
if(checkedPlayServices())
{
buildGoogleApiClient();
createLocationRequest();
if(location_switch.isChecked())
{
displayLocation();
}
}
}
}
}
private void setUpLocation() {
if(ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED &&
ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED)
{
//Request runtime permission
ActivityCompat.requestPermissions(this,new String[]{
Manifest.permission.ACCESS_COARSE_LOCATION,
Manifest.permission.ACCESS_FINE_LOCATION
},MY_PERMISSION_REQUEST_CODE);
}
else
{
if(checkedPlayServices())
{
buildGoogleApiClient();
createLocationRequest();
if(location_switch.isChecked())
{
displayLocation();
}
}
}
}
private void createLocationRequest() {
mLocationRequest = new LocationRequest();
mLocationRequest.setInterval(UPDATE_INTERVAL);
mLocationRequest.setFastestInterval(FASTEST_INTERVAL);
mLocationRequest.setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY);
mLocationRequest.setSmallestDisplacement(DISPLACEMENT);
}
private void buildGoogleApiClient() {
mGoogleApiClient = new GoogleApiClient.Builder(this)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.addApi(LocationServices.API)
.build();
mGoogleApiClient.connect();
}
private boolean checkedPlayServices() {
int resultCode = GooglePlayServicesUtil.isGooglePlayServicesAvailable(this);
if (resultCode != ConnectionResult.SUCCESS) {
if (GooglePlayServicesUtil.isUserRecoverableError(resultCode))
GooglePlayServicesUtil.getErrorDialog(resultCode, this, PLAY_SERVICE_RES_REQUEST).show();
else {
Toast.makeText(this, "This device is not supported", Toast.LENGTH_SHORT).show();
finish();
}
return false;
}
return true;
}
private void stopLocationUpdates() {
if(ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED &&
ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED)
{
return;
}
LocationServices.FusedLocationApi.removeLocationUpdates(mGoogleApiClient,this);
}
private void displayLocation() {
if(ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED &&
ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED)
{
return;
}
mLastLocation = LocationServices.FusedLocationApi.getLastLocation(mGoogleApiClient);
if (mLastLocation != null)
{
if(location_switch.isChecked())
{
final double latitude = mLastLocation.getLatitude();
final double longitude = mLastLocation.getLongitude();
//Update to firebase
geoFire.setLocation(FirebaseAuth.getInstance().getCurrentUser().getUid(), new GeoLocation(latitude, longitude), new GeoFire.CompletionListener() {
@Override
public void onComplete(String key, DatabaseError error) {
//Add Marker
mCurrent = mMap.addMarker(new MarkerOptions().position(new LatLng(latitude,longitude))
.title("You are here!").snippet("Consider yourself located")
.icon(BitmapDescriptorFactory.fromResource(R.drawable.car)));
//Move camera to this position
mMap.animateCamera(CameraUpdateFactory.newLatLngZoom(new LatLng(latitude,longitude),15.0f));
//Draw animation rotate marker
rotateMarker(mCurrent,-360,mMap);
if(mCurrent != null) {
mCurrent.remove(); // Remove marker
}
}
});
}
}
else
{
Log.d("ERROR","Cannot get your location");
}
}
private void rotateMarker(final Marker mCurrent, final float i, GoogleMap mMap) {
final Handler handler = new Handler();
final long start = SystemClock.uptimeMillis();
final float startRotation = mCurrent.getRotation();
final long duration = 1500;
final Interpolator interpolator = new LinearInterpolator();
handler.post(new Runnable() {
@Override
public void run() {
long elapsed = SystemClock.uptimeMillis() - start;
float t = interpolator.getInterpolation((float)elapsed/duration);
float rot = t*i+(1-t)*startRotation;
mCurrent.setRotation(-rot > 180?rot/2:rot);
if(t<1.0)
{
handler.postDelayed(this,16);
}
}
});
}
private void StartLocationUpdates() {
if(ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED &&
ActivityCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_GRANTED)
{
return;
}
LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiClient,mLocationRequest,this);
}
@Override
public void onMapReady(GoogleMap googleMap) {
mMap = googleMap;
}
@Override
public void onLocationChanged(Location location) {
mLastLocation = location;
displayLocation();
}
//@Override
public void onStatusChanged(String s, int i, Bundle bundle) {
}
//@Override
public void onProviderEnabled(String s) {
}
//@Override
public void onProviderDisabled(String s) {
}
@Override
public void onConnected(@Nullable Bundle bundle) {
displayLocation();
StartLocationUpdates();
}
@Override
public void onConnectionSuspended(int i) {
mGoogleApiClient.connect();
}
@Override
public void onConnectionFailed(@NonNull ConnectionResult connectionResult) {
}
}
I tried to debug it and it always points out the mCurrent = mMap.addMarker part. I tried a lot but it always crashes. Please help me fix it. Thankyou
also this is the logcat
01-28 06:15:29.817 5620-5739/com.judemark.triber.driverapp E/MPlugin: Unsupported class: com.mediatek.common.telephony.IOnlyOwnerSimSupport
01-28 06:15:30.126 5620-5620/com.judemark.triber.driverapp E/Minikin: addFont failed to create font /system/fonts/Padauk.ttf
01-28 06:15:30.248 5620-5620/com.judemark.triber.driverapp E/Minikin: addFont failed to create font /system/fonts/NanumGothic.ttf
01-28 06:15:30.251 5620-5620/com.judemark.triber.driverapp E/Minikin: addFont failed to create font /system/fonts/DroidSansFallback.ttf
01-28 06:15:30.251 5620-5620/com.judemark.triber.driverapp E/Minikin: addFont failed to create font /system/fonts/MTLmr3m.ttf
01-28 06:15:30.597 5620-5620/com.judemark.triber.driverapp E/MultiWindowProxy: getServiceInstance failed!
01-28 06:15:31.138 5620-5798/com.judemark.triber.driverapp E/GED: Failed to get GED Log Buf, err(0)
01-28 06:15:31.616 5620-5800/com.judemark.triber.driverapp E/NativeCrypto: ssl=0x7f765eb680 cert_verify_callback x509_store_ctx=0x7f618579f0 arg=0x0
01-28 06:15:31.616 5620-5800/com.judemark.triber.driverapp E/NativeCrypto: ssl=0x7f765eb680 cert_verify_callback calling verifyCertificateChain authMethod=ECDHE_RSA
01-28 06:16:01.626 5620-5620/com.judemark.triber.driverapp E/MultiWindowProxy: getServiceInstance failed!
01-28 06:16:02.729 5620-7093/com.judemark.triber.driverapp E/NativeCrypto: ssl=0x7f65a74b00 cert_verify_callback x509_store_ctx=0x7f49332220 arg=0x0
01-28 06:16:02.729 5620-7093/com.judemark.triber.driverapp E/NativeCrypto: ssl=0x7f65a74b00 cert_verify_callback calling verifyCertificateChain authMethod=ECDHE_ECDSA
01-28 06:16:04.864 5620-7095/com.judemark.triber.driverapp E/NativeCrypto: ssl=0x7f5e659d80 cert_verify_callback x509_store_ctx=0x7f49128260 arg=0x0
01-28 06:16:04.865 5620-7095/com.judemark.triber.driverapp E/NativeCrypto: ssl=0x7f5e659d80 cert_verify_callback calling verifyCertificateChain authMethod=ECDHE_ECDSA
01-28 06:16:07.272 5620-5620/com.judemark.triber.driverapp E/UncaughtException: com.google.maps.api.android.lib6.common.apiexception.b: Failed to decode image. The provided image must be a Bitmap.
at com.google.maps.api.android.lib6.impl.m.a(:com.google.android.gms.DynamiteModulesB@11975448:12)
at com.google.maps.api.android.lib6.impl.n.a(:com.google.android.gms.DynamiteModulesB@11975448:7)
at com.google.maps.api.android.lib6.impl.cz.<init>(:com.google.android.gms.DynamiteModulesB@11975448:25)
at com.google.maps.api.android.lib6.impl.ba.a(:com.google.android.gms.DynamiteModulesB@11975448:487)
at com.google.android.gms.maps.internal.k.onTransact(:com.google.android.gms.DynamiteModulesB@11975448:94)
at android.os.Binder.transact(Binder.java:392)
at com.google.android.gms.internal.zzeu.zza(Unknown Source)
at com.google.android.gms.maps.internal.zzg.addMarker(Unknown Source)
at com.google.android.gms.maps.GoogleMap.addMarker(Unknown Source)
at com.judemark.triber.driverapp.Welcome$2.onComplete(Welcome.java:213)
at com.firebase.geofire.GeoFire$2.onComplete(GeoFire.java:175)
at com.google.android.gms.internal.zzeek.run(Unknown Source)
at android.os.Handler.handleCallback(Handler.java:815)
at android.os.Handler.dispatchMessage(Handler.java:104)
at android.os.Looper.loop(Looper.java:207)
at android.app.ActivityThread.main(ActivityThread.java:5769)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:679)
01-28 06:16:07.508 5620-5620/com.judemark.triber.driverapp E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.judemark.triber.driverapp, PID: 5620
com.google.maps.api.android.lib6.common.apiexception.b: Failed to decode image. The provided image must be a Bitmap.
at com.google.maps.api.android.lib6.impl.m.a(:com.google.android.gms.DynamiteModulesB@11975448:12)
at com.google.maps.api.android.lib6.impl.n.a(:com.google.android.gms.DynamiteModulesB@11975448:7)
at com.google.maps.api.android.lib6.impl.cz.<init>(:com.google.android.gms.DynamiteModulesB@11975448:25)
at com.google.maps.api.android.lib6.impl.ba.a(:com.google.android.gms.DynamiteModulesB@11975448:487)
at com.google.android.gms.maps.internal.k.onTransact(:com.google.android.gms.DynamiteModulesB@11975448:94)
at android.os.Binder.transact(Binder.java:392)
at com.google.android.gms.internal.zzeu.zza(Unknown Source)
at com.google.android.gms.maps.internal.zzg.addMarker(Unknown Source)
at com.google.android.gms.maps.GoogleMap.addMarker(Unknown Source)
at com.judemark.triber.driverapp.Welcome$2.onComplete(Welcome.java:213)
at com.firebase.geofire.GeoFire$2.onComplete(GeoFire.java:175)
at com.google.android.gms.internal.zzeek.run(Unknown Source)
at android.os.Handler.handleCallback(Handler.java:815)
at android.os.Handler.dispatchMessage(Handler.java:104)
at android.os.Looper.loop(Looper.java:207)
at android.app.ActivityThread.main(ActivityThread.java:5769)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:679)
01-28 06:16:08.644 5620-7155/? E/NativeCrypto: ssl=0x7f457f5200 cert_verify_callback x509_store_ctx=0x7f35dbe350 arg=0x0
01-28 06:16:08.644 5620-7155/? E/NativeCrypto: ssl=0x7f457f5200 cert_verify_callback calling verifyCertificateChain authMethod=ECDHE_ECDSA