mirror of
https://github.com/scratchfoundation/scratchjr.git
synced 2024-11-28 10:05:59 -05:00
refactor permission request
This commit is contained in:
parent
b3d800ec3e
commit
4826fc0b1e
1 changed files with 26 additions and 21 deletions
|
@ -40,6 +40,8 @@ import java.io.ByteArrayOutputStream;
|
|||
import java.io.FileNotFoundException;
|
||||
import java.io.IOException;
|
||||
import java.io.InputStream;
|
||||
import java.util.Arrays;
|
||||
import java.util.Vector;
|
||||
|
||||
/**
|
||||
* Main activity for Scratch Jr., consisting of a full-screen landscape WebView.
|
||||
|
@ -103,6 +105,7 @@ public class ScratchJrActivity
|
|||
private final int SCRATCHJR_CAMERA_MIC_PERMISSION = 1;
|
||||
public int cameraPermissionResult = PackageManager.PERMISSION_DENIED;
|
||||
public int micPermissionResult = PackageManager.PERMISSION_DENIED;
|
||||
public int readExtPermissionResult = PackageManager.PERMISSION_DENIED;
|
||||
|
||||
/* Firebase analytics tracking */
|
||||
private FirebaseAnalytics _FirebaseAnalytics;
|
||||
|
@ -172,34 +175,33 @@ public class ScratchJrActivity
|
|||
requestPermissions();
|
||||
}
|
||||
|
||||
private void requestExtStoragePermissions() {
|
||||
int readExtPermissionResult = ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE);
|
||||
if (readExtPermissionResult != PackageManager.PERMISSION_GRANTED) {
|
||||
int requestCode = 2;
|
||||
ActivityCompat.requestPermissions(this,
|
||||
new String[]{Manifest.permission.READ_EXTERNAL_STORAGE}, requestCode);
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
Ask for all permissions when ScratchJr is first launched so that we are not asking a 5-7 year old to give permission
|
||||
*/
|
||||
public void requestPermissions() {
|
||||
requestExtStoragePermissions();
|
||||
cameraPermissionResult = ContextCompat.checkSelfPermission(this, Manifest.permission.CAMERA);
|
||||
micPermissionResult = ContextCompat.checkSelfPermission(this, Manifest.permission.RECORD_AUDIO);
|
||||
readExtPermissionResult = ContextCompat.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE);
|
||||
|
||||
String[] desiredPermissions;
|
||||
if (cameraPermissionResult != PackageManager.PERMISSION_GRANTED
|
||||
&& micPermissionResult != PackageManager.PERMISSION_GRANTED) {
|
||||
desiredPermissions = new String[]{
|
||||
Manifest.permission.CAMERA, Manifest.permission.RECORD_AUDIO
|
||||
};
|
||||
} else if (cameraPermissionResult != PackageManager.PERMISSION_GRANTED) {
|
||||
desiredPermissions = new String[]{Manifest.permission.CAMERA};
|
||||
} else if (micPermissionResult != PackageManager.PERMISSION_GRANTED) {
|
||||
desiredPermissions = new String[]{Manifest.permission.RECORD_AUDIO};
|
||||
} else {
|
||||
if (cameraPermissionResult == PackageManager.PERMISSION_GRANTED
|
||||
&& micPermissionResult == PackageManager.PERMISSION_GRANTED
|
||||
&& readExtPermissionResult == PackageManager.PERMISSION_GRANTED) {
|
||||
return;
|
||||
}
|
||||
|
||||
Vector<String> tmp = new Vector<String>(3);
|
||||
if (cameraPermissionResult != PackageManager.PERMISSION_GRANTED) {
|
||||
tmp.add(Manifest.permission.CAMERA);
|
||||
}
|
||||
if (micPermissionResult != PackageManager.PERMISSION_GRANTED) {
|
||||
tmp.add(Manifest.permission.RECORD_AUDIO);
|
||||
}
|
||||
if (readExtPermissionResult != PackageManager.PERMISSION_GRANTED) {
|
||||
tmp.add(Manifest.permission.READ_EXTERNAL_STORAGE);
|
||||
}
|
||||
Object[] tmpArray = tmp.toArray();
|
||||
String[] desiredPermissions = Arrays.copyOf(tmpArray, tmpArray.length, String[].class);
|
||||
|
||||
ActivityCompat.requestPermissions(this,
|
||||
desiredPermissions,
|
||||
SCRATCHJR_CAMERA_MIC_PERMISSION);
|
||||
|
@ -217,6 +219,9 @@ public class ScratchJrActivity
|
|||
if (permission.equals(Manifest.permission.RECORD_AUDIO)) {
|
||||
micPermissionResult = grantResults[permissionId];
|
||||
}
|
||||
if (permission.equals(Manifest.permission.READ_EXTERNAL_STORAGE)) {
|
||||
readExtPermissionResult = grantResults[permissionId];
|
||||
}
|
||||
permissionId++;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue