1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
|
/*
Q Light Controller
launcher.h
Copyright (c) Heikki Junnila
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0.txt
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef LAUNCHER_H
#define LAUNCHER_H
#include <QStringList>
#include <QWidget>
#include <QEvent>
/**
* Launcher is a very simple dialog for choosing whether to execute the main
* QLC application or the Fixture Editor application.
*
* Once the choice has been made, the launcher window terminates and the chosen
* application will be started. This kind of launcher is needed only for OSX
* because application bundles can launch only one binary program.
*/
class Launcher : public QWidget
{
Q_OBJECT
Q_DISABLE_COPY(Launcher)
public:
/**
* Create a new launcher widget with a parent object.
*
* @param parent Owning parent widget (optional)
*/
Launcher(QWidget* parent = 0);
/** Destructor */
~Launcher();
private slots:
/** Slot for fixture editor button click */
void slotFXEDClicked();
/** Slot for main application button click */
void slotQLCClicked();
private:
/** Launch Fixture Editor with given additional arguments */
void launchFXED(const QStringList& arguments = QStringList());
/** Launch Q Light Controller with given additional arguments */
void launchQLC(const QStringList& arguments = QStringList());
protected:
/** Acts as QApplication's event filter for QFileOpen events */
bool eventFilter(QObject* object, QEvent* event);
};
#endif
|