k
kabanov6. Juni 2018 03:57

ListView переключение между элементами по нажатию ENTER

ListView

как по нажатию ENTER переключаться на следующий элемент

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

12
BlinCT
  • 6. Juni 2018 04:17
Добрый день.
Вы можете на сайте Qt глянуть список кнопок и их код. И уже исходя из этого по конекту если получин этот код кнопки то что то делать.
Это я в простйо форме описал). Но куда копать вы уже поняли.
У Евгения где то была статья на подобную тему. Или если не найдете я дома гляну, вроде у меня чет было.
    k
    • 6. Juni 2018 04:25

    там не кнопки а TextField

      BlinCT
      • 6. Juni 2018 04:26

      Ну вот у меня в проекте вроде как раз в textField и была заложена работа с кодами кнопок. Но показать смогу только вечером.

        Evgenii Legotckoi
        • 6. Juni 2018 04:48
        • (bearbeitet)
        TextField {
            // listView - id объекта ListView
        
            // Enter на цифровой клавиатуре
            Keys.onEnterPressed: {
                console.log(event);
                listView.currentIndex = listView.currentIndex + 1;
            }
        
            // Enter на основной клавиатуре
            Keys.onReturnPressed: {
                console.log(event);
                listView.currentIndex = listView.currentIndex + 1;
            }
        }
          k
          • 6. Juni 2018 09:09

          не работает это

            Evgenii Legotckoi
            • 6. Juni 2018 09:17

            код показывайте
            экстрасенсы в отпуске

              BlinCT
              • 6. Juni 2018 09:48
              Вот у меня такая реализация
              TextField
              {
                  id:textWork
                  inputMask: ("NN:NN:NN")
                  text: "00:00:00"
                  anchors.right: parent.right
                  width: 76
                  font.pixelSize: 14
                  background: Rectangle {
                      color: "transparent"
                      border.width: 0
                  }
              
                  Keys.onPressed:
                  {
                      console.log("testtextwork ", event.key)
                      if(event.key === Qt.Key_Enter ||  event.key === Qt.Key_Return)
                      {
                          setTime(circletimercontent1, textWork.text)
                      }
                  }
              }
                k
                • 7. Juni 2018 03:11
                //...
                Rectangle {
                    Component {
                        id: cDelegate
                        Item {
                            Row {
                               ComboBox {
                                   delegate: ItemDelegate {
                                       Label {
                                           //...
                                       }
                                   }
                               }
                            
                               TextField {
                                   //...
                                    Keys.onEnterPressed: {
                                        //...
                                    }
                                    Keys.onReturnPressed: {
                                        //...
                                    }
                               }
                               
                            }
                        }
                    }
                   
                    ListView {
                         id: listView
                         delegate: cDelegate
                         model: lModel
                         //...
                    }
                }
                
                



                  Evgenii Legotckoi
                  • 7. Juni 2018 03:26

                  Доступность элементов в объекте Component довольно ограничена как извне, так и изнутри.
                  Поэтому очень часто возникает такая проблема, что не удаётся достучаться до некоторых компонентов просто обращением к id.


                  Перепишите код для начала так.
                  Rectangle {
                  
                      ListView {
                           id: listView
                           delegate: {
                              id: cDelegate
                              Item {
                                  Row {
                                     ComboBox {
                                         delegate: ItemDelegate {
                                             Label {
                                             //...
                                             }
                                         }
                                     }
                              
                                     TextField {
                                         //...
                                          Keys.onEnterPressed: {
                                              lModel.currentIndex = lModel.currentIndex + 1;
                                              //...
                                          }
                                          Keys.onReturnPressed: {
                                              //...
                                          }
                                      }
                                     
                                   }
                               }
                           }
                           model: lModel
                           //...
                      }
                  }
                    k
                    • 7. Juni 2018 03:42
                    • (bearbeitet)

                    так там же объект Component как раз и требуется

                      Evgenii Legotckoi
                      • 7. Juni 2018 03:52
                      • Die Antwort wurde als Lösung markiert.

                      Ну в смысле вот так переписать, я пропустил Item


                      Rectangle {
                      
                          ListView {
                               id: listView
                               delegate: Item {
                                  id: cDelegate
                                  Item {
                                      Row {
                                         ComboBox {
                                             delegate: ItemDelegate {
                                                 Label {
                                                 //...
                                                 }
                                             }
                                         }
                                  
                                         TextField {
                                             //...
                                              Keys.onEnterPressed: {
                                                  lModel.currentIndex = lModel.currentIndex + 1;
                                                  //...
                                              }
                                              Keys.onReturnPressed: {
                                                  //...
                                              }
                                          }
                                         
                                       }
                                   }
                               }
                               model: lModel
                               //...
                          }
                      }
                      Требуется то он требуется. Но в property delegate можно сразу прописывать Item , Rectangle или ещё что-нибудь.
                      Минус Component в том, что докопаться до того, что у него внутри довольно трудно и точно так же, он не очень хорошо знает, что творится вокруг него.
                      Очень обособленный элемент получается, что создаёт некоторые трудности при разработке. Я стараюсь избегать Component. Лучше тогда отдельный QML файл прописать для делегата со всякими алиасами и внутренними свойствами для хранения id других элементов.
                        k
                        • 7. Juni 2018 03:59
                        • (bearbeitet)

                        а как сделать так чтобы в Item были видны данные из модели, и при этом сохранять текст из textField в той же модели?

                          Kommentare

                          Nur autorisierte Benutzer können Kommentare posten.
                          Bitte Anmelden oder Registrieren
                          Letzte Kommentare
                          A
                          ALO1ZE19. Oktober 2024 08:19
                          Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                          ИМ
                          Игорь Максимов5. Oktober 2024 07:51
                          Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                          d
                          dblas55. Juli 2024 11:02
                          QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                          k
                          kmssr8. Februar 2024 18:43
                          Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                          Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                          Jetzt im Forum diskutieren
                          J
                          JacobFib17. Oktober 2024 03:27
                          добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
                          JW
                          Jhon Wick1. Oktober 2024 15:52
                          Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
                          КГ
                          Кирилл Гусарев27. September 2024 09:09
                          Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
                          F
                          Fynjy22. Juli 2024 04:15
                          при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

                          Folgen Sie uns in sozialen Netzwerken