Skip to content

Latest commit

Β 

History

History
155 lines (130 loc) Β· 5.11 KB

README.md

File metadata and controls

155 lines (130 loc) Β· 5.11 KB

Awesome Code scanner

License Download Bintray

Github Followers GitHub stars GitHub forks GitHub watchers

Awesome Code scanner library for Android, This is multi code scanner module. You can scan QR, Barcode etc in your app using this library. This library is based on ZXing. If you are not familiar with ZXing then check this. link

Sample Screen

Sample

Why Awesome Code scanner

  • Scanning Animation
  • Back and front facing cameras Supported
  • You Can customize viewfinder View
  • Provide control for Auto focus and flash light
  • Portrait and landscape screen orientations
  • Focus on Touch

Uses (example)

Step 1

Add dependency in your gradle:

dependencies {
    implementation 'com.gpfreetech:AwesomeCodeScanner:1.1'
}

Step 2

Add camera permission to AndroidManifest.xml

<uses-permission android:name="android.permission.CAMERA"/>

Don't forget to add dynamic permissions on API >= 23;

Step 3

Here your layout file code:

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    
        
        <com.gpfreetech.awesomescanner.ui.ScannerView
            android:id="@+id/scanner_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_weight=".3"
            app:autoFocusButtonColor="@android:color/white"
            app:autoFocusButtonVisible="true"
            app:flashButtonColor="@android:color/white"
            app:flashButtonVisible="true"
            app:frameAspectRatioHeight="1"
            app:frameAspectRatioWidth="1"
            app:frameColor="@android:color/white"
            app:frameCornersRadius="0dp"
            app:frameCornersSize="50dp"
            app:frameSize="0.70"
            app:frameThickness="5dp"
            app:maskColor="#77000000"
            app:isAnimated="true"/>
</FrameLayout>

Step 4

And add following code to your activity:

Java

public class MainActivity extends AppCompatActivity {

    private GpCodeScanner mCodeScanner;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        
        ScannerView scannerView = findViewById(R.id.scanner_view);
        
        mCodeScanner = new GpCodeScanner(this, scannerView);
        
        mCodeScanner.setDecodeCallback(new DecodeCallback() {
            @Override
            public void onDecoded(@NonNull final Result result) {
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        Toast.makeText(getApplicationContext(), result.getText(), Toast.LENGTH_SHORT).show();
                        txtScanText.setText("" + result.getText());
                    }
                });
            }
        });

        scannerView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                mCodeScanner.startPreview();
            }
        });
    }

    @Override
    protected void onResume() {
        super.onResume();
        if(mCodeScanner!=null) {
            mCodeScanner.startPreview();
        }
    }

    @Override
    protected void onPause() {
        if(mCodeScanner!=null) {
            mCodeScanner.releaseResources();
        }
        super.onPause();
    }
}

Additional Methods

Change / set BACK or FRONT Camera

mCodeScanner = new GpCodeScanner(this, scannerView,GpCodeScanner.CAMERA_FRONT);

or

mCodeScanner = new GpCodeScanner(this, scannerView,GpCodeScanner.CAMERA_BACK);

Animation Enable / disable

// in your .xml 
app:isAnimated="true | false"

Who's using it

Does your app use Awesome Code scanner library? If you want to be featured on this list drop me a line.

How to make contributions

Please read and follow the steps in CONTRIBUTING.md