Unity适配Android6.0权限管理

1.需求:

Unity项目中适配Android6.0权限管理

2.实现原理:

在Unity中使用到相关权限时候调用Andorid层,让Android层去请求权限。 ###3.实现:

public int XXPERMISSIONCODE = 0;
	public boolean requstePermission(String permisson){
		if (ContextCompat.checkSelfPermission(this, permisson) != PackageManager.PERMISSION_GRANTED) {
			//无权限,开始请求权限
			ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.READ_CONTACTS},XXPERMISSIONCODE);
			return false;
		}else{
			return true;
		}
	}
	@Override
	public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults){
		switch (requestCode){
			case XXPERMISSIONCODE:
				if (grantResults[0] == PackageManager.PERMISSION_GRANTED){
					//有权限了,回调Unity接口
				}else{
					if (ActivityCompat.shouldShowRequestPermissionRationale(this,permissions[0])) {
						//尝试告诉用户为什么要请求权限,可以再次发起请求或者返回Unity无权限
					}else {
						//无法再次请求权限,可以处理直接退出程序或者告诉Unity无权限
					}
				}
				break;
		}
		super.onRequestPermissionsResult(requestCode, permissions, grantResults);
	}

4.接口解释:

public static int checkSelfPermission(Context context, String permission)

查询是否有对应的权限: 返回值等于PackageManager.PERMISSION_GRANTED为有权限 返回值等于PackageManager.PERMISSION_DENIED 为无权限

public static void requestPermissions(final Activity activity,final String[] permissions, final int requestCode)

异步请求对应的权限,完成后会回调onRequestPermissionsResult。 注意:这个方法不必判断是否为Android6.0+,系统会自己办你出来,如果小于M的,会直接回调,并且为获得权限。

public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults)

系统回调

public static boolean shouldShowRequestPermissionRationale(Activity activity, String permission)

判断是否还能再发起请求,当用户勾选不再提示之后,返回false。可以对True和Fasle情况分别对用户进行说明和操作。

###Android6.0权限管理

对于6.0以下的权限及在安装的时候,根据权限声明产生一个权限列表,用户只有在同意之后才能完成app的安装,造成了我们想要使用某个app,就要默默忍受其一些不必要的权限(比如是个app都要访问通讯录、短信等)。而在6.0以后,我们可以直接安装,当app需要我们授予不恰当的权限的时候,我们可以予以拒绝(比如:单机的象棋对战,请求访问任何权限,我都是不同意的)。当然你也可以在设置界面对每个app的权限进行查看,以及对单个权限进行授权或者解除授权。 新的权限机制更好的保护了用户的隐私,Google将权限分为两类,一类是Normal Permissions,这类权限一般不涉及用户隐私,是不需要用户进行授权的,比如手机震动、访问网络等;另一类是Dangerous Permission,一般是涉及到用户隐私的,需要用户进行授权,比如读取sdcard、访问通讯录等。

转载于:https://my.oschina.net/yaogunfantuan/blog/837975

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值