/* * Copyright (C) 2008 ZXing authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.google.zxing.client.android; import idv.Zero.KerKerInput.R; import com.google.zxing.BarcodeFormat; import com.google.zxing.BinaryBitmap; import com.google.zxing.DecodeHintType; import com.google.zxing.MultiFormatReader; import com.google.zxing.ReaderException; import com.google.zxing.Result; import com.google.zxing.common.GlobalHistogramBinarizer; import android.os.Bundle; import android.os.Handler; import android.os.Looper; import android.os.Message; import android.util.Log; import java.util.Hashtable; import java.util.Vector; /** * This thread does all the heavy lifting of decoding the images. * * @author dswitkin@google.com (Daniel Switkin) */ final class DecodeThread extends Thread { public static final String BARCODE_BITMAP = "barcode_bitmap"; private static final String TAG = "DecodeThread"; private Handler handler; private final MultiFormatReader multiFormatReader; private ASyncBarcodeDecoder activity; DecodeThread(ASyncBarcodeDecoder iactivity) { activity = iactivity; multiFormatReader = new MultiFormatReader(); setDecodeAllMode(); } Handler getHandler() { return handler; } @Override public void run() { Looper.prepare(); handler = new Handler() { @Override public void handleMessage(Message message) { switch (message.what) { case R.id.decode: decode((byte[]) message.obj, message.arg1, message.arg2); break; case R.id.quit: Looper.myLooper().quit(); break; } } }; Looper.loop(); } private void setDecodeAllMode() { Hashtable<DecodeHintType, Object> hints = new Hashtable<DecodeHintType, Object>(3); Vector<BarcodeFormat> vector = new Vector<BarcodeFormat>(8); vector.addElement(BarcodeFormat.UPC_A); vector.addElement(BarcodeFormat.UPC_E); vector.addElement(BarcodeFormat.EAN_13); vector.addElement(BarcodeFormat.EAN_8); vector.addElement(BarcodeFormat.CODE_39); vector.addElement(BarcodeFormat.CODE_128); vector.addElement(BarcodeFormat.QR_CODE); hints.put(DecodeHintType.POSSIBLE_FORMATS, vector); multiFormatReader.setHints(hints); } /** * Decode the data within the viewfinder rectangle, and time how long it took. For efficiency, * reuse the same reader objects from one decode to the next. * * @param data The YUV preview frame. * @param width The width of the preview frame. * @param height The height of the preview frame. */ private void decode(byte[] data, int width, int height) { long start = System.currentTimeMillis(); boolean success; Result rawResult = null; BaseLuminanceSource source = CameraManager.get().buildLuminanceSource(data, width, height); BinaryBitmap bitmap = new BinaryBitmap(new GlobalHistogramBinarizer(source)); try { rawResult = multiFormatReader.decodeWithState(bitmap); success = true; } catch (ReaderException e) { success = false; } long end = System.currentTimeMillis(); if (success) { Log.v(TAG, "Found barcode (" + (end - start) + " ms):\n" + rawResult.toString()); Message message = Message.obtain(activity.getHandler(), R.id.decode_succeeded, rawResult); Bundle bundle = new Bundle(); bundle.putParcelable(BARCODE_BITMAP, source.renderCroppedGreyscaleBitmap()); message.setData(bundle); message.sendToTarget(); } else { Message message = Message.obtain(activity.getHandler(), R.id.decode_failed); message.sendToTarget(); } } }