|
|
@ -50,9 +50,9 @@ void UBWidgetList::addWidget(QWidget *widget) |
|
|
|
{ |
|
|
|
{ |
|
|
|
if(NULL != mpLayout){ |
|
|
|
if(NULL != mpLayout){ |
|
|
|
mpEmptyLabel->setVisible(false); |
|
|
|
mpEmptyLabel->setVisible(false); |
|
|
|
|
|
|
|
mWidgets << widget; |
|
|
|
updateSize(true, widget); |
|
|
|
updateSize(true, widget); |
|
|
|
mpLayout->addWidget(widget); |
|
|
|
mpLayout->addWidget(widget); |
|
|
|
mWidgets << widget; |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -76,34 +76,31 @@ void UBWidgetList::updateSize(bool widgetAdded, QWidget *widget) |
|
|
|
int newWidgetHeight; |
|
|
|
int newWidgetHeight; |
|
|
|
|
|
|
|
|
|
|
|
if(eWidgetListOrientation_Vertical == mOrientation){ |
|
|
|
if(eWidgetListOrientation_Vertical == mOrientation){ |
|
|
|
scaleFactor = (float)mpContainer->width() / (float)widget->width(); |
|
|
|
scaleFactor = (float)widget->width() / (float)mpContainer->width(); |
|
|
|
}else{ |
|
|
|
}else{ |
|
|
|
scaleFactor = (float)mpContainer->height() / (float)widget->height(); |
|
|
|
scaleFactor = (float)widget->height() / (float)mpContainer->height(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
newWidgetWidth = (int)((float)widget->width()*scaleFactor); |
|
|
|
newWidgetWidth = widget->width()/scaleFactor; |
|
|
|
newWidgetHeight = (int)((float)widget->height()*scaleFactor); |
|
|
|
newWidgetHeight = widget->height()/scaleFactor; |
|
|
|
|
|
|
|
|
|
|
|
qDebug() << "container size " << mpContainer->size(); |
|
|
|
|
|
|
|
qDebug() << "widget size " << widget->size(); |
|
|
|
|
|
|
|
qDebug() << "scale factor " << scaleFactor; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
widget->resize(newWidgetWidth, newWidgetHeight); |
|
|
|
widget->resize(newWidgetWidth, newWidgetHeight); |
|
|
|
|
|
|
|
|
|
|
|
qDebug() << "widget new value " << newWidgetWidth << "x" << newWidgetHeight; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Now we have to update the container
|
|
|
|
// Now we have to update the container
|
|
|
|
if(eWidgetListOrientation_Vertical == mOrientation){ |
|
|
|
if(eWidgetListOrientation_Vertical == mOrientation){ |
|
|
|
if(widgetAdded){ |
|
|
|
if(widgetAdded){ |
|
|
|
mpContainer->resize(mpContainer->width(), mpContainer->height() + newWidgetHeight); |
|
|
|
mpContainer->resize(mpContainer->width(), mpContainer->height() + newWidgetHeight); |
|
|
|
}else{ |
|
|
|
} |
|
|
|
|
|
|
|
else{ |
|
|
|
mpContainer->resize(mpContainer->width(), mpContainer->height() - newWidgetHeight); |
|
|
|
mpContainer->resize(mpContainer->width(), mpContainer->height() - newWidgetHeight); |
|
|
|
} |
|
|
|
} |
|
|
|
}else{ |
|
|
|
} |
|
|
|
|
|
|
|
else{ |
|
|
|
if(widgetAdded){ |
|
|
|
if(widgetAdded){ |
|
|
|
mpContainer->resize(mpContainer->width() + newWidgetWidth, mpContainer->height()); |
|
|
|
mpContainer->resize(mpContainer->width() + newWidgetWidth, mpContainer->height()); |
|
|
|
}else{ |
|
|
|
} |
|
|
|
|
|
|
|
else{ |
|
|
|
mpContainer->resize(mpContainer->width() - newWidgetWidth, mpContainer->height()); |
|
|
|
mpContainer->resize(mpContainer->width() - newWidgetWidth, mpContainer->height()); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -119,15 +116,20 @@ void UBWidgetList::resizeEvent(QResizeEvent *ev) |
|
|
|
float scale; |
|
|
|
float scale; |
|
|
|
if(eWidgetListOrientation_Vertical == mOrientation){ |
|
|
|
if(eWidgetListOrientation_Vertical == mOrientation){ |
|
|
|
scale = (float)ev->size().width() / (float)ev->oldSize().width(); |
|
|
|
scale = (float)ev->size().width() / (float)ev->oldSize().width(); |
|
|
|
|
|
|
|
if(scale != 0 && scale < 10){ |
|
|
|
updateAllWidgetsize(scale); |
|
|
|
updateAllWidgetsize(scale); |
|
|
|
mpContainer->resize(width() - 2, mpContainer->height()*scale); |
|
|
|
mpContainer->resize(width() - 2, mpContainer->height()*scale); |
|
|
|
}else{ |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
else{ |
|
|
|
scale = (float)ev->size().height() / (float)ev->oldSize().height(); |
|
|
|
scale = (float)ev->size().height() / (float)ev->oldSize().height(); |
|
|
|
|
|
|
|
if(scale != 0 && scale < 10){ |
|
|
|
updateAllWidgetsize(scale); |
|
|
|
updateAllWidgetsize(scale); |
|
|
|
mpContainer->resize(mpContainer->width()*scale, height() - 2); |
|
|
|
mpContainer->resize(mpContainer->width()*scale, height() - 2); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
void UBWidgetList::updateAllWidgetsize(float scale) |
|
|
|
void UBWidgetList::updateAllWidgetsize(float scale) |
|
|
|
{ |
|
|
|
{ |
|
|
@ -154,3 +156,4 @@ void UBWidgetList::setEmptyText(const QString &text) |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// TODO : - add onHover 'delete' button
|
|
|
|
// TODO : - add onHover 'delete' button
|
|
|
|
|
|
|
|
|
|
|
|