aspose_omr_cloud 0.23.1 aspose_omr_cloud: ^0.23.1 copied to clipboard
This SDK allows you to work with Aspose.OMR for Cloud REST APIs in your Dart or Flutter applications quickly and easily
Aspose.OMR Cloud SDK for Dart #
- API version: 5.0
- SDK version: 0.23.01
Aspose.OMR Cloud is an easy-to-use and versatile online service for designing, rendering and recognizing hand-filled answer sheets, exam papers, surveys, ballots, and similar forms. With it, you can quickly develop on-premise, mobile, and web-based applications for optical mark recognition (OMR). These applications require minimal resources on the client side - all the work will be performed by remote services.
With Aspose.OMR Cloud SDK for Dart, you can bring the power of Optical Mark Recognition (OMR) on Android, iOS, Linux, macOS, Windows, and other platforms using Flutter open source framework. This software development kit (SDK) simplifies the interaction with Aspose.OMR Cloud services, allowing you to focus on business logic rather than the technical details. It handles all the routine operations such as establishing connections, sending API requests, and parsing responses, wrapping all these tasks into a few simple methods that can be used in Dart source code.
Contents of this package #
The repository contains:
- Aspose.OMR Cloud SDK for Dart
- Demo project - a simple Flutter application that demonstrates how to use Aspose.OMR Cloud SDK for Dart for generating and recognizing OMR forms.
- Demo data (aspose-omr-cloud-demo-data):
- Configuration file (aspose-omr-cloud-demo-data/test_config.json);
- Source code of the questionnaire, associated images, and a scanned image of the filled questionnaire for recognition test (aspose-omr-cloud-demo-data/Data);
- The directory for storing a generated printable form, recognition pattern (.OMR) file, and recognition results (aspose-omr-cloud-demo-data/Temp).
Licensing #
Aspose.OMR Cloud SDK for Dart, demo application, documentation, and form templates are distributed under MIT License.
dependencies:
aspose_omr_cloud: 0.23.01
Prerequisites #
The following packages are required to run applications based on Aspose.OMR Cloud SDK for Dart:
- Dart SDK 2.12.0 or later.
- http API 0.13.0 or later
Authorization #
Aspose.OMR Cloud follows industry standards and best practices to keep your data secure. All communication with OCR REST API is done using JWT authentication, which provides an open-standard, highly secure way to exchange information. Time-limited JWT tokens are generated using Client ID and Client Secret credentials that are specific for each application.
- Sign in to Aspose Cloud API Dashboard.
- Go to Applications page.
- Create the storage for exchanging files by clicking the plus icon and following the required steps. You can either use your own cloud storage, create a new storage in our cloud, or reuse the existing one.
- Give the application an easily recognizable name so it can be quickly found in a long list.
- Click Save button.
- Click the newly created application and copy the values from Client Id and Client Secret fields.
Installation and usage #
- Clone or download the repository.
- Run the demo project. The actual steps may vary depending on your platform.
The demo application generates a printable OMR-ready form (aspose-omr-cloud-demo-data/Temp/Aspose_test.png) along with the recognition pattern file (aspose-omr-cloud-demo-data/Temp/Aspose_test.omr). The latter is used by Aspose.OMR recognition engine to match filled bubbles with template fields.
Then it recognizes the scanned image of the filled questionnaire and saves results in aspose-omr-cloud-demo-data/Temp/Aspose_test.csv file.
Configuring #
The configuration file (aspose-omr-cloud-demo-data/test_config.json) contains the basic parameters for working with Aspose.OMR Cloud.
- app_key - the value from Client Secret field of the application (see Authorization).
- app_sid - the value from Client Id field of the application (see Authorization).
- base_path - root URL of Aspose.OMR Cloud service.
- data_folder - path to the directory with the source code of the questionnaire, associated images and scanned images of the filled questionnaires. Specify the path relative to the configuration file.
- result_folder - path to the directory for storing a generated printable form, recognition pattern and recognition results. Specify the path relative to the configuration file.
How it works? #
Aspose.OMR Cloud supports end-to-end OMR process - from designing a form to recognizing its filled hardcopies. The workflow includes the following stages:
All resource-consuming tasks (generation and recognition of OMR forms) are done in the cloud, freeing up resources on the end user's device. All cloud tasks are queued, which prevents multiple simultaneous requests from interfering with each other and consuming too much processor time.
Aspose.OMR Cloud SDK for Dart implements wrapper classes that allow you to interact with the Aspose.OMR Cloud REST API without writing low-level HTTP requests and parsing responses. The demo project source code (example/main.dart) contains extensive comments on all major parts of the code, so you can easily understand the basics without having to consult the SDK reference documentation.
Generating a printable form #
To generate a printable form and a recognition pattern file, send the form sources and page configuration to the Aspose.OMR Cloud queue and get the results a few seconds later.
The processing time can vary from a few milliseconds to a couple of seconds, depending on the current load of the Aspose.OMR Cloud service.
GenerateTemplateApi
This class contains wrapper methods for generating the printable form from the source code and working with the form generation queue.
OmrGenerateTask
This class allows you to prepare a request for sending the form source code, associated images, and page layout to the generation queue.
Page layout
The paper size, orientation, font, and other layout settings are configured through PageSettings
object which is passed to the settings
property of OmrGenerateTask
object.
Working with images
Aspose.OMR Cloud allows you to customize forms by adding images (such as your company logo) to them. In addition to describing the image element in the form's source code, each image file must be directly submitted to the generation queue.
Images are specified in images
property of the OmrGenerateTask
object as a collection of key-value pairs (Map<String, String>
). The key contains the image file name, and the value contains the contents of the image file.
OMRResponse
Depending on the request type, this class contains:
- The current state of the queued form generation request, along with the printable OMR form and recognition pattern file, if the form has been generated.
- The current state of the queued form recognition request, along with recognition results, if the form has been recognized.
Recognizing a filled form #
To recognize the filled form, send its scanned image or photo along with the recognition pattern file to the Aspose.OMR Cloud queue and get the results a few seconds later.
The processing time can vary from a few milliseconds to a couple of seconds, depending on the current load of the Aspose.OMR Cloud service.
RecognizeTemplateApi
This class contains wrapper methods for recognizing the scanned or photographed form and working with the form recognition queue.
OmrRecognizeTask
This class allows you to prepare a request for sending the form image to the recognition queue.
The form must be accompanied by the recognition pattern (.OMR) file, which tells Aspose.OMR recognition engine how to match filled bubbles with template fields. Please note that the recognition template file must be taken from the same generation response as the printable form, otherwise the recognition results are not guaranteed to be correct.
Recognition accuracy threshold
A respondent can fill out the form with a pen, pencil or marker, and use various marks inside the bubbles - from a solid fill to small crosses or checks.
Recognition accuracy threshold (recognitionThreshold
) property of OmrRecognizeTask
object determines how marks are processed during recognition. You can provide a value from 0 to 100. Lower values allow even the lightest marks to be recognized, but may cause dirt or paper defects to be treated as marks. Higher values require a more solid fill and may cause pencil marks or small checkmarks to be ignored.
Important: Instruct respondents to use the same type of marks for all bubbles. Otherwise, recognition results may be inaccurate. If you plan to use your smartphone's camera instead of a scanner, we recommend a solid fill with a pen or marker.