LiveEdgeDetection is an Android document detection library built on top of OpenCV. It scans documents from camera live mode and allows you to adjust crop using the detected 4 edges and performs perspective transformation of the cropped image.
It works best with a dark background.
The source code of OpenCV is here https://git.mxtracks.info/opencv/openCV-android-sdk The code was too big for github, but the main problem was jitpack.io was not able to build jitpack/jitpack.io#4119
This library is available in JitPack.io repository. To use it, make sure to add the below inside root build.gradle file
allprojects {
repositories {
...
maven { url "https://jitpack.io" } // for this library
maven { url 'https://artifactory.mxtracks.info/artifactory/gradle-dev-local/' } // for the OpenCV library
}
}
and add the repository's url to the app's build.gradle file.
dependencies {
implementation 'com.github.hannesa2:LiveEdgeDetection:$latestVersion'
}
Out of the box it uses OpenCV.
- Start startActivityForResult from your activity
startActivityForResult(new Intent(this, ScanActivity.class), REQUEST_CODE);
- Get a file path for cropped image on onActivityResult
String filePath = data.getExtras().getString(ScanConstants.SCANNED_RESULT);
Bitmap baseBitmap = ScanUtils.decodeBitmapFromFile(filePath, ScanConstants.IMAGE_NAME);
- Display the image using TouchImageView
<com.ortiz.touchview.TouchImageView
android:id="@+id/scanned_image"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="center" />
Copyright 2020 hannesa2.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
https://github.com/itext/itext7/blob/develop/LICENSE.md
This program is offered under a commercial and under the AGPL license.
For commercial licensing, contact us at https://itextpdf.com/sales. For AGPL licensing, see below.
AGPL licensing:
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.