I am working with such a great library zxing to read QR code. I already got QR code successfully.
Now, My application runs in landscape mode and camera takes the whole screen and red QR detection rectangle box is in the middle. I wanna change this to portrait mode & replace the camera view only with the red QR detection rectangle box.
I change CaptureActivity tag which is inside the zxing library manifest file.
android:screenOrientation="portrait"
.
But found nothing what I actually want. I don't know where I have to change/write code to get this.
First, please don't copy our app completely. In this case you're going to need to write your own app anyway; it is definitely not as simple as changing the layout orientation. Not only is the UI not written for portrait, but neither is the app code.
If you want to use only fixed portrait mode, then this is not so hard. Fully supporting all 4 rotations, with front/back cameras, gets hard to get right. But not just 1 case.
First you need to design a portrait-mode UI. (Don't copy the red-line design please.)
The actual app code doesn't care about orientation for QR codes. You don't have to do anything there at all. But you do need to make changes to get the screen display right.
You will need to query Camera.getOrientation()
to detect how the camera is mounted. Usually it's such that "up" is to your right, and I think just about every device works this way for compatibility. But technically you need to know so you know how much to rotate the preview image.
Then you use Camera.setDisplayOrientation()
to tell it how much to rotate the image to make it rotated correctly for your portrait mode screen. This is usually "90".
Finally you need to select the preview size with Camera.Parameters.setPreviewSize()
but will possibly need to flip the values you've chosen (480x800 vs 800x480) because you're in portrait.
I was in same problem and got stuck about 2 days on it. Actually you have to do some tasks to achieve your goal.
Your main.xml file should look like:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello" />
<FrameLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_gravity="center_horizontal">
<include layout="@layout/capture"/>
</FrameLayout>
</LinearLayout>
Your main Activity should look like:
public class ScannerActivity extends CaptureActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
@Override
public void handleDecode(Result rawResult, Bitmap barcode)
{
Toast.makeText(this.getApplicationContext(), "Scanned code " + rawResult.getText(), Toast.LENGTH_LONG).show();
}
}
In the manifest file add permission following:
<uses-permission android:name="android.permission.CAMERA"/>
and finally very IMPORTANT task you need to do for camera rotation problem, replace the following method into the
CameraManager.java (in the package com.google.zxing.client.android.camera)
@SuppressLint("NewApi") public void startPreview() {
Camera theCamera = camera;
if (theCamera != null && !previewing) {
theCamera.setDisplayOrientation(90);
theCamera.startPreview();
previewing = true;
}
}
that's all . run and enjoy :-)
thanks..
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With