diff --git a/CHANGELOG.md b/CHANGELOG.md index 23fc88e..9578b5c 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,7 @@ +## [2.0.32](https://github.com/spoonconsulting/cordova-plugin-simple-camera-preview/compare/2.0.31...2.0.32) (2024-11-28) +* **Android:** Use videoDuration parameter to configure duration of a video +* **iOS:** Use videoDuration parameter to configure duration of a video + ## [2.0.31](https://github.com/spoonconsulting/cordova-plugin-simple-camera-preview/compare/2.0.30...2.0.31) (2024-11-04) * **iOS:** Automatic stop video after 30s diff --git a/package-lock.json b/package-lock.json index db58461..d915991 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,12 +1,12 @@ { "name": "@spoonconsulting/cordova-plugin-simple-camera-preview", - "version": "2.0.31", + "version": "2.0.32", "lockfileVersion": 2, "requires": true, "packages": { "": { "name": "@spoonconsulting/cordova-plugin-simple-camera-preview", - "version": "2.0.31", + "version": "2.0.32", "license": "Apache 2.0", "devDependencies": {} } diff --git a/package.json b/package.json index f4511fa..bf69460 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@spoonconsulting/cordova-plugin-simple-camera-preview", - "version": "2.0.31", + "version": "2.0.32", "description": "Cordova plugin that allows camera interaction from HTML code for showing camera preview below or on top of the HTML.", "keywords": [ "cordova", diff --git a/plugin.xml b/plugin.xml index fe5f0ad..a78825f 100644 --- a/plugin.xml +++ b/plugin.xml @@ -1,6 +1,6 @@ - + cordova-plugin-simple-camera-preview Cordova plugin that allows camera interaction from HTML code. Show camera preview popup on top of the HTML. diff --git a/src/android/CameraPreviewFragment.java b/src/android/CameraPreviewFragment.java index f799c8a..0ed6e20 100644 --- a/src/android/CameraPreviewFragment.java +++ b/src/android/CameraPreviewFragment.java @@ -285,7 +285,7 @@ public void hasFlash(HasFlashCallback hasFlashCallback) { hasFlashCallback.onResult(camera.getCameraInfo().hasFlashUnit()); } - public void startVideoCapture(VideoCallback videoCallback, boolean recordWithAudio) { + public void startVideoCapture(VideoCallback videoCallback, boolean recordWithAudio, int videoDuration) { if (recording != null) { recording.stop(); recording = null; @@ -308,7 +308,7 @@ public void startVideoCapture(VideoCallback videoCallback, boolean recordWithAud public void run() { stopVideoCapture(); } - }, 30000); + }, videoDuration); PendingRecording pendingRecording = videoCapture.getOutput() .prepareRecording(this.getContext().getApplicationContext(), outputOptions); diff --git a/src/android/SimpleCameraPreview.java b/src/android/SimpleCameraPreview.java index f259d7f..33129cb 100644 --- a/src/android/SimpleCameraPreview.java +++ b/src/android/SimpleCameraPreview.java @@ -79,7 +79,7 @@ public boolean execute(String action, JSONArray args, CallbackContext callbackCo return initVideoCallback(callbackContext); case "startVideoCapture": - return startVideoCapture(args.getBoolean(0), callbackContext); + return startVideoCapture((JSONObject) args.get(0), callbackContext); case "stopVideoCapture": return stopVideoCapture(callbackContext); @@ -120,12 +120,28 @@ private boolean initVideoCallback(CallbackContext callbackContext) { return true; } - private boolean startVideoCapture(boolean recordWithAudio, CallbackContext callbackContext) { + private boolean startVideoCapture(JSONObject options, CallbackContext callbackContext) { if (fragment == null) { callbackContext.error("Camera is closed"); return true; } + boolean recordWithAudio; + try { + recordWithAudio = options.getBoolean("recordWithAudio"); + } catch (JSONException e) { + e.printStackTrace(); + recordWithAudio = false; + } + + int videoDuration; + try { + videoDuration = options.getInt("videoDurationMs"); + } catch (JSONException e) { + e.printStackTrace(); + videoDuration = 3000; + } + if (recordWithAudio && !PermissionHelper.hasPermission(this, Manifest.permission.RECORD_AUDIO)) { String[] permissions = {Manifest.permission.RECORD_AUDIO}; PermissionHelper.requestPermissions(this, VIDEO_REQUEST_CODE_PERMISSIONS, permissions); @@ -181,7 +197,7 @@ public void onError(String errMessage) { pluginResult.setKeepCallback(true); videoCallbackContext.sendPluginResult(pluginResult); } - }, recordWithAudio); + }, recordWithAudio, videoDuration); } callbackContext.success(); return true; diff --git a/src/ios/CameraSessionManager.h b/src/ios/CameraSessionManager.h index 4d0a07f..96a79dc 100644 --- a/src/ios/CameraSessionManager.h +++ b/src/ios/CameraSessionManager.h @@ -12,7 +12,7 @@ - (BOOL) deviceHasUltraWideCamera; - (void) deallocSession; - (void) updateOrientation:(AVCaptureVideoOrientation)orientation; -- (void) startRecording:(NSURL *)fileURL recordingDelegate:(id)recordingDelegate; +- (void) startRecording:(NSURL *)fileURL recordingDelegate:(id)recordingDelegate videoDurationMs:(NSInteger)videoDuration; - (void) stopRecording; - (AVCaptureVideoOrientation) getCurrentOrientation:(UIInterfaceOrientation)toInterfaceOrientation; + (AVCaptureSessionPreset) calculateResolution:(NSInteger)targetSize; diff --git a/src/ios/CameraSessionManager.m b/src/ios/CameraSessionManager.m index 3f0c81e..4500985 100644 --- a/src/ios/CameraSessionManager.m +++ b/src/ios/CameraSessionManager.m @@ -239,14 +239,16 @@ - (void)switchCameraTo:(NSString*)cameraMode completion:(void (^)(BOOL success)) }); } -- (void)startRecording:(NSURL *)fileURL recordingDelegate:(id)recordingDelegate { +- (void)startRecording:(NSURL *)fileURL recordingDelegate:(id)recordingDelegate videoDurationMs:(NSInteger)videoDurationMs { if (!self.movieFileOutput.isRecording) { AVCaptureConnection *connection = [self.movieFileOutput connectionWithMediaType:AVMediaTypeVideo]; if ([connection isVideoOrientationSupported]) { connection.videoOrientation = [self getCurrentOrientation]; } [self.movieFileOutput startRecordingToOutputFileURL:fileURL recordingDelegate:recordingDelegate]; - _videoTimer = [NSTimer scheduledTimerWithTimeInterval:30.0 + + NSInteger videoDurationInSec = videoDurationMs / 1000; + _videoTimer = [NSTimer scheduledTimerWithTimeInterval:videoDurationInSec target:self selector:@selector(stopRecording) userInfo:nil diff --git a/src/ios/SimpleCameraPreview.m b/src/ios/SimpleCameraPreview.m index 5fa2b28..af7dbf7 100644 --- a/src/ios/SimpleCameraPreview.m +++ b/src/ios/SimpleCameraPreview.m @@ -368,13 +368,16 @@ - (void) initVideoCallback:(CDVInvokedUrlCommand*)command { } - (void)startVideoCapture:(CDVInvokedUrlCommand*)command { + NSDictionary* config = command.arguments[0]; + NSInteger videoDuration = ((NSNumber*)config[@"videoDurationMs"]).intValue; + if (self.sessionManager != nil && !self.sessionManager.movieFileOutput.isRecording) { NSArray *paths = NSSearchPathForDirectoriesInDomains(NSLibraryDirectory, NSUserDomainMask, YES); NSString *libraryDirectory = [[paths objectAtIndex:0] stringByAppendingPathComponent:@"NoCloud"]; NSString* uniqueFileName = [NSString stringWithFormat:@"%@.mp4",[[NSUUID UUID] UUIDString]]; NSString *dataPath = [libraryDirectory stringByAppendingPathComponent:uniqueFileName]; NSURL *fileURL = [NSURL fileURLWithPath:dataPath]; - [self.sessionManager startRecording:fileURL recordingDelegate:self]; + [self.sessionManager startRecording:fileURL recordingDelegate:self videoDurationMs:videoDuration]; } else { CDVPluginResult *pluginResult = [CDVPluginResult resultWithStatus:CDVCommandStatus_ERROR messageAsString:@"Session not initialized or already recording"]; [self.commandDelegate sendPluginResult:pluginResult callbackId:command.callbackId]; diff --git a/www/SimpleCameraPreview.js b/www/SimpleCameraPreview.js index 1bdfa29..03136cc 100755 --- a/www/SimpleCameraPreview.js +++ b/www/SimpleCameraPreview.js @@ -20,7 +20,8 @@ SimpleCameraPreview.startVideoCapture = function (options, onSuccess, onError) { options = options || {}; options.recordWithAudio = options.recordWithAudio != null ? options.recordWithAudio : true; - exec(onSuccess, onError, PLUGIN_NAME, "startVideoCapture", [options.recordWithAudio]); + options.videoDurationMs = options.videoDurationMs != null ? options.videoDurationMs : 3000; + exec(onSuccess, onError, PLUGIN_NAME, "startVideoCapture", [options]); }; SimpleCameraPreview.stopVideoCapture = function (onSuccess, onError) {