Михаиллл
Михаиллл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
                        i
                        innorwallNov. 11, 2024, 10:12 p.m.
                        Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
                        i
                        innorwallNov. 11, 2024, 6:23 p.m.
                        QML - Tutorial 035. Using enumerations in QML without C ++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
                        i
                        innorwallNov. 11, 2024, 3:50 p.m.
                        Qt/C++ - Lesson 052. Customization Qt Audio player in the style of AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
                        i
                        innorwallNov. 11, 2024, 2:19 p.m.
                        Heap sorting algorithm The role of raloxifene in preventing breast cancer priligy precio
                        i
                        innorwallNov. 11, 2024, 1:55 p.m.
                        PyQt5 - Lesson 006. Work with QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
                        Now discuss on the forum
                        i
                        innorwallNov. 11, 2024, 8:56 p.m.
                        добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
                        i
                        innorwallNov. 11, 2024, 10:55 a.m.
                        Всё ещё разбираюсь с кешем. 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
                        9AnonimOct. 25, 2024, 9:10 a.m.
                        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                        Follow us in social networks