Serving UI via HTTP
To load a simple user interface via HTTP we need to have a web-server, which serves the UI documents. We start off with our own simple web-server using a python one-liner. But first, we need to have our demo user interface. For this, we create a small Remote.qml
file in our project folder and create a red rectangle inside.
To serve this file we can start a small python script:
Now our file should be reachable via http://localhost:8080/Remote.qml
. You can test it with:
Or just point your browser to the location. Your browser does not understand QML and will not be able to render the document through.
Hopefully, Qt 6 provides such a browser in the form of the qml
binary. You can directly load a remote QML document by using the following command:
Sweet and simple.
Another way of importing a remote QML document is to dynamically load it using QML ! For this, we use a Loader
element to retrieve for us the remote document.
Now we can ask the qml
executable to load the local main.qml
loader document.
To load another file over the network from Remote.qml
, you will need to create a dedicated qmldir
file in the same directory on the server. Once done, you will be able to reference the component by its name.
Networked Components
Let us create a small experiment. We add to our remote side a small button as a reusable component.
Here's the directory structure that we will use:
Our main.qml
is the same as in our previous example:
In the remote
directory, we will update the Remote.qml
file so that it uses a custom Button
component coming from our own remote Button.qml
file:
Using a qmldir
, we will define the content of our (remote) QML directory:
And finally we will create our dummy Button.qml
file:
We can now launch our web-server (keep in mind that we now have a remote
subdirectory):
And remote QML loader:
Importing a QML components directory
By defining a qmldir
file, it's also possible to directly import a library of components from a remote repository. To do so, a classical import works:
Last updated