Merge pull request #16 from nickgerman/master
Added continuous autofocus on Android if the API Level supports it + added explicit enabling of all ZBar barcode formats
This commit is contained in:
72
android/BarcodeFormat.java
Normal file
72
android/BarcodeFormat.java
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
package org.cloudsky.cordovaPlugins;
|
||||||
|
|
||||||
|
import net.sourceforge.zbar.Symbol;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
public class BarcodeFormat {
|
||||||
|
private int mId;
|
||||||
|
private String mName;
|
||||||
|
|
||||||
|
public static final BarcodeFormat NONE = new BarcodeFormat(Symbol.NONE, "NONE");
|
||||||
|
public static final BarcodeFormat PARTIAL = new BarcodeFormat(Symbol.PARTIAL, "PARTIAL");
|
||||||
|
public static final BarcodeFormat EAN8 = new BarcodeFormat(Symbol.EAN8, "EAN8");
|
||||||
|
public static final BarcodeFormat UPCE = new BarcodeFormat(Symbol.UPCE, "UPCE");
|
||||||
|
public static final BarcodeFormat ISBN10 = new BarcodeFormat(Symbol.ISBN10, "ISBN10");
|
||||||
|
public static final BarcodeFormat UPCA = new BarcodeFormat(Symbol.UPCA, "UPCA");
|
||||||
|
public static final BarcodeFormat EAN13 = new BarcodeFormat(Symbol.EAN13, "EAN13");
|
||||||
|
public static final BarcodeFormat ISBN13 = new BarcodeFormat(Symbol.ISBN13, "ISBN13");
|
||||||
|
public static final BarcodeFormat I25 = new BarcodeFormat(Symbol.I25, "I25");
|
||||||
|
public static final BarcodeFormat DATABAR = new BarcodeFormat(Symbol.DATABAR, "DATABAR");
|
||||||
|
public static final BarcodeFormat DATABAR_EXP = new BarcodeFormat(Symbol.DATABAR_EXP, "DATABAR_EXP");
|
||||||
|
public static final BarcodeFormat CODABAR = new BarcodeFormat(Symbol.CODABAR, "CODABAR");
|
||||||
|
public static final BarcodeFormat CODE39 = new BarcodeFormat(Symbol.CODE39, "CODE39");
|
||||||
|
public static final BarcodeFormat PDF417 = new BarcodeFormat(Symbol.PDF417, "PDF417");
|
||||||
|
public static final BarcodeFormat QRCODE = new BarcodeFormat(Symbol.QRCODE, "QRCODE");
|
||||||
|
public static final BarcodeFormat CODE93 = new BarcodeFormat(Symbol.CODE93, "CODE93");
|
||||||
|
public static final BarcodeFormat CODE128 = new BarcodeFormat(Symbol.CODE128, "CODE128");
|
||||||
|
|
||||||
|
public static final List<BarcodeFormat> ALL_FORMATS = new ArrayList<BarcodeFormat>();
|
||||||
|
|
||||||
|
static {
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.PARTIAL);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.EAN8);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.UPCE);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.ISBN10);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.UPCA);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.EAN13);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.ISBN13);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.I25);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.DATABAR);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.DATABAR_EXP);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.CODABAR);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.CODE39);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.PDF417);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.QRCODE);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.CODE93);
|
||||||
|
ALL_FORMATS.add(BarcodeFormat.CODE128);
|
||||||
|
}
|
||||||
|
|
||||||
|
public BarcodeFormat(int id, String name) {
|
||||||
|
mId = id;
|
||||||
|
mName = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return mId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return mName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static BarcodeFormat getFormatById(int id) {
|
||||||
|
for(BarcodeFormat format : ALL_FORMATS) {
|
||||||
|
if(format.getId() == id) {
|
||||||
|
return format;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return BarcodeFormat.NONE;
|
||||||
|
}
|
||||||
|
}
|
@@ -23,6 +23,12 @@ import android.view.ViewGroup;
|
|||||||
import android.widget.FrameLayout;
|
import android.widget.FrameLayout;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.EnumMap;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
import net.sourceforge.zbar.ImageScanner;
|
import net.sourceforge.zbar.ImageScanner;
|
||||||
import net.sourceforge.zbar.Image;
|
import net.sourceforge.zbar.Image;
|
||||||
import net.sourceforge.zbar.Symbol;
|
import net.sourceforge.zbar.Symbol;
|
||||||
@@ -32,6 +38,9 @@ import net.sourceforge.zbar.Config;
|
|||||||
public class ZBarScannerActivity extends Activity
|
public class ZBarScannerActivity extends Activity
|
||||||
implements SurfaceHolder.Callback {
|
implements SurfaceHolder.Callback {
|
||||||
|
|
||||||
|
//for barcode types
|
||||||
|
private Collection<ZBarcodeFormat> mFormats = null;
|
||||||
|
|
||||||
// Config ----------------------------------------------------------
|
// Config ----------------------------------------------------------
|
||||||
|
|
||||||
private static int autoFocusInterval = 500; // Interval between AFcallback and next AF attempt.
|
private static int autoFocusInterval = 500; // Interval between AFcallback and next AF attempt.
|
||||||
@@ -93,6 +102,11 @@ implements SurfaceHolder.Callback {
|
|||||||
scanner.setConfig(0, Config.X_DENSITY, 3);
|
scanner.setConfig(0, Config.X_DENSITY, 3);
|
||||||
scanner.setConfig(0, Config.Y_DENSITY, 3);
|
scanner.setConfig(0, Config.Y_DENSITY, 3);
|
||||||
|
|
||||||
|
// Set the config for barcode formats
|
||||||
|
for(ZBarcodeFormat format : getFormats()) {
|
||||||
|
scanner.setConfig(format.getId(), Config.ENABLE, 1);
|
||||||
|
}
|
||||||
|
|
||||||
// Set content view
|
// Set content view
|
||||||
setContentView(getResourceId("layout/cszbarscanner"));
|
setContentView(getResourceId("layout/cszbarscanner"));
|
||||||
|
|
||||||
@@ -126,6 +140,7 @@ implements SurfaceHolder.Callback {
|
|||||||
// Add preview SurfaceView to the screen
|
// Add preview SurfaceView to the screen
|
||||||
FrameLayout scannerView = (FrameLayout) findViewById(getResourceId("id/csZbarScannerView"));
|
FrameLayout scannerView = (FrameLayout) findViewById(getResourceId("id/csZbarScannerView"));
|
||||||
scannerView.addView(scannerSurface);
|
scannerView.addView(scannerSurface);
|
||||||
|
|
||||||
findViewById(getResourceId("id/csZbarScannerTitle")).bringToFront();
|
findViewById(getResourceId("id/csZbarScannerTitle")).bringToFront();
|
||||||
findViewById(getResourceId("id/csZbarScannerInstructions")).bringToFront();
|
findViewById(getResourceId("id/csZbarScannerInstructions")).bringToFront();
|
||||||
findViewById(getResourceId("id/csZbarScannerSightContainer")).bringToFront();
|
findViewById(getResourceId("id/csZbarScannerSightContainer")).bringToFront();
|
||||||
@@ -170,6 +185,10 @@ implements SurfaceHolder.Callback {
|
|||||||
} else {
|
} else {
|
||||||
camParams.setFlashMode(Camera.Parameters.FLASH_MODE_AUTO);
|
camParams.setFlashMode(Camera.Parameters.FLASH_MODE_AUTO);
|
||||||
}
|
}
|
||||||
|
if (android.os.Build.VERSION.SDK_INT >= 14) {
|
||||||
|
camParams.setFocusMode(Camera.Parameters.FOCUS_MODE_CONTINUOUS_PICTURE);
|
||||||
|
}
|
||||||
|
|
||||||
try { camera.setParameters(camParams); }
|
try { camera.setParameters(camParams); }
|
||||||
catch (RuntimeException e) {
|
catch (RuntimeException e) {
|
||||||
Log.d("csZBar", "Unsupported camera parameter reported for flash mode: "+flashMode);
|
Log.d("csZBar", "Unsupported camera parameter reported for flash mode: "+flashMode);
|
||||||
@@ -347,6 +366,14 @@ implements SurfaceHolder.Callback {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Collection<ZBarcodeFormat> getFormats() {
|
||||||
|
if(mFormats == null) {
|
||||||
|
return ZBarcodeFormat.ALL_FORMATS;
|
||||||
|
}
|
||||||
|
return mFormats;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Start the camera preview if possible.
|
// Start the camera preview if possible.
|
||||||
// If start is attempted but fails, exit with error message.
|
// If start is attempted but fails, exit with error message.
|
||||||
private void tryStartPreview () {
|
private void tryStartPreview () {
|
||||||
@@ -358,7 +385,7 @@ implements SurfaceHolder.Callback {
|
|||||||
camera.setPreviewDisplay(holder);
|
camera.setPreviewDisplay(holder);
|
||||||
camera.setPreviewCallback(previewCb);
|
camera.setPreviewCallback(previewCb);
|
||||||
camera.startPreview();
|
camera.startPreview();
|
||||||
camera.autoFocus(autoFocusCb); // We are not using any of the
|
//camera.autoFocus(autoFocusCb); // We are not using any of the
|
||||||
// continuous autofocus modes as that does not seem to work
|
// continuous autofocus modes as that does not seem to work
|
||||||
// well with flash setting of "on"... At least with this
|
// well with flash setting of "on"... At least with this
|
||||||
// simple and stupid focus method, we get to turn the flash
|
// simple and stupid focus method, we get to turn the flash
|
||||||
|
72
android/ZBarcodeFormat.java
Normal file
72
android/ZBarcodeFormat.java
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
package org.cloudsky.cordovaPlugins;
|
||||||
|
|
||||||
|
import net.sourceforge.zbar.Symbol;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
|
||||||
|
public class ZBarcodeFormat {
|
||||||
|
private int mId;
|
||||||
|
private String mName;
|
||||||
|
|
||||||
|
public static final ZBarcodeFormat NONE = new ZBarcodeFormat(Symbol.NONE, "NONE");
|
||||||
|
public static final ZBarcodeFormat PARTIAL = new ZBarcodeFormat(Symbol.PARTIAL, "PARTIAL");
|
||||||
|
public static final ZBarcodeFormat EAN8 = new ZBarcodeFormat(Symbol.EAN8, "EAN8");
|
||||||
|
public static final ZBarcodeFormat UPCE = new ZBarcodeFormat(Symbol.UPCE, "UPCE");
|
||||||
|
public static final ZBarcodeFormat ISBN10 = new ZBarcodeFormat(Symbol.ISBN10, "ISBN10");
|
||||||
|
public static final ZBarcodeFormat UPCA = new ZBarcodeFormat(Symbol.UPCA, "UPCA");
|
||||||
|
public static final ZBarcodeFormat EAN13 = new ZBarcodeFormat(Symbol.EAN13, "EAN13");
|
||||||
|
public static final ZBarcodeFormat ISBN13 = new ZBarcodeFormat(Symbol.ISBN13, "ISBN13");
|
||||||
|
public static final ZBarcodeFormat I25 = new ZBarcodeFormat(Symbol.I25, "I25");
|
||||||
|
public static final ZBarcodeFormat DATABAR = new ZBarcodeFormat(Symbol.DATABAR, "DATABAR");
|
||||||
|
public static final ZBarcodeFormat DATABAR_EXP = new ZBarcodeFormat(Symbol.DATABAR_EXP, "DATABAR_EXP");
|
||||||
|
public static final ZBarcodeFormat CODABAR = new ZBarcodeFormat(Symbol.CODABAR, "CODABAR");
|
||||||
|
public static final ZBarcodeFormat CODE39 = new ZBarcodeFormat(Symbol.CODE39, "CODE39");
|
||||||
|
public static final ZBarcodeFormat PDF417 = new ZBarcodeFormat(Symbol.PDF417, "PDF417");
|
||||||
|
public static final ZBarcodeFormat QRCODE = new ZBarcodeFormat(Symbol.QRCODE, "QRCODE");
|
||||||
|
public static final ZBarcodeFormat CODE93 = new ZBarcodeFormat(Symbol.CODE93, "CODE93");
|
||||||
|
public static final ZBarcodeFormat CODE128 = new ZBarcodeFormat(Symbol.CODE128, "CODE128");
|
||||||
|
|
||||||
|
public static final List<ZBarcodeFormat> ALL_FORMATS = new ArrayList<ZBarcodeFormat>();
|
||||||
|
|
||||||
|
static {
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.PARTIAL);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.EAN8);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.UPCE);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.ISBN10);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.UPCA);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.EAN13);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.ISBN13);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.I25);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.DATABAR);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.DATABAR_EXP);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.CODABAR);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.CODE39);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.PDF417);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.QRCODE);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.CODE93);
|
||||||
|
ALL_FORMATS.add(ZBarcodeFormat.CODE128);
|
||||||
|
}
|
||||||
|
|
||||||
|
public ZBarcodeFormat(int id, String name) {
|
||||||
|
mId = id;
|
||||||
|
mName = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getId() {
|
||||||
|
return mId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getName() {
|
||||||
|
return mName;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ZBarcodeFormat getFormatById(int id) {
|
||||||
|
for(ZBarcodeFormat format : ALL_FORMATS) {
|
||||||
|
if(format.getId() == id) {
|
||||||
|
return format;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ZBarcodeFormat.NONE;
|
||||||
|
}
|
||||||
|
}
|
@@ -44,6 +44,7 @@
|
|||||||
<color name="csZbarScannerBackground">#000000</color>
|
<color name="csZbarScannerBackground">#000000</color>
|
||||||
</config-file>
|
</config-file>
|
||||||
<resource-file src="android/res/layout/cszbarscanner.xml" target="res/layout/cszbarscanner.xml" />
|
<resource-file src="android/res/layout/cszbarscanner.xml" target="res/layout/cszbarscanner.xml" />
|
||||||
|
<source-file src="android/ZBarcodeFormat.java" target-dir="src/org/cloudsky/cordovaPlugins" />
|
||||||
<source-file src="android/ZBar.java" target-dir="src/org/cloudsky/cordovaPlugins" />
|
<source-file src="android/ZBar.java" target-dir="src/org/cloudsky/cordovaPlugins" />
|
||||||
<source-file src="android/ZBarScannerActivity.java" target-dir="src/org/cloudsky/cordovaPlugins" />
|
<source-file src="android/ZBarScannerActivity.java" target-dir="src/org/cloudsky/cordovaPlugins" />
|
||||||
<source-file src="android/libs/zbar.jar" target-dir="libs" />
|
<source-file src="android/libs/zbar.jar" target-dir="libs" />
|
||||||
|
Reference in New Issue
Block a user