Android: A / libc: фатальный сигнал 11 (SIGSEGV), код 1, адрес ошибки 0x8 в TID 18372 - PullRequest
0 голосов
/ 30 мая 2018

Я тестирую приложение с mapbox sdk и вместо поставщика движка mapbox я создал класс с именем "GoogleLocationEngine", используя эту ссылку для отслеживания местоположения пользователя (Google API): https://github.com/mapbox/mapbox-android-demo/issues/449

но приложение выдает мне эту ошибку (обычно в фоновом режиме):

A/libc: Fatal signal 11 (SIGSEGV), code 1, fault addr 0x8 in tid 18372

, хотя при использовании метода mapbox sdk:

LocationEngineProvider(context).obtainBestLocationEngineAvailable() 

ошибка по-прежнему отображаетсяи я не знаю, как это отследить, так как я могу решить это?Мое устройство - SAMSUNG Galaxy Note 4 (SM-N900C), вот мой MainActivity.java:

import android.location.Location;
import android.os.Bundle;
import android.support.annotation.NonNull;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.widget.Toast;

import com.google.android.gms.location.LocationCallback;
import com.google.android.gms.location.LocationResult;
import com.mapbox.android.core.location.LocationEngine;
import com.mapbox.android.core.location.LocationEngineListener;
import com.mapbox.android.core.location.LocationEnginePriority;
import com.mapbox.android.core.permissions.PermissionsListener;
import com.mapbox.android.core.permissions.PermissionsManager;
import com.mapbox.mapboxsdk.Mapbox;
import com.mapbox.mapboxsdk.camera.CameraUpdateFactory;
import com.mapbox.mapboxsdk.geometry.LatLng;
import com.mapbox.mapboxsdk.maps.MapView;
import com.mapbox.mapboxsdk.maps.MapboxMap;
import com.mapbox.mapboxsdk.plugins.locationlayer.LocationLayerPlugin;
import com.mapbox.mapboxsdk.plugins.locationlayer.modes.CameraMode;
import com.mapbox.mapboxsdk.plugins.locationlayer.modes.RenderMode;

import java.util.List;

public class MainActivity extends AppCompatActivity implements
    LocationEngineListener,
    PermissionsListener{

private MapView mapView;
private MapboxMap map;
private PermissionsManager permissionsManager;
private LocationEngine locationEngine;
private Location originLocation;


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    Mapbox.getInstance(this, getString(R.string.access_token));
    setContentView(R.layout.activity_main);
    mapView = findViewById(R.id.mapView);
    mapView.onCreate(savedInstanceState);
    mapView.getMapAsync(mapboxMap -> {
        map = mapboxMap;
        enableLocation();
    });

}

private void enableLocation(){

    if(PermissionsManager.areLocationPermissionsGranted(this)){

        initializeLocationEngine();
        initializeLocationLayer();

    } else {
        permissionsManager = new PermissionsManager(this);
        permissionsManager.requestLocationPermissions(this);
    }
}

@SuppressWarnings("MissingPermission")
private void initializeLocationEngine(){
    locationEngine = GoogleLocationEngine.getLocationEngine(this);
    locationEngine.setPriority(LocationEnginePriority.HIGH_ACCURACY);
    locationEngine.activate();

    Location lastLocation = locationEngine.getLastLocation();

    if(lastLocation != null){
        originLocation = lastLocation;
        setCameraPosition(lastLocation);
    } else {
        locationEngine.addLocationEngineListener(this);
    }
}

@SuppressWarnings("MissingPermission")
private void initializeLocationLayer(){
    LocationLayerPlugin locationLayerPlugin = new LocationLayerPlugin(mapView, map, locationEngine);
    locationLayerPlugin.setLocationLayerEnabled(true);
    locationLayerPlugin.setCameraMode(CameraMode.TRACKING);
    locationLayerPlugin.setRenderMode(RenderMode.NORMAL);


}

private void setCameraPosition(Location location){
    map.animateCamera(CameraUpdateFactory.newLatLngZoom(new LatLng(location.getLatitude() , location.getLongitude()) , 13.0));
}

@SuppressWarnings("MissingPermission")
@Override
public void onConnected() {
    Log.d("onConnected" , "is Connected");
    locationEngine.requestLocationUpdates();
}

@Override
public void onLocationChanged(Location location) {
    if(location != null){
        originLocation = location;
        setCameraPosition(location);
    } else
        Toast.makeText(this, "Location is null", Toast.LENGTH_SHORT).show();
}

@Override
public void onExplanationNeeded(List<String> permissionsToExplain) {
    //present a toast or a dialog
    Toast.makeText(this, permissionsToExplain.get(0) , Toast.LENGTH_SHORT).show();
}

@Override
public void onPermissionResult(boolean granted) {
    if(granted){
        enableLocation();
    }
}

@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
    permissionsManager.onRequestPermissionsResult(requestCode , permissions , grantResults);
}

@Override
public void onStart() {
    super.onStart();
    mapView.onStart();
}

@Override
public void onResume() {
    super.onResume();
    mapView.onResume();
}

@Override
public void onPause() {
    super.onPause();
    mapView.onPause();
}

@Override
public void onStop() {
    super.onStop();
    mapView.onStop();
}

@Override
public void onLowMemory() {
    super.onLowMemory();
    mapView.onLowMemory();
}

@Override
protected void onDestroy() {
    super.onDestroy();
    mapView.onDestroy();
}

@Override
protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    mapView.onSaveInstanceState(outState);
    }

}

ОБНОВЛЕНИЕ: Недавно я понял, что метод

locationEngine = new LocationEngineProvider(this).obtainBestLocationEngineAvailable();

не работает!я думал, что этот метод работает для меня, но когда я прокомментировал его и протестировал мое приложение, оно не показывало мое местоположение, когда я использовал свой класс GoogleLocationEngine, он работал, но все еще остается та же ошибка.есть идеи, дорогие друзья?

1 Ответ

0 голосов
/ 05 июня 2018

Проблема была решена! на основе этого абзаца:

Важно включить события жизненного цикла onStart () и onStop () слоя размещения в соответствующие методы действий.Это предотвращает утечки памяти и уменьшает потребление батареи.Плагин поддерживает новые API-интерфейсы LifecycleObserver, добавив плагин в качестве наблюдателя жизненного цикла в вашу деятельность, вам не нужно будет вручную обрабатывать жизненные циклы.

ссылка на источник: mapbox_locationLayer

и это mapboxDemo_LocationLayerPluginActivity.java (GitHub) , я должен использовать эти методы в своих функциях:

    locationPlugin = new LocationLayerPlugin(mapView, mapboxMap, locationEngine);
    locationPlugin.setLocationLayerEnabled(true);
    locationPlugin.setCameraMode(CameraMode.TRACKING);
    locationPlugin.setRenderMode(RenderMode.COMPASS);
    Lifecycle lifecycle = getLifecycle();
    lifecycle.addObserver(locationPlugin);

и в моем onStart ():

@Override
public void onStart() {
    super.onStart();
    mapView.onStart();
    if(locationEngine != null){
        locationEngine.requestLocationUpdates();
        locationEngine.addLocationEngineListener(this);
    }
}

также в моем onStop ():

@Override
public void onStop() {
    super.onStop();
    mapView.onStop();
    if(locationEngine != null){
        locationEngine.removeLocationEngineListener(this);
        locationEngine.removeLocationUpdates();
    }
}

, а затем ошибка фатального сигнала исчезла.

Я должен сказать спасибо команде поддержки mapboxза поддержку и решение этой проблемы.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...