NewsLab
Jun 28 23:13 UTC

Libre Barcode Project (graphicore.github.io)

285 points|by luu||64 comments|Read full story on graphicore.github.io

Comments (64)

62 shown
  1. 1. 1bpp||context
    Is anyone willing to sacrifice their sanity for the sake of implementing a QR renderer as TTF hinting code?
  2. 2. iguessthislldo||context
    I love seeing nonsense like that. How that work graphically though? Just keep adding to a same QR code that keeps getting denser as more text is added? I guess it doesn't have to practical though :)
  3. 3. gus_massa||context
    Someone implemented the Bad Apple animation inside a font https://blog.erk.dev/posts/anifont/ ( https://news.ycombinator.com/item?id=373170550 | 177 points | Aug 2023 | 62 comments )
  4. 4. ValdikSS||context

        - https://fuglede.github.io/llama.ttf/
        - https://github.com/bjia56/translate.ttf
        - https://github.com/hsfzxjy/handwriter.ttf
    
    Harfbuzz now has WASM interpreter for a shaper. You can make pretty much arbitrary programs in fonts now.

    https://www.youtube.com/watch?v=Ms1Drb9Vw9M

  5. 5. foodevl||context
  6. 6. dmitrygr||context
    This is a perversion of the most sickening nature. Nicely done!
  7. 7. breakingcups||context
    I'm surprised at this reaction, this has been standard practice for many years in various companies where I worked.
  8. 8. dfox||context
    The fact that this is standard practice does not mean that it is not perverse. It kind of works sanely for plain Code39 (and even then you will see effects of doing that in weird places, like VAG stamping human readable VIN on a chassis, including the Code39 start/stop symbols), once you start using barcode fonts for Code128-derived symbologies (ie. UPC/EAN) the whole thing becomes a pointless exercise.
  9. 9. Dwedit||context
    I mean there was already the Bad Apple font (keep adding another character to your text and you get the next video frame)
  10. 10. utopiah||context
    Damn, yes please.

    Another cool font, but less original, I stumbled upon recently is Marelle https://marelle.forge.apps.education.fr/ for cursive.

  11. 11. endre||context
    this is genius
  12. 12. albert_e||context
    > https://marelle.forge.apps.education.fr/

    This website is in French so I was unable tounderstand the text

    and the website is very resistant to automatic translation by Google Translate

    >https://marelle-forge-apps-education-fr.translate.goog/?_x_t...

    What gives?

  13. 13. utopiah||context
    No problem translating it with Firefox :

    " Marelle is a free cursive police force for teaching writing in elementary school. Introduction

    This project is supported by the Digital Directorate for Education of the Ministry of National Education, and developed in the Forge of Digital Educational Commons.

    The Marelle police is designed specifically for teaching cursive writing in elementary school, it was developed by a team of teachers and designers specialized in writing systems.

    Teaching Cursive Writing

    Structure and sequence of letters, rhythm and proportion, contextual variants: the Marelle font was thought around specific criteria to offer a quality model to teachers and students. Particular attention has been paid to the trace of numbers, capital letters and punctuation. A complete professional tool

    The Marelle police offers 3 types of variants:

        uppercase sticks or cursive
        with or without lineage Seyes
        height of ascendants and descendants
    
    These variants can be combined to best meet the needs of teachers and students." etc
  14. 14. jurgemaister||context
    > cursive police force
  15. 15. ligne||context
    Homographs are tricky :-)
  16. 16. bombcar||context
    I know I've often cursive'd the police.
  17. 17. albert_e||context
    Thanks!

    (the first line made me laugh)

    I now understand why there is no English version (though still surprised Google could not translate it)

  18. 18. piltboy||context
    "Marelle is a free cursive font designed for teaching handwriting in [French] elementary school."

    I'm not sure they owe it to anyone to make the website available in English :-)

  19. 19. albert_e||context
    That there is not much use for an english version -- is only evident to me with hindsight after reading the english translation :)

    Thanks

  20. 20. tokai||context
    ooh thanks, the Bâton in capital letter is very nice.
  21. 21. tecleandor||context
    Nice! That looks pretty similar to the one in "Cuadernos Rubio", a system that was super popular from the 60s to the 90s in Spain (that still exists) for learning handwriting in primary school.
  22. 22. mos_basik||context
    Love it. Flashbacks to CE1 and CE2 (2nd and 3rd grade in the US system) in a French embassy school, simultaneously handling "immersion in real french", "using a fountain pen for the first time", "different long division" (https://en.wikipedia.org/wiki/Long_division#Eurasia) and "different cursive" (I think the method I was coming from was D'Nealian? https://en.wikipedia.org/wiki/D%27Nealian)
  23. 23. nemoniac||context
    ASCII only?
  24. 24. Terr_||context
    More or less, AFAICT the underlying barcode standards don't support Unicode, if that's what you mean.

    It looks like Code 128 could potentially handle some ISO-8859-1 accented latin characters, but I'm not sure how to test it.

  25. 25. ale42||context
    Code 128 supports some ISO-8859-1 indeed, but it requires switching between encodings (there are 3 of them), and couldn't work with 128B (I guess the one used by the font, as it supports ASCII). See the table on Wikipedia: https://en.wikipedia.org/wiki/Code_128
  26. 26. trashb||context
    actually it seems they support 128A 128B and 128C with the correct encoder.

      To use these fonts you have to use an encoder like the one below. It is an optimizing encoder, that means, it produces the shortest barcode that can encode the input. For this the encoder, if necessary or shorter, switches between the three available Code Sets (list from Wikipedia):
    
    https://graphicore.github.io/librebarcode/documentation/code...
  27. 27. matsemann||context
    Even with plain ASCII we sometime struggle with the various scanners, as they emulate keyboards. So for instance using : in the barcode as a separator of values becomes wonky if the OS has a different input language than expected.
  28. 28. alex_suzuki||context
    This would be more interesting if you wouldn’t need to calculate checksums yourself, and could just write the barcode value. Good luck doing that with something like Reed-Solomon (QR, Data Matrix, etc.) or the shenanigans they’re doing with GS1 DataBar.
  29. 29. ahlCVA||context
    Barcode fonts have been around for ages. But what's cute about this one is that it can calculate the EAN13 checksum on its own.
  30. 30. alex_suzuki||context
    It can’t, at least for Code 128? There’s a text field that you enter the text into, and then the start/stop/checksum characters are computed.
  31. 31. ahlCVA||context
    It seems like it doesn't do this for Code 128 (possibly because it is variable-width?). It definitely works with EAN13 though - I tried it locally using only the TTF file.
  32. 32. alex_suzuki||context
    Oh, interesting! I tried it in Word on macOS but didn't get it to work. But it works in the browser (question mark = calculates check digit).

    It uses this, which i have no idea what it is :-) https://learn.microsoft.com/en-us/typography/opentype/spec/f...

  33. 33. dfox||context
    Do not do this unless you do not have any other choice. Preferrably use whatever native barcode support of the printer involved, if it does not have that, just generate the barcode as vector image or bitmap with a resolution that is a integer fraction of the printers resolution. Generating correct Code128 as a SVG is about the same amount of work as generating the correct input for some sort of barcode font (the hard part is determining the switches between character sets, not generating bars from bytes).
  34. 34. alex_suzuki||context
    Shameless plug for my web-based Zint frontend: https://barcode.new (in-browser WASM)

    I wrote it specifically because most online barcode generators don’t support vector output or suck in some other way: ads, signup necessary, code payload exposed to server-side processing etc.

  35. 35. pwdisswordfishs||context
    Aside from obfuscating the source code to sell licenses, how does this benefit from WASM?

    Barcodes have been generated for decades on low-resource embedded devices. Even what would have been a modest-to-low-end machine 25 years ago would have no problem handling the compute needed for this job.

    On this end, it just looks like the user has to deal with the penalty of dealing with 1 MB of resources when hitting the main page.

  36. 36. alex_suzuki||context
    The benefit of WASM in this case is that you can wrap a mature library written in C/C++ (in this case, Zint), and run it in a runtime that supports WASM, e.g. the browser. There's plenty of people who occasionally need to create barcodes, and not in some industrial, automated way, and a browser is just an easy way to accomplish that. Yes, you have 1MB loaded when you load the page, but hopefully that will be served from a cache.
  37. 37. nolroz||context
    One MEGAbyte?? How could you!?
  38. 38. Theodores||context
    As a connoisseur of SVG, I like the approach, the results, the use of Zint and WASM. That said, there are a few opportunities.

    The version string isn't needed these days, nor the XML header or the doctype.

    The code/url/page title can go in the SVG title, to make it show on mouseover.

    The id=barcode is also superfluous. Since id codes should be unique, this could be a problem when many QR codes exist on a page.

    The background rectangle does not need x=0, y=0 since that is implied.

    The 'hard coding' of the black and white is what you want to avoid any dark mode issues, however, I would still use currentColor and transparent rather than black, just to put myself in a world of dark/light mode pain, fixed in CSS.

  39. 39. alex_suzuki||context
    This is super cool, thank you!

    The SVG is actually generated by Zint itself, only lightly patched in the wrapper. Zint is a pretty old barcode generator (not meant disrespectfully, quite the opposite actually), it's quite possible that some of its decisions when rendering to SVG are out of date or very conservative. The use of id/global namespace does feel like a potential pain point though, which I will take up with the upstream project.

  40. 40. pwdisswordfishs||context
    > There's plenty of people who occasionally need to create barcodes

    > hopefully that [1MB] will be served from a cache

  41. 41. tfpgh||context
    This is amazing!
  42. 42. mark-r||context
    I once worked at a company that used a Code39 font cartridge in HP Laserjets. When HP stopped putting font cartridge slots in their printers, I had the task of intercepting print jobs and detecting the font selection sequence, then taking the text and converting it to a Code128 bitmap graphic. It wasn't hard at all, kind of fun actually.
  43. 43. darksim905||context
    'font' cartridge? the what now?
  44. 44. ValdikSS||context
    In the dark ages, when printers were PostScript and more powerful (and expensive) than the computers which printed on them, you added fonts by installing additional hardware modules, similar to a game console cartridge.
  45. 45. darksim905||context
    The links someone else shared are pretty cool, a little before my time (born late 80s). That's kinda neat, it makes me think of a post on HN some time back by Donald Knuth on the letter S and the technical challenges back then about that as a letter, mathmatically. I'm guessing given that, that's why printers needed these modules and were set up this way. Neat!
  46. 46. wildzzz||context
    They were ROM cards that stored extra typefaces or other PostScript functions.
  47. 47. EvanAnderson||context
    You're one of today's lucky 10,000.

    Like another poster said, laser printers "back in the day" were freestanding computers with various communications interfaces that happened to have fancy paper handling and printing peripherals attached. In the case of the Apple LaserWriter, for example, it was arguably a more powerful computer[0] than the Mac machines of the day that were sending print jobs to it.

    There were different ROM "personalities" available for laser printers, some of which came on pluggable cartridges.

    Check these links out:

    - https://www.pagetable.com/?p=1673

    - https://www.pagetable.com/?p=1721

    - https://www.pagetable.com/?p=1850

    Michael Steil, the blogger responsible for those links, has done work extracting code and PostScript data out of some of those old cartridges. It's a really cool aspect of retrocomputing many people aren't even aware of.

    [0] https://web.archive.org/web/20240404213221/https://lowendmac...

  48. 48. darksim905||context
    commented elsewhere but The links you shared are pretty cool, a little before my time (born late 80s). That's kinda neat, it makes me think of a post on HN some time back by Donald Knuth on the letter S and the technical challenges back then about that as a letter, mathmatically. I'm guessing given that, that's why printers needed these modules and were set up this way. Neat!
  49. 49. mark-r||context
    The LaserWriter was like something from the future compared to the Laserjet. I think they used the same Canon print engine, but the HP was far less sophisticated. It only used bitmap fonts, nothing scalable like Adobe's Type 1 for Postscript. Knuth probably used a supercomputer for his typesetting.
  50. 50. mark-r||context
    And if you don't know the origin of the phrase "lucky 10,000" then it's your lucky day too!

    https://xkcd.com/1053/

  51. 51. xp84||context
    Up until like 15 years ago, lots of laser printers even had RAM slots as well. Populating them with extra RAM made them behave better when printing big PDFs and stuff.
  52. 52. benj111||context
    Don't say it too loudly. I'm sure HP would love to introduce 'Font as a service'
  53. 53. Theodores||context
    You have given me the encouragement I needed...

    Recently I put some 8-bit graphics in SVG using lines and stroke dash arrays. I also got them animated, in a space efficient way, by keeping the lines that do not change from frame to frame. (I now have Maria and Willy from 'Jet Set Willy' for the wait after a form is submitted, plus a few Space Invaders. I am resisting the urge to do Pac-Man ghosts, but I will invent a need for them...)

    Since an SVG can be a mystery box full of CSS, SMIL, Javascript and 'foreign object' imports, I am tempted to give it a go, so that a CSS variable is passed to the depths of the shadow DOM in a URL fragment or query string, to magically return either a barcode or a QR code.

    This will take a little while, but I am keen to give it a go. In some ways, SVG is like 'Duplo LEGO' with the Libre Barcode as a font more like 'LEGO Technik', requiring vastly more skill.

    Just because you can doesn't mean that you should, plus there are many barcode libraries that I know well, so why reinvent the wheel?

    The typical barcode library usually comes with fluff, formats and libraries that I don't need. Hence 'qr.svg#upc-number' with it just being one file has appeal.

    I am not yet up to speed on the latest AI toys, however, given the problem space is well defined, could I just ask AI chat bot to churn out the code for this in a matter of seconds, for it to encapsulate the logic in an SVG? Would it know how to specify 'crisp edges' and what the deal is with aspect ratio?

    Similarly, could I also ask the AI nicely to create my own barcode font?

    These seem manageable problems for todays trillion-dollar wonder tech, it is not as if I am asking for a cure for cancer or anything hard, yet I lack confidence in an AI solution, and feel I might as well work it out myself, given my goal is learning SVG rather than prompting.

    My lack of confidence is the AI solution is due to the scarcity of people writing online about doing cool things with CSS variables, URL fragments and code in SVG. A Google search does not show 'stroke dash array' things for QR codes and online QR code generators create lots of fully fledged rect-angles, that lack the space efficiency or human-readability of my prefered approach, even if gzip doesn't care.

    Sorry for bringing AI into everything, I just have my doubts that the new toys are that capable when it comes to novel solutions.

  54. 54. jpitz||context
    I did exactly that ( bitmap ) for a retail application back in ~2000. It was just a couple of constants for the stop and start sigils plus an array of bits for the digits....it was a quick work.
  55. 55. OrangeMusic||context
    I'm sorry, after reading your comment several times I still don't understand why we shouldn't use this. What is the problem with it?
  56. 56. ciupicri||context
    It's not clear to me how can I put FNC3 and the beginning of the Code 128 bar code.
  57. 57. joewhale||context
    fyi code 39 barcodes are outdated because of the lack of check sums and leads to false positives.
  58. 58. infogulch||context
    Neat! Barcodes are much more complex that I knew before looking into it. I used JsBarcode [1] to create a special barcode that reprograms a cheap barcode scanner we got on Amazon to be able to scan both UPS and FedEx tracking numbers. It is published on CodePen [2].

    [1]: https://github.com/lindell/JsBarcode

    [2]: https://codepen.io/infogulch/pen/yyLJdrP

  59. 59. muhammadusman||context
    just curious: are barcodes better in anyway compared to a QR code?
  60. 60. wps||context
    I believe they are much faster to scan, as you don’t need to identify the corners.
  61. 61. dimatura||context
    They are simpler and can be read by more devices, especially legacy devices that are still pretty widely deployed. Other than that, not much to say in their favor. They have lower data density compared to 2D codes such as QR or datamatrix. Many linear barcode symbologies have weak or nonexistent error correction capability. But often you don't need that extra data, and the cost of changing processes and equipment to upgrade to a new barcode format is seen as not worth it.
  62. 62. ChrisMarshallNY||context
    Very nice.

    Now, do it with QR codes...