blob: d20e0bc7c377bdccb24c97656aac96b18426941f [file] [log] [blame]
/*
* Copyright 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.example.android.basicpermissions
import android.Manifest
import android.content.Intent
import android.content.pm.PackageManager
import android.os.Bundle
import android.support.design.widget.Snackbar
import android.support.v4.app.ActivityCompat
import android.support.v7.app.AppCompatActivity
import android.view.View
import android.widget.Button
import com.example.android.basicpermissions.camera.CameraPreviewActivity
import com.example.android.basicpermissions.util.checkSelfPermissionCompat
import com.example.android.basicpermissions.util.requestPermissionsCompat
import com.example.android.basicpermissions.util.shouldShowRequestPermissionRationaleCompat
import com.example.android.basicpermissions.util.showSnackbar
const val PERMISSION_REQUEST_CAMERA = 0
/**
* Launcher Activity that demonstrates the use of runtime permissions for Android M.
* This Activity requests permissions to access the camera
* ([android.Manifest.permission.CAMERA])
* when the 'Show Camera Preview' button is clicked to start [CameraPreviewActivity] once
* the permission has been granted.
*
* <p>First, the status of the Camera permission is checked using [ActivityCompat.checkSelfPermission]
* If it has not been granted ([PackageManager.PERMISSION_GRANTED]), it is requested by
* calling [ActivityCompat.requestPermissions]. The result of the request is
* returned to the
* [android.support.v4.app.ActivityCompat.OnRequestPermissionsResultCallback], which starts
* if the permission has been granted.
*
* <p>Note that there is no need to check the API level, the support library
* already takes care of this. Similar helper methods for permissions are also available in
* ([ActivityCompat],
* [android.support.v4.content.ContextCompat] and [android.support.v4.app.Fragment]).
*/
class MainActivity : AppCompatActivity(), ActivityCompat.OnRequestPermissionsResultCallback {
private lateinit var layout: View
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
layout = findViewById(R.id.main_layout)
// Register a listener for the 'Show Camera Preview' button.
findViewById<Button>(R.id.button_open_camera).setOnClickListener { showCameraPreview() }
}
override fun onRequestPermissionsResult(
requestCode: Int,
permissions: Array<String>,
grantResults: IntArray
) {
if (requestCode == PERMISSION_REQUEST_CAMERA) {
// Request for camera permission.
if (grantResults.size == 1 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
// Permission has been granted. Start camera preview Activity.
layout.showSnackbar(R.string.camera_permission_granted, Snackbar.LENGTH_SHORT)
startCamera()
} else {
// Permission request was denied.
layout.showSnackbar(R.string.camera_permission_denied, Snackbar.LENGTH_SHORT)
}
}
}
private fun showCameraPreview() {
// Check if the Camera permission has been granted
if (checkSelfPermissionCompat(Manifest.permission.CAMERA) ==
PackageManager.PERMISSION_GRANTED) {
// Permission is already available, start camera preview
layout.showSnackbar(R.string.camera_permission_available, Snackbar.LENGTH_SHORT)
startCamera()
} else {
// Permission is missing and must be requested.
requestCameraPermission()
}
}
/**
* Requests the [android.Manifest.permission.CAMERA] permission.
* If an additional rationale should be displayed, the user has to launch the request from
* a SnackBar that includes additional information.
*/
private fun requestCameraPermission() {
// Permission has not been granted and must be requested.
if (shouldShowRequestPermissionRationaleCompat(Manifest.permission.CAMERA)) {
// Provide an additional rationale to the user if the permission was not granted
// and the user would benefit from additional context for the use of the permission.
// Display a SnackBar with a button to request the missing permission.
layout.showSnackbar(R.string.camera_access_required,
Snackbar.LENGTH_INDEFINITE, R.string.ok) {
requestPermissionsCompat(arrayOf(Manifest.permission.CAMERA),
PERMISSION_REQUEST_CAMERA)
}
} else {
layout.showSnackbar(R.string.camera_permission_not_available, Snackbar.LENGTH_SHORT)
// Request the permission. The result will be received in onRequestPermissionResult().
requestPermissionsCompat(arrayOf(Manifest.permission.CAMERA), PERMISSION_REQUEST_CAMERA)
}
}
private fun startCamera() {
val intent = Intent(this, CameraPreviewActivity::class.java)
startActivity(intent)
}
}