Search

Atalasoft Knowledge Base

FIX: AutoDiscardBlankPages Doesn't Work With Canon Scanners

Administrator
DotTwain

PROBLEM::
My Canon scanner seems to ignore the device.AutoDiscardBlankPages property

SOLUTION::
When your device.Identity.Manufacturer is Canon:
* Use custom cap 0x8001 to enable/disable auto blank page detection
* Use custom cap 0x8076 to set threshold for blank page (default is 10%)

EXPLANATION:
The scanner manufacturer (Canon) chooses implement their AutoDiscardBlankPages differently than the TWAIN specification provides. (They are likely doing this so they can provide additional control over HOW the scanner defines a "blank page"... something the TWAIN specification doesn't address).

So, instead of reading the TWAIN standard AutoDiscardBlankPages property, Canon uses the TWAIN specification's Custom Code space to create their own

(bool) CAP_0x8001 - auto discard on/off
(int)  CAP_0x8076 - auto discard threshold
(?)    CAP_0x801e - ??

You see, the TWAIN specification is not "tightly policed" ... while the spec is very clear in requirements, there's no licensing body that tests compliance... so every scanner device maker and driver writer is free to implement however much or little of the spec they wish, yet can still call their device a TWAIN device.

Atalasoft actually sits on the TWAIN board of directors... we've made very strong efforts to be as 100% TWAIN compliant as we possibly can be. The Custom capabilities are part of the TWAIN spec (in terms of how to get/set them) but each device maker is free to use these custom caps in any manner they wish (so long as they honor the TWAIN way of get/set and type identification

So, when Canon decided they wanted more finite control over blank page discarding, they needed extra fields other than "on/off" so, they implemented the whole feature in custom capabilities, and ignore the TWAIN standard auto discard blank pages on/off command.

So, if the device.Identity.Manufacturer name is "Canon", you should use those custom codes for the discard instead of the TWAIN way (you can still set the TWAIN setting for the auto discard, it just won't honor it if it's Canon).

Be aware though - CAP0x8001, 0x8076, and 0x801e could be assigned to completely different things by other manufacturers (Fujitsu, Kodak, etc...) - so don't just always set this - ONLY set them if the device manufacturer contains "Canon" or else you may find that you've enabled the "halt and do a little dance" instruction.

Okay, no, not really... but my point is that those caps could be assigned to ANYTHING on another scanner manufacturer's model - the capabilities in the 0x8000 range are completely custom and each manufacturer can do what they like with them.

Original Article:
Q10372 - PRB: AutoDiscardBlankPages Doesn't Work With Canon Scanners

Details
Last Modified: 6 Years Ago
Last Modified By: Administrator
Type: FIX
Article not rated yet.
Article has been viewed 726 times.
Options
Also In This Category