Download Data from URL/de: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
No edit summary
 
(Cleaned up Syntax)
 
(12 intermediate revisions by 4 users not shown)
Line 1: Line 1:
'''German''' [[Download Data from URL|English]] [[Download Data from URL Bulgarian|Български]] [[Download Data from URL Korean|한국어]][[Download Data from URL Persian|فارسی]]
[[Category:snippets]]
[[Category:HowTo]]
[[Category:German]]


=Daten von <span class="caps">URL</span> herunterladen=


Der folgende Code-Schnippsel demonstriert, wie Daten von einer <span class="caps">URL</span> als [http://doc.qt.io/qt-5.0/qtcore/qbytearray.html QByteArray] ''[qt.io]'' heruntergeladen werden können. Die heruntergeladenen Daten können dann entweder als Datei gespeichert oder in ein passendes Objekt konvertiert werden.<br /> Wird beispielsweise ein Bild heruntergeladen, kann es mit Hilfe der [http://doc.qt.io/qt-5.0/qtgui/qimage.html#loadFromData-2 loadFromData()] ''[qt.io]'' Funktion in ein [http://doc.qt.io/qt-5.0/qtgui/qpixmap.html QPixmap] ''[qt.io]'' oder [http://doc.qt.io/qt-5.0/qtgui/qimage.html QImage] ''[qt.io]'' konvertiert werden.
'''German''' [[Download_Data_from_URL|English]] [[Download_Data_from_URL_Bulgarian|Български]] [[Download_Data_from_URL_Korean|한국어]][[Download_Data_from_URL_Persian|فارسی]]
 
= Daten von URL herunterladen =
 
Der folgende Code-Schnippsel demonstriert, wie Daten von einer URL als [http://doc.qt.io/qt-5.0/qtcore/qbytearray.html QByteArray] heruntergeladen werden können. Die heruntergeladenen Daten können dann entweder als Datei gespeichert oder in ein passendes Objekt konvertiert werden.
Wird beispielsweise ein Bild heruntergeladen, kann es mit Hilfe der [http://doc.qt.io/qt-5.0/qtgui/qimage.html#loadFromData-2 loadFromData()] Funktion in ein [http://doc.qt.io/qt-5.0/qtgui/qpixmap.html QPixmap] oder [http://doc.qt.io/qt-5.0/qtgui/qimage.html QImage] konvertiert werden.


Beachte, dass obwohl der Name der Klasse FileDownloader ist, the heruntergeladenen Daten nicht als Datei auf der Festplatte gespeichert werden.
Beachte, dass obwohl der Name der Klasse FileDownloader ist, the heruntergeladenen Daten nicht als Datei auf der Festplatte gespeichert werden.


==Wichtige Klassen==
== Wichtige Klassen ==
 
* [http://doc.qt.io/qt-5.0/qtnetwork/qnetworkaccessmanager.html QNetworkAccessManager]
* [http://doc.qt.io/qt-5.0/qtnetwork/qnetworkrequest.html QNetworkRequest]
* [http://doc.qt.io/qt-5.0/qtnetwork/qnetworkreply.html QNetworkReply]
* [http://doc.qt.io/qt-5.0/qtcore/qurl.html QUrl]
 
== .pro Datei ==
 
<code>
QT += network
</code>
Für Symbian Geräte muss der Netzwerkdienst hinzugefügt werden.
<code>
symbian:TARGET.CAPABILITY+= NetworServices
</code>
 
== filedownloader.h ==
 
<code>
#ifndef FILEDOWNLOADER_H
#define FILEDOWNLOADER_H
 
#include <QObject>
#include <QByteArray>
#include <QNetworkAccessManager>
#include <QNetworkRequest>
#include <QNetworkReply>
 
class FileDownloader : public QObject
{
Q_OBJECT
public:
explicit FileDownloader(QUrl imageUrl, QObject *parent = 0);
 
virtual ~FileDownloader();
 
QByteArray downloadedData() const;
 
signals:
void downloaded();
 
private slots:
 
void fileDownloaded(QNetworkReply* pReply);
 
private:
 
QNetworkAccessManager m_WebCtrl;
 
QByteArray m_DownloadedData;
 
};
 
#endif // FILEDOWNLOADER_H
</code>
 
== filedownloader.cpp ==
 
<code>
#include "filedownloader.h"
 
FileDownloader::FileDownloader(QUrl imageUrl, QObject *parent) :
QObject(parent)
{
connect(&m_WebCtrl, SIGNAL (finished(QNetworkReply*)),
SLOT (fileDownloaded(QNetworkReply*)));


* [http://doc.qt.io/qt-5.0/qtnetwork/qnetworkaccessmanager.html QNetworkAccessManager] ''[qt.io]''
QNetworkRequest request(imageUrl);
* [http://doc.qt.io/qt-5.0/qtnetwork/qnetworkrequest.html QNetworkRequest] ''[qt.io]''
m_WebCtrl.get(request);
* [http://doc.qt.io/qt-5.0/qtnetwork/qnetworkreply.html QNetworkReply] ''[qt.io]''
}
* [http://doc.qt.io/qt-5.0/qtcore/qurl.html QUrl] ''[qt.io]''


==.pro Datei==
FileDownloader::~FileDownloader()
{


Für Symbian Geräte muss der Netzwerkdienst hinzugefügt werden.<br />
}


==filedownloader.h==
void FileDownloader::fileDownloaded(QNetworkReply* pReply)
{
m_DownloadedData = pReply->readAll();
//emit a signal
pReply->deleteLater();
emit downloaded();
}


==filedownloader.cpp==
QByteArray FileDownloader::downloadedData() const
{
return m_DownloadedData;
}
</code>


=Verwendung=
= Verwendung =


==Pixmap von <span class="caps">URL</span> laden==
== Pixmap von URL laden ==


* Slot deklarieren<br />
* Slot deklarieren
* '''downloaded()''' Signal mit Slot verbinden<br />
<code>
* QPixmap von den heruntergeladenen Daten laden<br />
private slots:


===Categories:===
void loadImage();
</code>
* '''downloaded()''' Signal mit Slot verbinden
<code>
QUrl imageUrl("http://qt.nokia.com/logo.png");
m_pImgCtrl = new FileDownloader(imageUrl, this);


* [[:Category:HowTo|HowTo]]
connect(m_pImgCtrl, SIGNAL (downloaded()), SLOT (loadImage()));
* [[:Category:snippets|snippets]]
</code>
* QPixmap von den heruntergeladenen Daten laden
<code>
void MainWindow::loadImage()
{
QPixmap buttonImage;
buttonImage.loadFromData(m_pImgCtrl->downloadedData());
}

Latest revision as of 17:45, 23 January 2016


German English Български 한국어فارسی

Daten von URL herunterladen

Der folgende Code-Schnippsel demonstriert, wie Daten von einer URL als QByteArray heruntergeladen werden können. Die heruntergeladenen Daten können dann entweder als Datei gespeichert oder in ein passendes Objekt konvertiert werden. Wird beispielsweise ein Bild heruntergeladen, kann es mit Hilfe der loadFromData() Funktion in ein QPixmap oder QImage konvertiert werden.

Beachte, dass obwohl der Name der Klasse FileDownloader ist, the heruntergeladenen Daten nicht als Datei auf der Festplatte gespeichert werden.

Wichtige Klassen

.pro Datei

QT += network

Für Symbian Geräte muss der Netzwerkdienst hinzugefügt werden.

symbian:TARGET.CAPABILITY+= NetworServices

filedownloader.h

#ifndef FILEDOWNLOADER_H
#define FILEDOWNLOADER_H

#include <QObject>
#include <QByteArray>
#include <QNetworkAccessManager>
#include <QNetworkRequest>
#include <QNetworkReply>

class FileDownloader : public QObject
{
 Q_OBJECT
public:
 explicit FileDownloader(QUrl imageUrl, QObject *parent = 0);

 virtual ~FileDownloader();

 QByteArray downloadedData() const;

signals:
 void downloaded();

private slots:

 void fileDownloaded(QNetworkReply* pReply);

private:

QNetworkAccessManager m_WebCtrl;

QByteArray m_DownloadedData;

};

#endif // FILEDOWNLOADER_H

filedownloader.cpp

#include "filedownloader.h"

FileDownloader::FileDownloader(QUrl imageUrl, QObject *parent) :
 QObject(parent)
{
 connect(&m_WebCtrl, SIGNAL (finished(QNetworkReply*)),
 SLOT (fileDownloaded(QNetworkReply*)));

 QNetworkRequest request(imageUrl);
 m_WebCtrl.get(request);
}

FileDownloader::~FileDownloader()
{

}

void FileDownloader::fileDownloaded(QNetworkReply* pReply)
{
 m_DownloadedData = pReply->readAll();
 //emit a signal
 pReply->deleteLater();
 emit downloaded();
}

QByteArray FileDownloader::downloadedData() const
{
 return m_DownloadedData;
}

Verwendung

Pixmap von URL laden

  • Slot deklarieren
private slots:

void loadImage();
  • downloaded() Signal mit Slot verbinden
QUrl imageUrl("http://qt.nokia.com/logo.png");
m_pImgCtrl = new FileDownloader(imageUrl, this);

connect(m_pImgCtrl, SIGNAL (downloaded()), SLOT (loadImage()));
  • QPixmap von den heruntergeladenen Daten laden

void MainWindow::loadImage() {

QPixmap buttonImage;
buttonImage.loadFromData(m_pImgCtrl->downloadedData());

}