© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB
6 июня 2018 г. 7:57

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

ListView

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

Добрый день.
Вы можете на сайте Qt глянуть список кнопок и их код. И уже исходя из этого по конекту если получин этот код кнопки то что то делать.
Это я в простйо форме описал). Но куда копать вы уже поняли.
У Евгения где то была статья на подобную тему. Или если не найдете я дома гляну, вроде у меня чет было.

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

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

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;
    }
}

Для Django рекомендую VDS-хостинг TIMEWEB

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

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

Для Django рекомендую VDS-хостинг TIMEWEB

Вот у меня такая реализация
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)
        }
    }
}
//...
Rectangle {
    Component {
        id: cDelegate
        Item {
            Row {
               ComboBox {
                   delegate: ItemDelegate {
                       Label {
                           //...
                       }
                   }
               }
            
               TextField {
                   //...
                    Keys.onEnterPressed: {
                        //...
                    }
                    Keys.onReturnPressed: {
                        //...
                    }
               }
               
            }
        }
    }
   
    ListView {
         id: listView
         delegate: cDelegate
         model: lModel
         //...
    }
}




Доступность элементов в объекте 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
         //...
    }
}

Для Django рекомендую VDS-хостинг TIMEWEB

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

Ну в смысле вот так переписать, я пропустил 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 других элементов.

Для Django рекомендую VDS-хостинг TIMEWEB

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

Ответы

Только авторизованные пользователи могут отвечать на форуме.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
15 октября 2018 г. 21:36
Allyans .

C++ - Тест 001. Первая программа и типы данных

  • Результат 60баллов,
  • Очки рейтинга-1
15 октября 2018 г. 11:25
Екатерина Самойлова

C++ - Тест 002. Константы

  • Результат 33баллов,
  • Очки рейтинга-10
15 октября 2018 г. 11:17
Екатерина Самойлова

C++ - Тест 006. Перечисления

  • Результат 80баллов,
  • Очки рейтинга4
Последние комментарии
10 октября 2018 г. 9:50
Евгений Легоцкой

Qt/C++ - Урок 083. Создание динамической библиотеки и подключение её в другой проект

Если и начинать писать о плагинах, то нужно тогда с Qt Creator начинать, там наверняка будет одинаковый принцип, но по Qt Creator хотя бы информация есть.
10 октября 2018 г. 9:48
ost.vld

Qt/C++ - Урок 083. Создание динамической библиотеки и подключение её в другой проект

О плагинах к QtCreator в целом, тоже интересно.
10 октября 2018 г. 9:46
ost.vld

Qt/C++ - Урок 083. Создание динамической библиотеки и подключение её в другой проект

ну типа того, создание программы, функционал которой можно расширять плагинами, и, в перспективе, создание API.
10 октября 2018 г. 8:31
Евгений Легоцкой

Qt/C++ - Урок 083. Создание динамической библиотеки и подключение её в другой проект

Типо как в Qt Creator? Самому бы интересно было о таком почитать. В данный момент я бы мог написать только о написании плагинов для Qt Designer. С этим есть некоторый опыт.
Сейчас обсуждают на форуме
15 октября 2018 г. 12:45
Allyans .

QGraphicsItem change color

Хорошо)
11 октября 2018 г. 10:13
Arrow

Работа с WebView в QML

Нашел в чем проблема. Пишу на случай если кому-то попадется такое же счастье с WebView как и мне. Проблема как оказалась с Debug версией, так как в Release и Profile все работает (...
10 октября 2018 г. 12:49
Виталий Антипов

Кто что делает на Qt?

Работаем по локальной сети. Файл базы, схемы и фото лежат на сервере. Чтобы не было проблем при одновременной работе с одним файлом, все запросы обернул в транзакции, как указано в документаци...
10 октября 2018 г. 11:21
Arrow

Редактирование записи на форуме

Добрый день! К сожалению встретил небольшой баг на форуме. При создании записи на форуме и вставке кода, через соответствующую кнопку номера строк проставляются верно, но каждый...
10 октября 2018 г. 9:46
Arrow

Настройка Qt Creator для Android

Я Genymotion  ставил с VBox в комплекте для личного использования, после добавил из списка телефон с нужным API. Запустил его и при компиляции Qt Creator сам нашел его и все запустилось...
Присоединяйтесь к нам в социальных сетях