Skip to content
This repository was archived by the owner on Jan 12, 2019. It is now read-only.

Conversation

@kmfree
Copy link

@kmfree kmfree commented Sep 18, 2016

@kmfree kmfree changed the title Added android changes ctb-android-changes Sep 18, 2016
Copy link
Member

@braebot braebot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the PR. I've added some preliminary comments. Also, if you could please provide a description in each of the 3 PRs for these changes, others will have more context.


try {
loadLibrary("cardioDecider");
System.loadLibrary("cardioDecider");
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You should probably rebase to the latest master. This change should not be here.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This appears to have slipped through FileMerge. Easy fix.

<uses-permission android:name="android.permission.CAMERA"/>
<uses-permission android:name="android.permission.VIBRATE"/>
<!-- We need this for tessdata-->
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why does tessdata need these extra permissions? Is the data not stored within the SDK itself?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

tessdata is an external directory read in by Tesseract. It needs to be included with the app/assets/bundle. With android the only way to do this is have it on the sd card or emulated storage build into most devices. Read/write external in this case does not mean external storage but rather the external emulated storage.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There should be no need to write it to external storage, the internal private storage for the app should be fine. I've had to do something similar with an OpenVPN binary that needs to read a configuration file from disk, it does need to be written to storage instead of the assets directory so it can be accessed as a file, but from the point of view of the app, internal storage should be ok.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is an issue with tesseract, not an inability to read from assets. C/C++ can do what you described. However to my knowledge Tesseract specifically does not. It is platform agnostic so it cannot use AssetManager/NDK without referencing android specific apis. I will look into adding this functionality with some flags/magic if that is the desired. It should also be noted that this is not writing to external storage. It is internal to the phone, not the apk. The write permission is required to do that. It may require code changes to tesseract. The current solution is the agreed method outside of changing the tesseract source. Having said that I am in agreement that this is sort of a stupid solution to something you would think would be more straight forward as it is with ios version.

Some relevant discussion on the topic: http://stackoverflow.com/questions/23174318/how-to-get-a-full-path-for-an-android-resource-file-init-tesseract-ocr-in-andro



/* Tesseract Imports */
import android.os.Environment;
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Imports should follow the standard sorting.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Will do.

* @throws Exception
*/
private void prepareDirectory(String path) {

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Extra newline

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It will be removed.

* Entry point for tessdata adapted from TessTwo
*/
private void tessSetup() {
DATA_PATH = getExternalFilesDir(null) + "/Tesseract/";//getFilesDir()+ "/Tesseract/";//getExternalFilesDir(null) + "/Tesseract/";//Environment.getExternalStorageDirectory().toString() + "/Tesseract/";
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Why can't you load the data from the assets themselves, without having to copy to another location?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is complicated issue for both android itself and tesseract. In iOS this can be read directly from the bundle, the same is not true for android assets. In order to read for tesseract it must be copied to external storage. Having said that in order to read the file as a stream, which should be doable directly from assets the tesseract input / engine might need to be modified. I suspect this is non-trivial. I suspect it can be done if that is a requirement.

See refs below for more detail
http://stackoverflow.com/questions/24129719/android-cant-find-file-in-assets-folder
http://stackoverflow.com/questions/33220378/tesseract-tessdata-folder-not-found-when-put-in-assets-folder

@Chandrakala14
Copy link

Chandrakala14 commented Sep 18, 2017

@kmfree I tried your code CTB changes, It is not working, generating some unknown 16 digit number instead of card number.

Is there any enhancements ?

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants