Customized camera view & rotation in Zxing for QR

2019-02-17 00:24发布

问题:

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.

回答1:

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..



回答2:

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.



回答3:

I had really terrible experience from this library for the same reason. It seems that even if you succeed showing the camera in portrait mode, it will be stretched (or the output image would be stretched, or the barcode won't be sensed, or some devices had it working fine yet others didn't).

I suspect that Android simply "likes" the camera preview to be in landscape mode, as this is its natural orientation when the user takes pictures.

In the end, what I've done is using landscape mode and rotate everything else, so the user thinks it's portrait mode, but it's not. I think many apps use this technique.

I suggest that if you somehow manage to handle this problem, test it on as many devices as you can.