Popout graphs Phase I: limit dock height to screen height; preserve original graph heights

This commit is contained in:
Guy Scharf 2020-08-01 12:45:02 -07:00
parent f25f991e9f
commit 2712fad0c6

View File

@ -20,7 +20,9 @@
#include <QVBoxLayout>
#include <QDockWidget>
#include <QMainWindow>
#include <QScreen>
#include <QWindow>
#include <QMessageBox>
#ifdef DEBUG_EFFICIENCY
@ -447,25 +449,42 @@ void MyDockWindow::closeEvent(QCloseEvent *event)
MyDockWindow * gGraphView::dock = nullptr;
void gGraphView::popoutGraph()
{
QScreen *screen = QGuiApplication::primaryScreen();
QRect screenGeometry = screen->availableGeometry();
int screenHeight = screenGeometry.height();
if (popout_graph) {
// Create new dock if we don't have one already
if (dock == nullptr) {
dock = new MyDockWindow(mainwin->getDaily(), Qt::Window);
dock->resize(width(),0);
// QScrollArea
}
QDockWidget * widget = new QDockWidget(dock);
widget->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred);
widget->setMouseTracking(true);
int h = dock->height()+popout_graph->height()+30;
if (h > height()) h = height();
dock->resize(dock->width(), h);
widget->resize(width(), popout_graph->height()+30);
gGraphView * gv = new gGraphView(widget, this);
widget->setWidget(gv);
//////// Create dock widget and resize dock to hold new widget
QDockWidget * newDockWidget = new QDockWidget(dock);
newDockWidget->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred);
newDockWidget->setMouseTracking(true);
int titleBarHeight = 30;
int newDockHeight = dock->height()+popout_graph->height()+titleBarHeight+2; // +2 for group box border
qDebug() << "widget geometry" << newDockWidget->frameGeometry() << "title bar height" << titleBarHeight;
if (newDockHeight > screenHeight) {
QMessageBox::warning(nullptr, STR_MessageBox_Warning,
QObject::tr("The popout window is full. You should capture the existing\npopout window, delete it, then pop out this graph again."));
return;
}
qDebug() << "dock height" << dock->height() << "popout graph height" << popout_graph->height();
dock->resize(dock->width(), newDockHeight);
newDockWidget->resize(width(), popout_graph->height()+titleBarHeight);
qDebug() << "dock height resized to" << dock->height() << "widget resized to" << newDockWidget->height();
//////// End resize dock to hold new widget
gGraphView * gv = new gGraphView(newDockWidget, this);
newDockWidget->setWidget(gv);
gv->setMouseTracking(true);
gv->setDay(this->day());
dock->addDockWidget(Qt::BottomDockWidgetArea, widget,Qt::Vertical);
dock->addDockWidget(Qt::BottomDockWidgetArea, newDockWidget, Qt::Vertical);
/////// Fix some resize glitches ///////
// https://stackoverflow.com/questions/26286646/create-a-qdockwidget-that-resizes-to-its-contents?rq=1
@ -486,6 +505,8 @@ void gGraphView::popoutGraph()
gGraph * graph = popout_graph;
/////////////////////
// Construct name for this popout graph
QString basename = graph->title()+" - ";
if (graph->m_day) {
// append the date of the graph's left edge to the snapshot name
@ -494,14 +515,14 @@ void gGraphView::popoutGraph()
QDateTime date = QDateTime::fromMSecsSinceEpoch(graph->min_x, Qt::LocalTime);
basename += date.date().toString(Qt::SystemLocaleLongDate);
}
QString newname = basename;
// Find a new name.. How many snapshots for each graph counts as stupid?
QString newtitle = graph->title();
newDockWidget->setWindowTitle(newname);
// end name construction and setting title
/////////////////////
widget->setWindowTitle(newname);
qDebug() << "original graph height is" << graph->height();
gGraph * newgraph = new gGraph(newname, nullptr, newtitle, graph->units(), graph->height(), graph->group());
newgraph->setHeight(graph->height());
@ -536,8 +557,9 @@ void gGraphView::popoutGraph()
newgraph->setSnapshot(false);
newgraph->setShowTitle(true);
qDebug() << "newgraph height" << newgraph->height() << "gv height" << gv->height();
gv->resetLayout();
// gv->resetLayout();
gv->timedRedraw(0);
//widget->setUpdatesEnabled(true);