Я следовал учебному пособию на Youtube, и он показал шаги по созданию приложений Google Map. поэтому я следовал этому руководству и получил логическую ошибку в этом коде.
package com.example.mymap;
import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity;
import androidx.core.app.ActivityCompat;
import androidx.core.content.ContextCompat;
import android.Manifest;
import android.content.pm.PackageManager;
import android.os.Bundle;
import android.util.Log;
import android.widget.Toast;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.OnMapReadyCallback;
import com.google.android.gms.maps.SupportMapFragment;
import java.lang.ref.SoftReference;
public class MapActivity extends AppCompatActivity implements OnMapReadyCallback {
private static final String TAG = "MapActivity";
private static final String FINE_LOCATION = Manifest.permission.ACCESS_FINE_LOCATION;
private static final String COARSE_LOCATION = Manifest.permission.ACCESS_COARSE_LOCATION;
private static final int LOCATION_PERMISSION_REQUEST_CODE = 1234;
private boolean mLocationPermissionsGranted = false;
private GoogleMap mMap;
@Override
public void onMapReady(GoogleMap googleMap){
mMap = googleMap;
Toast.makeText(MapActivity.this, "Map is Ready", Toast.LENGTH_SHORT).show();
Log.d(TAG,"onMapReady : Map is Ready");
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_map);
getLocationPermission();
}
private void initMap(){
Log.d(TAG,"initMap: initializing map");
SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map);
mapFragment.getMapAsync(MapActivity.this);
}
private void getLocationPermission(){
Log.d(TAG,"getLocationPermissoin : getting Location Permssions");
String[] permissions =
{Manifest.permission.ACCESS_FINE_LOCATION,Manifest.permission.ACCESS_COARSE_LOCATION};
if (ContextCompat.checkSelfPermission(this.getApplicationContext(),
FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) {
if (ContextCompat.checkSelfPermission(this.getApplicationContext(),
COARSE_LOCATION )== PackageManager.PERMISSION_GRANTED) {
mLocationPermissionsGranted = true;
}
else{
ActivityCompat.requestPermissions(this,
permissions,
LOCATION_PERMISSION_REQUEST_CODE);
}
}
else{
ActivityCompat.requestPermissions(this,
permissions,
LOCATION_PERMISSION_REQUEST_CODE);}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) {
Log.d(TAG,"onRequestPermssionsResults: called...");
mLocationPermissionsGranted = false;
switch (requestCode){
case LOCATION_PERMISSION_REQUEST_CODE : {
if (grantResults.length>0){
for (int i = 0; i< grantResults.length;i++ ){
if (grantResults[i] != PackageManager.PERMISSION_GRANTED){
mLocationPermissionsGranted = false;
Log.d(TAG,"onRequestPermissionsResults: permissions failed");
return;
}
}
mLocationPermissionsGranted =true;
Log.d(TAG,"onRequestPermissionsResults: permissions Success");
//initialize map
initMap();
}
}
}
}
}
Это моя операция с картой, и проблема в том, что она не показывает мне тост или журнал для метода onMapReady. это было показано мне один раз, когда попросили разрешения. но после того, как я закрою и снова открою карту, тост не отображается методом onMapReady. Я думаю, что если onMapReady не выполняется, то карта мне не будет показана. но карта показывает мне, но не тост. Я надеюсь, вы понимаете, что при каждом запуске отображается карта, но тост отображается только один раз, когда меня спрашивают о разрешениях.
помогите мне с этой проблемой. я не могу найти точную проблему.