Skip to content

Releases: dynarithmic/twain_library

v5.5.5

30 Dec 23:14
Compare
Choose a tag to compare

Version 5.5.5

  • Create versions of DTWAIN DLL that contains full logging and minimal logging. The minimal
    logging versions of DTWAIN results in smaller sizes for the DLL files.

  • Update CAP_PRINTERSTRING to use (by default) TWON_ONEVALUE container on setting capability.

  • Fix issue with determining whether a TWAIN source supports a file system (CAP_FILESYSTEM).

  • Allow internal TWAIN message loop to loop indefinitely until the Source UI is closed. A new
    DTWAIN32.INI and DTWAIN64.INI section ("TwainLoopPeek") will list the TWAIN Product
    Names that will use the new looping mechanism using the Windows API function PeekMessage().
    By default, the looping method used will be the same as previous versions of DTWAIN
    (using the Windows API function GetMessage()).

  • Related to the update of the TWAIN message loop, functions DTWAIN_EnablePeekMessageLoop() and
    DTWAIN_IsPeekMessageLoopEnabled() allows programmatic control of which type of TWAIN message
    loop will be executed with a given TWAIN Source. By default, the message loop uses the
    Windows API function GetMessage() instead of PeekMessage().

  • Ensure setting string capabilities uses ANSI strings.

  • Change parameters to certain API functions from LONG to DWORD to delineate signed versus unsigned values.
    The size in bits of LONG and DWORD are the same, the only difference is that DWORD is an unsigned 32-bit integer
    while LONG is a signed 32-bit integer.

  • Add Japanese, Traditional Chinese, and Greek text resources.

  • All lines in the logs generated with DTWAIN_SetTwainLog() have timestamps (with the
    by-product of this change being that all the log lines are properly indented).

  • DTWDEMO32 and DTWDEMO64 programs now do not require VCRUNTIME140.DLL to be present.

  • On return of DTWAIN functions that handle pointers as input, the values that the pointers
    will point to are now logged (only available with full logging versions of DTWAIN DLL).

  • Added missing constants to twaininfo.txt

  • DTWAIN_SelectDefaultSource() will now only make a call to the TWAIN DSM if the DSM is version 2
    or greater (TWAINDSM.DLL).

  • DTWAIN_GetSourceDetails() now correctly reports custom capabilities that are also extended capabilities.

v5.5.4

25 Oct 12:07
d1f50b1
Compare
Choose a tag to compare

Version 5.5.4

  • Addressed issue with multiple calls to DTWAIN_SysInitialize() and DTWAIN_SysDestroy() not loading
    the twaininfo.txt file.

  • Fixed issue with TW_FRAME and Extended Image Information not being processed correctly for
    the TWEI_FRAME setting.

  • Fixed several incorrect language bindings for C#, Visual Basic, and Delphi. Also corrected
    a few incorrect function pointer definitions in dtwimpl.h (used when using DTWAIN in a
    C/C++ program that does not utilize import libraries).

  • Added missing constants to twaininfo.txt

v5.5.3

19 Oct 22:14
6795853
Compare
Choose a tag to compare

Version 5.5.3

  • Fixed several issues with retrieving extended image information (for example, barcode text,
    imprinter text, etc.) from TWAIN Sources using the DTWAIN Extended Image Information retrieval
    functions (DTWAIN_InitExtImageInfo, DTWAIN_GetExtImageInfoData, etc.).

  • Fixed issue with DTWAIN_ArrayGet...() functions possibly returning the incorrect status
    code.

  • TWAIN Select Source dialog and OCR Select Engine dialogs are now similar and have the same
    functionality. This includes adding DTWAIN_SelectOCREngine2() function that is similar
    to the current DTWAIN_SelectSource2() function, which allows positioning, sorting of the names
    in the dialog, etc.

  • More thorough checks are done to detect an invalid twaininfo.txt at startup.

  • Update C++, C#, and Visual Basic full demo programs to include on the main menu
    a "Language" option. This option allows you to dynamically switch the language used
    (for example, French, German, etc.) while the demo is running. The changes in the
    language will be seen in the TWAIN Select Source dialog, and in the logging text if
    logging is chosen.

v5.5.2-Update-2

01 Oct 21:08
Compare
Choose a tag to compare
  • Fix compilation issue with Delphi language bindings.

v5.5.2-Update-1

30 Sep 00:39
a2f7c01
Compare
Choose a tag to compare

Update twainresourcestrings_spanish.txt

v5.5.2

28 Sep 15:28
7d5866b
Compare
Choose a tag to compare

Version 5.5.2

  • Add support for acquiring buffered images using tiled data (DTWAIN_SetBufferedTileMode()).
    The device must support the ICAP_TILES capability for tiled data to be sent.

  • Fixed issue with custom resource files being loaded into memory using DTWAIN_LoadCustomStringResources()

  • Fixed issue DTWAIN_EnumCameras returning strings that were not properly encoded when using Unicode
    build of DTWAIN.

  • Fixed issues with DTWAIN_AcquireFile(Ex) and handling of file transfers directly from the TWAIN Source
    (DTWAIN_USESOURCEMODE flag).

  • Add DTWAIN_LOG_CONSOLEWITHHANDLER to list of available flags to DTWAIN_SetTwainLog(). This flag is only
    applicable when logging to the console. This flag allows safe(r) shutdown of DTWAIN if the logging
    console is terminated by Ctrl-C, closing the console window by clicking the 'X', etc.

  • Add some missing C# and VB interface functions.

  • Ensure that when logging to the console, the console is using UTF-8 encoding.

  • More thorough test for corruption of the twaininfo.txt resource file when DTWAIN_SysInitialize()
    is called.

  • Update C/C++ full demo program (DTWDEMO32 and DTWDEMO64) to show the JSON description of the opened
    TWAIN Source when displaying the source properties. The C# and VB version of DTWDEMOxx has also
    been updated to show this information (see the FullDemo projects for C# and VB).

  • Remove some resource constants from the language resource files. These constants have now been moved to
    twaininfo.txt.

  • Updated code to detect the running Windows OS version when starting a DTWAIN log. The new code
    now detects the latest Windows 11 version(s). The new code is courtesy of PJ Naughter.

  • Add various language files (Romanian, Russian, Portuguese, Simplified Chinese).

v5.5.1-Update-1

20 Sep 13:15
af5a1bd
Compare
Choose a tag to compare
Merge pull request #120 from dynarithmic/master-staging

Add resource files to additional_language_resource folder.

v5.5.1

13 Sep 23:12
4889692
Compare
Choose a tag to compare

Version 5.5.1

  • Load default English resources if twainresourcestrings_english.txt is not found, and
    additional language resources are not specified.

  • Optimizations to internal functions.

  • Fix DTWAIN_SetDefaultSource() for TWAIN 2.x data source managers (TWAINDSM.DLL). Note that
    DTWAIN_SetDefaultSource() is not guaranteed to work for TWAIN 1.x data source managers (TWAIN_32.DLL).

  • Fix issue with DTWAIN_SelectOCREngine() not working for Unicode builds of DTWAIN.

  • Adjust DTWAIN OCR error constants to match OCR error messages.

v5.5.0

06 Sep 00:21
0751d81
Compare
Choose a tag to compare

Version 5.5.0

  • Add support for Big TIFF files when calling DTWAIN_AcquireFile() and DTWAIN_AcquireFileEx().
    For more information, see the new file type constants (DTWAIN_BIGTIFFNONE, DTWAIN_BIGTIFFLZW, etc.)
    Big TIFF files are TIFF files that are allowed to be greater than 4 Gigabytes in size.

  • Update twaininfo.txt to add the new Big TIFF file type information.

  • Update the DTWDEMO.exe demo program, as well as the C# and Visual Basic full
    demo programs to display the TWAIN Source's custom data when displaying the Source Properties dialog box.

  • Optimize DTWAIN_AcquireFile() and DTWAIN_AcquireFileEx() when an unsupported file type is
    specified.

  • Optimize DTWAIN_IsTwainAvailable() when determining whether TWAIN is installed. The
    optimization is for the case where DTWAIN_IsTwainAvailable() is called before
    DTWAIN_SysInitialize().

  • Add function DTWAIN_IsTwainAvailableEx() to return a pipe-delimited string denoting
    the full TWAIN paths of both TWAIN 1.x and TWAIN 2.x Data Source managers.

  • Optimize DTWAIN_OpenSource() in these scenarios:
    a) if called more than once on a TWAIN Source
    b) When initially opening a TWAIN Source by not checking for the status of the feeder
    c) Capability processing has been minimized when calling DTWAIN_OpenSource().

  • Optimize DTWAIN_GetCapValues() and DTWAIN_SetCapValues() if a capability is not supported
    by the TWAIN Source.

  • Fixed an issue with DTWAIN_GetCapValuesEx2(), where the passed-in TWAIN data type was not
    being processed correctly for all scenarios.

  • Fixed issue with DTWAIN_TN_UIOPENING not being sent during DTWAIN notification processing.

  • Fixed issue with DTWAIN_EnumCameras() not returning all of the camera information (only top
    and bottom cameras were returned). Please note that "camera" in this context does not mean
    "digital camera", but instead the mechanism that scans the image. Only TWAIN devices that
    support an internal file system (DTWAIN_IsFileSystemSupported()) will have the ability to
    enumerate camera types.

  • Fixed minor issue with DTWAIN_EnumCameras() and logging, where unsupported TWAIN drivers that
    do not have an internal file system would log an exception instead of returning an error.

  • Added DTWAIN_EnumCamerasEx() that allows the application to enumerate any of the (currently)
    9 specific camera types defined by TWAIN. The camera types are described by the TWAIN
    constants:

    DTWAIN_FT_CAMERA         
    DTWAIN_FT_CAMERATOP      
    DTWAIN_FT_CAMERABOTTOM   
    DTWAIN_FT_CAMERAPREVIEW  
    DTWAIN_FT_DOMAIN         
    DTWAIN_FT_HOST           
    DTWAIN_FT_DIRECTORY      
    DTWAIN_FT_IMAGE          
    DTWAIN_FT_UNKNOWN        
    
  • Ensure that DTWAIN_GetCapValues() and other internal functions that call DTWAIN_GetCapValues()
    clears the returned user array of values if the TWAIN capability being tested is not supported
    by the device.

  • Adjust twaininfo.txt to properly reflect the new TWAIN 2.x capability information.
    Note: This new version of twaininfo.txt must be used with the current DTWAIN 5.5.x.
    The older version of twaininfo.txt can only be used with DTWAIN version 5.4.x or below.

  • Updated the various language bindings (C#, Delphi, Visual Basic, etc.) to reflect the new
    additions of the Big TIFF file type.

  • Updated the C/C++ "No import library" method of using DTWAIN to reflect the new functions,
    plus added missing DTWAIN API functions to dtwainx2.h and dtwimpl.cpp(.c).

  • Added the function DTWAIN_TestGetCap() that allows testing of a TWAIN Source's capability's
    MSG_GET functionality for all containers and data types. This function basically calls
    DTWAIN_GetCapValues(), checking for successful retrieval of information from the TWAIN
    device for each container type and data type supported by TWAIN. The DTWAIN_TestGetCap()
    function can be useful to determine a custom capability's container and data type if this
    information is not known by the programmer.

    The return value for DTWAIN_TestGetCap() is a DTWAIN_ARRAY, where the array consists of LONG (32-bit) values.
    The upper 16 bits of each value in the array denotes the successful data type, and the lower 16 bits
    denote the successful data type. The container type can be DTWAIN_CONTONEVALUE, DTWAIN_CONTRANGE,
    DTWAIN_CONTENUMERATION, and DTWAIN_CONTRANGE, while the data type will be one of the types defined
    in twain.h, i.e. TWTY_BOOL, TWTY_FRAME, TWTY_UINT16, etc.

    Note: Use DTWAIN_TestGetCap() with caution, as DTWAIN will attempt to test every container type and
    data type combination for the passed-in capability value.

  • Other minor bug fixes and enhancements.

v5.4.8

18 Aug 09:12
fabeb67
Compare
Choose a tag to compare

Version 5.4.8

  • Add additional TWAIN constants to twaininfo.txt

  • Output version of twaininfo.txt to logs generated by DTWAIN_SetTwainLog

  • Increase the maximum size of the DTWAIN resource and error strings to 8192 bytes.

  • Added DTWAIN_GetResourceString, DTWAIN_GetResourceStringA, and DTWAIN_GetResourceStringW
    API functions to allow access to the resource and error strings loaded by DTWAIN.

  • Fix issue with exception possibly occurring when closing TWAIN Source window without acquiring images.