QDeclarativeImageProvider non carica immagine in container
Domanda
Image {
id: backImage
source: "image://imageprovider/frontimage"
}
funziona bene, ma non funziona con colonna o un altro contenitore
Column {
Image {
id: backImage
source: "image://imageprovider/frontimage"
}
}
, mentre
Column {
Image {
id: backImage
source: "screen1.png"
}
}
OK. Perché?
Dichiarazione:
class QMLImageProvider : public QObject, public QDeclarativeImageProvider
{
Q_OBJECT
private:
QPixmap front;
QPixmap back;
public:
explicit QMLImageProvider();
QPixmap requestPixmap(const QString &id, QSize *size, const QSize &requestedSize);
};
applicazione:
QMLImageProvider::QMLImageProvider() : QObject(0),
QDeclarativeImageProvider(QDeclarativeImageProvider::Pixmap) {}
QPixmap QMLImageProvider::requestPixmap(const QString &id, QSize *size, const QSize &requestedSize) {
return QPixmap(QString("QML/screen1.png"));
}
registrazione:
screenArea = new QDeclarativeView(wgScreenArea);
qmlImageProvider = new QMLImageProvider();
screenArea->engine()->addImageProvider(GlobalVars::imageProviderID, qmlImageProvider);
screenArea->setSource(QUrl::fromLocalFile("QML/screen.qml"));
screenArea->setResizeMode(QDeclarativeView::SizeRootObjectToView);
P.S. Ci scusiamo per il mio inglese.
~ ~ RISOLTO
Column {
id:screenImage
Image {
id: backImage
width: screenImage.width
height: screenImage.height
source: "image://imageprovider/backimage"
}
}
Funziona! Grazie mille!
Soluzione
Forse che il Image
utilizzando il ImageProvider
non dichiara la sua larghezza e l'altezza in modo corretto? Column
s ottenere un po 'divertente con oggetti che non dichiarano la loro larghezza e l'altezza. Prova difficile codificare il width
e height
nel vostro Image
nel secondo esempio e dovrebbe funzionare.
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow