2017-02-13 2 views
0

В приведенном ниже коде, когда onActivityResult вызывается немедленно с RESULT_CANCELED.Кордова onActivityResult вызывается сразу после startActivityForResult с RESULT_CANCELED

Как было предложено в других ответах, я добавил setActivityResultCallback непосредственно перед startActivityForResult() и PluginResult # setKeepCallback (true) ;. Но ничего не помогает. Любое предложение?

.... 
    public boolean execute(String action, CordovaArgs args, CallbackContext callbackContext) throws JSONException { 

    this.callbackContext = callbackContext; 

    if (action.equals(ACTION_OPEN)) 
    { 
     if(PermissionHelper.hasPermission(this, READ)) 
     { 
      chooseFile(); 
     } 
    } 
    else 
    { 
     return false; 
    } 

    return true; 
} 

    public void chooseFile() { 

    final CordovaPlugin plugin = (CordovaPlugin) this; 
    Runnable worker = new Runnable() { 
     public void run() { 
      Intent filePickerIntent = new Intent(Intent.ACTION_PICK); 
      filePickerIntent.setType("image/*"); 
      plugin.cordova.setActivityResultCallback(plugin); 
      plugin.cordova.startActivityForResult(plugin, Intent.createChooser(filePickerIntent,"Choose file"), PICK_FILE_REQUEST); 
     } 
    }; 
    this.cordova.getThreadPool().execute(worker); 
    PluginResult r = new PluginResult(PluginResult.Status.NO_RESULT); 
    r.setKeepCallback(true); 
    callbackContext.sendPluginResult(r); 

} 

public void onActivityResult(int requestCode, int resultCode, Intent data) { 

    Log.d(TAG,"Enter onActivityResult"); 

    if (requestCode == PICK_FILE_REQUEST) { 

     Log.d(TAG,"requestCode == PICK_FILE_REQUEST"); 

     if (resultCode == Activity.RESULT_OK) { 

      Log.d(TAG,"Result Ok"); 

      Uri uri = data.getData(); 
      Log.d(TAG, uri.toString()); 

     } else if (resultCode == Activity.RESULT_CANCELED) { 

      Log.d(TAG,"Result canceled"); 

      callbackContext.error("OPERATION_CANCELLED"); 
      return; 
     } 

     this.callbackContext.sendPluginResult(new PluginResult(PluginResult.Status.ERROR, "UNKNOWN_ERROR")); 
    } 
} 
+0

Вы нашли решение @dpaksoni? – user3050534

ответ

0

Я сталкивался с таким же вопросом в одном из моих Cordova применения. Я не мог найти источник ошибки, но я решил его, создав новый проект и снова установив все плагины. Это сработало.

+0

Я пробовал то же самое, и это сработало. Но все еще путают, что было проблемой в предыдущем проекте. – dpaksoni

0

У меня возникла аналогичная проблема с моим приложением и после установки cordova-plugin-background-mode. Для меня проблема существует на Android 4.4.2, а не на android 6.0. Чтобы решить эту проблему, я поставил AndroidLaunchMode параметра в config.xml

<preference name="AndroidLaunchMode" value="singleTop" /> 
Смежные вопросы