Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. Qt for MCUs
  4. How to Optimize Font Memory Usage in Qt for MCUs 2.7.1 (fontcompiler-args not supported)
Forum Updated to NodeBB v4.3 + New Features

How to Optimize Font Memory Usage in Qt for MCUs 2.7.1 (fontcompiler-args not supported)

Scheduled Pinned Locked Moved Unsolved Qt for MCUs
6 Posts 3 Posters 867 Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • S Offline
    S Offline
    say_1
    wrote on last edited by
    #1

    Hi everyone,
    I'm working on a project using Qt for MCUs 2.7.1, and I'm currently facing a memory optimization issue related to fonts.

    Setup Details:

    • Qt version: 2.7.1 (mandatory due to customer constraint)
    • Toolchain: IAR
    • Fonts used: TTF
    • .qmlproject is exported using a .bat file that calls qmlprojectexporter.exe

    The generated file qul_font_engines.cpp alone is taking up around 3636 KB of memory, which is too large for our current memory constraints.
    My goal is to bring this down under 1000 KB if possible.

    What I've Already Tried (Please Don't Suggest These Again 🙂):

    • --fontcompiler-args option in the .bat file:
    • I tried using --fontcompiler-args "--chars=0123456789"
    • Result: Not supported in Qt for MCUs 2.7.1 → shows Unknown options: fontcompiler-args, chars
    • Verified fontcompiler.exe is present in 2.7.1, but CLI option is still not supported.
    • Cannot upgrade to Qt 2.8.0 or later due to customer-mandated toolchain freeze.
    • Tried setting font size lower in QML (font.pixelSize: 16) and limited font styles (font.bold/italic: false) → helped marginally but not enough.
    • Started reviewing QML files to eliminate unused text/glyphs.

    What I'm Looking For:

    • Are there any other ways in Qt for MCUs 2.7.1 to reduce the font memory footprint without relying on unsupported CLI arguments?
    • Is there a way to use fontCompilerOptions inside .qmlproject or .qmlprojectconfig that can limit the character set?
    • Can I manually run fontcompiler.exe to generate .qulfnt files and use them directly in my .qmlproject?
    • Any other suggestions to significantly reduce qul_font_engines.cpp size?

    Any advice or experience you can share would be greatly appreciated!
    Thanks in advance
    — Sayali

    1 Reply Last reply
    0
    • SGaistS Offline
      SGaistS Offline
      SGaist
      Lifetime Qt Champion
      wrote on last edited by
      #2

      Hi and welcome to devnet,

      First thing, sorry, I don't have experience with Qt for MCU. That said I was wondering: is just replacing qmlprojectexporter from 2.7.1 by the one from 2.8.2 an option ? The rest stays the same.

      Interested in AI ? www.idiap.ch
      Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

      1 Reply Last reply
      0
      • S Offline
        S Offline
        say_1
        wrote on last edited by
        #3

        Hi,
        Thank you so much for taking the time to respond — I really appreciate it.
        Yes, I have previously tried using the qmlprojectexporter from Qt for MCUs 2.8.2 while keeping the rest of the toolchain and setup on 2.7.1. The project compiles successfully with that approach.
        However, even with the 2.8.2 exporter, I did not observe any noticeable reduction in the generated font file size. The memory usage for qul_font_engines.cpp remains almost the same, which is the core issue I'm trying to address.
        Thanks again for your input — happy to hear any further ideas you might have!

        1 Reply Last reply
        0
        • S Offline
          S Offline
          say_1
          wrote on last edited by
          #4

          As a continuation of my earlier post regarding memory optimization, I switched the font engine from Static to Spark in my Qt for MCUs project to reduce memory footprint.

          I would like to understand the following:

          What specific library files are required when using the Spark font engine on an embedded environment?

          How should these libraries be linked or added to the build process to avoid runtime errors?

          Is there any documentation or steps specific to ensuring the Spark engine works properly during integration with an application?

          The build works fine on my side, but once integrated into the larger system, it fails unless the missing library is resolved.

          Any help or direction on resolving this and properly setting up Spark would be appreciated.

          jsulmJ 1 Reply Last reply
          0
          • S say_1

            As a continuation of my earlier post regarding memory optimization, I switched the font engine from Static to Spark in my Qt for MCUs project to reduce memory footprint.

            I would like to understand the following:

            What specific library files are required when using the Spark font engine on an embedded environment?

            How should these libraries be linked or added to the build process to avoid runtime errors?

            Is there any documentation or steps specific to ensuring the Spark engine works properly during integration with an application?

            The build works fine on my side, but once integrated into the larger system, it fails unless the missing library is resolved.

            Any help or direction on resolving this and properly setting up Spark would be appreciated.

            jsulmJ Offline
            jsulmJ Offline
            jsulm
            Lifetime Qt Champion
            wrote on last edited by
            #5

            @say_1 said in How to Optimize Font Memory Usage in Qt for MCUs 2.7.1 (fontcompiler-args not supported):

            What specific library files are required when using the Spark font engine on an embedded environment?

            You can check the direct dependencies of a library by using the ldd tool.

            "How should these libraries be linked or added to the build process to avoid runtime errors?" - not at all. You just need to make sure these libs are installed on the target machine.

            https://forum.qt.io/topic/113070/qt-code-of-conduct

            1 Reply Last reply
            0
            • S Offline
              S Offline
              say_1
              wrote on last edited by
              #6

              Hi again,
              This is a follow-up to my earlier post regarding the Spark font engine integration with complexTextRendering enabled.
              I’ve resolved all the build-time errors related to Spark integration, and both the platform and application layers build successfully. However, after flashing the final binary onto the hardware, all the text has disappeared from the screen — only images are visible. It seems like text rendering is completely missing at runtime.
              Regarding the previous suggestion to use the ldd tool to check for library dependencies — thank you for the recommendation. Since I'm working on different OS and building with MinGW, I wasn’t able to use ldd directly but did try some alternative tools available for Windows that perform similar dependency checks.
              Has anyone experienced a similar issue where the text doesn't appear on hardware after enabling Spark font engine with complexTextRendering = true? Any insights on what could be going wrong or how to debug this would be greatly appreciated.
              Thanks in advance!

              1 Reply Last reply
              0

              • Login

              • Login or register to search.
              • First post
                Last post
              0
              • Categories
              • Recent
              • Tags
              • Popular
              • Users
              • Groups
              • Search
              • Get Qt Extensions
              • Unsolved