Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tony-xlh/capacitor-plugin-camera-preview
A camera plugin for Capacitor using Dynamsoft Camera Enhancer
https://github.com/tony-xlh/capacitor-plugin-camera-preview
Last synced: 2 months ago
JSON representation
A camera plugin for Capacitor using Dynamsoft Camera Enhancer
- Host: GitHub
- URL: https://github.com/tony-xlh/capacitor-plugin-camera-preview
- Owner: tony-xlh
- Created: 2022-10-20T09:48:16.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-01-15T05:57:26.000Z (12 months ago)
- Last Synced: 2024-10-05T04:14:35.389Z (3 months ago)
- Language: Java
- Size: 914 KB
- Stars: 4
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
- awesome-capacitor - Camera Preview - Access camera using Dynamsoft Camera Enhancer. (Other plugins)
README
# capacitor-plugin-dynamsoft-camera-preview
A Capacitor plugin for camera preview using [Dynamsoft Camera Enhancer](https://www.dynamsoft.com/camera-enhancer/overview/).
[Online Demo](https://fastidious-squirrel-b4bc07.netlify.app/)
Note: This package is not actively maintained. Please use [capacitor-plugin-camera](https://www.npmjs.com/package/capacitor-plugin-camera).
## Supported Platforms
* Web
* Android
* iOS## Versions
For Capacitor v5, use v2.x.
For Capacitor v4, use v1.x.
## Install
```bash
npm install capacitor-plugin-dynamsoft-camera-preview
npx cap sync
```## Get Bitmap/UIImage via Reflection
If you are developing a plugin, you can use reflection to get the camera frames as Bitmap or UIImage on the native side.
Java:
```java
Class cls = Class.forName("com.dynamsoft.capacitor.dce.CameraPreviewPlugin");
Method m = cls.getMethod("getBitmap",null);
Bitmap bitmap = (Bitmap) m.invoke(null, null);
```Objective-C:
```objc
- (UIImage*)getUIImage{
UIImage *image = ((UIImage* (*)(id, SEL))objc_msgSend)(objc_getClass("CameraPreviewPlugin"), sel_registerName("getBitmap"));
return image;
}
```## API
* [`initialize()`](#initialize)
* [`getResolution()`](#getresolution)
* [`setResolution(...)`](#setresolution)
* [`getAllCameras()`](#getallcameras)
* [`getSelectedCamera()`](#getselectedcamera)
* [`selectCamera(...)`](#selectcamera)
* [`setScanRegion(...)`](#setscanregion)
* [`setZoom(...)`](#setzoom)
* [`setFocus(...)`](#setfocus)
* [`setDefaultUIElementURL(...)`](#setdefaultuielementurl)
* [`startCamera()`](#startcamera)
* [`stopCamera()`](#stopcamera)
* [`pauseCamera()`](#pausecamera)
* [`resumeCamera()`](#resumecamera)
* [`takeSnapshot(...)`](#takesnapshot)
* [`takeSnapshot2()`](#takesnapshot2)
* [`takePhoto()`](#takephoto)
* [`toggleTorch(...)`](#toggletorch)
* [`requestCameraPermission()`](#requestcamerapermission)
* [`isOpen()`](#isopen)
* [`addListener('onPlayed', ...)`](#addlisteneronplayed)
* [`removeAllListeners()`](#removealllisteners)
* [Interfaces](#interfaces)
* [Type Aliases](#type-aliases)### initialize()
```typescript
initialize() => Promise
```--------------------
### getResolution()
```typescript
getResolution() => Promise<{ resolution: string; }>
```**Returns:**
Promise<{ resolution: string; }>
--------------------
### setResolution(...)
```typescript
setResolution(options: { resolution: number; }) => Promise
```| Param | Type |
| ------------- | ------------------------------------ |
| **`options`** |{ resolution: number; }
|--------------------
### getAllCameras()
```typescript
getAllCameras() => Promise<{ cameras: string[]; }>
```**Returns:**
Promise<{ cameras: string[]; }>
--------------------
### getSelectedCamera()
```typescript
getSelectedCamera() => Promise<{ selectedCamera: string; }>
```**Returns:**
Promise<{ selectedCamera: string; }>
--------------------
### selectCamera(...)
```typescript
selectCamera(options: { cameraID: string; }) => Promise
```| Param | Type |
| ------------- | ---------------------------------- |
| **`options`** |{ cameraID: string; }
|--------------------
### setScanRegion(...)
```typescript
setScanRegion(options: { region: ScanRegion; }) => Promise
```| Param | Type |
| ------------- | -------------------------------------------------------------- |
| **`options`** |{ region: ScanRegion; }
|--------------------
### setZoom(...)
```typescript
setZoom(options: { factor: number; }) => Promise
```| Param | Type |
| ------------- | -------------------------------- |
| **`options`** |{ factor: number; }
|--------------------
### setFocus(...)
```typescript
setFocus(options: { x: number; y: number; }) => Promise
```| Param | Type |
| ------------- | -------------------------------------- |
| **`options`** |{ x: number; y: number; }
|--------------------
### setDefaultUIElementURL(...)
```typescript
setDefaultUIElementURL(url: string) => Promise
```Web Only
| Param | Type |
| --------- | ------------------- |
| **`url`** |string
|--------------------
### startCamera()
```typescript
startCamera() => Promise
```--------------------
### stopCamera()
```typescript
stopCamera() => Promise
```--------------------
### pauseCamera()
```typescript
pauseCamera() => Promise
```--------------------
### resumeCamera()
```typescript
resumeCamera() => Promise
```--------------------
### takeSnapshot(...)
```typescript
takeSnapshot(options: { quality?: number; }) => Promise<{ base64: string; }>
```take a snapshot as base64.
| Param | Type |
| ------------- | ---------------------------------- |
| **`options`** |{ quality?: number; }
|**Returns:**
Promise<{ base64: string; }>
--------------------
### takeSnapshot2()
```typescript
takeSnapshot2() => Promise<{ frame: DCEFrame; }>
```take a snapshot as DCEFrame. Web Only
**Returns:**
Promise<{ frame: DCEFrame; }>
--------------------
### takePhoto()
```typescript
takePhoto() => Promise<{ base64: string; }>
```**Returns:**
Promise<{ base64: string; }>
--------------------
### toggleTorch(...)
```typescript
toggleTorch(options: { on: boolean; }) => Promise
```| Param | Type |
| ------------- | ----------------------------- |
| **`options`** |{ on: boolean; }
|--------------------
### requestCameraPermission()
```typescript
requestCameraPermission() => Promise
```--------------------
### isOpen()
```typescript
isOpen() => Promise<{ isOpen: boolean; }>
```**Returns:**
Promise<{ isOpen: boolean; }>
--------------------
### addListener('onPlayed', ...)
```typescript
addListener(eventName: 'onPlayed', listenerFunc: onPlayedListener) => Promise & PluginListenerHandle
```| Param | Type |
| ------------------ | ------------------------------------------------------------- |
| **`eventName`** |'onPlayed'
|
| **`listenerFunc`** |onPlayedListener
|**Returns:**
Promise<PluginListenerHandle> & PluginListenerHandle
--------------------
### removeAllListeners()
```typescript
removeAllListeners() => Promise
```--------------------
### Interfaces
#### ScanRegion
measuredByPercentage: 0 in pixel, 1 in percent
| Prop | Type |
| -------------------------- | ------------------- |
| **`left`** |number
|
| **`top`** |number
|
| **`right`** |number
|
| **`bottom`** |number
|
| **`measuredByPercentage`** |number
|#### DCEFrame
| Prop | Type |
| ----------------- | ------------------------------------------------- |
| **`data`** |Uint8Array
|
| **`region`** |Region
|
| **`sx`** |number
|
| **`sy`** |number
|
| **`width`** |number
|
| **`height`** |number
|
| **`stride`** |number
|
| **`colorMode`** |string
|
| **`pixelFormat`** |string
|
| **`timeSpent`** |number
|
| **`timeStamp`** |number
|
| **`isCropped`** |boolean
|
| **`toCanvas`** |() => any
|
| **`_sWidth`** |number
|
| **`_sHeight`** |number
|
| **`_bUseWebGL`** |boolean
|#### Uint8Array
A typed array of 8-bit unsigned integer values. The contents are initialized to 0. If the
requested number of bytes could not be allocated an exception is raised.| Prop | Type | Description |
| ----------------------- | ----------------------------------------------------------- | ---------------------------------------------------------------------------- |
| **`BYTES_PER_ELEMENT`** |number
| The size in bytes of each element in the array. |
| **`buffer`** |ArrayBufferLike
| The ArrayBuffer instance referenced by the array. |
| **`byteLength`** |number
| The length in bytes of the array. |
| **`byteOffset`** |number
| The offset in bytes of the array. |
| **`length`** |number
| The length of the array. || Method | Signature | Description |
| ------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **copyWithin** | (target: number, start: number, end?: number \| undefined) => this | Returns the this object after copying a section of the array identified by start and end to the same array starting at position target |
| **every** | (predicate: (value: number, index: number, array: Uint8Array) => unknown, thisArg?: any) => boolean | Determines whether all the members of an array satisfy the specified test. |
| **fill** | (value: number, start?: number \| undefined, end?: number \| undefined) => this | Returns the this object after filling the section identified by start and end with value |
| **filter** | (predicate: (value: number, index: number, array: Uint8Array) => any, thisArg?: any) => Uint8Array | Returns the elements of an array that meet the condition specified in a callback function. |
| **find** | (predicate: (value: number, index: number, obj: Uint8Array) => boolean, thisArg?: any) => number \| undefined | Returns the value of the first element in the array where predicate is true, and undefined otherwise. |
| **findIndex** | (predicate: (value: number, index: number, obj: Uint8Array) => boolean, thisArg?: any) => number | Returns the index of the first element in the array where predicate is true, and -1 otherwise. |
| **forEach** | (callbackfn: (value: number, index: number, array: Uint8Array) => void, thisArg?: any) => void | Performs the specified action for each element in an array. |
| **indexOf** | (searchElement: number, fromIndex?: number \| undefined) => number | Returns the index of the first occurrence of a value in an array. |
| **join** | (separator?: string \| undefined) => string | Adds all the elements of an array separated by the specified separator string. |
| **lastIndexOf** | (searchElement: number, fromIndex?: number \| undefined) => number | Returns the index of the last occurrence of a value in an array. |
| **map** | (callbackfn: (value: number, index: number, array: Uint8Array) => number, thisArg?: any) => Uint8Array | Calls a defined callback function on each element of an array, and returns an array that contains the results. |
| **reduce** | (callbackfn: (previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => number) => number | Calls the specified callback function for all the elements in an array. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function. |
| **reduce** | (callbackfn: (previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => number, initialValue: number) => number | |
| **reduce** | <U>(callbackfn: (previousValue: U, currentValue: number, currentIndex: number, array: Uint8Array) => U, initialValue: U) => U | Calls the specified callback function for all the elements in an array. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function. |
| **reduceRight** | (callbackfn: (previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => number) => number | Calls the specified callback function for all the elements in an array, in descending order. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function. |
| **reduceRight** | (callbackfn: (previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => number, initialValue: number) => number | |
| **reduceRight** | <U>(callbackfn: (previousValue: U, currentValue: number, currentIndex: number, array: Uint8Array) => U, initialValue: U) => U | Calls the specified callback function for all the elements in an array, in descending order. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function. |
| **reverse** | () => Uint8Array | Reverses the elements in an Array. |
| **set** | (array: ArrayLike<number>, offset?: number \| undefined) => void | Sets a value or an array of values. |
| **slice** | (start?: number \| undefined, end?: number \| undefined) => Uint8Array | Returns a section of an array. |
| **some** | (predicate: (value: number, index: number, array: Uint8Array) => unknown, thisArg?: any) => boolean | Determines whether the specified callback function returns true for any element of an array. |
| **sort** | (compareFn?: ((a: number, b: number) => number) \| undefined) => this | Sorts an array. |
| **subarray** | (begin?: number \| undefined, end?: number \| undefined) => Uint8Array | Gets a new Uint8Array view of the ArrayBuffer store for this array, referencing the elements at begin, inclusive, up to end, exclusive. |
| **toLocaleString** | () => string | Converts a number to a string by using the current locale. |
| **toString** | () => string | Returns a string representation of an array. |
| **valueOf** | () => Uint8Array | Returns the primitive value of the specified object. |#### ArrayLike
| Prop | Type |
| ------------ | ------------------- |
| **`length`** |number
|#### ArrayBufferTypes
Allowed ArrayBuffer types for the buffer of an ArrayBufferView and related Typed Arrays.
| Prop | Type |
| ----------------- | --------------------------------------------------- |
| **`ArrayBuffer`** |ArrayBuffer
|#### ArrayBuffer
Represents a raw buffer of binary data, which is used to store data for the
different typed arrays. ArrayBuffers cannot be read from or written to directly,
but can be passed to a typed array or DataView Object to interpret the raw
buffer as needed.| Prop | Type | Description |
| ---------------- | ------------------- | ------------------------------------------------------------------------------- |
| **`byteLength`** |number
| Read-only. The length of the ArrayBuffer (in bytes). || Method | Signature | Description |
| --------- | --------------------------------------------------------------------------------------- | --------------------------------------------------------------- |
| **slice** | (begin: number, end?: number \| undefined) => ArrayBuffer | Returns a section of an ArrayBuffer. |#### Region
| Prop | Type |
| -------------------------------- | ------------------------------ |
| **`regionBottom`** |number
|
| **`regionRight`** |number
|
| **`regionLeft`** |number
|
| **`regionTop`** |number
|
| **`regionMeasuredByPercentage`** |number \| boolean
|#### PluginListenerHandle
| Prop | Type |
| ------------ | ----------------------------------------- |
| **`remove`** |() => Promise<void>
|### Type Aliases
#### ArrayBufferLike
ArrayBufferTypes[keyof ArrayBufferTypes]
#### onPlayedListener
(result: { resolution: string; }): void