Политика конфиденциальностиКонтактыО сайтеОтзывыGitHubDonate
© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB
j
10 июля 2018 г. 21:06

Выравнивание в layout и sizePolicy

Товарищи, подскажите, пожалуйста: создаю на форме QHBoxLayout, добавляю в него виджеты с указанием выравнивания по центру, layout выставляет размер виджетов равным возвращаемому sizeHint и не реагирует на sizePolicy (пробовал разные варианты). Хочу добиться чтобы размер виджетов в layout изменялся вместе с изменением размера окна. resizeEvent переопределен чтобы виджет всегда был квадратным. Если Qt::AlignCenter не указывать, то всё работает как надо за исключением выравнивания виджетов по левому верхнему краю.


int main()
{ QHBoxLayout *l2 = new QHBoxLayout; QScatterPlot *ph1 = new QScatterPlot;
QScatterPlot *ph2 = new QScatterPlot;
QScatterPlot *ph3 = new QScatterPlot;
QScatterPlot *ph4 = new QScatterPlot;
l2->addWidget(ph1, 1, Qt::AlignCenter); l2->addWidget(ph2, 1, Qt::AlignCenter); l2->addWidget(ph3, 1, Qt::AlignCenter); l2->addWidget(ph4, 1, Qt::AlignCenter); }

QScatterPlot::QScatterPlot(QWidget *parent) : QCustomPlot(parent)
{

setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding);
}

void QScatterPlot::resizeEvent(QResizeEvent *event)
{
int s = qMin(event->size().width(), event->size().height());
QSize size(s, s);
resize(size);
QResizeEvent e(size, event->oldSize());
QCustomPlot::resizeEvent(&e);
event->accept();
}

QSize QScatterPlot::sizeHint() const
{
return QSize(200, 200);
}
1

Добрый день!

Если вы переопределяете sizeHint и возвращаете фиксированные размеры в нём, то виджет всегда должен считаться по размеру того размера, который вы возвращаете в sieHint, по идее виджеты тогда никогда не должны реагировать на resizeEvent, как должны были бы.
Думаю, что Вам нужно создать в классе QScatterPlot, объявленные в классе переменные, отвечающие за ширину и высоту, которые будете устанавливать при событии resizeEvent, и с их помощью будете возвращать sizeHint
QSize QScatterPlot::sizeHint() const
{
  return QSize(m_width, m_height);
}


0

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
P
18 февраля 2019 г. 15:39
Poyar

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

  • Результат:73баллов,
  • Очки рейтинга1
НБ
15 февраля 2019 г. 13:09
Николай Булахтин

C++ - Тест 003. Условия и циклы

  • Результат:50баллов,
  • Очки рейтинга-4
НБ
15 февраля 2019 г. 13:03
Николай Булахтин

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

  • Результат:25баллов,
  • Очки рейтинга-10
Последние комментарии
V
14 февраля 2019 г. 18:41
Vlad15007

Спасибо огромное! Заработало!
А
12 февраля 2019 г. 9:26
Александр90

Сам разборался, спасибо.
А
12 февраля 2019 г. 8:19
Александр90

День добрый! Можешь выложить форму mainwindow.ui от урока? Заранее спасибо
11 февраля 2019 г. 10:51
Евгений Легоцкой

Нет, у меня проблема с жёстким диском случилась, занимался восстановлением ПК, ещё пару вечеров придётся этим заниматься, увы.
Сейчас обсуждают на форуме
17 февраля 2019 г. 17:28
Евгений Легоцкой

Добрый день. Очень извиняюсь за долгий ответ Первое, что нашёл, так это необходимость перерисовать чекбокс. void CheckBoxDelegate::paint(QPainter *painter, const QStyleOptionViewItem ...
15 февраля 2019 г. 15:36
Евгений Легоцкой

Ну я тут нашёл одно решение, но сам его не проверял. Вам нужно помещать фамилии скорее всего в ячейки заголовка, и потом просто перерисовывать их QHeaderView * header = m_ui->tableWidget...
15 февраля 2019 г. 7:53
Евгений Легоцкой

Добрый день! Не работал с remoteobjects, поэтому глянул документацию, чтобы рассмотреть, что это за зверь. После просмотра документации сложилось стойкой впечатление, что это вполне возм...
m
14 февраля 2019 г. 18:28
mr_roman

Нашел решение на Java. Удалось интегрировать в проект сервиса на Qt, теперь из Qt запускаю Java-код акселерометра.
Присоединяйтесь к нам в социальных сетях

Для зарегистрированных пользователей на сайте присутствует минимальное количество рекламы