Android核心技术-day01-03-短信发送器(授权代码封装)

本文介绍了一个针对 Android M (API 23) 的权限请求封装类,用于简化应用程序在运行时请求权限的过程。通过定义 BaseActivity 和 PermissionCallback 接口,实现了权限请求的统一管理和回调,包括权限检查、请求、再次请求时的用户提示以及权限请求结果的处理。

BaseActivity.java

package com.gaozewen.smssender;

import android.content.DialogInterface;
import android.content.pm.PackageManager;
import android.os.Build;
import android.support.annotation.NonNull;
import android.support.v4.app.ActivityCompat;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.widget.Toast;


public class BaseActivity extends AppCompatActivity {
    //**************** Android M Permission (Android 6.0权限控制代码封装)
    private int permissionRequestCode = 88;
    private PermissionCallback permissionRunnable;

    public interface PermissionCallback {
        void hasPermission();

        void noPermission();
    }

    /**
     * Android M运行时权限请求封装
     *
     * @param permissionDes 权限描述
     * @param runnable      请求权限回调
     * @param permissions   请求的权限(数组类型),直接从Manifest中读取相应的值,比如Manifest.permission.WRITE_CONTACTS
     */
    public void performCodeWithPermission(@NonNull String permissionDes, PermissionCallback runnable, @NonNull String... permissions) {
        if (permissions.length == 0)
            return;
        // this.permissionrequestCode = requestCode;
        this.permissionRunnable = runnable;
        // Build.VERSION.SDK_INT 来自 build.gradle.
        if ((Build.VERSION.SDK_INT < Build.VERSION_CODES.M) || checkPermissionGranted(permissions)) {
            if (permissionRunnable != null) {
                permissionRunnable.hasPermission();
                permissionRunnable = null;
            }
        } else {
            //permission has not been granted.
            requestPermission(permissionDes, permissionRequestCode, permissions);
        }

    }

    private boolean checkPermissionGranted(String[] permissions) {
        boolean isGranted = true;
        for (String p : permissions) {
            if (ActivityCompat.checkSelfPermission(this, p) != PackageManager.PERMISSION_GRANTED) {
                isGranted = false;
                break;
            }
        }
        return isGranted;
    }

    private void requestPermission(String permissionDes, final int requestCode, final String[] permissions) {
        if (shouldShowRequestPermissionRationale(permissions)) {
            /*1. 第一次请求权限时,用户拒绝了,下一次:shouldShowRequestPermissionRationale()  返回 true,应该显示一些为什么需要这个权限的说明
            2.第二次请求权限时,用户拒绝了,并选择了“不在提醒”的选项时:shouldShowRequestPermissionRationale()  返回 false
            3. 设备的策略禁止当前应用获取这个权限的授权:shouldShowRequestPermissionRationale()  返回 false*/
            // 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.
            // For example, if the request has been denied previously.

            //            Snackbar.make(getWindow().getDecorView(), requestName,
            //                    Snackbar.LENGTH_INDEFINITE)
            //                    .setAction(R.string.common_ok, new View.OnClickListener() {
            //                        @Override
            //                        public void onClick(View view) {
            //                            ActivityCompat.requestPermissions(BaseAppCompatActivity.this,
            //                                    permissions,
            //                                    requestCode);
            //                        }
            //                    })
            //                    .show();
            //如果用户之前拒绝过此权限,再提示一次准备授权相关权限
            new AlertDialog.Builder(this)
                    .setTitle("提示")
                    .setMessage(permissionDes)
                    .setPositiveButton("授权", new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            ActivityCompat.requestPermissions(BaseActivity.this, permissions, requestCode);
                        }
                    }).show();

        } else {
            // Contact permissions have not been granted yet. Request them directly.
            ActivityCompat.requestPermissions(BaseActivity.this, permissions, requestCode);
        }
    }

    private boolean shouldShowRequestPermissionRationale(String[] permissions) {
        boolean isShow = false;
        for (String p : permissions) {
            if (ActivityCompat.shouldShowRequestPermissionRationale(this, p)) {
                isShow = true;
                break;
            }
        }
        return isShow;
    }

    /**
     * Callback received when a permissions request has been completed.
     */
    @Override
    public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions,
                                           @NonNull int[] grantResults) {
        if (requestCode == permissionRequestCode) {
            if (verifyPermissions(grantResults)) {
                if (permissionRunnable != null) {
                    permissionRunnable.hasPermission();
                    permissionRunnable = null;
                }
            } else {
                Toast.makeText(this, "暂无权限执行相关操作!", Toast.LENGTH_SHORT).show();
                if (permissionRunnable != null) {
                    permissionRunnable.noPermission();
                    permissionRunnable = null;
                }
            }
        } else {
            super.onRequestPermissionsResult(requestCode, permissions, grantResults);
        }

    }

    public boolean verifyPermissions(int[] grantResults) {
        // At least one result must be checked.
        if (grantResults.length < 1) {
            return false;
        }

        // Verify that each required permission has been granted, otherwise return false.
        for (int result : grantResults) {
            if (result != PackageManager.PERMISSION_GRANTED) {
                return false;
            }
        }
        return true;
    }
    //********************** END Android M Permission ****************************************
}

AndroidManifest.xml

<uses-permission android:name="android.permission.SEND_SMS" />

MainActivity.java

package com.gaozewen.smssender;

import android.Manifest;
import android.os.Bundle;
import android.telephony.SmsManager;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends BaseActivity {

    private EditText mEt_phone;
    private EditText mEt_msg;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 1. 获取到界面上的控件
        mEt_phone = findViewById(R.id.et_phone);
        // 2. 获取到界面上的控件
        mEt_msg = findViewById(R.id.et_msg);
        // 3. 获取
        Button bt_sendMsg = findViewById(R.id.bt_sendMsg);
        // 4. 设置点击监听事件
        bt_sendMsg.setOnClickListener(new MySendMessageListener());

    }

    private class MySendMessageListener implements View.OnClickListener {
        @Override
        public void onClick(View view) {
            final String phone = mEt_phone.getText().toString().trim();
            final String msg = mEt_msg.getText().toString().trim();
            if("".equals(phone) || "".equals(msg)){
                Toast.makeText(MainActivity.this,"号码和内容不能为空",Toast.LENGTH_SHORT).show();
                return;
            }
            System.out.println(phone + ":" + msg);

            performCodeWithPermission("发送短信权限", new PermissionCallback() {
                @Override
                public void hasPermission() {
                    SmsManager smsManager = SmsManager.getDefault();
                    // 服务商,发送时 要处理的事件, 发送成功后 要处理的事件
                    smsManager.sendTextMessage(phone,null,msg,null,null);
                    // 5. 设置权限 <uses-permission android:name="android.permission.SEND_SMS" />
                }

                @Override
                public void noPermission() {

                }
            }, Manifest.permission.SEND_SMS);

        }
    }
}

MainActivityOld.java (6.0前)

package com.gaozewen.smssender;

import android.os.Bundle;
import android.telephony.SmsManager;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivityOld extends BaseActivity {

    private EditText mEt_phone;
    private EditText mEt_msg;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // 1. 获取到界面上的控件
        mEt_phone = findViewById(R.id.et_phone);
        // 2. 获取到界面上的控件
        mEt_msg = findViewById(R.id.et_msg);
        // 3. 获取
        Button bt_sendMsg = findViewById(R.id.bt_sendMsg);
        // 4. 设置点击监听事件
        bt_sendMsg.setOnClickListener(new MySendMessageListener());

    }

    private class MySendMessageListener implements View.OnClickListener {
        @Override
        public void onClick(View view) {
            String phone = mEt_phone.getText().toString().trim();
            String msg = mEt_msg.getText().toString().trim();
            if("".equals(phone) || "".equals(msg)){
                Toast.makeText(MainActivityOld.this,"号码和内容不能为空",Toast.LENGTH_SHORT).show();
                return;
            }
            System.out.println(phone + ":" + msg);
            SmsManager smsManager = SmsManager.getDefault();
            // 服务商,发送时 要处理的事件, 发送成功后 要处理的事件
            smsManager.sendTextMessage(phone,null,msg,null,null);
            // 5. 设置权限 <uses-permission android:name="android.permission.SEND_SMS" />
        }
    }
}

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值