package com.google.zxing.client.j2me;
-import com.google.zxing.MonochromeBitmapSource;
-import com.google.zxing.MultiFormatReader;
-import com.google.zxing.Reader;
-import com.google.zxing.ReaderException;
-import com.google.zxing.Result;
-
+import com.google.zxing.client.result.BookmarkDoCoMoResult;
+import com.google.zxing.client.result.EmailAddressResult;
+import com.google.zxing.client.result.EmailDoCoMoResult;
+import com.google.zxing.client.result.ParsedReaderResult;
+import com.google.zxing.client.result.ParsedReaderResultType;
+import com.google.zxing.client.result.UPCParsedResult;
+import com.google.zxing.client.result.URIParsedResult;
+
+import javax.microedition.io.ConnectionNotFoundException;
import javax.microedition.lcdui.Alert;
import javax.microedition.lcdui.AlertType;
import javax.microedition.lcdui.Canvas;
import javax.microedition.lcdui.CommandListener;
import javax.microedition.lcdui.Display;
import javax.microedition.lcdui.Displayable;
-import javax.microedition.lcdui.Graphics;
-import javax.microedition.lcdui.Image;
import javax.microedition.media.Manager;
import javax.microedition.media.MediaException;
import javax.microedition.media.Player;
*/
public final class ZXingMIDlet extends MIDlet {
+ private Canvas canvas;
private Player player;
private VideoControl videoControl;
+ Player getPlayer() {
+ return player;
+ }
+
+ VideoControl getVideoControl() {
+ return videoControl;
+ }
+
protected void startApp() throws MIDletStateChangeException {
try {
- player = Manager.createPlayer("capture://video");
+ player = createPlayer();
player.realize();
+ AdvancedMultimediaManager.setZoom(player);
videoControl = (VideoControl) player.getControl("VideoControl");
- Displayable canvas = new VideoCanvas();
+ canvas = new VideoCanvas(this);
+ canvas.setFullScreenMode(true);
videoControl.initDisplayMode(VideoControl.USE_DIRECT_VIDEO, canvas);
videoControl.setDisplayLocation(0, 0);
videoControl.setDisplaySize(canvas.getWidth(), canvas.getHeight());
videoControl.setVisible(true);
- /*
- FocusControl focusControl = (FocusControl)
- player.getControl("javax.microedition.amms.control.FocusControl");
- if (focusControl != null) {
- if (focusControl.isAutoFocusSupported()) {
- focusControl.setFocus(FocusControl.AUTO);
- }
- if (focusControl.isMacroSupported()) {
- focusControl.setMacro(true);
- }
- } else {
- System.out.println("FocusControl not supported");
- }
- */
- Display.getDisplay(this).setCurrent(canvas);
player.start();
+ Display.getDisplay(this).setCurrent(canvas);
} catch (IOException ioe) {
throw new MIDletStateChangeException(ioe.toString());
} catch (MediaException me) {
}
}
+ private static Player createPlayer() throws IOException, MediaException {
+ // Try a workaround for Nokias, which want to use capture://image in some cases
+ Player player = null;
+ String platform = System.getProperty("microedition.platform");
+ if (platform != null && platform.indexOf("Nokia") >= 0) {
+ try {
+ player = Manager.createPlayer("capture://image");
+ } catch (MediaException me) {
+ // if this fails, just continue with capture://video
+ }
+ }
+ if (player == null) {
+ player = Manager.createPlayer("capture://video");
+ }
+ return player;
+ }
+
protected void pauseApp() {
if (player != null) {
try {
protected void destroyApp(boolean unconditional) {
if (player != null) {
+ videoControl = null;
+ try {
+ player.stop();
+ } catch (MediaException me) {
+ // continue
+ }
+ player.deallocate();
player.close();
player = null;
- videoControl = null;
}
}
+ void stop() {
+ destroyApp(false);
+ notifyDestroyed();
+ }
+
// Convenience methods to show dialogs
+ private void showOpenURL(String title, final String display, final String uri) {
+ Alert alert = new Alert(title, display, null, AlertType.CONFIRMATION);
+ alert.setTimeout(Alert.FOREVER);
+ Command yes = new Command("Yes", Command.OK, 1);
+ alert.addCommand(yes);
+ Command no = new Command("No", Command.CANCEL, 1);
+ alert.addCommand(no);
+ CommandListener listener = new CommandListener() {
+ public void commandAction(Command command, Displayable displayable) {
+ if (command.getCommandType() == Command.OK) {
+ try {
+ platformRequest(uri);
+ } catch (ConnectionNotFoundException cnfe) {
+ showError(cnfe);
+ } finally {
+ stop();
+ }
+ } else {
+ // cancel
+ Display.getDisplay(ZXingMIDlet.this).setCurrent(canvas);
+ }
+ }
+ };
+ alert.setCommandListener(listener);
+ showAlert(alert);
+ }
+
private void showAlert(String title, String text) {
Alert alert = new Alert(title, text, null, AlertType.INFO);
alert.setTimeout(Alert.FOREVER);
showAlert(alert);
}
- private void showError(Throwable t) {
- showAlert(new Alert("Error", t.getMessage(), null, AlertType.ERROR));
+ void showError(Throwable t) {
+ String message = t.getMessage();
+ if (message != null && message.length() > 0) {
+ showError(message);
+ } else {
+ showError(t.toString());
+ }
}
+ void showError(String message) {
+ showAlert(new Alert("Error", message, null, AlertType.ERROR));
+ }
+
private void showAlert(Alert alert) {
Display display = Display.getDisplay(this);
- display.setCurrent(alert, display.getCurrent());
+ display.setCurrent(alert, canvas);
}
- private class VideoCanvas extends Canvas implements CommandListener {
- private final Command decode = new Command("Decode", Command.SCREEN, 1);
- private final Command exit = new Command("Exit", Command.EXIT, 1);
- private VideoCanvas() {
- addCommand(decode);
- addCommand(exit);
- setCommandListener(this);
- }
- protected void paint(Graphics graphics) {
- // do nothing
- }
- protected void keyPressed(int keyCode) {
- if (FIRE == getGameAction(keyCode)) {
- new SnapshotThread().start();
- }
- }
- public void commandAction(Command command, Displayable displayable) {
- if (command.equals(decode)) {
- new SnapshotThread().start();
- } else if (command.equals(exit)) {
- destroyApp(false);
- notifyDestroyed();
- }
- }
- }
-
- // TODO make sure we do not start two threads at once
- private class SnapshotThread extends Thread {
- public void run() {
- try {
- player.stop();
- byte[] snapshot = videoControl.getSnapshot(null);
- Image capturedImage = Image.createImage(snapshot, 0, snapshot.length);
- MonochromeBitmapSource source = new LCDUIImageMonochromeBitmapSource(capturedImage);
- Reader reader = new MultiFormatReader();
- Result result = reader.decode(source);
- showAlert("Barcode detected", result.getText());
- } catch (ReaderException re) {
- showError(re);
- } catch (MediaException me) {
- showError(me);
- } catch (Throwable t) {
- showError(t);
- } finally {
- try {
- player.start();
- } catch (MediaException me) {
- // continue?
- showError(me);
- }
- }
-
+ void handleDecodedText(String text) {
+ ParsedReaderResult result = ParsedReaderResult.parseReaderResult(text);
+ ParsedReaderResultType type = result.getType();
+ if (type.equals(ParsedReaderResultType.URI)) {
+ String uri = ((URIParsedResult) result).getURI();
+ showOpenURL("Open web page?", uri, uri);
+ } else if (type.equals(ParsedReaderResultType.BOOKMARK)) {
+ String uri = ((BookmarkDoCoMoResult) result).getURI();
+ showOpenURL("Open web page?", uri, uri);
+ } else if (type.equals(ParsedReaderResultType.EMAIL)) {
+ String email = ((EmailDoCoMoResult) result).getTo();
+ showOpenURL("Compose e-mail?", email, "mailto:" + email);
+ } else if (type.equals(ParsedReaderResultType.EMAIL_ADDRESS)) {
+ String email = ((EmailAddressResult) result).getEmailAddress();
+ showOpenURL("Compose e-mail?", email, "mailto:" + email);
+ } else if (type.equals(ParsedReaderResultType.UPC)) {
+ String upc = ((UPCParsedResult) result).getUPC();
+ String uri = "http://www.upcdatabase.com/item.asp?upc=" + upc;
+ showOpenURL("Look up UPC?", upc, uri);
+ } else {
+ showAlert("Barcode detected", result.getDisplayResult());
}
}