navigator.camera.getPicture callback doesn't execute until 2nd call
Asked Answered
S

2

3

I've got a phonegap (cordova) app running cordova 3.1.0 and when I call

navigator.camera.getPicture(success,fail,options)

with options as

var options={ 
        destinationType: navigator.camera.DestinationType.FILE_URI,
        sourceType: navigator.camera.PictureSourceType.SAVEDPHOTOALBUM,
        encodingType: navigator.camera.EncodingType.JPEG,
        mediaType: navigator.camera.MediaType.Picture
}

the success callback isn't called after the photo is selected by the user.

If I then call

navigator.camera.getPicture(success,fail,options)

again, the success callback from the first getPicture is called with the photo selected in the first step.

I've poked around in CameraLauncher.java (around line 395 onwards) and it seems that it calls

this.callbackContext.success(uri.toString());

in

onActivtyResult but this doesn't seem to be passed back until the next getPicture() call.

Anybody else come across this?

Further digging shows the same thing happening when calling getPicture from camera too.

I'm wondering if it's because when the camera activity finishes the webview hasn't resumed so the callback has nowhere to go - but this is wild speculation at best.

24 hours later, it seems that updating to Cordova 3.1.0.jar and dropping the 3.1 jar directly into an existing 3.0 project resolved this issue.

Softboiled answered 6/11, 2013 at 10:7 Comment(5)
OK. I updated Cordova to 3.1.0 and the problem went away. However, since I'm in a delicate timeframe and didn't want to kill my existing cordova projects I literally created a new project and copied Cordova-3.1.0.jar into my lib directory and removed 3.0.0 from same... Getting away with it so far...Softboiled
What full version of Cordova do you use? I use 3.1.0-0.15.0 and bug is not fixed in this version.Vying
does anybody found a solution? I'm facing the same problem even with cordova 4.0.0Clardy
are you solved this issue...Irradiance
With Cordova 5.1.0 experiencing the same issue with Android Jelly Bean 4.4.2 & 4.4.4. You mentioned callback triggered during second invoke, in my case this work around did not work as well. Here is my post #37809233Fellatio
S
1

So, what was happening was that on Android only the callback for getPicture was being triggered by requesting getPicture a second time.

This was resolved by updating my cordova install, creating an empty android project and then copying the /platforms/android/libs/cordova-3.1.0.jar from it, into /platforms/android/libs in my existing project and removing cordova-3.0.0.jar

Hope this saves somebody an hour or 3...

Softboiled answered 7/11, 2013 at 8:37 Comment(4)
having the same issue with Cordova 3.2Grape
3.4 same, and does not make callback at all on android.Sangfroid
@VladimirBezugliy nope, works great on windows phone and not in android. I opened specific thread here for 3.4 #23798576Sangfroid
I am experiencing same issue #37809233Fellatio
F
1

I tried the solution documented here for a similar issue with the barcode scanner, and it worked. https://github.com/zeroasterisk/MeteorRider/issues/16 (as referred to from here: https://github.com/wildabeast/BarcodeScanner/issues/107)

To summarize, it appears that the Android event pipeline gets "clogged", and you can run this code before your normal cordova plugin call to clear it.

if (device.platform === 'Android') {
  setInterval(function () {
     cordova.exec(null, null, '', '', [])
  }, 200);
}
Fridlund answered 2/10, 2014 at 18:7 Comment(1)
This seems to have fixed the issue for many but did not work for me in Android Jelly Bean 4.4.2 & 4.4.4. Here is my post #37809233Fellatio

© 2022 - 2024 — McMap. All rights reserved.