为了账号安全,请及时绑定邮箱和手机立即绑定

【Android】19.0 权限处理(一)——运行时权限处理:拨打电话

标签:
Android

https://img1.sycdn.imooc.com//5d2c0ff00001062d07220439.jpg

2019-02-19_211110.png


(不好意思,浏览器已中文翻译,虽然这翻译是磕碜了点)


3.0 话不多说,通过一个简单的小例子,体验一把到底什么是Android运行时权限

新建项目,RuntimePermissionTest,目录结构如下:


https://img1.sycdn.imooc.com//5d2c10360001edf503630656.jpg

2019-02-19_203507.png

4.0 在activity_main.xml中放一个button按钮控件。
<?xml version="1.0" encoding="utf-8"?><android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/make_call"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="拨打电话"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.05" /></android.support.constraint.ConstraintLayout>
5.0 接着在AndroidManifest.xml中增加一行<uses-permission android:name="android.permission.CALL_PHONE"/>:
<?xml version="1.0" encoding="utf-8"?><manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.runtimepermissiontest">


    <uses-permission android:name="android.permission.CALL_PHONE"/>
    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application></manifest>
6.0 MainActivity.java,说明都在代码里,总之步骤分为三步走。
package com.example.runtimepermissiontest;import android.Manifest;import android.content.Intent;import android.content.pm.PackageManager;import android.net.Uri;import android.support.v4.app.ActivityCompat;import android.support.v4.content.ContextCompat;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.view.View;import android.widget.Button;import android.widget.Toast;public class MainActivity extends AppCompatActivity {    @Override
    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button makeCall = (Button) findViewById(R.id.make_call);
        makeCall.setOnClickListener(new View.OnClickListener() {            @Override
            public void onClick(View v) {                //第一步,判断用户是否给应用授权了
                //借助ContextCompat.checkSelfPermission()方法
                //该方法接收两个参数一个是上下文,没什么好说的。
                //第二个是具体的权限名
                //然后把方法的返回值和PackageManager.PERMISSION_GRANTED作比较,相等说明用户已经授权
                if (ContextCompat.checkSelfPermission(MainActivity.this,
                        Manifest.permission.CALL_PHONE) != PackageManager.PERMISSION_GRANTED) {                    //第二步,如果不等于,则需要调用 ActivityCompat.requestPermissions()方法来向用户申请权限
                    //该方法接收三个参数,第一个要求是Activity的实例
                    //第二个是一个String数组,把需要申请的权限名放入数组即可
                    //第三个是请求码,是唯一值即可,这里用的“1”
                    ActivityCompat.requestPermissions(MainActivity.this,                            new String[]{Manifest.permission.CALL_PHONE}, 1);
                } else {
                    call();
                }
            }
        });
    }    private void call() {        try {
            Intent intent = new Intent(Intent.ACTION_CALL);
            intent.setData(Uri.parse("tel:10010"));
            startActivity(intent);
        } catch (SecurityException e) {
            e.printStackTrace();
        }
    }    //第三步,调用完requestPermissions()方法后,系统会弹出一个权限申请的对话框
    // 无论结果如何,最终都会回调onRequestPermissionsResult()方法
    //授权的结果,会封装在grantResults中。
    // 判断一下,如果同意了授权就打电话,没有就凉凉了……

    @Override
    public void onRequestPermissionsResult(int requestCode, String[] permissions,                                           int[] grantResults) {        switch (requestCode) {            case 1:                if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
                    call();
                } else {
                    Toast.makeText(this, "抱歉,没有该权限!", Toast.LENGTH_SHORT).show();
                }
        }

    }
}
7.0 跑一下,最后的效果如下:

点击“拨打电话”,提示如下:


https://img1.sycdn.imooc.com//5d2c106e0001851b03870802.jpg

2019-02-19_202643.png


选择,拒绝:


https://img1.sycdn.imooc.com//5d2c107f0001ecab03870802.jpg

2019-02-19_202705.png


选择允许:

https://img1.sycdn.imooc.com//5d2c108f0001a5b903870802.jpg

2019-02-19_202716.png



作者:我睡醒刚刚
链接:https://www.jianshu.com/p/84c28dfb9362


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消