Adding support for reading 3 of 9 Extended barcodes (containing lowercase characters) with GdPicture9

Microsoft .NET

3 of 9 barcodes are just about everywhere, and are one of the easiest barcodes to work with being widely supported by many SDK's. 3 of 9 originally supported only a subset of the ASCII character set, and later was extended to support the full range of characters. Often you will find 3 of 9 barcodes in the form of a font style that you can use in word processors, web applications, and other types of software. They can be copy and pasted. They are easy to draw, and most importantly, they are very easy to understand. You can read more on Wikipedia about it, but lets talk more about how GdPicture SDK deals with it.

code39-sample

GdPicture does support drawing 3 of 9 barcodes with the extended character set using the Barcode1DWriterType.Barcode1DWriterCode39Extended enumeration with Barcode1DWrite, but I found that it lacked the ability to read them using Barcode1DReaderDoScan. If you look deeper into the enumerations available for these methods, oddly enough both Barcode1DWriterType.Barcode1DWriterCode39 and Barcode1DWriterType.Barcode1DWriterCode39Extended exist for drawing the barcode, but only Barcode1DReaderType.Barcode1DWriterCode39 exists for reading when using Barcode1DReaderDoScan.

gI_78908_LOGO-GD9

Now, let me clarify before we look at a solution. GdPicture does technically read the barcode with extended characters, but it doesn't actually return the extended ASCII characters. Instead, it returns each uppercase character prefixed with the + character, which is a token indicating the character casing, such as the sign in a signed integer. In the examples below we will look at the most common scenario which is support for lower case characters, which are only part of the extended character set.

string threeOfNine    = "ABC123"; // normal character set
string threeOfNineExt = "abc123"; // extended character set

These are the raw values you would normally expect to see when reading 3 of 9 barcodes using a proper SDK. In GdPicture however, let us take a look at the difference when reading the extended barcodes.

string threeOfNine    = "ABC123";    // normal character set
string threeOfNineExt = "+A+B+C123"; // extended character set

This pattern is very consistent, so we can write a simple function to parse and return the correct character casing.

/// <devdoc>
/// This method is for GdPicture9's lack of support for *reading* the 3 of 9 Extended character set,
/// which allows for lowercase characters. GdPicture will still return a barcode value, but each lower
/// case character is preceded by + character to indicate the casing difference.
/// 
/// ie. TEst (raw value of *TEst*) would be returned as TE+S+T (raw value of *TE+S+T*)
/// </devdoc>
private static string Get3Of9ExtendedBarcodeValue(string s)
{
    var newValue = string.Empty;

    for (int i = 0; i < s.Length; i++)
        if (s[i] == '+')
            newValue += s[++i].ToString(CultureInfo.InvariantCulture).ToLower();
        else
            newValue += s[i];

    return newValue.Replace("+", string.Empty);
}

The method is pretty straight forward, iterating over each character and identifying the token. When the token is found we do a forward lookup in the array, which will be the actual character value, and we know to return the lowercase value. We also increment the loop counter at the same time since we are processing that character. Otherwise if no token is found, we simply return the character as is.

Simple!

Now, I have only written this function to account for the casing differences between the character sets because that was the scenario I needed to solve for the project I was working on. I could have used other barcode libraries, but we already had licensing for GdPicture and it is significantly faster than most of the libraries out there, and I tested quite a few. I might revisit this blog at a later time and write a new one discussing the other extended characters, but for now we will leave it there.

Happy coding!

42 Comments

  1. Pingback: Sochi-psiholog-Russia

  2. Pingback: who makes viagra pills

  3. Pingback: vardenafil 20mg

  4. Pingback: 100 mg viagra side effects

  5. Pingback: t.me/s/psy_chat_online

  6. Pingback: clomiphene 50mg ovulation

  7. Pingback: afinitor cost

  8. Pingback: Forum

  9. Pingback: fildena.homes

  10. Pingback: 439W6fo

  11. Pingback: psy

  12. Pingback: r2f.ru

  13. Pingback: xblx.ru

  14. Pingback: dilts.g-u.su

  15. Pingback: anatoliy-alekseyevich-derkach.ru

  16. Pingback: where to buy cheap toradol for sale

  17. Pingback: artane and coolock credit union

  18. Pingback: zanaflex for sciatica pain

  19. Pingback: cyproheptadine hydrochloride syrup ip side effects

  20. Pingback: street value of tizanidine 2mg

  21. Pingback: periactin sciroppo dosaggio

  22. Pingback: can you get generic ketorolac pills

  23. Pingback: baclofen compared to vicodin

  24. Pingback: azathioprine irregular heartbeat

  25. Pingback: maxalt wine

  26. Pingback: classe terapeutica piroxicam

  27. Pingback: how effective is meloxicam for pain

  28. Pingback: prospecto de lioresal

  29. Pingback: imdur pill

  30. Pingback: what are side effects of mobic

  31. Pingback: imuran proctitis

  32. Pingback: rizatriptan benzoate drug bank

  33. Pingback: can you take sumatriptan and paracetamol together

  34. Pingback: where can i buy generic pyridostigmine without dr prescription

  35. Pingback: diclofenac vs celebrex

  36. Pingback: cilostazol en insuficiencia cardiaca

  37. Pingback: can mebeverine be taken after food

  38. Pingback: indomethacin 75 sr

  39. Pingback: migraine injection imitrex

  40. Pingback: amitriptyline dose for sleep

  41. Pingback: mestinon tabs

  42. Pingback: elavil mgs

Leave a Comment