Nano Hash - криптовалюты, майнинг, программирование

Отслеживание подвижных вкладок в QTabWidget

У меня есть вопрос относительно QTabWidget: у него есть свойство с именем movable. , это позволяет смешивать позиции вкладок. Когда позиция вкладки перемещается, ее индекс обновляется. Вот моя проблема. Допустим, у меня есть 4 вкладки, каждая из которых представляет некоторый объект Foo, но с разными параметрами. Это означает, что для меня важно точно знать, какой объект находится в какой позиции. Когда я закрываю вкладку, я хотел бы уничтожить правильный объект Foo, поэтому мне нужно следить за ним. Когда я перемещаю вкладку, она меняет свой индекс, поэтому, скажем, у меня есть интересующий меня объект на вкладке 0, и я перемещаю его на одно место позади, таким образом, теперь он имеет индекс 1, а не 0. Как я могу это узнать? Как получать уведомления об изменении индексов? У меня есть список этих объектов как отдельное свойство. Таким образом, если кто-то закроет вкладку, я могу уничтожить, а затем удалить элемент из списка с соответствующим индексом (но только если я не буду перемещать вкладки, потому что тогда они меняют индексы). Я не публиковал никаких примеров кода, потому что это очень общая проблема, но если это необходимо, я, конечно, могу это сделать. Я хотел бы получить всю помощь по этому поводу!

23.06.2015

Ответы:


1

Для вещей, которые вы упомянули, вам не нужно отслеживать движение вкладок. Когда индекс виджета имеет значение (например, если вы хотите закрыть индекс вкладки и хотите знать, какой виджет в данный момент находится в этом индексе), используйте QTabWidget::widget для преобразования индекса в виджет и QTabWidget::indexOf для преобразования виджета в индекс.

Отслеживание перемещений вкладок требуется редко. Вы можете получить QTabBar объектов с помощью QTabWidget::tabBar и использовать его сигнал QTabBar::tabMoved.

23.06.2015
  • Спасибо за ответ, как дополнительный вопрос. Эти две строки делают то же самое? delete ui->tbMain->widget(index); и ui->tbMain->removeTab(index);? 24.06.2015
  • QTabWidget::removeTab удаляет виджет только из виджета вкладки, и вы несете ответственность за его последующее удаление. Но вы не можете удалить его, пока он все еще находится в виджете вкладок (поскольку виджет вкладок владеет им и попытается получить к нему доступ и удалить его в будущем), поэтому никогда не следует использовать первую строку кода. Вы должны вызвать removeTab, а затем вручную удалить соответствующий виджет. 24.06.2015
  • Я спросил, потому что я столкнулся со странным поведением. Я подумал именно так, как вы сказали, и поэтому сначала я удалил вкладку, а затем удалил указанный объект - это привело к удалению всех вкладок, которые находились за вкладкой, которую я закрывал! Итак, после этого я запустил только строку удаления, и это привело к удалению только одной вкладки, как я и хотел... 24.06.2015
  • Похоже, у вас была какая-то логическая ошибка в вашем коде. 24.06.2015
  • Я проверю это завтра, но я бы так не сказал. Я просто запустил строки, которые я разместил в слоте закрытия вкладки. 24.06.2015
  • Я проверил это. Я использую слот tabCloseRequested(int), а единственная строка — delete ui->tbMain->widget(index);, и это удаляет вкладку. 24.06.2015
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..