app上架-您的应用在运行时,未同步告知权限申请的使用目的,向用户索取(相机)等权限,不符合华为应用市场审核标准。

上架提示

您的应用在运行时,未同步告知权限申请的使用目的,向用户索取(相机)等权限,不符合华为应用市场审核标准。

测试步骤:管理-添加-点击二维码,申请相机权限

修改建议:APP在调用终端敏感权限时,应同步说明权限申请的使用目的,包括但不限于申请权限的名称、服务的具体功能、用途;告知方式不限于弹窗、蒙层、浮窗、或者自定义操作系统权限弹框等。请排查应用内所有权限申请行为,确保均符合要求。

当看到这个提示时我也是一脸懵B啊!!!华为你在搞事情啊!

打工人何必为难打工人!!!

先看华为官网给的示例应该怎么解决!

应用申请的权限,都必须有明确、合理的使用场景和功能说明,禁止诱导或误导用户授权,应用使用的权限必须与申请所述的一致。在申请敏感权限时,需同步告知用户申请该权限的目的。未经用户同意,不得更改用户权限授权状态。

下面时示例:

我的解决方式

我是使用的 Snackbar 这种方式来解决的;

Snackbar 是 Android design support library 中的一个组件,它的作用和Toast类似,显示吐司,但Snackbar的特别之处在于Snackbar显示的提示信息可以和用户交互,更好地获取用户反馈信息。同时,它显示的吐司带有动画效果,从屏幕下方慢慢展开显示。 Goggle官方这样介绍:"SnackBars提供了一个轻量级的反馈操作。他们在屏幕的底部显示一条简短的信息,如果是较大的设备就显示在左下角。SnackBar出现在屏幕中所有其他元素的上方,同一时间仅仅只有一条SnackBar"。总之,SnackBar的特点大致下面几条: ①与Toast一样可以进行吐司信息; ②可以与用户交互操作; ③一个时刻只能有唯一一个 Snackbar 显示。

上代码

public class SnackBarUtil {

    /**
     * 自定义 SnackBar 布局
     *
     * @param activity a
     * @param view     a
     * @param msg      a
     * @param tip      as
     */
    public static void show(Activity activity, View view, String msg, String tip) {
        try {


            //获取示例 findViewById(android.R.id.content) //LENGTH_LONG/LENGTH_SHORT: 会自动消失 LENGTH_INDEFINITE: 需要手动点击消失
            Snackbar snackbar = Snackbar.make(view, "", Snackbar.LENGTH_LONG);
            //设置 Snackbar 的深度,避免被其他控件遮挡
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                snackbar.getView().setElevation(0);
            }
            //设置背景透明,避免自带黑色背景影响
            snackbar.getView().setBackgroundColor(Color.TRANSPARENT);
            //设置padding 取消自定义时黑色边框
            snackbar.getView().setPadding(0, 0, 0, 0);
            Snackbar.SnackbarLayout snackbarLayout = (Snackbar.SnackbarLayout) snackbar.getView();
            //设置SnackBar的显示位置
            //ViewGroup.LayoutParams layoutParams = snackbarLayout.getLayoutParams();

            FrameLayout.LayoutParams flp = new FrameLayout.LayoutParams(FrameLayout.LayoutParams.MATCH_PARENT, FrameLayout.LayoutParams.WRAP_CONTENT); // 将原来Snackbar的宽高传入新的LayoutParams
            flp.gravity = Gravity.CENTER | Gravity.TOP; // 设置显示位置
            flp.topMargin = StatusBarCompat.getStatusBarHeight(activity);

            ((View) snackbarLayout).setLayoutParams(flp);
            //获取自定义布局
            //LayoutInflater inflater = (LayoutInflater) getBaseContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            View inflate = LayoutInflater.from(activity).inflate(R.layout.snack_bar_layout, null);
            //获取布局内控件
            TextView textView = inflate.findViewById(R.id.snacl_bar_title);

            //设置文本
            textView.setText(msg);
            TextView textViewSub = inflate.findViewById(R.id.snacl_bar_tip);
            textViewSub.setText(tip);
            //将自定义布局添加到 Snackbar 中
            snackbarLayout.addView(inflate);
            //显示 因为只有华为上架出现这个问题,我做了个判断
            if ("huawei".equals(Build.MANUFACTURER.toLowerCase())) {
                snackbar.show();
            }
        } catch (Exception e) {

        }
    }

}

使用

boolean b = new PermissionsChecker(this).lacksPermissions(Permission.CAMERA);
if (b) {
     SnackBarUtil.show(this, llItem2, "相机权限说明:", "用于扫二维码操作");
}

效果

snack_bar_layout布局文件

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="vertical">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginStart="14dp"
        android:layout_marginEnd="14dp"
        android:background="@drawable/bg_white_cor10"
        android:orientation="vertical"
        android:padding="10dp">

        <TextView
            android:id="@+id/snacl_bar_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="标题"
            android:textColor="@color/color33"
            android:textSize="20sp" />

        <TextView
            android:id="@+id/snacl_bar_tip"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="6dp"
            android:text="提示"
            android:textColor="@color/color33"
            android:textSize="16sp" />
    </LinearLayout>
</FrameLayout>
相关推荐
shaodong112312 分钟前
鸿蒙HarmonyOS系统相机Camera相关API使用
华为·harmonyos·鸿蒙·相机
港股研究社36 分钟前
华为Mate 70系列发布,揭示AI+消费电子产业化新阶段
人工智能·华为
途普智能40 分钟前
途普科技企业知识中台完成华为昇思MindSpore技术认证
数据库·人工智能·科技·华为·知识图谱
ZZZCY20032 小时前
华为ENSP--BGP路由协议实验详解
华为·智能路由器
楚疏笃4 小时前
鸿蒙学习统一上架与多端分发-应用分发(2)
学习·华为·harmonyos
cdut_suye11 小时前
C++11新特性探索:Lambda表达式与函数包装器的实用指南
开发语言·数据库·c++·人工智能·python·机器学习·华为
李洋-蛟龙腾飞公司15 小时前
HarmonyOS Next元服务大学之道动卡互动
华为·harmonyos
好看资源平台15 小时前
鸿蒙心路旅程:从实践到创新——开发者的深度技术分享
华为·harmonyos
帅比九日1 天前
【HarmonyOS NEXT】深入解析HarmonyOS NEXT中的媒体处理功能
华为·harmonyos·harmonyos next