Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yushulx/capture-vision-maui
https://github.com/yushulx/capture-vision-maui
barcode datamatrix dotnet library maui pdf417 qrcode
Last synced: 4 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/yushulx/capture-vision-maui
- Owner: yushulx
- Created: 2023-06-16T09:09:28.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-03-14T01:19:16.000Z (10 months ago)
- Last Synced: 2024-09-10T11:10:35.400Z (4 months ago)
- Topics: barcode, datamatrix, dotnet, library, maui, pdf417, qrcode
- Language: C#
- Homepage: https://www.nuget.org/packages/Capture.Vision.Maui
- Size: 279 KB
- Stars: 18
- Watchers: 2
- Forks: 3
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# .NET MAUI Camera View with Dynamsoft Vision SDKs
The project's goal is to assist developers in creating .NET MAUI applications featuring a custom camera view. It utilizes [Dynamsoft Vision SDKs](https://www.dynamsoft.com/) for barcode, MRZ (Machine Readable Zone), and document detection.## Example
[https://github.com/yushulx/Capture-Vision-Maui/tree/main/Capture.Vision.Maui.Example](https://github.com/yushulx/Capture-Vision-Maui/tree/main/Capture.Vision.Maui.Example)- Windows
![.NET MAUI Windows QR code scanner](https://camo.githubusercontent.com/5b212f793f3ae53c7d2d2ba926f9edafeb3c117b9f63b2ea2ab668cc8938732f/68747470733a2f2f7777772e64796e616d736f66742e636f6d2f636f6465706f6f6c2f696d672f323032342f30312f646f746e65742d6d6175692d626172636f64652d646f63756d656e742d6d727a2e706e67)
- iOS
![.NET MAUI iOS: detect barcode, document and mrz](https://camo.githubusercontent.com/0a574bc8762d3fb99eef52023f217dcc7c152f0f9a8699370aa3840d8bf3bc8c/68747470733a2f2f7777772e64796e616d736f66742e636f6d2f636f6465706f6f6c2f696d672f323032342f30332f646f746e65742d6d6175692d696f732d626172636f64652d646f63756d656e742d6d727a2e706e67)## Demo Video: .NET MAUI QR Code Scanner
- Windows
[https://github.com/yushulx/Capture-Vision-Maui/assets/2202306/df6ce0d1-93b8-4e26-be6a-cfe82ba3d267](https://github.com/yushulx/Capture-Vision-Maui/assets/2202306/df6ce0d1-93b8-4e26-be6a-cfe82ba3d267)
- Android
[https://github.com/yushulx/Capture-Vision-Maui/assets/2202306/73551440-6720-4912-8605-cee9882bbee2](https://github.com/yushulx/Capture-Vision-Maui/assets/2202306/73551440-6720-4912-8605-cee9882bbee2)
## Supported Platforms
- Android
- iOS
- Windows## Features
- Read 1D barcodes, QR codes, PDF417, DataMatrix, and other formats from camera frames.
- Recognize Machine Readable Zones (MRZ) from camera frames.
- Detect document edges within camera frames.## Getting Started
1. Enable the camera view in `MauiProgram.cs`:```csharp
builder.UseNativeCameraView()
```2. Request a [free trial license](https://www.dynamsoft.com/customer/license/trialLicense/?product=dcv&package=cross-platform) and replace `LICENSE-KEY` with your own license key in the platform-specific code.
**App.xaml.cs for Windows:**```csharp
using Dynamsoft;
using Microsoft.UI.Xaml;
namespace Capture.Vision.Maui.Example.WinUI
{
public partial class App : MauiWinUIApplication
{
public App()
{
this.InitializeComponent();
BarcodeQRCodeReader.InitLicense("LICENSE-KEY");
DocumentScanner.InitLicense("LICENSE-KEY");
MrzScanner.InitLicense("LICENSE-KEY");
}
}
}
```**MainActivity.cs for Android:**
```csharp
using Android.App;
using Android.Content.PM;
using Android.OS;
using Dynamsoft;
namespace Capture.Vision.Maui.Example
{
public class MainActivity : MauiAppCompatActivity
{
protected override void OnCreate(Bundle savedInstanceState)
{
base.OnCreate(savedInstanceState);
// Your platform-specific code here
BarcodeQRCodeReader.InitLicense("LICENSE-KEY");
DocumentScanner.InitLicense("LICENSE-KEY");
MrzScanner.InitLicense("LICENSE-KEY");
}
}
}
```**Program.cs for iOS:**
```csharp
using ObjCRuntime;
using UIKit;
using Dynamsoft;static void Main(string[] args)
{
DocumentScanner.InitLicense("LICENSE-KEY");
BarcodeQRCodeReader.InitLicense("LICENSE-KEY");
MrzScanner.InitLicense("LICENSE-KEY");
UIApplication.Main(args, null, typeof(AppDelegate));
}
```3. Create a content page to add the camera view:
```xml
```Set `EnableBarcode`, `EnableDocumentDetect`, and `EnableMrz` to activate barcode, document, and MRZ (Machine Readable Zone) detection, respectively. Use the `cameraView_ResultReady` event to retrieve the results.
```csharp
private void cameraView_ResultReady(object sender, ResultReadyEventArgs e)
{
if (e.Result is BarcodeResult[])
{}
else if (e.Result is DocumentResult)
{}
else if (e.Result is MrzResult)
{}
}
```## Custom Image Processing
In the `cameraView_FrameReady` event, you can access the camera frame for custom image processing.```csharp
private void cameraView_FrameReady(object sender, FrameReadyEventArgs e)
{
// process image
}
```The `FrameReadyEventArgs` provide the image buffer, width, height, stride and format.
```csharp
public class FrameReadyEventArgs : EventArgs
{
public enum PixelFormat
{
GRAYSCALE,
RGB888,
BGR888,
RGBA8888,
BGRA8888,
}
public FrameReadyEventArgs(byte[] buffer, int width, int height, int stride, PixelFormat pixelFormat)
{
Buffer = buffer;
Width = width;
Height = height;
Stride = stride;
Format = pixelFormat;
}public byte[] Buffer { get; private set; }
public int Width { get; private set; }
public int Height { get; private set; }
public int Stride { get; private set; }
public PixelFormat Format { get; private set; }
}
```Currently, frames captured from Windows and Android devices are in the `GRAYSCALE` format, whereas frames from iOS devices use the `BGRA8888` format.
## Barcode Parameters Configuration
Configure the barcode detection parameters to suit specific scenarios and requirements. This includes adjusting settings for barcode types, scanning precision, and other relevant factors.
```csharp
public CameraPage()
{
InitializeComponent();
...
// cameraView.BarcodeParameters = "{\"Version\":\"3.0\", \"ImageParameter\":{\"Name\":\"IP1\", \"BarcodeFormatIds\":[\"BF_QR_CODE\", \"BF_ONED\"], \"ExpectedBarcodesCount\":20}}";
}
```## References
- Camera: [https://github.com/hjam40/Camera.MAUI](https://github.com/hjam40/Camera.MAUI)
- Barcode: [https://github.com/yushulx/dotnet-barcode-qr-code-sdk](https://github.com/yushulx/dotnet-barcode-qr-code-sdk)
- Capture Vision: [https://github.com/yushulx/Capture-Vision](https://github.com/yushulx/Capture-Vision)## Building NuGet Package from Source Code
```bash
cd Capture.Vision.Maui
dotnet build --configuration Release
```