/* * 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 org.ovirt.mobile.movirt.camera; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.Bundle; import android.os.Handler; import android.os.Message; import com.google.zxing.Result; import com.google.zxing.client.android.R; import org.ovirt.mobile.movirt.ui.CameraActivity; /** * This class handles all the messaging which comprises the state machine for capture. * * @author dswitkin@google.com (Daniel Switkin) * modified by Nika */ public final class CaptureActivityHandler extends Handler { public static final int ZXING_RESTART = 0x7f0b0008; private static final String TAG = CaptureActivityHandler.class.getSimpleName(); private final CameraActivity activity; private final DecodeThread decodeThread; private final CameraManager cameraManager; private State state; public CaptureActivityHandler(CameraActivity activity, CameraManager cameraManager) { this.activity = activity; decodeThread = new DecodeThread(activity); decodeThread.start(); state = State.SUCCESS; // Start ourselves capturing previews and decoding. this.cameraManager = cameraManager; cameraManager.startPreview(); restartPreviewAndDecode(); } @Override public void handleMessage(Message message) { switch (message.what) { case ZXING_RESTART: restartPreviewAndDecode(); break; case R.id.zxing_decode_succeeded: state = State.SUCCESS; Bundle bundle = message.getData(); Bitmap barcode = null; if (bundle != null) { byte[] compressedBitmap = bundle.getByteArray(DecodeThread.BARCODE_BITMAP); if (compressedBitmap != null) { barcode = BitmapFactory.decodeByteArray(compressedBitmap, 0, compressedBitmap.length, null); // Mutable copy: barcode = barcode.copy(Bitmap.Config.ARGB_8888, true); } } activity.handleDecode((Result) message.obj, barcode); break; case R.id.zxing_decode_failed: // We're decoding as fast as possible, so when one decode fails, start another. state = State.PREVIEW; cameraManager.requestPreviewFrame(decodeThread.getHandler(), R.id.zxing_decode); break; } } public void quitSynchronously() { state = State.DONE; cameraManager.stopPreview(); Message quit = Message.obtain(decodeThread.getHandler(), R.id.zxing_back_button); quit.sendToTarget(); try { // Wait at most half a second; should be enough time, and onPause() will timeout quickly decodeThread.join(500L); } catch (InterruptedException e) { // continue } // Be absolutely sure we don't send any queued up messages removeMessages(R.id.zxing_decode_succeeded); removeMessages(R.id.zxing_decode_failed); } private void restartPreviewAndDecode() { if (state == State.SUCCESS) { state = State.PREVIEW; cameraManager.requestPreviewFrame(decodeThread.getHandler(), R.id.zxing_decode); activity.drawViewfinder(); } } private enum State { PREVIEW, SUCCESS, DONE } }