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"
@faceDetected="doFaceDetected"
@faceImage="doImageCreated"
@frameImage="doImageCreated"
@endCapture="doEndCapture"
@qrCodeContent="doQRCodeContent"
@status="doStatus"
@permissionDenied="doPermissionDenied"
/>
</Page>
</template>
<script>
export default {
data: () => ({}),
methods: {
async onLoaded(args) {
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({ faceDetected }) {
console.log('[YooCamera] faceDetected', faceDetected)
},
doImageCreated({
count,
total,
image: {
path,
source
}
}) {
if (total === 0) {
console.log('[YooCamera] doFaceImage', `[${count}] ${path}`)
} else {
console.log('[YooCamera] doFaceImage', `[${count}] of [${total}] - ${path}`)
}
console.log('[YooCamera] doFaceImage', path, source)
},
doEndCapture() {
console.log('[YooCamera] doEndCapture')
},
doQRCodeContent({ content }) {
console.log('[YooCamera] doQRCodeContent', content)
},
doStatus({ status }) {
console.log('[YooCamera] doStatus', JSON.parse(status))
},
doToggleLens() {
const currentCameraLens = this.$yoo.camera.getLens()
console.log('[YooCamera] doToggleLens', currentCameraLens)
this.$yoo.camera.toggleLens()
},
doStartCapture(captureType) {
console.log('[YooCamera] doStartCapture', captureType)
this.$yoo.camera.startCapture(captureType)
},
doFaceDetectionBox(status) {
console.log('[YooCamera] doFaceDetectionBox', status)
this.$yoo.camera.setFaceDetectionBox(status)
},
doPermissionDenied() {
console.log('[YooCamera] doPermissionDenied')
}
}
}
</script>
Function | Parameters | Valid values | Return Type | Description |
---|---|---|---|---|
requestPermission | - | - | promise | Ask to 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 | captureType: string |
| void | Set capture type none, face, barcode or frame. |
stopCapture | - | - | void | Stop any type of capture. |
toggleLens | - | - | void | Set camera lens facing front or back. |
getLens | - | - | number | Return number that represents lens face state: 0 for front 1 for back camera. |
setFaceNumberOfImages | faceNumberOfImages: number | Any positive number value | void | Default value is 0. For value 0 is saved infinity images. When saved images reached the "face number os images", the onEndCapture is triggered. |
setFaceDetectionBox | faceDetectionBox: boolean | true or false | void | Set to show face detection box when face detected. |
setFaceTimeBetweenImages | faceTimeBetweenImages: number | Any positive number that represent time in milli seconds | void | Set saving face images time interval in milli seconds. |
setFacePaddingPercent | facePaddingPercent: number | Any positive number value | void | Set face image and bounding box padding in percent. |
setFaceImageSize | faceImageSize: number | Any positive number value | void | Set face image size to be saved. |
setFaceCaptureMinSize | faceCaptureMinSize: number | Value between 0 and 1 . Represents the percentage. | void | Set the minimum face capture related by percentage with the screen width. |
setFaceCaptureMaxSize | faceCaptureMaxSize: number | Value between 0 and 1 . Represents the percentage. | void | Set the maximum face capture related by percentage with the screen width. |
setFrameNumberOfImages | frameNumberOfImages: number | Any positive number value | void | Default value is 0. For value 0 is saved infinity images. When saved images reached the "frame number os images", the onEndCapture is triggered. |
setFrameTimeBetweenImages | frameTimeBetweenImages: number | Any positive number that represent time in milli seconds | void | Set saving frame images time interval in milli seconds. |
setFaceSaveImages | faceSaveImages: boolean | true or false | void | Set to enable/disable face save images when capturing faces. |
setFaceROIEnable | faceROIEnable: boolean | true or false | void | Enable/disable face region of interest capture. |
setFaceROIOffset | topOffset: number, rightOffset: number,bottomOffset: number, leftOffset: number | Values between 0 and 1 . Represents the percentage. | void |
|
setFaceROIMinSize | minimumSize: number | Values between 0 and 1 . Represents the percentage. | void | Set the minimum face size related with the region of interest. |
Event | Parameters | Description |
---|---|---|
faceImage | { count: number, total: number, image: object = { path: string, source: blob } } | Must have started capture type of face. Emitted when the face image file is created:
|
frameImage | { count: number, total: number, image: object = { path: string, source: blob } } | Must have started capture type of frame. Emitted when the frame image file is created:
|
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 or frame. Emitted when the number of face or frame image files created is equal of the number of images set (see the method setFaceNumberOfImages for face and setFrameNumberOfImages for frame). |
qrCodeContent | { content: string } | Must have started capture type of barcode (see startCapture ). Emitted when the camera scan 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 key error constants used by the onError
event.
KeyError | Description |
---|---|
NOT_STARTED_PREVIEW | Tried to start a process that depends on to start the camera preview. |
INVALID_CAPTURE_TYPE | Tried to start a non-existent capture type. |
INVALID_FACE_NUMBER_OF_IMAGES | Tried to input invalid face number of images to capture. |
INVALID_FACE_TIME_BETWEEN_IMAGES | Tried to input invalid face time interval to capture face. |
INVALID_FACE_PADDING_PERCENT | Tried to input invalid face padding percent. |
INVALID_FACE_IMAGE_SIZE | Tried to input invalid image width or height. |
INVALID_FACE_CAPTURE_MIN_SIZE | Tried to input invalid face capture minimum size. |
INVALID_FACE_CAPTURE_MAX_SIZE | Tried to input invalid face capture maximum size. |
INVALID_FRAME_NUMBER_OF_IMAGES | Tried to input invalid frame number of images to capture. |
INVALID_FRAME_TIME_BETWEEN_IMAGES | Tried to input invalid frame time interval to capture face. |
INVALID_FACE_ROI_OFFSET | Tried to input invalid face region of interest offset. |
INVALID_FACE_ROI_MIN_SIZE | Tried to input invalid face region of interest minimum size. |
Pre-define message constants used by the onMessage
event.
Message | Description |
---|---|
INVALID_CAPTURE_FACE_MIN_SIZE | Face width percentage in relation of the screen width is less than the setted (setFaceCaptureMinSize ). |
INVALID_CAPTURE_FACE_MAX_SIZE | Face width percentage in relation of the screen width is more than the setted (setFaceCaptureMaxSize ). |
INVALID_CAPTURE_FACE_OUT_OF_ROI | Face bounding box is out of the setted region of interest (setFaceROIOffset ). |
INVALID_CAPTURE_FACE_ROI_MIN_SIZE | Face width percentage in relation of the screen width is less than the setted (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.