diff options
author | Ken Moore <moorekou@gmail.com> | 2016-04-25 13:08:12 -0400 |
---|---|---|
committer | Ken Moore <moorekou@gmail.com> | 2016-04-25 13:08:12 -0400 |
commit | ed5ecf7ea7a482b4649e66ecb35fbc60af680684 (patch) | |
tree | acc0fa17d228259e847f55c678db9fb0a9b50f0c /src-qt5/core/lumina-desktop/BootSplash.cpp | |
parent | Merge branch 'master' of github.com:pcbsd/lumina (diff) | |
download | lumina-ed5ecf7ea7a482b4649e66ecb35fbc60af680684.tar.gz lumina-ed5ecf7ea7a482b4649e66ecb35fbc60af680684.tar.bz2 lumina-ed5ecf7ea7a482b4649e66ecb35fbc60af680684.zip |
Rearrange the Lumina source tree quite a bit:
Now the utilites are arranged by category (core, core-utils, desktop-utils), so all the -utils may be excluded by a package system (or turned into separate packages) as needed.
Diffstat (limited to 'src-qt5/core/lumina-desktop/BootSplash.cpp')
-rw-r--r-- | src-qt5/core/lumina-desktop/BootSplash.cpp | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/src-qt5/core/lumina-desktop/BootSplash.cpp b/src-qt5/core/lumina-desktop/BootSplash.cpp new file mode 100644 index 00000000..e75bca21 --- /dev/null +++ b/src-qt5/core/lumina-desktop/BootSplash.cpp @@ -0,0 +1,62 @@ +#include "BootSplash.h" +#include "ui_BootSplash.h" + +#include <LuminaXDG.h> + +BootSplash::BootSplash() : QWidget(0, Qt::SplashScreen | Qt::X11BypassWindowManagerHint | Qt::WindowStaysOnTopHint | Qt::WindowDoesNotAcceptFocus), ui(new Ui::BootSplash){ + ui->setupUi(this); + this->setObjectName("LuminaBootSplash"); //for theme styling + //Center the window on the primary screen + QPoint ctr = QApplication::desktop()->screenGeometry().center(); + this->move( ctr.x()-(this->width()/2), ctr.y()-(this->height()/2) ); +} + +void BootSplash::showScreen(QString loading){ //update icon, text, and progress + QString txt, icon; + int per = 0; + if(loading=="init"){ + txt = tr("Initializing Session …"); per = 10; + icon = "preferences-system-login"; + }else if(loading=="settings"){ + txt = tr("Loading System Settings …"); per = 20; + icon = "user-home"; + }else if(loading=="user"){ + txt = tr("Loading User Preferences …"); per = 30; + icon = "preferences-desktop-user"; + }else if(loading=="systray"){ + txt = tr("Preparing System Tray …"); per = 40; + icon = "preferences-plugin"; + }else if(loading=="wm"){ + txt = tr("Starting Window Manager …"); per = 50; + icon = "preferences-system-windows-actions"; + }else if(loading=="apps"){ + txt = tr("Detecting Applications …"); per = 60; + icon = "preferences-desktop-icons"; + }else if(loading=="menus"){ + txt = tr("Preparing Menus …"); per = 70; + icon = "preferences-system-windows"; + }else if(loading=="desktop"){ + txt = tr("Preparing Workspace …"); per = 80; + icon = "preferences-desktop-wallpaper"; + }else if(loading=="final"){ + txt = tr("Finalizing …"); per = 90; + icon = "pcbsd"; + }else if(loading.startsWith("app::")){ + txt = QString(tr("Starting App: %1")).arg(loading.section("::",1,50)); per = -1; + } + if(per>0){ ui->progressBar->setValue(per); } + else{ ui->progressBar->setRange(0,0); } //loading indicator + ui->label_text->setText(txt); + if(!icon.isEmpty()){ui->label_icon->setPixmap( LXDG::findIcon(icon, "Lumina-DE").pixmap(64,64) ); } + this->raise(); + this->show(); + this->update(); + QApplication::processEvents(); +} + +void BootSplash::showText(QString txt){ //will only update the text, not the icon/progress + ui->label_text->setText(txt); + this->show(); + this->update(); + QApplication::processEvents(); +} |