Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
@yoonit/nativescript-camera
Advanced tools
Yoonit Camera have a custom view that shows a preview layer of the front/back camera and detects human faces in it and read qr code.
A NativeScript plugin to provide:
npm i -s @yoonit/nativescript-camera
All the functionalities that the @yoonit/nativescript-camera
provides is accessed through the YoonitCamera
component, that includes the camera preview. Below we have the basic usage code, for more details, your can see the Methods, Events or the Demo Vue.
main.js
import Vue from 'nativescript-vue'
import YoonitCamera from '@yoonit/nativescript-camera/vue'
Vue.use(YoonitCamera)
After that, you can access the camera object in your entire project using this.$yoo.camera
App.vue
<template>
<Page @loaded="onLoaded">
<YoonitCamera
ref="yooCamera"
lens="front"
captureType="face"
imageCapture=true
imageCaptureAmount=10
imageCaptureInterval=500
faceDetectionBox=true
@faceDetected="doFaceDetected"
@imageCaptured="doImageCaptured"
@endCapture="doEndCapture"
@qrCodeContent="doQRCodeContent"
@status="doStatus"
@permissionDenied="doPermissionDenied"
/>
</Page>
</template>
<script>
export default {
data: () => ({}),
methods: {
async onLoaded() {
console.log('[YooCamera] Getting Camera view')
this.$yoo.camera.registerElement(this.$refs.yooCamera)
console.log('[YooCamera] Getting permission')
if (await this.$yoo.camera.requestPermission()) {
console.log('[YooCamera] Permission granted, start preview')
this.$yoo.camera.preview()
}
},
doFaceDetected({ x, y, width, height }) {
console.log('[YooCamera] doFaceDetected', `{x: ${x}, y: ${y}, width: ${width}, height: ${height}}`)
if (!x || !y || !width || !height) {
this.imagePath = null
}
},
doImageCaptured({
type,
count,
total,
image: {
path,
source
}
}) {
if (total === 0) {
console.log('[YooCamera] doImageCreated', `${type}: [${count}] ${path}`)
this.imageCreated = `${count}`
} else {
console.log('[YooCamera] doImageCreated', `${type}: [${count}] of [${total}] - ${path}`)
this.imageCreated = `${count} de ${total}`
}
this.imagePath = source
},
doEndCapture() {
console.log('[YooCamera] doEndCapture')
},
doQRCodeContent({ content }) {
console.log('[YooCamera] doQRCodeContent', content)
},
doStatus({ status }) {
console.log('[YooCamera] doStatus', status)
},
doPermissionDenied() {
console.log('[YooCamera] doPermissionDenied')
}
}
}
</script>
Props | Input/Format | Default value | Description |
---|---|---|---|
lens | "front" or "back" | "front" | The camera lens to use "front" or "back". |
captureType | "none" , "front" , "frame" or "qrcode" | "none" | The capture type of the camera. |
imageCapture | boolean | false | Enable/disabled save image capture. |
imageCaptureAmount | number | 0 | The image capture amount goal. |
imageCaptureInterval | number | 1000 | The image capture time interval in milliseconds. |
imageCaptureWidth | "NNpx" | "200px" | The image capture width in pixels. |
imageCaptureHeight | "NNpx" | "200px" | The image capture height in pixels. |
colorEncoding | "RGB" or "YUV" | "RGB" | Only for android. The image capture color encoding type: "RGB" or "YUV" . |
faceDetectionBox | boolean | false | Show/hide the face detection box. |
faceMinSize | "NN%" | "0%" | The face minimum size percentage to capture. |
faceMaxSize | "NN%" | "100%" | The face maximum size percentage to capture. |
faceROI | boolean | false | Enable/disable the region of interest capture. |
faceROITopOffset | "NN%" | "0%" | Distance in percentage of the top face bounding box with the top of the camera preview. |
faceROIRightOffset | "NN%" | "0%" | Distance in percentage of the right face bounding box with the right of the camera preview. |
faceROIBottomOffset | "NN%" | "0%" | Distance in percentage of the bottom face bounding box with the bottom of the camera preview. |
faceROILeftOffset | "NN%" | "0%" | Distance in percentage of the left face bounding box with the left of the camera preview. |
faceROIMinSize | "NN%" | "0%" | The minimum face size related within the ROI. |
Function | Parameters | Valid values | Return Type | Description |
---|---|---|---|---|
requestPermission | - | - | promise | Ask the user to give the permission to access camera. |
hasPermission | - | - | boolean | Return if application has camera permission. |
preview | - | - | void | Start camera preview if has permission. |
startCapture | type: string |
| void | Set capture type "none", "face", "qrcode" or "frame". Default value is "none" . |
stopCapture | - | - | void | Stop any type of capture. |
toggleLens | - | - | void | Toggle camera lens facing "front"/"back". |
setCameraLens | lens: string | "front" or "back" | void | Set camera to use "front" or "back" lens. Default value is "front" . |
getLens | - | - | string | Return "front" or "back". |
setImageCapture | enable: boolean | true or false | void | Enable/disabled save image capture. Default value is false |
setImageCaptureAmount | amount: Int | Any positive Int value | void | For value 0 , save infinity images. When the capture image amount is reached, the event onEndCapture is triggered. Default value is 0 . |
setImageCaptureInterval | interval: number | Any positive number that represent time in milliseconds | void | Set the image capture time interval in milliseconds. |
setImageCaptureWidth | width: string | Value format must be in NNpx | void | Set the image capture width in pixels. |
setImageCaptureHeight | height: string | Value format must be in NNpx | void | Set the image capture height in pixels. |
setImageCaptureColorEncoding | colorEncoding: string | "YUV" or "RGB" | void | Only for android. Set the image capture color encoding type: "RGB" or "YUV" . |
setFaceDetectionBox | enable: boolean | true or false | void | Set to show/hide the face detection box. |
setFacePaddingPercent | percentage: string | Value format must be in NN% | void | Set face image capture and detection box padding in percentage. |
setFaceCaptureMinSize | percentage: string | Value format must be in NN% | void | Set the face minimum size percentage to capture. |
setFaceCaptureMaxSize | percentage: string | Value format must be in NN% | void | Set the face maximum size percentage to capture. |
setFaceROIEnable | enable: boolean | true or false | void | Enable/disable face region of interest capture. |
setFaceROITopOffset | percentage: string | Value format must be in NN% | void | Distance in percentage of the top face bounding box with the top of the camera preview. |
setFaceROIRightOffset | percentage: string | Value format must be in NN% | void | Distance in percentage of the right face bounding box with the right of the camera preview. |
setFaceROIBottomOffset | percentage: string | Value format must be in NN% | void | Distance in percentage of the bottom face bounding box with the bottom of the camera preview. |
setFaceROILeftOffset | percentage: string | Value format must be in NN% | void | Distance in percentage of the left face bounding box with the left of the camera preview. |
setFaceROIMinSize | percentage: string | Value format must be in NN% | void | Set the minimum face size related within the ROI. |
Event | Parameters | Description |
---|---|---|
imageCaptured | { type: string, count: number, total: number, image: object = { path: string, source: blob } } | Must have started capture type of face/frame. Emitted when the face image file saved:
|
faceDetected | { x: number, y: number, width: number, height: number } | Must have started capture type of face. Emit the detected face bounding box. Emit all parameters null if no more face detecting. |
endCapture | - | Must have started capture type of face/frame. Emitted when the number of image files created is equal of the number of images set (see the method setImageCaptureAmount ). |
qrCodeContent | { content: string } | Must have started capture type of qrcode (see startCapture ). Emitted when the camera read a QR Code. |
status | { type: 'error'/'message', status: string } | Emit message error from native. Used more often for debug purpose. |
permissionDenied | - | Emit when try to preview but there is not camera permission. |
Pre-define message constants used by the status
event.
Message | Description |
---|---|
INVALID_CAPTURE_FACE_MIN_SIZE | Face width percentage in relation of the screen width is less than the set (setFaceCaptureMinSize ). |
INVALID_CAPTURE_FACE_MAX_SIZE | Face width percentage in relation of the screen width is more than the set (setFaceCaptureMaxSize ). |
INVALID_CAPTURE_FACE_OUT_OF_ROI | Face bounding box is out of the set region of interest (setFaceROIOffset ). |
INVALID_CAPTURE_FACE_ROI_MIN_SIZE | Face width percentage in relation of the screen width is less than the set (setFaceROIMinSize ). |
Clone the repo, change what you want and send PR.
Contributions are always welcome!
Code with ❤ by the Cyberlabs AI Front-End Team
FAQs
Yoonit Camera have a custom view that shows a preview layer of the front/back camera and detects human faces in it and read qr code.
The npm package @yoonit/nativescript-camera receives a total of 29 weekly downloads. As such, @yoonit/nativescript-camera popularity was classified as not popular.
We found that @yoonit/nativescript-camera demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 11 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.