[libcalamaresui] Prep-work for image-slideshow
Doesn't compile (but I need to get it off this machine) - Prepare to implement a picture-based slideshow alongside QML - Split QML loading into the slideshow component This might be good prep-work for moving QML loading out of the QMLViewStep as well.
This commit is contained in:
parent
bb2b5fd982
commit
df1f9f1b56
@ -20,6 +20,8 @@
|
|||||||
|
|
||||||
#include "ExecutionViewStep.h"
|
#include "ExecutionViewStep.h"
|
||||||
|
|
||||||
|
#include "Slideshow.h"
|
||||||
|
|
||||||
#include "Branding.h"
|
#include "Branding.h"
|
||||||
#include "Job.h"
|
#include "Job.h"
|
||||||
#include "JobQueue.h"
|
#include "JobQueue.h"
|
||||||
@ -37,10 +39,6 @@
|
|||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QLabel>
|
#include <QLabel>
|
||||||
#include <QProgressBar>
|
#include <QProgressBar>
|
||||||
#include <QQmlComponent>
|
|
||||||
#include <QQmlEngine>
|
|
||||||
#include <QQuickItem>
|
|
||||||
#include <QQuickWidget>
|
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
|
|
||||||
namespace Calamares
|
namespace Calamares
|
||||||
@ -51,20 +49,14 @@ ExecutionViewStep::ExecutionViewStep( QObject* parent )
|
|||||||
, m_widget( new QWidget )
|
, m_widget( new QWidget )
|
||||||
, m_progressBar( new QProgressBar )
|
, m_progressBar( new QProgressBar )
|
||||||
, m_label( new QLabel )
|
, m_label( new QLabel )
|
||||||
, m_qmlShow( new QQuickWidget )
|
, m_slideshow( nullptr )
|
||||||
, m_qmlComponent( nullptr )
|
|
||||||
, m_qmlObject( nullptr )
|
|
||||||
{
|
{
|
||||||
QVBoxLayout* layout = new QVBoxLayout( m_widget );
|
QVBoxLayout* layout = new QVBoxLayout( m_widget );
|
||||||
QVBoxLayout* innerLayout = new QVBoxLayout;
|
QVBoxLayout* innerLayout = new QVBoxLayout;
|
||||||
|
|
||||||
m_progressBar->setMaximum( 10000 );
|
m_progressBar->setMaximum( 10000 );
|
||||||
|
|
||||||
m_qmlShow->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Expanding );
|
layout->addWidget( m_slideshow->widget() );
|
||||||
m_qmlShow->setResizeMode( QQuickWidget::SizeRootObjectToView );
|
|
||||||
m_qmlShow->engine()->addImportPath( CalamaresUtils::qmlModulesDir().absolutePath() );
|
|
||||||
|
|
||||||
layout->addWidget( m_qmlShow );
|
|
||||||
CalamaresUtils::unmarginLayout( layout );
|
CalamaresUtils::unmarginLayout( layout );
|
||||||
layout->addLayout( innerLayout );
|
layout->addLayout( innerLayout );
|
||||||
|
|
||||||
@ -72,7 +64,6 @@ ExecutionViewStep::ExecutionViewStep( QObject* parent )
|
|||||||
innerLayout->addWidget( m_progressBar );
|
innerLayout->addWidget( m_progressBar );
|
||||||
innerLayout->addWidget( m_label );
|
innerLayout->addWidget( m_label );
|
||||||
|
|
||||||
cDebug() << "QML import paths:" << Logger::DebugList( m_qmlShow->engine()->importPathList() );
|
|
||||||
if ( Branding::instance()->slideshowAPI() == 2 )
|
if ( Branding::instance()->slideshowAPI() == 2 )
|
||||||
{
|
{
|
||||||
cDebug() << "QML load on startup, API 2.";
|
cDebug() << "QML load on startup, API 2.";
|
||||||
@ -80,9 +71,6 @@ ExecutionViewStep::ExecutionViewStep( QObject* parent )
|
|||||||
}
|
}
|
||||||
|
|
||||||
connect( JobQueue::instance(), &JobQueue::progress, this, &ExecutionViewStep::updateFromJobQueue );
|
connect( JobQueue::instance(), &JobQueue::progress, this, &ExecutionViewStep::updateFromJobQueue );
|
||||||
#if QT_VERSION >= QT_VERSION_CHECK( 5, 10, 0 )
|
|
||||||
CALAMARES_RETRANSLATE( m_qmlShow->engine()->retranslate(); )
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -27,13 +27,12 @@
|
|||||||
class QLabel;
|
class QLabel;
|
||||||
class QObject;
|
class QObject;
|
||||||
class QProgressBar;
|
class QProgressBar;
|
||||||
class QQmlComponent;
|
|
||||||
class QQuickItem;
|
|
||||||
class QQuickWidget;
|
|
||||||
|
|
||||||
namespace Calamares
|
namespace Calamares
|
||||||
{
|
{
|
||||||
|
|
||||||
|
class Slideshow;
|
||||||
|
|
||||||
class ExecutionViewStep : public ViewStep
|
class ExecutionViewStep : public ViewStep
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@ -67,9 +66,7 @@ private:
|
|||||||
QWidget* m_widget;
|
QWidget* m_widget;
|
||||||
QProgressBar* m_progressBar;
|
QProgressBar* m_progressBar;
|
||||||
QLabel* m_label;
|
QLabel* m_label;
|
||||||
QQuickWidget* m_qmlShow;
|
Slideshow* m_slideshow;
|
||||||
QQmlComponent* m_qmlComponent;
|
|
||||||
QQuickItem* m_qmlObject; ///< The actual show
|
|
||||||
|
|
||||||
QStringList m_jobInstanceKeys;
|
QStringList m_jobInstanceKeys;
|
||||||
|
|
||||||
|
55
src/libcalamaresui/viewpages/Slideshow.cpp
Normal file
55
src/libcalamaresui/viewpages/Slideshow.cpp
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
||||||
|
* Copyright 2014-2015, Teo Mrnjavac <teo@kde.org>
|
||||||
|
* Copyright 2018, Adriaan de Groot <groot@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "Slideshow.h"
|
||||||
|
|
||||||
|
#include "utils/Dirs.h"
|
||||||
|
#include "utils/Logger.h"
|
||||||
|
|
||||||
|
#include <QQuickWidget>
|
||||||
|
#include <QQmlComponent>
|
||||||
|
#include <QQmlEngine>
|
||||||
|
#include <QQuickItem>
|
||||||
|
|
||||||
|
namespace Calamares
|
||||||
|
{
|
||||||
|
|
||||||
|
Slideshow::~Slideshow()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
SlideshowQML::SlideshowQML(QWidget* parent)
|
||||||
|
: Slideshow( parent )
|
||||||
|
, m_qmlShow( new QQuickWidget )
|
||||||
|
, m_qmlComponent( nullptr )
|
||||||
|
, m_qmlObject( nullptr )
|
||||||
|
{
|
||||||
|
m_qmlShow->setSizePolicy( QSizePolicy::Expanding, QSizePolicy::Expanding );
|
||||||
|
m_qmlShow->setResizeMode( QQuickWidget::SizeRootObjectToView );
|
||||||
|
m_qmlShow->engine()->addImportPath( CalamaresUtils::qmlModulesDir().absolutePath() );
|
||||||
|
|
||||||
|
cDebug() << "QML import paths:" << Logger::DebugList( m_qmlShow->engine()->importPathList() );
|
||||||
|
#if QT_VERSION >= QT_VERSION_CHECK( 5, 10, 0 )
|
||||||
|
CALAMARES_RETRANSLATE( m_qmlShow->engine()->retranslate(); )
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
66
src/libcalamaresui/viewpages/Slideshow.h
Normal file
66
src/libcalamaresui/viewpages/Slideshow.h
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Aurélien Gâteau <agateau@kde.org>
|
||||||
|
* Copyright 2014-2015, Teo Mrnjavac <teo@kde.org>
|
||||||
|
* Copyright 2018, Adriaan de Groot <groot@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef LIBCALAMARESUI_SLIDESHOW_H
|
||||||
|
#define LIBCALAMARESUI_SLIDESHOW_H
|
||||||
|
|
||||||
|
#include <QWidget>
|
||||||
|
|
||||||
|
class QQmlComponent;
|
||||||
|
class QQuickItem;
|
||||||
|
class QQuickWidget;
|
||||||
|
|
||||||
|
namespace Calamares
|
||||||
|
{
|
||||||
|
|
||||||
|
class Slideshow
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Slideshow( QWidget* parent ) {};
|
||||||
|
virtual ~Slideshow();
|
||||||
|
|
||||||
|
virtual QWidget* widget() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class SlideshowQML : public Slideshow
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
SlideshowQML( QWidget* parent );
|
||||||
|
virtual ~SlideshowQML();
|
||||||
|
|
||||||
|
QWidget* widget() override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
QQuickWidget* m_qmlShow;
|
||||||
|
QQmlComponent* m_qmlComponent;
|
||||||
|
QQuickItem* m_qmlObject; ///< The actual show
|
||||||
|
};
|
||||||
|
|
||||||
|
class SlideshowPictures : public Slideshow
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
SlideshowPictures( QWidget* parent );
|
||||||
|
virtual ~SlideshowPictures();
|
||||||
|
|
||||||
|
QWidget* widget() override;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif
|
Loading…
Reference in New Issue
Block a user