Solicitando permissões do Android
Se o seu aplicativo for compatível com o Android 6.0 ou superior, adicione o código a seguir em seu arquivo de atividade para solicitar aos usuários do aplicativo que concedam permissões do Android em tempo de execução. Para obter mais informações sobre esse requisito, consulte a documentação do desenvolvedor do Android
Figura 1. Solicitação de Permissão Figura 2. Permissão de Acesso ao
Acesso ao Location (GPS) Arquivo
Acesso ao Location (GPS) Arquivo
Adicione os seguintes instruções '
import'
ao início do arquivo:import android.content.pm.PackageManager;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v4.content.ContextCompat;
import android.Manifest;
import android.widget.Toast;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
Adicione estas variáveis estáticas à classe '
BasicMapActivity'
:/**
* permissions request code
*/
private final static int REQUEST_CODE_ASK_PERMISSIONS = 1;
/**
* Permissions that need to be explicitly requested from end user.
*/
private static final String[] REQUIRED_SDK_PERMISSIONS = new String[] {
Manifest.permission.ACCESS_FINE_LOCATION, Manifest.permission.WRITE_EXTERNAL_STORAGE };
Nota:
- A partir do nível 19 da API,
android.permission.WRITE_EXTERNAL_STORAGE
não é mais necessário quando um cache de disco isolado é usado e o caminho do cache de disco isolado está em um diretório de arquivos específico do aplicativo. Você pode recuperar esse caminho chamandogetExternalFilesDir(String)
egetExternalCacheDir()
. android.permission.ACCESS_FINE_LOCATION
não é necessário para inicializar ou usar o SDK. No entanto, é necessário se você usar os seguintes componentes:PositioningManager
NavigationManager
PositionSimulator
- LiveSight
android.permission.CAMERA
é necessário quando os recursos do LiveSight (realidade aumentada) são usados.
Adicione os seguintes métodos à classe '
BasicMapActivity'
:/**
* Checks the dynamically-controlled permissions and requests missing permissions from end user.
*/
protected void checkPermissions() {
final List<String> missingPermissions = new ArrayList<String>();
// check all required dynamic permissions
for (final String permission : REQUIRED_SDK_PERMISSIONS) {
final int result = ContextCompat.checkSelfPermission(this, permission);
if (result != PackageManager.PERMISSION_GRANTED) {
missingPermissions.add(permission);
}
}
if (!missingPermissions.isEmpty()) {
// request all missing permissions
final String[] permissions = missingPermissions
.toArray(new String[missingPermissions.size()]);
ActivityCompat.requestPermissions(this, permissions, REQUEST_CODE_ASK_PERMISSIONS);
} else {
final int[] grantResults = new int[REQUIRED_SDK_PERMISSIONS.length];
Arrays.fill(grantResults, PackageManager.PERMISSION_GRANTED);
onRequestPermissionsResult(REQUEST_CODE_ASK_PERMISSIONS, REQUIRED_SDK_PERMISSIONS,
grantResults);
}
}
@Override
public void onRequestPermissionsResult(int requestCode, @NonNull String permissions[],
@NonNull int[] grantResults) {
switch (requestCode) {
case REQUEST_CODE_ASK_PERMISSIONS:
for (int index = permissions.length - 1; index >= 0; --index) {
if (grantResults[index] != PackageManager.PERMISSION_GRANTED) {
// exit the app if one permission is not granted
Toast.makeText(this, "Required permission '" + permissions[index]
+ "' not granted, exiting", Toast.LENGTH_LONG).show();
finish();
return;
}
}
// all permissions were granted
initialize();
break;
}
}
Por fim, altere a chamada do método
onCreate(Bundle)
de initialize()
para checkPermissions()
:@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
checkPermissions();
}
Nenhum comentário:
Postar um comentário