20 августа 2019 г. 3:04

Работе с лоадерами в QML

Ку. Такой вопрос у меня есть лоадеры в контейнере колумн , в последнем лоадере используется условие из первого ( if(taskStatus.value == "Работа" valuePath Сменить на нужный мне).По логам выходит что послдений лоадер срабатывает быстрее чем условие из первого . Есть у кого какие мысли как фиксануть ?

 Column {
        id: column
        width: parent.width
        spacing: Theme.paddingMedium

        Loader {
            id: taskStatus 
            width: parent.width
            displayName: qsTr("Статус")
            valuePath: "Some.value"
            catalogKey: "SomeName.value"
            values: navigator.getPath(catalogValue)
            onValueChanged:  console.log(taskStatus.value) // логи
            readOnlyField: (value == "Выполнена" || value == "Не выполнена")
            internalType: "katalog"
        }
// ..............................


        Row {
            width: parent.width
            spacing: Theme.paddingMedium


        SectionHeader {
            text: qsTr("Основная информация")
        }

        Row {
            width: parent.width
            spacing: Theme.paddingMedium
 // some loaders .....
            Loader{} 
        }

 // some loaders .....
        Loader{} 

        Loader {
            id: timeStart
            width: parent.width
            displayName: qsTr("Время начала")
            type: "Date"
            // вот тут условие ,то в комментарии не работает
            valuePath : autoSet ? /*&& taskStatus.value == "В работе"*/ ? "other" : "Some.Value"
           onValueChanged: console.log(taskStatusCatalog.value) // Логи
            readOnlyField: taskStatus.value == "Назначена" ? false : true

            internalType: "none"
        }
// some loaders .....
            Loader{} 
    }
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.
8

как вариант проверять создан ли первый лоадер, что-то вроде Component.onCompleted

пробовал так, но тогда для последнего лоадера ВальюПас не задается

  Loader {
            id: taskStatus 
            width: parent.width
            displayName: qsTr("Статус")
            valuePath: "Some.value"
            catalogKey: "SomeName.value"
            values: navigator.getPath(catalogValue)
            onValueChanged: console.log(taskStatus.value)
//            Component.onCompleted: {
//                if(taskStatus.value == "В работе" &&  autoSet ) {
//                    timeStart.valuePath = "other"
//                } else {
//                    timeStart.valuePath =  "Some.value"
//                }
//                //может как то тут попробовать обновить модель ?

//            }
            readOnlyField: (value == "Выполнена" || value == "Не выполнена")
            internalType: "katalog"
        }
  • 20 августа 2019 г. 4:19
  • (ред.)

может есть вариант как то самому переопределить порядок загрузкт лоадеров?

p.s. Хотя вот тут в лоадере условие из первого учитывается

// some loaders .....
        Loader{} 

        Loader {
            id: timeStart
            width: parent.width
            displayName: qsTr("Время начала")
            type: "Date"
            // вот тут условие что в комментарии ,не работает
            valuePath : autoSet ? /*&& taskStatus.value == "В работе"*/ ? "other" : "Some.Value"
           onValueChanged: console.log(taskStatus.value) // Логи
         //вот тут все нормально работает 
         readOnlyField: taskStatus.value == "Назначена" ? false : true

            internalType: "none"
        }
// some loaders .....
            Loader{} 
    }

а можно кратко суть зачем столько лоадеров и какой у них должен быть принцип работы?

а можно кратко суть зачем столько лоадеров и какой у них должен быть принцип работы?

  • 20 августа 2019 г. 5:57
  • (ред.)

если кратко, отдельно в файле оределены лодеры для каждого типа(datatime textfield label etc.) , которые заполняются значениями из плюсов , я просто MyLoader заменил на Loader чтобы не путаться. Суть вот в чем , при статусе задачи в работе например , и при выставленнов флаге сет = тру , проставлять автоматически время(т е я тупо меняю валью пас который обращается к плюсам на тот что жеско задан в QML)

 // вот пример из того файла где определены лоадеры
function setValue() {
        if(valuePath != "none" && valuePath != "other" ){
            if (entyNumb != -1) {
                getEntyti()
            } else {
                getTask()
            }
            if (type == "DateTime") {
                value = Navigator.timeToIsoDate(value)
            }
        } else if(valuePath != "none" && valuePath == "other" ){
            if (type == "DateTime") {
                value = Navigator.DateToTime_t() 
                value = Navigator.timeToIsoDate(value)
            }
            console.log("other valuePath")
        } else {
            console.log("unknow valuePath")
        }
    }

если правильно понимаю то вам просто нужно менять значение в лейблах по определенному событию - тогда зачем вам лоадер, может легче отправлять сигнал из плюсов и в слоте присваивать значения в зависимости от статуса

  • 5 сентября 2019 г. 9:45
  • Ответ был помечен как решение.

разобрался )))

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Ищу работу?
25,000.00 руб. - 30,000.00 руб.
Разработчик Qt/C++
Barnaul, Altai Krai, Russia

Для зарегистрированных пользователей на сайте присутствует минимальное количество рекламы

ЮА
17 сентября 2019 г. 8:51
Юлия Александрова

C++ - Тест 001. Первая программа и типы данных

  • Результат:33баллов,
  • Очки рейтинга-10
ЮА
17 сентября 2019 г. 8:36
Юлия Александрова

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:10баллов,
  • Очки рейтинга-10
ВД
16 сентября 2019 г. 11:47
Виктор Дзенькив

C++ - Тест 002. Константы

  • Результат:75баллов,
  • Очки рейтинга2
Последние комментарии
17 сентября 2019 г. 6:07
Misha Lebedev

Кстати интересные темы нашёл тут https://emacsway.github.io/ru/django-framework/#django-models Может что полезного тоже Евгений найдёте
17 сентября 2019 г. 4:50
Misha Lebedev

Доброго времени суток. Спасибо за хороший ответ, У меня ситуация така что в галлереи будет несколько миллионов фотографий с фильтрами и тегами , и я опасаюсь за производительност . Это ос…
17 сентября 2019 г. 3:23
Евгений Легоцкой

Добрый день. Да, я тоже читал ту статью в своё время и согласен с тем, что внешние ключи гораздо лучше, чем GenericForeignKey. Выборки в ряде случае работают быстрее. Но лично мне про…
14 сентября 2019 г. 17:08
Misha Lebedev

Приветствую вас Евгений , давно наблюда за развитием вашего замечательного портала, много полезно тут нашел , переодически зачитываюсь. Теперь по сушеству, делаю портал и там идеально ложи…
10 сентября 2019 г. 16:38
Евгений Легоцкой

function view для модели Article и LikeDislike.LIKE будет выглядеть так def like(request, pk): obj = Article.objects.get(pk=pk) try: likedislike = LikeDislike.objects.get(cont…
Сейчас обсуждают на форуме
p
17 сентября 2019 г. 5:02
pstMem

Да, действительно нужно дебажить, по другому не словить исключение. Уже решил проблему, был выход за предел массива, не правильные входные данные, так что всегда проверяйте размер массива.
17 сентября 2019 г. 3:39
Евгений Легоцкой

Добрый день! На удалённом сервере вряд ли. Этот класс из core модуля, а удалённый сервер - это ещё и network модуль нужно подтягивать. Тут на удалэнном сервере нужно делать программу…
17 сентября 2019 г. 3:30
Евгений Легоцкой

Добрый день! Попробуйте toHex() А также создние QString с помощью from методов. Может быть QString::fromLatin1(). В документации на QString почти два десятка методов from, один из них…
m
16 сентября 2019 г. 13:54
mihamuz

Однозначно PostgreSql не ниже 10 ки.
R
16 сентября 2019 г. 7:09
RED_Spider

прочитайте https://doc.qt.io/archives/qt-5.11/osx-deployment.html QMAKE_POST_LINK += "~/Qt/5.12.0/clang_64/bin/macdeployqt $${TARGET}.app $$escape_expand( \\n\\t )"
EVILEG
О нас
Услуги
© EVILEG 2015-2019
Рекомендует хостинг TIMEWEB