Михаиллл
МихаилллAug. 11, 2019, 9:15 a.m.

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

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

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.

Do you like it? Share on social networks!

11
R
  • Aug. 11, 2019, 9:39 a.m.
  • (edited)

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

    Михаиллл
    • Aug. 11, 2019, 10:12 a.m.

    Не могу, 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
      • Aug. 11, 2019, 11:37 a.m.

      Тому що для календаря потрібний
      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
        • Aug. 11, 2019, 12:32 p.m.

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

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

          Михаиллл
          • Aug. 11, 2019, 1:33 p.m.

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

            Evgenii Legotckoi
            • Aug. 11, 2019, 2:08 p.m.
            • (edited)

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

            MonthGrid {
                month: Calendar.December
                year: 2015
                locale: Qt.locale("en_US")
                delegate: Item {
            
                    MouseArea {
                        anchors.fill.parent
                    }
                }
            }
            
              Михаиллл
              • Aug. 11, 2019, 2:56 p.m.

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

                Evgenii Legotckoi
                • Aug. 11, 2019, 3:20 p.m.

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

                  Михаиллл
                  • Aug. 11, 2019, 4:45 p.m.

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

                      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
                    • Aug. 11, 2019, 5:21 p.m.
                    • The answer was marked as a solution.

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

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

                    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.
                      • Aug. 12, 2019, 4:06 a.m.
                      • (edited)

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


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

                        Comments

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

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

                        • Result:50points,
                        • Rating points-4
                        m

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

                        • Result:80points,
                        • Rating points4
                        m

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

                        • Result:20points,
                        • Rating points-10
                        Last comments
                        ИМ
                        Игорь МаксимовNov. 22, 2024, 10:51 p.m.
                        Django - Tutorial 017. Customize the login page to Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                        Evgenii Legotckoi
                        Evgenii LegotckoiNov. 1, 2024, 12:37 a.m.
                        Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                        A
                        ALO1ZEOct. 19, 2024, 6:19 p.m.
                        Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                        ИМ
                        Игорь МаксимовOct. 5, 2024, 5:51 p.m.
                        Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                        d
                        dblas5July 5, 2024, 9:02 p.m.
                        QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                        Now discuss on the forum
                        Evgenii Legotckoi
                        Evgenii LegotckoiJune 25, 2024, 1:11 a.m.
                        добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                        t
                        tonypeachey1Nov. 15, 2024, 5:04 p.m.
                        google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                        NSProject
                        NSProjectJune 4, 2022, 1:49 p.m.
                        Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                        9
                        9AnonimOct. 25, 2024, 7:10 p.m.
                        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                        Follow us in social networks