安卓检查APP是否被用户拒绝调用摄像头和麦克风权限

这里介绍一个自己写的权限获取检测工具类,使用后台调用的方法,获取用户是否允许了APP调用摄像头和麦克风权限(唯一缺陷就是只能在确认摄像头和麦克风没有被其他程序使用,否则会抛出异常,返回false)

那么可以看一下代码:

import android.hardware.Camera;
import android.media.AudioFormat;
import android.media.AudioRecord;
import android.media.MediaRecorder;
 
/**
 * @author xiaoming 权限验证工具类
 */
public class PermissionTest {
 
    /**
     * 作用:用户是否同意打开相机权限
     * 
     * @return true 同意 false 拒绝
     */
    public boolean isCameraPermission() {
 
        try {
            Camera.open().release();
            return true;
        } catch (Exception e) {
            return false;
        }
 
    }
 
    /**
     * 作用:用户是否同意录音权限
     * 
     * @return true 同意 false 拒绝
     */
    public boolean isVoicePermission() {
 
        try {
            AudioRecord record = new AudioRecord(MediaRecorder.AudioSource.MIC, 22050, AudioFormat.CHANNEL_CONFIGURATION_MONO,
                    AudioFormat.ENCODING_PCM_16BIT, AudioRecord.getMinBufferSize(22050, AudioFormat.CHANNEL_CONFIGURATION_MONO,
                            AudioFormat.ENCODING_PCM_16BIT));
            record.startRecording();
            int recordingState = record.getRecordingState();
            if(recordingState == AudioRecord.RECORDSTATE_STOPPED){
                return false;
            }
            record.release();
            return true;
        } catch (Exception e) {
            return false;
        }
 
    }
 
}

写法中有什么不足,大牛们可以给一些指导性建议,谢谢。


UniApp是一个基于Vue.js的跨平台框架,它允许开发者编写一套代码,然后在多个平台上运行,包括Web、iOS、Android等。要实现在uniApp调用外部监控摄像头的功能,你可以按照以下步骤操作: 1. **引入权限请求**:首先需要在项目中处理获取用户设备权限的问题,因为访问摄像头通常涉及到用户的隐私,所以需要先向用户请求访问权限。 ```javascript uni.requestPermissions({ permissions: ['scope.camera'], success: function(res) { if (res.status === 'success') { // 接下来可以调用摄像头 } else { console.log('用户拒绝了相机权限'); } }, fail: function(err) { console.error('权限请求失败', err); } }); ``` 2. **使用uni-app提供的API**:uni-app提供了一套统一的API `uni.getUserMedia` 来访问设备的摄像头麦克风。这需要在生命周期钩子中初始化,并监听`camera`对象的变化。 ```javascript let camera; uni.getUserMedia({ mediaSource: 'camera', resolution: { width: 640, height: 480 }, }, successCallback, errorCallback); // 成功回调 function successCallback(stream) { camera = stream; // 存储摄像头流 } // 错误回调 function errorCallback(error) { console.error('无法打开摄像头', error); } ``` 3. **实时视频预览**:创建一个视频元素并设置其srcObject属性,展示摄像头视频流。 ```javascript <video id="camera-preview" style="width: 100%;"></video> // ... const videoElement = document.getElementById('camera-preview'); videoElement.srcObject = camera; videoElement.play(); ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值