Идеологически верный выбор инструментов. |
Здравствуйте, гость ( Вход | Регистрация )
Идеологически верный выбор инструментов. |
Obey-Kun |
2.4.2010, 2:29
Сообщение
#1
|
Студент Группа: Участник Сообщений: 96 Регистрация: 24.3.2010 Пользователь №: 1556 Спасибо сказали: 3 раз(а) Репутация: 0 |
Есть mainwindow. Там тулбары с экшнами, менюшки, указатель на мой QGraphicsView.
В моём унаследованном от QGraphicsView виджете есть Tool *m_tool. Tool — абстрактный класс инструмента (всякие выделения, создание наборов итемов в сцене и т. п). Во вью также есть enum'ный флаг выбранного инструмента. В зависимости от выбранного флага при нажатии ЛКМ создаётся соответственный инструмент. Так вот. Как идеологически верно менять значения флага выбранного инструмента во вью? Пока видится так: QToolBar'ы по дефолту испускают сигнал actionTriggered ( QAction * action ). В мейнвиндове я создам слот, который принимал бы этот сигнал и испускал в зависимости от нажатого экшна что-то типа signalChangeToolType(const MyView::ToolTypeEnum& type). Ну а этот сигнал принимался бы слотом во вью slotSetToolType(const ToolTypeEnum& type), что меняло бы флаг. Это правильно? И кстати, выбор инструмента вообще обычно делают в турбаре или где? P:S: делаю что-то похожее на Cad. |
|
|
Litkevich Yuriy |
2.4.2010, 4:06
Сообщение
#2
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
|
|
|
Obey-Kun |
2.4.2010, 17:56
Сообщение
#3
|
Студент Группа: Участник Сообщений: 96 Регистрация: 24.3.2010 Пользователь №: 1556 Спасибо сказали: 3 раз(а) Репутация: 0 |
фублин.
посмотрел на то, как панель с инструментами и палитра сделана в KDE'шном KolourPaint — и правда обычный QToolBar . А раньше думал, что тулбары это только мелкие кнопочки сверху под менюбаром . И насчёт сигналов. А можно в мейнвиндове сделать вот так?
То есть чтобы сигнал triggered() запускал слот с конкретным параметром. (m_pick_rectangle_selection -- указатель на QAction, а m_view -- указатель на мой объект-отображние) |
|
|
Litkevich Yuriy |
3.4.2010, 1:31
Сообщение
#4
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
|
|
|
Obey-Kun |
3.4.2010, 1:56
Сообщение
#5
|
Студент Группа: Участник Сообщений: 96 Регистрация: 24.3.2010 Пользователь №: 1556 Спасибо сказали: 3 раз(а) Репутация: 0 |
Речь шла об этом?
Странно, даже enum не даёт использовать. где почитать про то, о чём вы упомянули (регистрация типа в системе метаинформаци Qt)? |
|
|
Litkevich Yuriy |
3.4.2010, 2:22
Сообщение
#6
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
вообще-то ошибки компиляции быть не должно, просто соединение может не установиться.
Покажи полностью объявление класса, в котором объявлен слот pickInstrument вообще существуем много всяких примочек в Qt, чтобы зарегестрировать свои типы данных: Q_ENUMS Q_DECLARE_METATYPE qRegisterMetaType() ... |
|
|
Obey-Kun |
3.4.2010, 3:17
Сообщение
#7
|
Студент Группа: Участник Сообщений: 96 Регистрация: 24.3.2010 Пользователь №: 1556 Спасибо сказали: 3 раз(а) Репутация: 0 |
я балбес, декларэйшн не написал
теперь заработало и я не свой объект передаю, а енумную фигню спасибо Кстати, правлильная ошибка из-за отсутствия соответствующих макросов выглядит примерно так:
добавил Q_ENUMS(QFrost::ToolType) после макроса Q_OBJECT в хедерах классов, где енум надо использовать в системе сигналов-слотов, но это не помогло... как надо-то? странно... смотрите, сейчас сделано так:
И ругается
Если заставить этот connect выполняться попозже, то всё ок, коннект проходит и всё работает. Есть идеи? Сообщение отредактировал Obey-Kun - 3.4.2010, 3:08 |
|
|
Litkevich Yuriy |
3.4.2010, 3:24
Сообщение
#8
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
QObject::connect: Cannot connect (null)::signalToolC... проблему выделил жирным. Т.е. неизвестно какому классу принадлежит функцияconnect(parent, SIGNAL(signalToolChosen(QFrost::ToolType)), вообще соединять в дочернем объекте сигнал родителя - плохая идея, т.к., как минимум, при чтении кода, сначала читается код верхнего, по иерархии, объекта. И лишь при возникновении непонимания лезишь внутрь дочернего.SLOT(slotSetTool(QFrost::ToolType))); Поэтому такое соединение нужно делать в родительском объекте. |
|
|
Obey-Kun |
3.4.2010, 3:26
Сообщение
#9
|
Студент Группа: Участник Сообщений: 96 Регистрация: 24.3.2010 Пользователь №: 1556 Спасибо сказали: 3 раз(а) Репутация: 0 |
Экспериментировал. В MainWindow было:
Ясен пень, что connect(parent, SIGNAL(signalToolChosen(QFrost::ToolType)), SLOT(slotSetTool(QFrost::ToolType))); в конструкторе Area как надо не работало, ведь создавалось оно без родительского виджета, а потом уже он назначался. Исправил на:
Разумеется, всё заработало. |
|
|
Litkevich Yuriy |
3.4.2010, 3:26
Сообщение
#10
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
мало того объявления родительского сигнала в дочернем объекте не видно, обычно. Наверное это и есть причина ошибки. Дело в том, что компилятор не контролирует соединение
|
|
|
Текстовая версия | Сейчас: 27.11.2024, 6:53 |