BlinCT
BlinCT19 мая 2016 г. 15:56

Переключение между двумя обьектами класса

handlers, id, qml, signals

Всем привет.
Пытаюсь решить такую задачу, в main.qml есть 4 контента с которыми надо работать.

CircleTimerContent  //Заполнение данными из файла CircleTimerContent
{
    id:circletimercontent
    anchors.top: parent.top
    anchors.topMargin: dp(125)
    anchors.horizontalCenter: parent.horizontalCenter
    width: dp(130)
    height: dp(130)
}
 
CircleTimerContent  //Заполнение данными из файла CircleTimerContent
{
    id:circletimercontent2
    anchors.top: circletimercontent.bottom
    anchors.right: circletimercontent.left
    anchors.left: parent.left
 
    anchors.topMargin: dp(10)
    anchors.horizontalCenter: parent.horizontalCenter
}
 
ToolBarContent  //Заполнение данными из файла ToolBarContent
{
    id: toolbarcontent
    onChecked:
    {
        settimecontent.flag = check
        circletimercontent.flag = check
        circletimercontent2.flag = check
    }
}
 
SetTimeContent  //Заполнение данными из файла SetTimeContent
{
    id:settimecontent
    anchors.top: toolbarcontent.bottom
    anchors.topMargin: dp(5)
}

Первые 2 это объекты одного класса, работают одинаково. На третьем располагается переключатель который меняет режимы для выше описанных 2 объектов. На 4 находится объект на котором есть текстовая надпись и поле ввода.

Описание CircleTimerContent.qml

import QtQuick 2.0
import CircleTimer 1.0
 
CircleTimer
{
    id: circletimer
    property alias flag: circleTimerClicked.flag
 
    Text
    {
        id: texttimer
        anchors.centerIn: parent
        font.bold: true
        font.pixelSize: 15
    }
 
    onCircleTimeChanged:
    {
        texttimer.text = Qt.formatTime(circleTime, "hh:mm:ss")
    }
 
    MouseArea
    {
        id: circleTimerClicked
        anchors.fill: parent
        property bool flag: true
        onClicked:
        {
            if(circletimer.isClickedTimer(circleTimerClicked.width, circleTimerClicked.height, mouse.x, mouse.y))
            {
                if(circleTimerClicked.flag === false)
                {
                    console.log("bla bla")
                }
                else
                {
                    if (circletimer.isRunning())
                    {
                        circletimer.stop();
                    }
                    else
                    {
                        circletimer.start();
                    }
                }
            }
        }
    }
}

Здесь есть 2 режима, это если флаг один то мы может работать с таймерами а если другой то что то посылать во внешку.

Данные из SetTimerContent.qml

Item
{
    id: timerValue
    property alias flag: testtext.flag
    Label
    {
        id: labeltext
        text: "Timer: "
        width: 50
    }
    TextField
    {
        id:testtext
        inputMask: ("NN:NN")
        text: "00:00"
        anchors.left: labeltext.right
        width: 55
        property bool flag: true
        readOnly: flag
        Keys.onPressed:
        {
            console.log(event.key)
            if(event.key === Qt.Key_Enter ||  event.key === Qt.Key_Return)
            {
                circletimercontent.timerValue = testtext.text
                circletimercontent.testTimerValue = testtext.text
                circletimercontent.clear();
 
            }
        }
    }
}

Здесь на минимуме что я пытаюсь сделать так это при нажатии на один из объектов CircleTimerContent послать в поле labletext.text (так мне кажется возможно реализовать) id выбранного объекта. То есть в label будет содержатся название или circletimercontent или circletimercontent2. Этим мы будем определять что было выбрано.
На максимуме я хочу чтобы при выборе одного из объектов из поля testtext.text уже заданные данные посылались именно в выбранный объект CircleTimerContent.
Я думаю что если пойму как решить минимальную задачу с надписью то второе уже будет близким по решению и решить смогу сам. Но вот примерно как с надписью при выборе очень плохо понятно(

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

1
Evgenii Legotckoi
  • 20 мая 2016 г. 19:29
  • Ответ был помечен как решение.

Вот небольшой пример на эту тему, чтобы можно было выбирать какой-то целевой объект с помощью идентификаторов. В этом случае также необходимо использовать сигналы и обработчики сигналов. Ну а в CircleTimer объектах можно сделать также property alias для свойств text. Вместо них в примере даны Rectangle.

main.qml

import QtQuick 2.6
import QtQuick.Controls 1.5
 
ApplicationWindow {
    visible: true
    width: 640
    height: 480
    title: qsTr("Hello World")
 
    SetTimerContent  //Заполнение данными из файла SetTimeContent
    {
        id:settimercontent
        height: 50
        anchors.top: parent.top
        anchors.left: parent.left
        anchors.right: parent.right
        anchors.topMargin: 10
        anchors.leftMargin: 10
        anchors.rightMargin: 10
 
        onSetTextToTarget: {
            switch(targetId)
            {
            case 1:
                text1.text = text
                break;
            case 2:
                text2.text = text
                break;
            }
        }
    }
 
    Rectangle {
        id: firstRectangle
        height: 50
        color: "blue"
        anchors {
            top: settimercontent.bottom
            left: parent.left
            right: parent.right
            topMargin: 10
            leftMargin: 10
            rightMargin: 10
        }
 
        Text {
            id: text1
            anchors.centerIn: parent
        }
 
        MouseArea {
            anchors.fill: parent
            onClicked: {
                settimercontent.targetId = 1
            }
        }
    }
 
    Rectangle {
        id: secondRectangle
        height: 50
        color: "red"
        anchors {
            top: firstRectangle.bottom
            left: parent.left
            right: parent.right
            topMargin: 10
            leftMargin: 10
            rightMargin: 10
        }
 
        Text {
            id:text2
            anchors.centerIn: parent
        }
 
        MouseArea {
            anchors.fill: parent
            onClicked: {
                settimercontent.targetId = 2
            }
        }
    }
}

SetTimerContent.qml

import QtQuick 2.5
import QtQuick.Controls 1.4
 
Item
{
    id: timerValue
    property alias flag: testtext.flag
    property alias targetId: testtext.targetId
 
    signal setTextToTarget(var text, var targetId)
 
    Label
    {
        id: labeltext
        text: "Timer: "
        width: 50
    }
    TextField
    {
        id:testtext
        inputMask: ("NN:NN")
        text: "00:00"
        anchors.left: labeltext.right
        width: 55
        property bool flag: false
        property int targetId: 1
        readOnly: flag
        Keys.onPressed:
        {
            console.log(event.key)
            if(event.key === Qt.Key_Enter ||  event.key === Qt.Key_Return)
            {
                setTextToTarget(testtext.text, testtext.targetId)
            }
        }
    }
}

 

    Комментарии

    Только авторизованные пользователи могут публиковать комментарии.
    Пожалуйста, авторизуйтесь или зарегистрируйтесь
    Ua

    Qt - Тест 001. Сигналы и слоты

    • Результат:84баллов,
    • Очки рейтинга4
    Ua

    Qt - Тест 001. Сигналы и слоты

    • Результат:42баллов,
    • Очки рейтинга-8
    ОК

    Qt - Тест 001. Сигналы и слоты

    • Результат:47баллов,
    • Очки рейтинга-6
    Последние комментарии
    ИМ
    Игорь Максимов22 ноября 2024 г. 21:51
    Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    Evgenii Legotckoi
    Evgenii Legotckoi31 октября 2024 г. 23:37
    Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
    A
    ALO1ZE19 октября 2024 г. 17:19
    Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
    ИМ
    Игорь Максимов5 октября 2024 г. 16:51
    Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
    d
    dblas55 июля 2024 г. 20:02
    QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
    Сейчас обсуждают на форуме
    f
    firstlunoxod15 февраля 2025 г. 13:46
    Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
    Дмитрий
    Дмитрий3 февраля 2025 г. 16:24
    Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
    NW
    Nayo Wai30 января 2025 г. 19:22
    не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
    n
    nkly3 января 2025 г. 12:52
    Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
    M
    Marsel17 августа 2023 г. 0:26
    OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

    Следите за нами в социальных сетях