添加widget失败

预备知识:如果widget的配置文件里配置下述内容时,当用户添加widget时会打开对应的Activity进行配置

添加widget失败_第1张图片

 

正题:上周项目上遇到了一个bug,bug现象是:在桌面添加widget,流程是启动app的MainActivity,这个app是一个需要授权的app,当授权流程走完了之后,发现widget并没有添加成功,看log也没有报错信息,如果添加widget的时候不走授权流程,是没有问题。

从现象看,肯定是授权的流程有问题啦,看了代码逻辑和activity的启动关系,也没有发现任何问题。然后打印widget的流程开始分析,发现widget的provider居然收到了一个“android.appwidget.action.APPWIDGET_DELETE”的广播,这个广播我只知道在widget被删除的时候才会收到,可是我又没有做删除操作,这是为什么呢。。。除了用户主动删除,那就只能是系统删除了,那么系统为什么会发这个广播呢?开始看launcher的代码,在里面搜appwidget相关的代码,打log,调试,再结合之前看得出问题的app的各个activity的生命周期,终于知道了!!

MainActivity中启动PermissionActivity去检查权限,然后在PermissionActivity是这样写的

 if (!hasPermissions(activity, requiredPermissions)) { //activity:MainActivity
            final Intent intent = new Intent(activity,  newActivityClass);
            intent.putExtra(PREVIOUS_ACTIVITY_INTENT, activity.getIntent());
            activity.startActivity(intent);
            activity.finish();         //有问题代码
        }

如果在widget还没有add完成,对应的activity关闭,通俗得理解就是launcher认为用户不想添加widget了,所以launcher就执行了删除操作。

把上述有问题的代码删除了之后,发现还是添加不上widget,继续比较正常和非正常情况下widget的广播接收,发现有一个广播在异常情况的时候没有接收到android.appwidget.action.APPWIDGET_UPDATE_OPTIONS

这个广播从名字看似乎跟显示就有关系的,然后继续捋各个activity的生命周期,又发现了!还是在PermissionActivity里


    @Override
    public void onRequestPermissionsResult(int requestCode, String permissions[],
            int[] grantResults) {
        if (permissions != null && permissions.length > 0
                && isAllGranted(permissions, grantResults)) {
            mPreviousActivityIntent.setFlags(Intent.FLAG_ACTIVITY_NO_ANIMATION);
            
            startActivity(mPreviousActivityIntent); //有问题代码,start的是MainActivity
            finish();
            overridePendingTransition(0, 0);
        } else {
            Toast.makeText(this, R.string.missing_required_permission, Toast.LENGTH_SHORT).show();
            finish();
        }
    }

把问题处代码注释掉之后,一切OK,该收到的广播也都收到了

PS:其实我并不知道我的“前任“为什么这么写代码:check权限的时候,如果没有权限把MainActivity关闭,获取了权限之后再重新开启。虽然intent的参数全程都带着了,但是破坏了widget的启动流程

 

你可能感兴趣的:(android,widget)