data:image/s3,"s3://crabby-images/d3020/d302086adb4df4c2d22e9eedc6d9db07cfd95e82" alt=""
This plugin is used for accessing device's capture options.
Step 1 - Installing Media Capture Plugin
To install this plugin, we will open command prompt and run the following code −
C:\Users\username\Desktop\CordovaProject>cordova plugin add cordova-plugin-media-capture
Step 2 - Add Buttons
Since we want to show you how to capture audio, image and video, we will create three buttons in index.html.
<button id = "audioCapture">AUDIO</button> <button id = "imageCapture">IMAGE</button> <button id = "videoCapture">VIDEO</button>
Step 3 - Add Event Listeners
The next step is adding event listeners inside onDeviceReady in index.js.
document.getElementById("audioCapture").addEventListener("click", audioCapture); document.getElementById("imageCapture").addEventListener("click", imageCapture); document.getElementById("videoCapture").addEventListener("click", videoCapture);
Step 4A - Capture Audio Function
The first callback function in index.js is audioCapture. To start sound recorder, we will use captureAudio method. We are using two options − limit will allow recording only one audio clip per single capture operation and duration is number of seconds of a sound clip.
function audioCapture() { var options = { limit: 1, duration: 10 }; navigator.device.capture.captureAudio(onSuccess, onError, options); function onSuccess(mediaFiles) { var i, path, len; for (i = 0, len = mediaFiles.length; i < len; i += 1) { path = mediaFiles[i].fullPath; console.log(mediaFiles); } } function onError(error) { navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error'); } }
When we press AUDIO button, sound recorder will open.
data:image/s3,"s3://crabby-images/759f6/759f63ad9f74b80cb247c7496d9a24bd6bafaaf4" alt="Cordova Capture Audio"
Console will show returned array of objects that users captured.
data:image/s3,"s3://crabby-images/832a8/832a89b8a99a10cb0973bf9aaba4a43115451c34" alt="Cordova Capture Audio Log"
Step 4B - Capture Image Function
The function for capturing image will be the same as the last one. The only difference is that we are using captureImage method this time.
function imageCapture() { var options = { limit: 1 }; navigator.device.capture.captureImage(onSuccess, onError, options); function onSuccess(mediaFiles) { var i, path, len; for (i = 0, len = mediaFiles.length; i < len; i += 1) { path = mediaFiles[i].fullPath; console.log(mediaFiles); } } function onError(error) { navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error'); } }
Now we can click IMAGE button to start the camera.
data:image/s3,"s3://crabby-images/8d18a/8d18a38e1f2ad8a1d5a215235119f95135a1e318" alt="Cordova Capture Image"
When we take picture, the console will log the array with image object.
data:image/s3,"s3://crabby-images/ae1f6/ae1f69a427da430ded4e2879b7387d7f4cb215f1" alt="Cordova Capture Image Log"
Step 4C - Capture Video Function
Let's repeat the same concept for capturing video. We will use videoCapturemethod this time.
function videoCapture() { var options = { limit: 1, duration: 10 }; navigator.device.capture.captureVideo(onSuccess, onError, options); function onSuccess(mediaFiles) { var i, path, len; for (i = 0, len = mediaFiles.length; i < len; i += 1) { path = mediaFiles[i].fullPath; console.log(mediaFiles); } } function onError(error) { navigator.notification.alert('Error code: ' + error.code, null, 'Capture Error'); } }
If we press VIDEO button, the camera will open and we can record the video.
data:image/s3,"s3://crabby-images/84616/84616af1c5b8015f409a1bbf07a845bd17666f34" alt="Cordova Capture Video"
Once the video is saved, the console will return array once more. This time with video object inside.
data:image/s3,"s3://crabby-images/a5825/a5825f7ced04aaeb1dcdb087907776621d1d081e" alt="Cordova Capture Video Log"
Tidak ada komentar:
Posting Komentar