Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Customized camera view & rotation in Zxing for QR code?

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.

like image 923
Shihab Uddin Avatar asked Mar 23 '13 16:03

Shihab Uddin


Video Answer


2 Answers

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.

like image 173
Sean Owen Avatar answered Oct 20 '22 05:10

Sean Owen


I was in same problem and got stuck about 2 days on it. Actually you have to do some tasks to achieve your goal.

  1. Download Zxing library for read QR code.. (Hope you have already)
  2. Create a project and add Zxing library.
  3. 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>
    
  4. 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();
            }
        }
    
  5. In the manifest file add permission following:

     <uses-permission android:name="android.permission.CAMERA"/>
    
  6. 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..

like image 35
Saiful Avatar answered Oct 20 '22 03:10

Saiful