Evgenij LegotskojOct. 20, 2015, 12:06 p.m.

QML - Lesson 005. Using a Sprite and AnimatedSprite in QML Qt

Once on the sprites was written three lessons by drawing them to their practical application in Qt in this and this article, I believe that we can not ignore the use of sprites in QML Qt.

Sprites are used in QML is even easier than in Qt / C ++, QML because there are classes that are specifically designed to work with sprites: Sprite and AnimatedSprite.

The project structure to work with Sprite and AnimatedSprite

The project is created as a standard project QtQuick with controls, and then I throw out all superfluous Tipo menyubara and buttons. I am leaving only that we will use for demonstration.

  • main.cpp - the main project file that runs qml file;
  • main.qml - application window;
  • MainForm.ui.qml - form to work with the designer;
  • sprite_sheet.png - the image of our sprite.

sprite_sheet.png

main.qml

As a lesson in itself is quite simple, it will focus on the code only this file.

In this tutorial, I suggest two options for the use of sprites. One embodiment - is the application via SpriteSequence , which can be placed in different sprites with different sources. The second option - is using AnimatedSprite , which is taken one source. Both the use of sprites in this lesson will give the same result.

In SpriteSequence is given sprite size and its position in the main window of the application, while the frame size of the sprite and the number of its personnel is defined already in the Sprite object, which is placed in SpriteSequence . In the SpriteSequence you can put a few of these objects Sprite.

In the case of all parameters AnimatedSprite sizes and locations, as well as its size and frame number are specified in the AnimatedSprite. The difference is that only one image can be taken as a source of sprites.

Also, you must specify frameSync like true. Then sprites will work synchronously, if you do not, then they will run slowly and alternately.

import QtQuick 2.5
import QtQuick.Controls 1.4
import QtQuick.Dialogs 1.2

ApplicationWindow {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")

    MainForm {
        // Stretch the shape of the main window over the application window
        anchors.fill: parent

        /* Stretch the shape of the main window over the application window. 
         * Object sprites sequence. 
         * This object can be set different sprites with different pictures and their sequence
         * */
        SpriteSequence {
            id: image
            width: 20   // The width of the area under the sprite
            height: 20  // The height of the area under the sprite
            // Sprite is located at the top left of the application window
            anchors.left: parent.left
            anchors.leftMargin: 100
            anchors.top: parent.top
            anchors.topMargin: 100

            Sprite {
                id: sprite
                source: "sprite_sheet.png"
                frameCount: 15     
                frameWidth: 20   
                frameHeight:  20   
                frameSync: true     
            }
        }

        AnimatedSprite {
            id: animatedSprite

            width: 20 // The width of the area under the sprite 
            height: 20 // The height of the area under the sprite
            // Sprite is located at the top right of the application window
            anchors.right: parent.right
            anchors.rightMargin: 100
            anchors.top: parent.top
            anchors.topMargin: 100

            source: "sprite_sheet.png"
            frameCount: 15  
            frameWidth: 20  
            frameHeight: 20 
            frameSync: true 
        }
    }
}

Conclusion

As a result, you will receive an application in the left and right corner which will house works equally sprites explosions. Demonstration applications, see the video tutorial, are also shown in the video tutorial behaviors sprites if not configured properly.

Video

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
Support the author Donate

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
ZK

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:60points,
  • Rating points-1
V

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:70points,
  • Rating points1
V

C++ - Тест 003. Условия и циклы

  • Result:71points,
  • Rating points1
Popular publications in the last 90 Days
Last comments
RS

Django - Tutorial 007. Adding Pagination based on django-bootstrap3

а как быть если нет базы и запроса в БД, а данные приходят по запросу в api стороннего сервера, а клиент серверное приложение на django и я хочу реализовать пагинацию на стороне django. В апи я …
e
  • ethen
  • Aug. 28, 2021, 3:49 p.m.

Release of the C++/Qt and QML application deployment utility CQtDeployer v1.5.0

Благодарю. Действительно, подменил файлы от версии 4.0, и все заработало)

Release of the C++/Qt and QML application deployment utility CQtDeployer v1.5.0

На данный момент Qt Installer Framework не поддерживает Windows 7 смотрите баг #2224
  • 4X_Pro
  • Aug. 26, 2021, 7:32 a.m.

Распознавание изображений на Python с помощью TensorFlow и Keras

Понимаю. А ещё понимаю, что не потратить время нельзя. День всё равно пройдёт, и вопрос только в том, на что он будет потрачен: на то, что приносит в жизни удовольствие или нет. Насчёт заст…
KS

Qt/C++ - Lesson 023. Moving QGraphicsItem on QGraphicsScene with mouse help

здравствуйте! Подскажите, пожалуйста, как можно на Вашем примере реализовать вывод контекстного меню при нажатии на квадрат правой кнопкой мыши с целью решения задач: изменить объект и удалить? …
Now discuss on the forum
EK

HTTP server на Qt

Мой файл webapp1.ini [listener];host=192.168.0.100port=8080minThreads=4maxThreads=100cleanupInterval=60000readTimeout=60000maxRequestSize=16000maxMultiPartSize=10000000…

QScrollArea dynamically add QCheckBoxes

Всё правильно. Это просто спамер, который отправился в вечный бан.
a
  • ad40
  • Sept. 15, 2021, 3:32 a.m.

Qt proxyModel

Добрый день! Разобрался с задачей! (иногда отвлеченное участие приводит к нахождению решения , так что не могу не выразить благодарность участникам данного форума) Все оказаолось дов…
JaM

Update data | Django, Ajax

Привет, добрался я к реализации системы общения, тут как раз получилось что попал на ваши статейки, все работает как часы, но осталась одна маленькая деталь, как обновлять сообщения в диалоге и …
DCh

Вызов функции Python с Qml

Всем здравствуйте. Незамысловатая задача появилась у меня - вызвать функцию Python с Qml. Смотрел уроки на этом сайте, но что-то я не понимаю. Сверял код Qt C++, вроде как всё также, …
About
Services
© EVILEG 2015-2021
Recommend hosting TIMEWEB