Qt cvičení - žárovka: Porovnání verzí

Z GeoWikiCZ
Skočit na navigaci Skočit na vyhledávání
m
m
Řádek 67: Řádek 67:
 
     sviti = !sviti;
 
     sviti = !sviti;
 
}
 
}
 +
</pre>
  
</pre>
+
Při volání funkce <tt>label->setPixmap</tt> nelze přímo zadat jméno obrázku, ale je nutné explicitní přetypování na <tt>QPixmap</tt> (poznámka: alternativně lze vytvořit dva objekty typu QPixmap a předávat je při volání slotu).

Verze z 26. 9. 2009, 17:30

Napište Qt GUI aplikaci, která bude obsahovat dva widgety PushButton (vypínač) a Label (žárovka). Po stisknutí vypínače se žárovka rozsvítí nebo zhasne. Do widgetu Label lze místo textu umístit obrázek (atribut pixmap), použijte

zhasnutou Zarovka1.png a rozsvícenou žárovku Zarovka2.png

Oba obrázky žárovek vznikly úpravou obrázku [1]. Obrázky nakopírujte (například) do adersáře projektu.

Qt-zarovka.png

Protože žárovka je buď zhasnutá nebo rozsvícená, musí slot tlačítka "vypínač" žárovky rozsvěcet nebo zhasínat. Aplikace musí tedy udržovat dva stavy. Pro jejich implementaci použijte proměnnou typu bool (privátní atribut sviti třídy MainWindow).

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QtGui/QMainWindow>

namespace Ui
{
    class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = 0);
    ~MainWindow();

private:
    Ui::MainWindow *ui;
    bool sviti;

private slots:
    void on_pushButton_clicked();
};

#endif // MAINWINDOW_H

Počáteční nastavení zajišťuje konstruktor (sviti = false;), po každém volání slotu je stav přepnut (operátor negace je !, znak vykřičník).

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent), ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    sviti = false;
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::on_pushButton_clicked()
{
    if (sviti)
        ui->label->setPixmap(QPixmap("zarovka1.png"));
    else
        ui->label->setPixmap(QPixmap("zarovka2.png"));

    sviti = !sviti;
}

Při volání funkce label->setPixmap nelze přímo zadat jméno obrázku, ale je nutné explicitní přetypování na QPixmap (poznámka: alternativně lze vytvořit dva objekty typu QPixmap a předávat je při volání slotu).