From 4de0932c944ecc39936b554606a2d184cc91d77f Mon Sep 17 00:00:00 2001 From: "antoine.gonzalez" Date: Wed, 29 Nov 2023 18:11:33 +0100 Subject: [PATCH] Add quickstart #130 --- docs/api/index.md | 9 ++ docs/conf.py | 2 - docs/dependencies.md | 10 +++ docs/dev/index.md | 9 ++ docs/index.md | 24 +++-- docs/quickstart.md | 202 +++++++++++++++++++++++++++++++++++++++++++ 6 files changed, 248 insertions(+), 8 deletions(-) create mode 100644 docs/api/index.md create mode 100644 docs/dependencies.md create mode 100644 docs/dev/index.md create mode 100644 docs/quickstart.md diff --git a/docs/api/index.md b/docs/api/index.md new file mode 100644 index 00000000..4580a9d0 --- /dev/null +++ b/docs/api/index.md @@ -0,0 +1,9 @@ +# API reference + +:::{admonition} WIP +:class: attention + +This documentation is a work in progress. +::: + +This page is the index of the API reference. \ No newline at end of file diff --git a/docs/conf.py b/docs/conf.py index 63afd4c8..01205c29 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -1,8 +1,6 @@ # coding: utf-8 source_suffix = { - '.rst': 'restructuredtext', - '.txt': 'markdown', '.md': 'markdown', } source_encoding = 'utf-8' diff --git a/docs/dependencies.md b/docs/dependencies.md new file mode 100644 index 00000000..fcdc68ea --- /dev/null +++ b/docs/dependencies.md @@ -0,0 +1,10 @@ +# Dependencies and compatibility matrix + +:::{admonition} WIP +:class: attention + +This documentation is a work in progress. +::: + +This page contains information about which depencency to include depending on your devices. +A compatibility matrix can be found at the bottom. \ No newline at end of file diff --git a/docs/dev/index.md b/docs/dev/index.md new file mode 100644 index 00000000..de061e09 --- /dev/null +++ b/docs/dev/index.md @@ -0,0 +1,9 @@ +# Development + +:::{admonition} WIP +:class: attention + +This documentation is a work in progress. +::: + +This page is the index of the developer's guide to contributing. \ No newline at end of file diff --git a/docs/index.md b/docs/index.md index b02f0d80..6ba7835f 100644 --- a/docs/index.md +++ b/docs/index.md @@ -1,5 +1,11 @@ # enioka Haute Couture Android Barcode Scanning Library +:::{admonition} WIP +:class: attention + +This documentation is a work in progress. +::: + This library makes the integration of all barcode scanners easy in any Android application, avoiding vendor lock-in and lowering the cost of advanced scanner integration. @@ -11,7 +17,8 @@ It is compatible with: - GeneralScan Bluetooth rings - And a few others, check full compatibility table below. -When there are no compatible hardware devices available, the library provides a camera reader based on ZBar (default) or ZXing. +When there are no compatible hardware devices available, the library provides a camera reader based +on ZBar (default) or ZXing. Through a common abstraction, it provides access to the following methods (provided the hardware supports them): - press/release the scanner's trigger @@ -21,11 +28,16 @@ Through a common abstraction, it provides access to the following methods (provi - enable/disable colored LEDs - set scanner enabled symbologies -Finally, it provides a ready to use Service that handles scanner lifecycles, as well as a template Activity, and a sample demo -application, allowing to use scanners in a matter of minutes. +Finally, it provides a ready to use Service that handles scanner lifecycles, as well as a template +Activity, and a sample demo application, allowing to use scanners in a matter of minutes. -:::{admonition} WIP -:class: attention +:::{toctree} +:numbered: +:maxdepth: 3 +:titlesonly: -This documentation is a work in progress. +quickstart +dependencies +api/index +dev/index ::: \ No newline at end of file diff --git a/docs/quickstart.md b/docs/quickstart.md new file mode 100644 index 00000000..7a766625 --- /dev/null +++ b/docs/quickstart.md @@ -0,0 +1,202 @@ +# Quick Start + +:::{admonition} WIP +:class: attention + +This documentation is a work in progress. +::: + +:::{admonition} TODO +:class: attention + +* Edit source links to redirect to the API reference. Maybe a `guides` section could help too. +* Simplify the quick start, currently too much text and too many parts +::: + +This guide will show you the minimum required steps to include **enioka Scan** in your application. +It assumes that you already have a configured Android Studio project. + +This guide will only go over the minimal code. For a more in-depth guide for each use case, check +the [API reference](/api/index). + +## Add the required dependencies + +In order to use **enioka Scan**, you need to add the corresponding dependency to your `build.gradle`. + +```groovy +repositories { + mavenCentral() +} +dependencies { + implementation 'com.enioka.scanner:scanner:2.4.1:aar' +} +``` + +Depending on your scanning devices, this single dependency may be enough. For some devices, other +dependencies are required, you can check [Dependencies](/dependencies) for a detailed overview. + +## Using the library + +There are different ways to use the library, depending on where it has to be used. And in any ways, +the library does not hide its low-level objects which are an always available fallback. Most scanner +capabilities are exposed through the [`Scanner`][scanner-api] API, though the default behavior of +the [`ScannerServiceApi`][scanner-service-api] API ought to be enough for simply receiving scanned +data. + +### Using enioka Scan in an activity + +The simplest way to use **enioka Scan** is to extend the provided +[`ScannerCompatActivity`][scanner-compat-activity]: + +```java +import com.enioka.scanner.activities.ScannerCompatActivity; + +public class MyScanningActivity extends ScannerCompatActivity { +} +``` + +This creates an activity with a very simple layout, which displays status messages from the scanners +as well as scanning results and some utility buttons: triggers for the scanner, a toggle for +illumination, and a beep trigger. + +Now, most activities of course want to use their own layouts. This is allowed by setting two fields +(one for the camera layout, one for the laser layout) in the constructor of the activity: + +```java +@Override +protected void MyScanningActivity() { + super.onCreate(); + layoutIdLaser = R.layout.activity_parcel_scan_laser; + layoutIdCamera = R.layout.activity_parcel_scan_camera; +} +``` + +There are a few other fields to allow you to customize further the activity, which are all +documented inside the class. These include options to rename the toggle illumination button ID, to +disable camera or laser or both, or enable a fallback dialog with manual input and auto-completion. + +If the provided template does not suit your needs, but you still want to take advantage of the +[`ScannerServiceApi`][scanner-service-api], simply make sure that your activity follows the steps +described in the section below. + +if you use a custom layout, you need to use our Camera scanning view. The ID of this view should by +default be `camera_scan_view` (which can be customized inside the constructor as for the other +views). This view accepts a few parameters, which are displayed here with their default values: + +```xml + +``` + +Finally, note that inside the activity code there are a few hooks that can be overloaded - these are +public or protected methods, with full javadoc. Of notice are: + +* `onData(List data)` +* `onStatusChanged(Scanner, ScannerStatusCallback.Status)` + +### Using enioka Scan outside of an activity + +The library exposes a service which can be bound as any other bound service: + +```java +ScannerServiceApi scannerService; +boolean serviceBound = false; + +ServiceConnection connection = new ServiceConnection() { + @Override + public void onServiceConnected(ComponentName className, + IBinder service) { + // We've bound to ScannerService, cast the IBinder and get the ScannerServiceApi instance + ScannerService.LocalBinder binder = (ScannerService.LocalBinder) service; + scannerService = binder.getService(); + serviceBound = true; + } + + @Override + public void onServiceDisconnected(ComponentName arg0) { + serviceBound = false; + scannerService = null; + } + }; + +// Bind to ScannerService service +// Make sure to bind the ScannerService class (or any implementation of the API), not the ScannerServiceApi interface +Intent intent = new Intent(this, ScannerService.class); +bindService(intent, connection, Context.BIND_AUTO_CREATE); +``` + +It is then possible to use the [`ScannerServiceApi`][scanner-service-api] object to access the +different endpoints of the service. The most interesting one is `registerClient()` which hooks +scanning callbacks and scanner/provider discovery notifications to a class implementing the +[`ScannerClient`][scanner-client] interface such as a custom activity. + +Please remember to unbind the service when it is not needed anymore, as for any other service. This +will often be in "onDestroy" hooks. Also, as this is a bound service, it is destroyed whenever it +has no bound clients left. Many applications actually bind the service on startup onto the +application context to be sure it is never destroyed and therefore is very quick to bind from +anywhere, but this depends on the use-case and is not compulsory at all. + +If you want to bind the service inside your application class, a helper is provided to avoid +boilerplate code that can be used as such: + +```java +public class App extends Application { + ScannerServiceBinderHelper serviceBinder; + + @Override + public void onCreate() { + super.onCreate(); + serviceBinder = ScannerServiceBinderHelper.bind(this); // a second overload exists with a configuration Bundle. + } + + @Override + public void onTerminate() { + super.onTerminate(); + serviceBinder.disconnect(); + } +} +``` + +Finally, there are a few Intent extra properties which can be set to control the behaviour of the +service such as filters used in the scanner search. +These can be found as static strings inside the [`ScannerServiceApi`][scanner-service-api] interface +, and methods in the [`ScannerSearchOptions`][scanner-search-options] class help converting search +parameters to and from those intent extras. + +## Using the camera + +When there is no laser scanner available, or when a button is clicked, the `ScannerCompatActivity` +activity will fallback to using the device camera (if any) to scan barcodes. This leverages two +different barcode scanning libraries, ZBar and ZXing in recent versions. It is compatible both with +very old Camera APIs as well as more recent Camera 2 APIs. It tries to set the best camera +parameters for barcode scanning, including dynamically setting the camera resolution according to +the processing speed of the device. As a result, it may take a few dozen seconds to reach the most +suitable settings on first startup - the resolution is then stored and reused on subsequent +initialisations. + +The camera scanner can actually be used easily inside your own activities without any links with the +rest of the library (no need to use the scanner service, etc) by just adding the +`CameraBarcodeScanView` to your layouts, and then registering a callback on this view using +`CameraBarcodeScanView.setResultHandler`. Other APIs are available to enable the torch or pause +scanning. + +The provided Camera activity will display a target rectangle, which can be moved or tapped to change +or refresh the autofocus area. + +[mock-sdk]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan_mock +[scanner-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/Scanner.java +[scanner-client]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/service/ScannerClient.java +[scanner-compat-activity]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/activities/ScannerCompatActivity.java +[scanner-provider-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/ScannerProvider.java +[scanner-search-options]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/api/ScannerSearchOptions.java +[scanner-service-api]: https://github.com/enioka-Haute-Couture/enioka_scan/blob/master/enioka_scan/src/main/java/com/enioka/scanner/service/ScannerServiceApi.java