Qt wiki will be updated on October 12th 2023 starting at 11:30 AM (EEST) and the maintenance will last around 2-3 hours. During the maintenance the site will be unavailable.
Download Data from URL/de: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
[[Category:snippets]]<br />[[Category:HowTo]]<br />[[Category:German]] | |||
= | [toc align_right="yes&quot; depth="2&quot;] | ||
Der folgende Code-Schnippsel demonstriert, wie Daten von einer | '''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 "QByteArray&quot;:http://doc.qt.io/qt-5.0/qtcore/qbytearray.html 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 "loadFromData()":http://doc.qt.io/qt-5.0/qtgui/qimage.html#loadFromData-2 Funktion in ein "QPixmap&quot;:http://doc.qt.io/qt-5.0/qtgui/qpixmap.html oder "QImage&quot;:http://doc.qt.io/qt-5.0/qtgui/qimage.html 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 == | ||
* "QNetworkAccessManager&quot;:http://doc.qt.io/qt-5.0/qtnetwork/qnetworkaccessmanager.html | |||
* "QNetworkRequest&quot;:http://doc.qt.io/qt-5.0/qtnetwork/qnetworkrequest.html | |||
* "QNetworkReply&quot;:http://doc.qt.io/qt-5.0/qtnetwork/qnetworkreply.html | |||
* "QUrl&quot;:http://doc.qt.io/qt-5.0/qtcore/qurl.html | |||
== .pro Datei == | |||
<code><br />QT ''= network<br /></code><br />Für Symbian Geräte muss der Netzwerkdienst hinzugefügt werden.<br /><code><br />symbian:TARGET.CAPABILITY''= NetworServices<br /></code> | |||
== filedownloader.h == | |||
<code><br />#ifndef FILEDOWNLOADER_H<br />#define FILEDOWNLOADER_H | |||
#include <QObject&gt;<br />#include <QByteArray&gt;<br />#include <QNetworkAccessManager&gt;<br />#include <QNetworkRequest&gt;<br />#include <QNetworkReply&gt; | |||
class FileDownloader : public QObject<br />{<br /> Q_OBJECT<br />public:<br /> explicit FileDownloader(QUrl imageUrl, QObject '''parent = 0); | |||
<br /> virtual ~FileDownloader(); | |||
<br /> QByteArray downloadedData() const; | |||
<br />signals:<br /> void downloaded(); | |||
<br />private slots: | |||
<br /> void fileDownloaded(QNetworkReply''' pReply); | |||
private: | |||
QNetworkAccessManager m_WebCtrl; | |||
QByteArray m_DownloadedData; | |||
}; | |||
#endif // FILEDOWNLOADER_H<br /></code> | |||
==. | == filedownloader.cpp == | ||
<code><br />#include "filedownloader.h&quot; | |||
FileDownloader::FileDownloader(QUrl imageUrl, QObject '''parent) :<br /> QObject(parent)<br />{<br /> connect(&m_WebCtrl, SIGNAL (finished(QNetworkReply*)),<br /> SLOT (fileDownloaded(QNetworkReply*))); | |||
<br /> QNetworkRequest request(imageUrl);<br /> m_WebCtrl.get(request);<br />} | |||
<br />FileDownloader::~FileDownloader()<br />{ | |||
<br />} | |||
<br />void FileDownloader::fileDownloaded(QNetworkReply''' pReply)<br />{<br /> m_DownloadedData = pReply->readAll();<br /> //emit a signal<br /> pReply->deleteLater();<br /> emit downloaded();<br />} | |||
QByteArray FileDownloader::downloadedData() const<br />{<br /> return m_DownloadedData;<br />}<br /></code> | |||
=Verwendung= | = Verwendung = | ||
==Pixmap von | == Pixmap von URL laden == | ||
* Slot deklarieren<br /> | * Slot deklarieren<br /><code><br />private slots: | ||
void loadImage();<br /></code><br />* '''downloaded()''' Signal mit Slot verbinden<br /><code><br />QUrl imageUrl("http://qt.nokia.com/logo.png&quot;);<br />m_pImgCtrl = new FileDownloader(imageUrl, this); | |||
* | connect(m_pImgCtrl, SIGNAL (downloaded()), SLOT (loadImage()));<br /></code><br />* QPixmap von den heruntergeladenen Daten laden<br /><code><br />void MainWindow::loadImage()<br />{<br /> QPixmap buttonImage;<br /> buttonImage.loadFromData(m_pImgCtrl->downloadedData());<br />} | ||
Revision as of 10:48, 24 February 2015
[toc align_right="yes" depth="2"]
German English Български 한국어فارسی
Daten von URL herunterladen
Der folgende Code-Schnippsel demonstriert, wie Daten von einer URL als "QByteArray":http://doc.qt.io/qt-5.0/qtcore/qbytearray.html 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()":http://doc.qt.io/qt-5.0/qtgui/qimage.html#loadFromData-2 Funktion in ein "QPixmap":http://doc.qt.io/qt-5.0/qtgui/qpixmap.html oder "QImage":http://doc.qt.io/qt-5.0/qtgui/qimage.html konvertiert werden.
Beachte, dass obwohl der Name der Klasse FileDownloader ist, the heruntergeladenen Daten nicht als Datei auf der Festplatte gespeichert werden.
Wichtige Klassen
- "QNetworkAccessManager":http://doc.qt.io/qt-5.0/qtnetwork/qnetworkaccessmanager.html
- "QNetworkRequest":http://doc.qt.io/qt-5.0/qtnetwork/qnetworkrequest.html
- "QNetworkReply":http://doc.qt.io/qt-5.0/qtnetwork/qnetworkreply.html
- "QUrl":http://doc.qt.io/qt-5.0/qtcore/qurl.html
.pro Datei
<br />QT ''= network<br />
Für Symbian Geräte muss der Netzwerkdienst hinzugefügt werden.
<br />symbian:TARGET.CAPABILITY''= NetworServices<br />
filedownloader.h
<br />#ifndef FILEDOWNLOADER_H<br />#define FILEDOWNLOADER_H
#include <QObject&gt;<br />#include <QByteArray&gt;<br />#include <QNetworkAccessManager&gt;<br />#include <QNetworkRequest&gt;<br />#include <QNetworkReply&gt;
class FileDownloader : public QObject<br />{<br /> Q_OBJECT<br />public:<br /> explicit FileDownloader(QUrl imageUrl, QObject '''parent = 0);
<br /> virtual ~FileDownloader();
<br /> QByteArray downloadedData() const;
<br />signals:<br /> void downloaded();
<br />private slots:
<br /> void fileDownloaded(QNetworkReply''' pReply);
private:
QNetworkAccessManager m_WebCtrl;
QByteArray m_DownloadedData;
};
#endif // FILEDOWNLOADER_H<br />
filedownloader.cpp
<br />#include "filedownloader.h&quot;
FileDownloader::FileDownloader(QUrl imageUrl, QObject '''parent) :<br /> QObject(parent)<br />{<br /> connect(&m_WebCtrl, SIGNAL (finished(QNetworkReply*)),<br /> SLOT (fileDownloaded(QNetworkReply*)));
<br /> QNetworkRequest request(imageUrl);<br /> m_WebCtrl.get(request);<br />}
<br />FileDownloader::~FileDownloader()<br />{
<br />}
<br />void FileDownloader::fileDownloaded(QNetworkReply''' pReply)<br />{<br /> m_DownloadedData = pReply->readAll();<br /> //emit a signal<br /> pReply->deleteLater();<br /> emit downloaded();<br />}
QByteArray FileDownloader::downloadedData() const<br />{<br /> return m_DownloadedData;<br />}<br />
Verwendung
Pixmap von URL laden
- Slot deklarieren
<br />private slots: void loadImage();<br />
* downloaded() Signal mit Slot verbinden<br />QUrl imageUrl("http://qt.nokia.com/logo.png&quot;);<br />m_pImgCtrl = new FileDownloader(imageUrl, this); connect(m_pImgCtrl, SIGNAL (downloaded()), SLOT (loadImage()));<br />
* QPixmap von den heruntergeladenen Daten laden
void MainWindow::loadImage()
{
QPixmap buttonImage;
buttonImage.loadFromData(m_pImgCtrl->downloadedData());
}