Я не знаю, почему мое приложение не перестает падать - PullRequest
0 голосов
/ 30 октября 2019

Я пишу приложение, которому нужно местоположение. Logcat говорит мне, что мой код ясен, без ошибок. Но когда я запускаю приложение (эмулированное или на моем телефоне), оно падает.

Вот мой код:

package com.example.a291019;


import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.ContextCompat;
import android.Manifest;
import android.content.Context;
import android.content.pm.PackageManager;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;


public class MainActivity extends AppCompatActivity {

    TextView txtLocation = findViewById(R.id.txtLocation);

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        LocationManager locationManager = (LocationManager)getSystemService(Context.LOCATION_SERVICE);
        if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_DENIED || ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_DENIED) {

            assert locationManager != null;
            locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 500, 10, new LocationListener() {
                @Override
                public void onLocationChanged(Location location) {
                    Log.d("GPS", "Latitude" + location.getLatitude() + " et longitude " + location.getLongitude());
                    txtLocation.setText(Log.d("GPS", String.format("Latitude%s et longitude %s", location.getLatitude(), location.getLongitude())));
                }

                @Override
                public void onStatusChanged(String provider, int status, Bundle extras) {

                }

                @Override
                public void onProviderEnabled(String provider) {

                }

                @Override
                public void onProviderDisabled(String provider) {

                }

            });
        }


    }
}

Ответы [ 2 ]

4 голосов
/ 30 октября 2019

с моей точки зрения, инициализация этой строки в этой позиции неверна:

public class MainActivity extends AppCompatActivity {
    TextView txtLocation = findViewById(R.id.txtLocation);

она должна быть расположена после этой строки:

setContentView(R.layout.activity_main);

это позициягде вы определяете ответственный макет для этого действия.

Таким образом, вызов findViewById для члена класса не может работать.

0 голосов
/ 30 октября 2019

1) Переместите эту строку в onCreate и сделайте ее final:

final TextView txtLocation = findViewById(R.id.txtLocation);

2) Log.d() возвращает целое число и не должно быть параметром метода setText, сделайте это вместоиз этого:

txtLocation.setText(String.format("Latitude%s et longitude %s", 
    location.getLatitude(), location.getLongitude()));

Фиксированный код:

package com.example.a291019;

import android.Manifest;
import android.content.Context;
import android.content.pm.PackageManager;
import android.location.Location;
import android.location.LocationListener;
import android.location.LocationManager;
import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;

import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.ContextCompat;


public class MainActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    final TextView txtLocation = findViewById(R.id.txtLocation);

    LocationManager locationManager = (LocationManager) 
 getSystemService(Context.LOCATION_SERVICE);
    if (ContextCompat.checkSelfPermission(this, 
 Manifest.permission.ACCESS_FINE_LOCATION) != PackageManager.PERMISSION_DENIED || 
 ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_COARSE_LOCATION) 
 != PackageManager.PERMISSION_DENIED) {

        assert locationManager != null;
        locationManager.requestLocationUpdates(LocationManager.GPS_PROVIDER, 500, 10, 
          new LocationListener() {
            @Override
            public void onLocationChanged(Location location) {
                Log.d("GPS", "Latitude" + location.getLatitude() + " et longitude " + 
                    location.getLongitude());
                txtLocation.setText(String.format("Latitude%s et longitude %s", 
                    location.getLatitude(), location.getLongitude()));
            }

            @Override
            public void onStatusChanged(String provider, int status, Bundle extras) {

            }

            @Override
            public void onProviderEnabled(String provider) {

            }

            @Override
            public void onProviderDisabled(String provider) {

            }

        });
    }

  }
}
...