Михаиллл
Михаиллл11 августа 2019 г. 9:15

Как в QML сделать календарь?

Добрый день.
Как в QML сделать календарь?
Это не подходит, т.к. использую QtQuick.Controls 2.12

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

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

11
R
  • 11 августа 2019 г. 9:39
  • (ред.)

Так ви можите використовувати і 1.4 одночасно

    Михаиллл
    • 11 августа 2019 г. 10:12

    Не могу, qt так не работает.
    Если делаю так, то страничка не работает:

    import QtQuick 2.12
    import QtQuick.XmlListModel 2.12
    import QtQuick.Controls 2.12
    import AppCore 1.0
    import QtQuick.Controls 1.12
    
      R
      • 11 августа 2019 г. 11:37

      Тому що для календаря потрібний
      import QtQuick.Controls 1.4
      Якщо в файлі нічого специфічного не використовується то можна просто замінити версію, а якщо ніяк то або винести календар в окремий файл а потім підключити його, або... Вроді так теж має працювати
      import QtQuick.Controls 1.4 as Controlold

      Controlold.Calendar {
      minimumDate: new Date(2017, 0, 1)
      maximumDate: new Date(2018, 0, 1)
      }

      Краще ще почитати
      https://doc.qt.io/qt-5/qtqml-syntax-imports.html

        Evgenii Legotckoi
        • 11 августа 2019 г. 12:32

        к слову говоря есть и для вторых контролов какие-то наработки по календарю.

        https://doc.qt.io/archives/qt-5.7/qt-labs-calendar2-qmlmodule.html

          Михаиллл
          • 11 августа 2019 г. 13:33

          С помощью этого получилось вставить календарь. Но как прикрутить подсветку и маусареи к нужным дням?

            Evgenii Legotckoi
            • 11 августа 2019 г. 14:08
            • (ред.)

            Можете сделать это с помощью делегата. Предполагаю, что это можно сделать примерно так

            MonthGrid {
                month: Calendar.December
                year: 2015
                locale: Qt.locale("en_US")
                delegate: Item {
            
                    MouseArea {
                        anchors.fill.parent
                    }
                }
            }
            
              Михаиллл
              • 11 августа 2019 г. 14:56

              Но мне нужно привязать к дням месяца, а не ко всему месяцу.

                Evgenii Legotckoi
                • 11 августа 2019 г. 15:20

                делегат отвечает за представление одного дня в месяце в данном случае. Да, вы добавляете MouseArea к делегату, а уже в обработчиках MouseArea можете проверить, какой именно день кликнули.

                  Михаиллл
                  • 11 августа 2019 г. 16:45

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

                      MonthGrid {
                          id: mothGrid1
                          month: Calendar.December
                          year: 2019
                          x: 23
                          y: 154
                          width: 340
                          height: 355
                          //locale: Qt.locale("en_US")
                  
                          delegate: Item {
                              MouseArea{
                                  anchors.fill: parent
                                  //onClicked: console.log("day = " )
                              }
                          }
                  
                    Evgenii Legotckoi
                    • 11 августа 2019 г. 17:21
                    • Ответ был помечен как решение.

                    Ну потому, что делегат отвечает за представление одного элемента модели, когда вы его переопределяете, то вам нужно полностью написать его вёрстку. Естественно, что у вас ничего не отображается в этом случае, поскольку вы не написали, что отображать в делегате. Делегат - это внешний вид одной ячейки даты календаря, если вы не указываете нигде текст ячейки, то и не увидите его.

                    Вот рабочий код

                    import QtQuick 2.12
                    import QtQuick.Window 2.12
                    import Qt.labs.calendar 1.0
                    
                    Window {
                        visible: true
                        width: 640
                        height: 480
                        title: qsTr("Hello World")
                    
                    
                        MonthGrid {
                            id: mothGrid1
                            month: Calendar.December
                            year: 2019
                            x: 20
                            y: 20
                            width: 340
                            height: 355
                    
                            delegate: Item {
                                Text {
                                    anchors.fill: parent
                                    text: model.day
                                }
                                MouseArea{
                                    anchors.fill: parent
                                }
                            }
                        }
                    }
                    
                    

                    Вообще, вы можете использовать такое обращение к данным модели

                    • model.date : date The date of the cell
                    • model.day : int The number of the day
                    • model.today : bool Whether the delegate represents today
                    • model.weekNumber : int The week number
                    • model.month : int The number of the month
                    • model.year : int The number of the year
                      Pavel K.
                      • 12 августа 2019 г. 4:06
                      • (ред.)

                      в самом Qt есть пример календаря (welcome->examples->Calendar Widget Example)


                      есть и тут пример

                        Комментарии

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

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

                        • Результат:50баллов,
                        • Очки рейтинга-4
                        m
                        • molni99
                        • 26 октября 2024 г. 6:37

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

                        • Результат:80баллов,
                        • Очки рейтинга4
                        m
                        • molni99
                        • 26 октября 2024 г. 6:29

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

                        • Результат:20баллов,
                        • Очки рейтинга-10
                        Последние комментарии
                        i
                        innorwall15 ноября 2024 г. 7:27
                        Релиз утилиты развертывания С++/Qt и QML приложений CQtDeployer v1.4.0 (Binary Box) optionally substituted alkoxy, optionally substituted alkenyloxy, optionally substituted alkynyloxy, optionally substituted aryloxy, OCH, OC H, OC H, OC H, OC H, OC H, OC H, O C CH, OCH CH OH, O…
                        i
                        innorwall15 ноября 2024 г. 2:26
                        Qt/C++ - Урок 031. QCustomPlot - строим график по времени buy generic priligy We can just chat, and we will not lose too much time anyway
                        i
                        innorwall15 ноября 2024 г. 0:03
                        Qt/C++ - Урок 060. Настройка внешнего вида приложения в рантайме I didnt have an issue work colors priligy dapoxetine 60mg revia cost uk August 3, 2022 Reply
                        i
                        innorwall14 ноября 2024 г. 16:42
                        Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                        Сейчас обсуждают на форуме
                        i
                        innorwall14 ноября 2024 г. 8:39
                        добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                        i
                        innorwall11 ноября 2024 г. 15:55
                        Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                        9
                        9Anonim25 октября 2024 г. 14:10
                        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                        ИМ
                        Игорь Максимов3 октября 2024 г. 9:05
                        Реализация навигации по разделам Спасибо Евгений!

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