Skip to content

Akylas/OSS-DocumentScanner

Folders and files

NameName
Last commit message
Last commit date
Nov 25, 2023
Jan 8, 2025
Oct 15, 2024
Jan 23, 2025
Jan 24, 2025
Sep 9, 2024
Jul 29, 2020
Jan 23, 2025
Nov 9, 2023
Nov 3, 2023
Oct 16, 2024
Jan 21, 2025
Oct 17, 2024
Jan 23, 2025
Jan 16, 2025
Nov 7, 2024
Jun 18, 2024
Oct 18, 2024
Nov 7, 2024
Oct 23, 2024
Dec 11, 2024
Oct 15, 2024
Jun 30, 2022
Oct 15, 2024
Oct 30, 2023
Oct 15, 2024
May 24, 2024
Oct 16, 2024
Oct 22, 2024
Jan 22, 2025
Oct 21, 2023
Jan 24, 2025
Jan 16, 2025
Jul 14, 2022
Jun 11, 2024
Dec 21, 2023
Dec 4, 2023
Jan 1, 2024
Dec 4, 2023
Oct 15, 2024
Dec 21, 2023
Jul 14, 2022
Mar 20, 2024
Jun 11, 2024
Jun 11, 2024
Jul 29, 2024
Oct 1, 2024
Oct 1, 2024
Jan 8, 2025
Jan 7, 2025
Oct 17, 2024
Dec 7, 2024
Oct 17, 2024
Nov 9, 2024
Nov 9, 2024
Apr 9, 2024
Jan 20, 2025

Repository files navigation

This repository is now the home of 2 apps

Contributor Covenant GitHub repo stars GitHub License GitHub All Releases GitHub release GitHub release

Small translation badge

Installation

OSS Document Scanner Oss CardWallet
Get it on IzzyOnDroid Get it on IzzyOnDroid
Get it on PlayStore Get it on PlayStore
Get it on GitHub Get it on GitHub
Download on the App Store Download on the App Store
Get it on Obtainium Get it on Obtainium

AppVerifier hashes

OSS Document Scanner:

com.akylas.documentscanner
0D:10:AA:10:E0:3A:7E:76:97:22:BE:43:88:BE:63:BD:15:7A:7B:7B:F1:96:FB:3C:EB:AB:87:37:F9:6C:A8:71

OSS CardWallet:

com.akylas.cardwallet
0D:10:AA:10:E0:3A:7E:76:97:22:BE:43:88:BE:63:BD:15:7A:7B:7B:F1:96:FB:3C:EB:AB:87:37:F9:6C:A8:71

Enjoying OSS Document Scanner or OSS Card Wallet?

Please consider making a small donation to help fund the project. Developing an application, especially one that is open source and completely free, takes a lot of time and effort.


Open Source app to scan your documents.

Screenshots

| | | |

| | | |

Having issues, suggestions and feedback?

You can,

Contributors

Thanks to our contributors:

Languages: Übersetzungsstatus

Übersetzungsstatus

The Translations are hosted by Weblate.org.

Feature Graphic generated with hotpot.ai

Building Setup

This repo can be used to build 2 different apps: OSS DocumentScanner and OSS CardWallet

Those apps are using Nativescript which is a cross platform framework to build apps for iOS/Android

Setup / Environment

This project uses a few environment variables. While most are for publishing and thus not necessary for most, some are used to decide which app to build:

  • APP_ID: com.akylas.documentscanner or com.akylas.cardwallet
  • APP_BUILD_PATH: build/documentscanner or build/cardwallet
  • APP_RESOURCES: App_Resources/documentscanner or App_Resources/cardwallet

You can either define them yourself. If you are using vscode the vscode/settings.json of this repo defines different custom shells which will try to source .env.documentscanner and .env.cardwallet. To do this it use the plugin dotenv from omzsh here If those variables are not define the project will default to variables for OSS DocumentScanner

Nativescript

First setup Nativescript

This project is optimized to be built with Akylas Fork. Though it would work with main it is best to use this fork. The package.json defines a resolution to ../NativeScript/dist/packages/core so clone the fork and build it using npm run setup:yarn && npm run ui-mobile-base:build && npm run core:build

Another change is that this project uses new features of the Nativescript cli which were not released yet. So for now you need to clone it, build with npm run setup then use it with PATH_TO_CLI_FOLDER/bin/ns

dotenv

The app uses .env file to set up needed environment variables. .env is not commited as it contains sensitive data Simply create a .env file with:

source .env.ci

Then "source" the file in the terminal so that variable are exported and available to nativescript cli. I use dotenv plugin for zsh which automatically loads the .env file

3rd parties

This app also uses opencv and tesseract. I did not include the libraries in git because there are huge and would make the github repo too big. There are 2 ways to install them:

  • download from here and uncompress them at the root
  • build them yourself:

OpenCV

  • Android: You can download Opencv 4.8.0 for android here. Then place the necessary libs/includes in the opencv/android at the root of this repo like shown here: opencv directory structure

  • iOS : You can download Opencv 4.8.0 for iOS here. Then place the opencv2.xcframework in the opencv/ios at the root of this repo

This should be enough. Android and iOS build will use it using symlinks

Tesseract

It is a bit trickier for Tesseract as we need to compile it

  • Android:

    • clone https://github.com/Akylas/Tesseract4Android
    • build with ./gradlew assembleRelease
    • search for the built static libs (search for libtesseract.a) in tesseract4android/build/intermediates/cxx/*/obj
    • copy the static libs and the includes(in tesseract4android/src/main/cpp/tesseract/src/include) in the tesseract/android at the root of this repo like shown here: opencv directory structure
  • iOS:

Yarn

You need to use yarn with this project as it uses the portal: protocol for some dependencies. Note that the project has some yarn link for easy local dev for me. The best is for you to remove the resolutions part of the package.json

Building

Now that all is setup and that you prepared the 3rd party libraries you can actually build and run the app:

  • yarn
  • ns run android --no-hmr --env.devlog (replace by ios for iOS...)

This should run the app on the first discovered device or emulator.