From 938f52dcc44639528c266bcdd78aebce0b561189 Mon Sep 17 00:00:00 2001 From: John Levon Date: Thu, 12 Sep 2002 00:56:53 +0000 Subject: [PATCH] amortise panel load times git-svn-id: svn://svn.lyx.org/lyx/lyx-devel/trunk@5277 a592a061-630c-0410-9148-cb99ea01b6c8 --- src/frontends/qt2/ChangeLog | 5 +++++ src/frontends/qt2/QMathDialog.C | 36 +++++++++++++++++++++++---------- src/frontends/qt2/QMathDialog.h | 5 ++++- 3 files changed, 34 insertions(+), 12 deletions(-) diff --git a/src/frontends/qt2/ChangeLog b/src/frontends/qt2/ChangeLog index cc9575275d..31756df02e 100644 --- a/src/frontends/qt2/ChangeLog +++ b/src/frontends/qt2/ChangeLog @@ -1,3 +1,8 @@ +2002-09-12 John Levon + + * QMathDialog.h: + * QMathDialog.C: load icon palettes on demand + 2002-09-12 John Levon * QMathDialog.C: get the scrollbars right on first show diff --git a/src/frontends/qt2/QMathDialog.C b/src/frontends/qt2/QMathDialog.C index 5fec31db39..721068fb16 100644 --- a/src/frontends/qt2/QMathDialog.C +++ b/src/frontends/qt2/QMathDialog.C @@ -32,7 +32,7 @@ using std::endl; class QScrollViewSingle : public QScrollView { public: QScrollViewSingle(QWidget * p) - : QScrollView(p) { + : QScrollView(p), w_(0) { setResizePolicy(Manual); setHScrollBarMode(AlwaysOff); setVScrollBarMode(AlwaysOn); @@ -70,6 +70,8 @@ namespace { latex_ams_misc }; int const nr_panels = sizeof(panels)/sizeof(panels[0]); + +bool panel_initialised[nr_panels]; } @@ -83,11 +85,27 @@ QMathDialog::QMathDialog(QMath * form) functionsLB->insertItem(function_names[i]); } - for (int i = 0; i < nr_panels; ++i) { - addPanel(panels[i]); + for (int i = 0; i < nr_panels; ++i) { + QScrollViewSingle * view = new QScrollViewSingle(symbolsWS); + symbolsWS->addWidget(view, i); } + + // aboutToShow() only fires when != 0 in Qt 2 ! symbolsWS->raiseWidget(0); - symbolsWS->resize(symbolsWS->sizeHint()); + addPanel(0); + panel_initialised[0] = true; + + connect(symbolsWS, SIGNAL(aboutToShow(int)), this, SLOT(showingPanel(int))); +} + + +void QMathDialog::showingPanel(int num) +{ + if (panel_initialised[num]) + return; + + addPanel(num); + panel_initialised[num] = true; } @@ -104,15 +122,11 @@ IconPalette * QMathDialog::makePanel(QWidget * parent, char const ** entries) } -void QMathDialog::addPanel(char const ** entries) +void QMathDialog::addPanel(int num) { - static int id = 0; - - QScrollViewSingle * view = new QScrollViewSingle(symbolsWS); - - IconPalette * p = makePanel(view->viewport(), entries); + QScrollViewSingle * view = static_cast(symbolsWS->visibleWidget()); + IconPalette * p = makePanel(view->viewport(), panels[num]); view->setChild(p); - symbolsWS->addWidget(view, id++); } diff --git a/src/frontends/qt2/QMathDialog.h b/src/frontends/qt2/QMathDialog.h index ed28a88ffc..c19b7413c0 100644 --- a/src/frontends/qt2/QMathDialog.h +++ b/src/frontends/qt2/QMathDialog.h @@ -37,6 +37,9 @@ public slots: virtual void subscriptClicked(); virtual void superscriptClicked(); void symbol_clicked(string str); + + /// about to show a symbol panel + void showingPanel(int); protected: //needed ? virtual void closeEvent(QCloseEvent * e); @@ -46,7 +49,7 @@ private: IconPalette * makePanel(QWidget * parent, char const ** entries); /// add a symbol panel - void addPanel(char const ** entries); + void addPanel(int num); /// owning form QMath * form_;