I am working with multi-page scanned text documents and I use FineReader 12 SDK as a underlying OCR engine. Sometimes, the document is scanned upside down or different orientation and causes all the resulted recognition characters are to be unrecognized symbols.
- Is there way to know if the document is not in the right orientation before recognition\analysis\process ?
- How to do the correct transform or orientation on the document instead of trial and error ?
- The documents are always of english language and can we enforce if the detected language is english and do the transform based on that ?
Any help appreciated.
 
                        
This problem can be solved using custom .ini processing profiles. You can automatically detect orientation and skew using the right properties, then apply or prohibit orientation correction and/or deskewing.
In your code between Engine initialization and recognition, call this method as described in the FRE documentation, section
Working with ProfilesCreate a new file
document.inisomewhere in your project and pass it to this method call in order to tell the SDK to check for properties in this file before processing your files.Add these lines in your freshly created file:
If you do not want to use a file for setting these properties for any reason, you can call them in your code. Have a glance at the documentation describing all the props objects tree for that. Using a file is way easier to understand what you are doing without browsing hundred lines of code.
For your language issue, I suggest you to use RecognizerParams and enforce specific properties. Again, have a look at the documentation for custom profiles as it is pretty powerful.
After doing this, you should be good to go, and all your image files should be close do 0° orientation for processing. Choosing a language based on document orientation is a very specific workflow, the only option will be to code it.
Good luck on your project !