Privacy policyContactsAbout siteOpinionsGitHubDonate
© EVILEG 2015-2018
Recommend hosting
TIMEWEB
Dec. 20, 2016, 1:28 p.m.

QML Window fullscreen

fullscreen, Wwindow, QML

Добрый день Евгений, есть простой вопрос на который не могу найти ответ, помогите если можете.
Почему данный код не работает ?

Мои действия
1) Запускаю код, лог выдаёт:
qml: No FullScreen
2) Максимизирую окно, лог выдаёт:
qml: No FullScreen
qml: No FullScreen
3) Сворачиваю в окно, лог выдаёт:
qml: FullScreen
qml: FullScreen

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

Window
{
id: root
width: 100
height: 100
visible: true

function cellResize()
{
if(root.visibility == Window.Maximized)
console.log(“FullScreen”)
else
console.log(“No FullScreen”)
}

onWidthChanged: cellResize()
onHeightChanged: cellResize()
}

5

Добрый день.
Ну вообще-то всё правильно работает. Нет никакой задержки. Просто у вас код вызывается дважды.
У вас добавлено два обработчика. Один на изменение ширины, другой на изменение высоты.
При изменении размеров окна срабатывают два обработчика, вот та функция и вызывается дважды.
Почему при запуске приложения срабатывает всего один раз… понятия не имею.

Если хотите видеть вызов функции один раз, то используйте другой обработчик:

import QtQuick 2.7
import QtQuick.Controls 2.0
import QtQuick.Layouts 1.0
 
ApplicationWindow
{
    id: root
    width: 100
    height: 100
    visible: true
 
    function cellResize()
    {
        if(root.visibility == ApplicationWindow.Maximized)
            console.log("FullScreen")
        else
            console.log("No FullScreen")
    }
 
    onVisibilityChanged: cellResize()
}

 

0

Спасибо, ваше решение помогло, нужно глубже копать Ассистант. И последнее из данной тематики.
Часть кода, я хочу чтобы при изменении ширины менялась высота окна, (и наоборот при изменении высоты менялась ширина). Вроде бы в коде всё понятно, меняем ширину и должна менятся сразу высота и равняться ширине, но получается что высота вроде перерисовывается и лог показывает что она поменялась, но вид на глаз она остаётся неизменной. Посоветуйте может решали такую проблему.

Лог:
qml: Width: 302 Height: 300
qml: Width: 314 Height: 314
qml: Width: 322 Height: 322
qml: Width: 323 Height: 323

ApplicationWindow
{
    id: root
    width: 300
    height: 300
    visible: true
 
    property var widthChangeFlag: false
 
    function cellResize()
    {
     if(widthChangeFlag)
        root.setHeight(root.width)
     console.log("Width: " + root.width + " Height: " + root.height)
    }
 
    onWidthChanged: { cellResize(); widthChangeFlag = true; }
}

 

0

Какая у Вас ОС?
Под Ubuntu 16.04 изменение видно, но с багом, скачет между размером, который начальный, до изменения ширины, и размером равным ширине. Обработчик изменения ширины срабатывает с правильными параметрами, но видимо на вашем ПК высота после этого возвращается в исходный размер, а не в размер ширины.

Минимальный вариант реализации такой:
Поведение этого кода скорее всего будет такое же, как и описали Вы.

ApplicationWindow
{
    id: root
    width: 300
    height: width
    visible: true
}

Полагаю, что это баг Qt. А вообще, если вы просто тестируете работу данного кейса с изменением размеров, то не надо издеваться над ApplicationWindow, лучше накидайте туда объектов Rectangle и с ними балуйтесь. Они должны будут себя вести адекватнее.
А ApplicationWindow слишком зависимо от конкретной ОС.

0
Использую Windows 7 64bit, так как вы и написали “после этого возвращается в исходный размер, а не в размер ширины.”
Попробовал этот вариант с Rectangle, все работает отлично. Почему мне важно чтобы это работало, у меня много объектов внутри ApplicationWindow, и я меняю их размер динамически. Со всем разобрался кроме этого момента, ApplicationWindow – это для меня корень из которого я рисую все объекты. Ну если это баг то ничего не поделаешь.
0
Размеры-то других элементов внутри ApplicationWindow без проблем будут меняться, здесь этот баг влияние не должен оказывать.
Он оказывает такое влияние только на собственную высоту. С остальными элементами, что внутри должно без проблем работать. Так что, думаю, что не всё потеряно.
0

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Last comments
Feb. 21, 2019, 12:51 p.m.
Евгений Легоцкой

Иногда CMake приходится перезапускать начисто, не обновляет кэш
R
Feb. 21, 2019, 12:29 p.m.
RandyGallup

Я указал данные строки, т.к. без них у меня вылетала следующая ошибка: By not providing "FindQt5Core.cmake" in CMAKE_MODULE_PATH this project has asked CMake to find a package configurat...
Feb. 21, 2019, 12:08 p.m.
BlinCT

Вот атк выглядит мой проектник, посмотрите его. cmake_minimum_required(VERSION 3.6)project(projecttimer)set(CMAKE_CXX_STANDARD 11)set(CMAKE_AUTOMOC ON)set(CMAKE_AUTORCC ON)find_packa...
Feb. 21, 2019, 12:04 p.m.
BlinCT

Смотрите, если вы используете глобально для проекта -DCMAKE_PREFIX_PATH= то вам не надо уже указывать вот эти строкиset(Qt5Core_DIR "C:/Qt/5.12.1/mingw73_64/lib/cmake/Qt5Core")set(Qt5Gui_DIR...
R
Feb. 21, 2019, 11:54 a.m.
RandyGallup

Даже не запускается. main.cpp у меня точно такой же, как в статье. CMakeLists.txt пришлось немного подправить (прикрепил ниже), т.к. не находились некоторые файлы. cmake_minimum_requi...
Now discuss on the forum
Feb. 21, 2019, 8:58 a.m.
Евгений Легоцкой

Ну у меня координаты передавались в зависимости от положения курсора мыши, а в вам по сути нужно будет аналогичным способом посылать даннные из полей ввода. Так что здесь скорее интерфес...
Feb. 20, 2019, 9:55 p.m.
Евгений Легоцкой

Не до конца понимаю сути вопроса, наверное, нужно увидеть программный код и попытку его применения, но к методам базового класса можно обращаться в наследованном классе через вызов по имени ба...
MU
Feb. 20, 2019, 3:06 p.m.
Maciej Urmański

Yes, ok I have solution! Thank you for directing me about annotate.:) Solution is: users_in = User.objects.filter(joined_users__goal=goal, joined_users__joined=True)
Feb. 20, 2019, 2:40 p.m.
Евгений Легоцкой

Думаю, что ещё можно переопределить mouseReleaseEvent(QMouseEvent* event) у QTableView, который содержит модель и немного поиграться с индексом. Если это индекс, который соответству...
Feb. 20, 2019, 10:34 a.m.
Евгений Легоцкой

Да, так тоже можно. Единственный момент в том, что lupdate не всегда понимает, к какому контексту это дело относится, и может запихать в левый контекст. В небольшом проекте это не критич...
Join us in social networks

For registered users on the site there is a minimum amount of advertising