diff --git a/androidtest/AndroidManifest.xml b/androidtest/AndroidManifest.xml
index 8bff0d559..f443b8f78 100755
--- a/androidtest/AndroidManifest.xml
+++ b/androidtest/AndroidManifest.xml
@@ -15,13 +15,16 @@
limitations under the License.
-->
+ package="com.google.zxing.client.androidtest"
+ android:versionName="1.0"
+ android:versionCode="1">
+ android:label="@string/app_name"
+ android:screenOrientation="portrait">
@@ -31,7 +34,8 @@
android:screenOrientation="landscape">
+ android:label="@string/benchmark_name"
+ android:screenOrientation="portrait"/>
diff --git a/androidtest/res/layout/camera_parameters.xml b/androidtest/res/layout/camera_parameters.xml
new file mode 100755
index 000000000..2dc2d7b75
--- /dev/null
+++ b/androidtest/res/layout/camera_parameters.xml
@@ -0,0 +1,50 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/androidtest/res/layout/camera_test.xml b/androidtest/res/layout/camera_test.xml
index 30a30a817..b8fc4c2e1 100755
--- a/androidtest/res/layout/camera_test.xml
+++ b/androidtest/res/layout/camera_test.xml
@@ -41,22 +41,15 @@
android:layout_weight="1"
android:background="@color/transparent"/>
-
-
-
-
-
+
diff --git a/androidtest/res/layout/test.xml b/androidtest/res/layout/test.xml
index 1c733c03b..e29dffd2a 100755
--- a/androidtest/res/layout/test.xml
+++ b/androidtest/res/layout/test.xml
@@ -20,14 +20,14 @@
android:gravity="center_horizontal"
android:padding="10px">
-
-
+
+ android:text="@string/get_camera_parameters"/>
+
+
+
diff --git a/androidtest/res/values/strings.xml b/androidtest/res/values/strings.xml
index ac53797ee..d3c96a276 100755
--- a/androidtest/res/values/strings.xml
+++ b/androidtest/res/values/strings.xml
@@ -15,31 +15,41 @@
limitations under the License.
-->
+ About
+ A utility written by the ZXing Team to help with the development
+ of Barcode Scanner.
ZXing Test
- Scan anything
- Scan product
- Scan QR Code
- Search Book Contents
- Test camera
- Encode URL
- Encode email
- Encode phone
- Encode SMS
- Encode contact
- Encode location
- Encode bad data
- No barcode found
- "The user gave up and pressed Back"
- Found barcode
- Press the shutter button or Search to save test images to the
- SD card. Press DPAD_CENTER to trigger autofocus.
- Save succeeded
- Save failed - is the SD card installed?
- Share via barcode
ZXing Benchmark
Place images in /sdcard/zxingbenchmark, then check \"adb logcat\"
for results. Turn on Airplane Mode first for more reliable results.
Run benchmark
- Benchmark running...\u2026
+ Benchmark running\u2026
+
+ Encode bad data
+ Encode contact
+ Encode email
+ Encode location
+ Encode phone
+ Encode SMS
+ Encode URL
+
+ Get camera parameters
+ OK
+ Collecting camera parameters to email to ZXing Team\u2026
+
+ No barcode found
+ "The user gave up and pressed Back"
+ Found barcode
+
+ Save failed - is the SD card installed?
+ Save succeeded
+ Scan anything
+ Scan product
+ Scan QR Code
+ Search Book Contents
+ Share via barcode
+ Press the shutter button or Search to save test images to the
+ SD card. Press DPAD_CENTER to trigger autofocus.
+ Take test photos
diff --git a/androidtest/src/com/google/zxing/client/androidtest/CameraManager.java b/androidtest/src/com/google/zxing/client/androidtest/CameraManager.java
index 05c5990da..f70b091cb 100755
--- a/androidtest/src/com/google/zxing/client/androidtest/CameraManager.java
+++ b/androidtest/src/com/google/zxing/client/androidtest/CameraManager.java
@@ -65,13 +65,18 @@ final class CameraManager {
mPreviewing = false;
}
- public void openDriver(SurfaceHolder holder) throws IOException {
- // "throws IOException added to accommodate Android 1.5
+ // Throws IOException added to accommodate Android 1.5.
+ public String openDriver(SurfaceHolder holder, boolean getParameters) throws IOException {
+ String result = null;
if (mCamera == null) {
mCamera = Camera.open();
mCamera.setPreviewDisplay(holder);
+ if (getParameters) {
+ result = collectCameraParameters();
+ }
setCameraParameters();
}
+ return result;
}
public void closeDriver() {
@@ -110,7 +115,7 @@ final class CameraManager {
if (mCamera != null && mPreviewing) {
mPreviewHandler = handler;
mPreviewMessage = message;
- mCamera.setOneShotPreviewCallback(previewCallback);
+ mCamera.setPreviewCallback(previewCallback);
}
}
@@ -132,7 +137,7 @@ final class CameraManager {
*/
public Rect getFramingRect() {
if (mFramingRect == null) {
- int width = mScreenResolution.x;
+ int width = mScreenResolution.x * 3 / 4;
int height = mScreenResolution.y * 3 / 4;
int leftOffset = (mScreenResolution.x - width) / 2;
int topOffset = (mScreenResolution.y - height) / 2;
@@ -148,6 +153,7 @@ final class CameraManager {
private final Camera.PreviewCallback previewCallback = new Camera.PreviewCallback() {
public void onPreviewFrame(byte[] data, Camera camera) {
if (mPreviewHandler != null) {
+ mCamera.setPreviewCallback(null);
Message message = mPreviewHandler.obtainMessage(mPreviewMessage,
mScreenResolution.x, mScreenResolution.y, data);
message.sendToTarget();
@@ -179,6 +185,19 @@ final class CameraManager {
mCamera.setParameters(parameters);
}
+ private String collectCameraParameters() {
+ Camera.Parameters parameters = mCamera.getParameters();
+ String[] params = parameters.flatten().split(";");
+ StringBuffer result = new StringBuffer();
+ result.append("Default camera parameters:");
+ for (String param : params) {
+ result.append("\n ");
+ result.append(param);
+ }
+ result.append('\n');
+ return result.toString();
+ }
+
private Point getScreenResolution() {
if (mScreenResolution == null) {
WindowManager wm = (WindowManager) mContext.getSystemService(Context.WINDOW_SERVICE);
diff --git a/androidtest/src/com/google/zxing/client/androidtest/CameraTestActivity.java b/androidtest/src/com/google/zxing/client/androidtest/CameraTestActivity.java
index c23bec108..bc41a8c99 100755
--- a/androidtest/src/com/google/zxing/client/androidtest/CameraTestActivity.java
+++ b/androidtest/src/com/google/zxing/client/androidtest/CameraTestActivity.java
@@ -17,6 +17,8 @@
package com.google.zxing.client.androidtest;
import android.app.Activity;
+import android.content.Intent;
+import android.os.Build;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
@@ -31,7 +33,11 @@ import java.io.IOException;
public final class CameraTestActivity extends Activity implements SurfaceHolder.Callback {
- private SaveThread mSaveThread;
+ public static final String GET_CAMERA_PARAMETERS = "GET_CAMERA_PARAMETERS";
+ private static final String[] EMAIL_ADDRESS = {"zxing@googlegroups.com"};
+
+ private SaveThread mSaveThread = null;
+ private boolean mGetCameraParameters;
@Override
public void onCreate(Bundle icicle) {
@@ -41,8 +47,13 @@ public final class CameraTestActivity extends Activity implements SurfaceHolder.
Window window = getWindow();
window.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
window.addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
- setContentView(R.layout.camera_test);
+ mGetCameraParameters = getIntent().getBooleanExtra(GET_CAMERA_PARAMETERS, false);
+ if (mGetCameraParameters) {
+ setContentView(R.layout.camera_parameters);
+ } else {
+ setContentView(R.layout.camera_test);
+ }
CameraManager.init(getApplication());
SurfaceView surfaceView = (SurfaceView) findViewById(R.id.preview_view);
@@ -54,7 +65,7 @@ public final class CameraTestActivity extends Activity implements SurfaceHolder.
@Override
protected void onResume() {
super.onResume();
- if (mSaveThread == null) {
+ if (mSaveThread == null && !mGetCameraParameters) {
mSaveThread = new SaveThread(this, CameraManager.get().getFramingRect());
mSaveThread.start();
}
@@ -96,28 +107,33 @@ public final class CameraTestActivity extends Activity implements SurfaceHolder.
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
- if (keyCode == KeyEvent.KEYCODE_DPAD_CENTER) {
- if (event.getRepeatCount() == 0) {
- CameraManager.get().requestAutoFocus(mHandler, R.id.auto_focus);
+ if (!mGetCameraParameters) {
+ if (keyCode == KeyEvent.KEYCODE_DPAD_CENTER) {
+ if (event.getRepeatCount() == 0) {
+ CameraManager.get().requestAutoFocus(mHandler, R.id.auto_focus);
+ }
+ return true;
+ } else if (keyCode == KeyEvent.KEYCODE_CAMERA || keyCode == KeyEvent.KEYCODE_SEARCH) {
+ if (event.getRepeatCount() == 0) {
+ CameraManager.get().requestPreviewFrame(mSaveThread.mHandler, R.id.save);
+ }
+ return true;
}
- return true;
- } else if (keyCode == KeyEvent.KEYCODE_CAMERA || keyCode == KeyEvent.KEYCODE_SEARCH) {
- if (event.getRepeatCount() == 0) {
- CameraManager.get().requestPreviewFrame(mSaveThread.mHandler, R.id.save);
- }
- return true;
}
return super.onKeyDown(keyCode, event);
}
public void surfaceCreated(SurfaceHolder holder) {
try {
- CameraManager.get().openDriver(holder);
- } catch (IOException ioe) {
+ String parameters = CameraManager.get().openDriver(holder, mGetCameraParameters);
+ CameraManager.get().startPreview();
+ if (mGetCameraParameters) {
+ collectStatsAndSendEmail(parameters);
+ }
+ } catch (IOException e) {
// IOException clause added for Android 1.5
- throw new RuntimeException(ioe);
+ throw new RuntimeException(e);
}
- CameraManager.get().startPreview();
}
public void surfaceDestroyed(SurfaceHolder holder) {
@@ -128,4 +144,49 @@ public final class CameraTestActivity extends Activity implements SurfaceHolder.
}
+ private void collectStatsAndSendEmail(String parameters) {
+ StringBuffer result = new StringBuffer();
+ result.append("Device info:");
+ result.append("\n Board: ");
+ result.append(Build.BOARD);
+ result.append("\n Brand: ");
+ result.append(Build.BRAND);
+ result.append("\n Device: ");
+ result.append(Build.DEVICE);
+ result.append("\n Display: ");
+ result.append(Build.DISPLAY);
+ result.append("\n Fingerprint: ");
+ result.append(Build.FINGERPRINT);
+ result.append("\n Host: ");
+ result.append(Build.HOST);
+ result.append("\n ID: ");
+ result.append(Build.ID);
+ result.append("\n Model: ");
+ result.append(Build.MODEL);
+ result.append("\n Product: ");
+ result.append(Build.PRODUCT);
+ result.append("\n Tags: ");
+ result.append(Build.TAGS);
+ result.append("\n Type: ");
+ result.append(Build.TYPE);
+ result.append("\n User: ");
+ result.append(Build.USER);
+ result.append("\n Version Incremental: ");
+ result.append(Build.VERSION.INCREMENTAL);
+ result.append("\n Version Release: ");
+ result.append(Build.VERSION.RELEASE);
+ result.append("\n Version SDK: ");
+ result.append(Build.VERSION.SDK);
+
+ result.append("\n\n");
+ result.append(parameters);
+
+ Intent intent = new Intent(Intent.ACTION_SEND);
+ intent.putExtra(Intent.EXTRA_EMAIL, EMAIL_ADDRESS);
+ intent.putExtra(Intent.EXTRA_SUBJECT, "Camera parameters report");
+ intent.putExtra(Intent.EXTRA_TEXT, result.toString());
+ intent.setType("text/plain");
+ startActivity(intent);
+ }
+
}
diff --git a/androidtest/src/com/google/zxing/client/androidtest/ZXingTestActivity.java b/androidtest/src/com/google/zxing/client/androidtest/ZXingTestActivity.java
index 6560ec518..d8f76c209 100755
--- a/androidtest/src/com/google/zxing/client/androidtest/ZXingTestActivity.java
+++ b/androidtest/src/com/google/zxing/client/androidtest/ZXingTestActivity.java
@@ -19,66 +19,87 @@ package com.google.zxing.client.androidtest;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.Intent;
+import android.content.pm.PackageInfo;
+import android.content.pm.PackageManager;
import android.os.Bundle;
import android.provider.Contacts;
+import android.view.Menu;
+import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
public final class ZXingTestActivity extends Activity {
+ private static final int ABOUT_ID = Menu.FIRST;
+ private static final String PACKAGE_NAME = "com.google.zxing.client.androidtest";
+
@Override
public void onCreate(Bundle icicle) {
super.onCreate(icicle);
-
setContentView(R.layout.test);
- View test_camera = findViewById(R.id.test_camera);
- test_camera.setOnClickListener(mTestCamera);
-
- View run_benchmark = findViewById(R.id.run_benchmark);
- run_benchmark.setOnClickListener(mRunBenchmark);
-
- View scan_product = findViewById(R.id.scan_product);
- scan_product.setOnClickListener(mScanProduct);
-
- View scan_qr_code = findViewById(R.id.scan_qr_code);
- scan_qr_code.setOnClickListener(mScanQRCode);
-
- View scan_anything = findViewById(R.id.scan_anything);
- scan_anything.setOnClickListener(mScanAnything);
-
- View search_book_contents = findViewById(R.id.search_book_contents);
- search_book_contents.setOnClickListener(mSearchBookContents);
-
- View encode_url = findViewById(R.id.encode_url);
- encode_url.setOnClickListener(mEncodeURL);
-
- View encode_email = findViewById(R.id.encode_email);
- encode_email.setOnClickListener(mEncodeEmail);
-
- View encode_phone = findViewById(R.id.encode_phone);
- encode_phone.setOnClickListener(mEncodePhone);
-
- View encode_sms = findViewById(R.id.encode_sms);
- encode_sms.setOnClickListener(mEncodeSMS);
-
- View encode_contact = findViewById(R.id.encode_contact);
- encode_contact.setOnClickListener(mEncodeContact);
-
- View encode_location = findViewById(R.id.encode_location);
- encode_location.setOnClickListener(mEncodeLocation);
-
- View encode_bad_data = findViewById(R.id.encode_bad_data);
- encode_bad_data.setOnClickListener(mEncodeBadData);
-
- View share_via_barcode = findViewById(R.id.share_via_barcode);
- share_via_barcode.setOnClickListener(mShareViaBarcode);
+ findViewById(R.id.take_test_photos).setOnClickListener(mTakeTestPhotos);
+ findViewById(R.id.get_camera_parameters).setOnClickListener(mGetCameraParameters);
+ findViewById(R.id.run_benchmark).setOnClickListener(mRunBenchmark);
+ findViewById(R.id.scan_product).setOnClickListener(mScanProduct);
+ findViewById(R.id.scan_qr_code).setOnClickListener(mScanQRCode);
+ findViewById(R.id.scan_anything).setOnClickListener(mScanAnything);
+ findViewById(R.id.search_book_contents).setOnClickListener(mSearchBookContents);
+ findViewById(R.id.encode_url).setOnClickListener(mEncodeURL);
+ findViewById(R.id.encode_email).setOnClickListener(mEncodeEmail);
+ findViewById(R.id.encode_phone).setOnClickListener(mEncodePhone);
+ findViewById(R.id.encode_sms).setOnClickListener(mEncodeSMS);
+ findViewById(R.id.encode_contact).setOnClickListener(mEncodeContact);
+ findViewById(R.id.encode_location).setOnClickListener(mEncodeLocation);
+ findViewById(R.id.encode_bad_data).setOnClickListener(mEncodeBadData);
+ findViewById(R.id.share_via_barcode).setOnClickListener(mShareViaBarcode);
}
- public final Button.OnClickListener mTestCamera = new Button.OnClickListener() {
+ @Override
+ public boolean onCreateOptionsMenu(Menu menu) {
+ super.onCreateOptionsMenu(menu);
+ menu.add(0, ABOUT_ID, 0, R.string.about_menu)
+ .setIcon(android.R.drawable.ic_menu_info_details);
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ switch (item.getItemId()) {
+ case ABOUT_ID:
+ int versionCode = 0;
+ String versionName = "unknown";
+ try {
+ PackageInfo info = getPackageManager().getPackageInfo(PACKAGE_NAME, 0);
+ versionCode = info.versionCode;
+ versionName = info.versionName;
+ } catch (PackageManager.NameNotFoundException e) {
+ }
+ AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ builder.setTitle(getString(R.string.app_name) + " " + versionName + " (" + versionCode +
+ ")");
+ builder.setMessage(getString(R.string.about_message));
+ builder.setPositiveButton(R.string.ok_button, null);
+ builder.show();
+ break;
+ }
+ return super.onOptionsItemSelected(item);
+ }
+
+ public final Button.OnClickListener mTakeTestPhotos = new Button.OnClickListener() {
public void onClick(View v) {
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setClassName(ZXingTestActivity.this, CameraTestActivity.class.getName());
+ intent.putExtra(CameraTestActivity.GET_CAMERA_PARAMETERS, false);
+ startActivity(intent);
+ }
+ };
+
+ public final Button.OnClickListener mGetCameraParameters = new Button.OnClickListener() {
+ public void onClick(View v) {
+ Intent intent = new Intent(Intent.ACTION_VIEW);
+ intent.setClassName(ZXingTestActivity.this, CameraTestActivity.class.getName());
+ intent.putExtra(CameraTestActivity.GET_CAMERA_PARAMETERS, true);
startActivity(intent);
}
};