C

Customizing runtime environment

Environment and input

By default, the basic environment variables and startup options of Boot to Qt applications are set in /etc/default/qt or /etc/appcontroller.conf on embedded Linux devices.

You can customize this file if your target device has other input devices in addition to the ones that the Boot to Qt stack is configured for by default.

When you need to configure input devices, see Input in Embedded Linux Devices for more information.

USB input devices, such as keyboards and mice, are automatically recognized. The mouse pointer is shown automatically if a mouse is connected.

However, hotplugging might not work. This means that the input devices, such as a keyboard and mouse, have to be connected at boot time.

Switching to tslib for resistive touchscreens

For touchscreens that don't provide modern multitouch capabilities it might be necessary to use the tslib library instead of relying on direct event device access and the Linux kernel's multitouch protocol. The tslib library also allows calibration and is more suitable for resistive touchscreens that are often used in an industrial setting.

  • To enable tslib, add the following lines to /etc/default/qt on the device:
    QT_QPA_EGLFS_NO_LIBINPUT=1
    QT_QPA_EGLFS_TSLIB=1

    Note: The tslib plugin provides no multitouch events (QTouchEvent). It only generates mouse events (QMouseEvent).

  • If necessary, the device can be specified explicitly by setting TSLIB_TSDEVICE:
    TSLIB_TSDEVICE=/dev/input/event1
  • The touchscreen calibration can be done with ts_calibrate and the calibration file can be used by setting TSLIB_CALIBFILE:
    TSLIB_CALIBFILE=/etc/calibration.conf

Booting to a custom application

By default, the Boot to Qt Demo Launcher is configured to run on startup.

Follow these steps to have your application launch on boot:

  1. Go to Projects > Run for the Boot to Qt version you want to customize.
  2. Under Deployment, select Add Deploy Step > Change default application.
  3. Re-deploy your project. In Edit mode, select and hold (or right-click) the project and select Deploy, or select (Run).

Your application will now be launched on the next device reboot.

Alternatively, you can also run the following command on the device:

appcontroller --make-default <path>

Where <path> is the install path of your application binary on the device.

To remove your application from the default startup, run the following command on the device:

appcontroller --remove-default

Configuring the physical screen size for scalable user interfaces

The Boot to Qt Demo Launcher and Qt Quick Controls scale automatically to screens of different sizes, from 7" touchscreens to 60" or larger TVs to ensure readability and touch friendliness. For this, Qt has to know the physical dimensions of the screen. By default it tries to query these values from the framebuffer devices. Many kernel drivers do not provide this information, however.

To override and manually set a desired screen size, go the Launcher Settings view and change the values in the Physical screen size in millimeters boxes. Then tap the reboot button or restart your application. The controls will adjust their sizes based on the new settings.

Switching between portrait and landscape views

Depending on device screen dimensions and application requirements, it might be desirable to change the default view orientation. The following example shows how to rotate your application in QML:

import QtQuick 2.2

Item {
    id: root
    width: 800
    height: 1280
    // Container element for rotating
    Rectangle {
        id: main
        // Swap the width and height of the root item
        width: root.height
        height: root.width
        anchors.centerIn: parent
        // Rotate 90 degrees clockwise around transformOrigin
        rotation: 90
        // The rotated content
        Text {
            text: qsTr("Hello World")
            anchors.centerIn: parent
        }
        MouseArea {
            anchors.fill: parent
            onClicked: {
                Qt.quit();
            }
        }
    }
}

Resizing the SD Card root partition

By default, the Boot to Qt image has some extra free space reserved for development purposes, but not all of the extra capacity that the SD card might have is available. The Boot to Qt image includes tools for extending the root partition in the SD card to its full size.

Warning: The tools modify the partition layout which can cause data loss. Don't carry out the following steps if you're unsure or your SD card contains important files.

To resize the partition:

  1. Resize the partition table for the root partition, which is usually the second partition:
    parted -s /dev/mmcblk0 resizepart 2 100%
  2. Resize the file system on the second partition:
    resize2fs /dev/mmcblk0p2

where /dev/mmcblk0 refers to the device node of the SD card, and /dev/mmcblk0p2 to the second partition on that SD card.

Setting up USB Ethernet on target device

USB access to an embedded target device supports two different USB protocols. Use the default protocol RNDIS (Remote Network Driver Interface Specification) when connecting the target device to either a Linux or Windows host. When you want to connect the target device to a macOS host, you need to change the protocol to CDC-ECM (Communications Device Class - Ethernet Control Model). CDC-ECM also works with Linux.

After installing Boot to Qt to your target device, change the protocol as follows:

  1. Open the following file on the target device:
    /etc/default/qdbd
  2. Find USB_ETHERNET_PROTOCOL in the file and set it as follows:
    • For Windows and Linux:
      USB_ETHERNET_PROTOCOL=rndis
    • For macOS and Linux:
      USB_ETHERNET_PROTOCOL=cdcecm
  3. Connect the target to host with a USB cable and restart the target device.

In case of problems, see Troubleshooting.

Available under certain Qt licenses.
Find out more.