Revert "Adverts widget supports population from web and from local files."

This reverts commit 85a611ed19.
This commit is contained in:
Andre Jochems
2015-11-09 13:08:38 +01:00
parent 85a611ed19
commit 5924b24782
16 changed files with 116 additions and 167 deletions

View File

@@ -13,22 +13,22 @@ CasinoCoinWebAPI::CasinoCoinWebAPI( QObject*a_pParent )
void CasinoCoinWebAPI::GetActivePromotions()
{
Get( s_strServerAddress + s_strServerEndpoint + "/ActivePromotions" );
Get( s_strServerAddress + "/" + s_strServerEndpoint + "/ActivePromotions" );
}
void CasinoCoinWebAPI::GetActiveCasinos()
{
Get( s_strServerAddress + s_strServerEndpoint + "/ActiveCasinos" );
Get( s_strServerAddress + "/" + s_strServerEndpoint + "/ActiveCasinos" );
}
void CasinoCoinWebAPI::GetActiveNewsItems()
{
Get( s_strServerAddress + s_strServerEndpoint + "/ActiveNewsItems" );
Get( s_strServerAddress + "/" + s_strServerEndpoint + "/ActiveNewsItems" );
}
void CasinoCoinWebAPI::GetActiveExchanges()
{
Get( s_strServerAddress + s_strServerEndpoint + "/ActiveExchanges" );
Get( s_strServerAddress + "/" + s_strServerEndpoint + "/ActiveExchanges" );
}
void CasinoCoinWebAPI::Get( const QString& a_rUrl )
@@ -43,11 +43,10 @@ void CasinoCoinWebAPI::slotParseNetworkResponse( QNetworkReply *finished )
if ( finished->error() != QNetworkReply::NoError )
{
// A communication error has occurred
qDebug() << finished->request().url();
emit signalNetworkError( finished->error(), finished->request().url() );
emit signalNetworkError( finished->error() );
return;
}
QByteArray data = finished->readAll();
QByteArray data = finished->readAll();
emit signalResponseReady( data );
}

View File

@@ -23,10 +23,7 @@ public:
signals:
void signalResponseReady( const QByteArray& a_rJsonFile );
void signalNetworkError
( QNetworkReply::NetworkError a_eError
, const QUrl a_rFailedUrl
);
void signalNetworkError( QNetworkReply::NetworkError a_eError );
public slots:
void slotParseNetworkResponse( QNetworkReply *finished );

View File

@@ -5,8 +5,6 @@
#include <QJsonValue>
#include <QDebug>
#include <QDir>
#include <QFile>
CasinoCoinWebAPIParser::CasinoCoinWebAPIParser( QObject* a_pParent )
: QObject(a_pParent)
@@ -25,37 +23,24 @@ void CasinoCoinWebAPIParser::slotParseAnswer( const QByteArray& a_rJsonFile )
QJsonObject jsonObjectResult = docAsObject.find( "Result" ).value().toObject();
if ( jsonObjectResult.find( "ActivePromotions" ).value().isArray() )
{
StoreFile( "ActivePromotions", a_rJsonFile );
ParsePromotions( docAsObject );
}
else if ( jsonObjectResult.find( "ActiveNewsItems" ).value().isArray() )
{
StoreFile( "ActiveNewsItems", a_rJsonFile );
ParseNewsItems( docAsObject );
}
else if ( jsonObjectResult.find( "ActiveCasinos" ).value().isArray() )
{
StoreFile( "ActiveCasinos", a_rJsonFile );
ParseCasinos( docAsObject );
}
else if ( jsonObjectResult.find( "ActiveExchanges" ).value().isArray() )
{
StoreFile( "ActiveExchanges", a_rJsonFile );
ParseExchanges( docAsObject );
}
}
}
}
void CasinoCoinWebAPIParser::slotNetworkError( QNetworkReply::NetworkError a_eError
, const QUrl a_rFailedUrl
)
{
qDebug() << "network error: " << a_eError;
QString strAccessedUrl = a_rFailedUrl.toString().split("/").last();
slotParseAnswer( ReadFile( strAccessedUrl ) );
}
void CasinoCoinWebAPIParser::ParsePromotions( const QJsonObject& a_rJsonPromotions )
{
qDebug() << "ParsePromotions";
@@ -79,41 +64,3 @@ void CasinoCoinWebAPIParser::ParseNewsItems( const QJsonObject& a_rJsonNewsItems
qDebug() << "Coming soon - ParseNewsItems";
qDebug() << a_rJsonNewsItems;
}
QByteArray CasinoCoinWebAPIParser::ReadFile( QString a_strSourcePath )
{
QByteArray strAnswer;
if ( !QDir( "offlineData" ).exists() )
{
QDir().mkdir( "offlineData" );
}
QFile fileOutput( QDir( "offlineData" ).absoluteFilePath( a_strSourcePath ) );
if ( !fileOutput.open( QIODevice::ReadOnly ) )
{
qWarning() << "cannot open file to read: " << QDir::current().relativeFilePath( a_strSourcePath );
}
else
{
strAnswer = fileOutput.readAll();
fileOutput.close();
}
return strAnswer;
}
void CasinoCoinWebAPIParser::StoreFile( QString a_strDestinationPath, const QByteArray& a_rJsonFile )
{
if ( !QDir( "offlineData" ).exists() )
{
QDir().mkdir( "offlineData" );
}
QFile fileOutput( QDir( "offlineData" ).absoluteFilePath( a_strDestinationPath ) );
if ( !fileOutput.open( QIODevice::WriteOnly | QIODevice::Truncate ) )
{
qWarning() << "cannot open file to write: " << QDir::current().relativeFilePath( a_strDestinationPath );
}
else
{
fileOutput.write( a_rJsonFile );
fileOutput.close();
}
}

View File

@@ -6,8 +6,6 @@
#include "jsonactivepromotionsparser.h"
#include "jsonsingleactivepromotion.h"
#include <QNetworkReply>
class CasinoCoinWebAPIParser : public QObject
{
Q_OBJECT
@@ -23,18 +21,12 @@ signals:
public slots:
void slotParseAnswer( const QByteArray& a_rJsonFile );
void slotNetworkError
( QNetworkReply::NetworkError a_eError
, const QUrl a_rFailedUrl
);
private:
void ParsePromotions( const QJsonObject& a_rJsonPromotions );
void ParseCasinos ( const QJsonObject& a_rJsonCasinos );
void ParseExchanges ( const QJsonObject& a_rJsonExchanges );
void ParseNewsItems ( const QJsonObject& a_rJsonNewsItems );
QByteArray ReadFile( QString a_strSourcePath );
void StoreFile( QString a_strDestinationPath, const QByteArray& a_rJsonFile );
};
#endif // CASINOCOINWEBAPIPARSER_H

View File

@@ -1,5 +1,4 @@
#include "jsonactivepromotionsparser.h"
#include "../qtquick_controls/cpp/qmlimageprovider.h"
#include <QDebug>
@@ -25,7 +24,7 @@ void JsonActivePromotionsParser::ResolvePromotionsArray()
{
if ( singleCasinoDescriptor.isObject() )
{
m_aActivePromotions.append( JsonSingleActivePromotion( singleCasinoDescriptor.toObject() ) );
m_aActiveCasinos.append( JsonSingleActivePromotion( singleCasinoDescriptor.toObject() ) );
}
}
}
@@ -34,21 +33,10 @@ void JsonActivePromotionsParser::ResolvePromotionsArray()
const QList<JsonSingleActivePromotion>& JsonActivePromotionsParser::GetPromotions() const
{
return m_aActivePromotions;
return m_aActiveCasinos;
}
QList<JsonSingleActivePromotion>& JsonActivePromotionsParser::GetPromotions()
{
return m_aActivePromotions;
}
void JsonActivePromotionsParser::AddImagesToPool( QmlImageProvider* a_pImageProvider )
{
if ( a_pImageProvider )
{
foreach( JsonSingleActivePromotion oPromotion, m_aActivePromotions )
{
a_pImageProvider->AddToImagePool( oPromotion.GetImageName(), oPromotion.GetAdvertImage() );
}
}
return m_aActiveCasinos;
}

View File

@@ -8,8 +8,6 @@
#include "jsonsingleactivepromotion.h"
class QmlImageProvider;
class JsonActivePromotionsParser : public QJsonObject
{
public:
@@ -19,13 +17,11 @@ public:
const QList<JsonSingleActivePromotion>& GetPromotions() const;
QList<JsonSingleActivePromotion>& GetPromotions();
void AddImagesToPool( QmlImageProvider* a_pImageProvider );
private:
void ResolvePromotionsArray();
QList<JsonSingleActivePromotion> m_aActivePromotions;
QList<JsonSingleActivePromotion> m_aActiveCasinos;
};
#endif // JSONACTIVEPROMOTIONSPARSER_H

View File

@@ -14,21 +14,40 @@ JsonSingleActivePromotion::JsonSingleActivePromotion()
JsonSingleActivePromotion::JsonSingleActivePromotion( const QJsonObject& a_rOther )
: QJsonObject( a_rOther )
{
m_strImageName = find( "promotion_title" ).value().toString().remove( GetRestrictedCharacters() );
StoreImage();
}
QRegExp JsonSingleActivePromotion::GetRestrictedCharacters()
QString JsonSingleActivePromotion::GetImagePath() const
{
return QRegExp( "[<,>|\\:()&;#?*% ]" );
return QString( "file://" + QDir::currentPath() + "/" + GetImageRelativePath() );
}
void JsonSingleActivePromotion::StoreImage()
QString JsonSingleActivePromotion::GetImageRelativePath() const
{
return QString( "adverts/" + find( "promotion_title" ).value().toString().remove( " " ) + "." + find( "image_mime_type" ).value().toString().split( "/" ).last() );
}
QString JsonSingleActivePromotion::StoreImage()
{
QString strReturn = QString();
if ( find( "image_mime_type" ).value().toString().split( "/" ).first().contains( "image" ) )
{
QString strFileName = GetImageRelativePath();
QByteArray binaryData = QByteArray::fromBase64( find( "promotion_image" ).value().toString().toLocal8Bit() );
m_oAdvertImage = QImage::fromData( binaryData );
if ( !QDir( "adverts" ).exists() )
{
QDir().mkdir( "adverts" );
}
QFile imageOutputFile( strFileName );
QImage outputImage = QImage::fromData( binaryData, "JPEG" );
if ( imageOutputFile.open( QIODevice::WriteOnly | QIODevice::Truncate ) )
{
outputImage.save( &imageOutputFile, 0 );
imageOutputFile.close();
strReturn = strFileName;
}
}
return strReturn;
}

View File

@@ -5,8 +5,6 @@
#include <QJsonValue>
#include <QJsonArray>
#include <QImage>
class JsonSingleActivePromotion : public QJsonObject
{
public:
@@ -14,16 +12,11 @@ public:
JsonSingleActivePromotion( const QJsonObject& a_rOther );
virtual ~JsonSingleActivePromotion(){}
QString GetImageName() const{ return m_strImageName; }
QImage GetAdvertImage() const { return m_oAdvertImage; }
QString GetImagePath() const;
private:
void StoreImage();
static QRegExp GetRestrictedCharacters();
QString m_strImageName;
QImage m_oAdvertImage;
QString GetImageRelativePath() const;
QString StoreImage();
};
#endif // JSONSINGLEACTIVEPROMOTION_H

View File

@@ -30,7 +30,7 @@ void GUIBannerControl::InitializeAdvertsView( GUIBannerListView* a_pView )
}
}
void GUIBannerControl::slotPopulateListView( JsonActivePromotionsParser* a_pActivePromotions )
void GUIBannerControl::slotPopulateFromWeb( JsonActivePromotionsParser* a_pActivePromotions )
{
if ( m_pAdvertsView )
{
@@ -39,3 +39,13 @@ void GUIBannerControl::slotPopulateListView( JsonActivePromotionsParser* a_pActi
}
}
void GUIBannerControl::slotPopulateLocally()
{
if ( m_pAdvertsView )
{
QmlBannerListModel* pAdvertsModel = new QmlBannerListModel( 0 );
m_pAdvertsView->SetModel( pAdvertsModel );
qDebug() << "Coming soon";
}
}

View File

@@ -18,7 +18,8 @@ public:
GUIBannerListView* GetAdvertsView() const { return m_pAdvertsView; }
public slots:
void slotPopulateListView( JsonActivePromotionsParser* a_pActivePromotions );
void slotPopulateFromWeb( JsonActivePromotionsParser* a_pActivePromotions );
void slotPopulateLocally();
signals:

View File

@@ -20,12 +20,10 @@ GUIBannerWidget::GUIBannerWidget(QWidget *parent)
, m_pBannerControl( 0 )
, m_pWebApiParserTemporary( new CasinoCoinWebAPIParser( this ) )
, m_pWebApiTemporary( new CasinoCoinWebAPI( this ) )
, m_pQmlImageProvider( 0 )
{
registerCustomQmlTypes();
connect( m_pWebApiTemporary, SIGNAL( signalResponseReady(const QByteArray&)), m_pWebApiParserTemporary, SLOT( slotParseAnswer(const QByteArray&)), Qt::UniqueConnection );
connect( m_pWebApiTemporary, SIGNAL( signalNetworkError(QNetworkReply::NetworkError,const QUrl)), m_pWebApiParserTemporary, SLOT( slotNetworkError(QNetworkReply::NetworkError,const QUrl)), Qt::UniqueConnection );
connect( m_pWebApiParserTemporary, SIGNAL( signalActivePromotionsParsed(JsonActivePromotionsParser*)), this, SLOT( slotPopulateFromWeb(JsonActivePromotionsParser*)), Qt::UniqueConnection );
connect( m_pWebApiTemporary, SIGNAL( signalNetworkError(QNetworkReply::NetworkError)), this, SLOT( slotNetworkError(QNetworkReply::NetworkError)), Qt::UniqueConnection );
}
GUIBannerWidget::~GUIBannerWidget()
@@ -38,18 +36,14 @@ void GUIBannerWidget::registerCustomQmlTypes()
qmlRegisterType<GUIBannerControl>("CasinoCoinControls", 1, 0, "GUIBannerControl" );
qmlRegisterType<GUIBannerListView>("CasinoCoinControls", 1, 0, "GUIBannerListView" );
qmlRegisterType<QmlBannerListModel>("CasinoCoinControls", 1, 0, "QmlBannerListModel" );
qmlRegisterType<QmlImageProvider>("CasinoCoinControls", 1, 0, "QmlImageProvider" );
}
QWidget* GUIBannerWidget::dockQmlToWidget()
{
QQuickView* pBannerWindow = new QQuickView;
pBannerWindow->setSource( QUrl( QStringLiteral( "qrc:/qml/qtquick_controls/qml/QmlGUIBannerWindow.qml" ) ) );
QQmlEngine* pEngine = pBannerWindow->engine();
if ( pEngine )
{
m_pQmlImageProvider = new QmlImageProvider();
pEngine->addImageProvider( "advertImages", m_pQmlImageProvider );
}
QWidget* pPlaceHolder = QWidget::createWindowContainer( pBannerWindow, this );
pPlaceHolder->setMinimumSize( 445, 120 );
pPlaceHolder->setMaximumSize( 445, 120 );
@@ -60,6 +54,10 @@ QWidget* GUIBannerWidget::dockQmlToWidget()
m_pBannerControl = pRootObject->findChild<GUIBannerControl*>();
if ( m_pBannerControl )
{
if ( m_pWebApiParserTemporary )
{
connect( m_pWebApiParserTemporary, SIGNAL( signalActivePromotionsParsed(JsonActivePromotionsParser*)), m_pBannerControl, SLOT( slotPopulateFromWeb(JsonActivePromotionsParser*)), Qt::UniqueConnection );
}
m_pBannerControl->setWidth( ( 115 * 3 ) + ( 4 * 10 ) + 60 );
m_pBannerControl->setHeight( 115 );
}
@@ -76,14 +74,15 @@ void GUIBannerWidget::PopulateBannerFromWeb()
}
}
void GUIBannerWidget::slotPopulateFromWeb( JsonActivePromotionsParser* a_pPromotionsParser )
void GUIBannerWidget::PopulateBannerLocally()
{
if ( a_pPromotionsParser )
{
a_pPromotionsParser->AddImagesToPool( m_pQmlImageProvider );
}
if ( m_pBannerControl )
{
m_pBannerControl->slotPopulateListView( a_pPromotionsParser );
m_pBannerControl->slotPopulateLocally();
}
}
void GUIBannerWidget::slotNetworkError( QNetworkReply::NetworkError a_eError )
{
PopulateBannerLocally();
}

View File

@@ -7,8 +7,6 @@
class CasinoCoinWebAPIParser;
class CasinoCoinWebAPI;
class GUIBannerControl;
class QmlImageProvider;
class JsonActivePromotionsParser;
class GUIBannerWidget : public QWidget
{
@@ -30,9 +28,9 @@ private:
CasinoCoinWebAPIParser* m_pWebApiParserTemporary;
CasinoCoinWebAPI* m_pWebApiTemporary;
QmlImageProvider* m_pQmlImageProvider;
private slots:
void slotPopulateFromWeb( JsonActivePromotionsParser* a_pPromotionsParser );
void slotNetworkError( QNetworkReply::NetworkError a_eError );
};
#endif // GUIBANNERWIDGET_H

View File

@@ -8,7 +8,7 @@ QmlBannerListItem::QmlBannerListItem(QString a_strImageSource, QString a_strDest
}
QmlBannerListItem::QmlBannerListItem( const JsonSingleActivePromotion& a_rCasinoDescription, QObject* a_pParent )
: QmlListItem( QVariant( a_rCasinoDescription.GetImageName() ), a_rCasinoDescription.find( "access_url" ).value().toVariant(), a_rCasinoDescription.find( "description" ).value().toVariant(), a_pParent )
: QmlListItem( QVariant( a_rCasinoDescription.GetImagePath() ), a_rCasinoDescription.find( "access_url" ).value().toVariant(), a_rCasinoDescription.find( "description" ).value().toVariant(), a_pParent )
{
}

View File

@@ -1,34 +1,39 @@
#include "qmlimageprovider.h"
#include <QDebug>
QmlImageProvider::QmlImageProvider( QQuickItem* a_pParent )
: QQuickPaintedItem( a_pParent )
{
QmlImageProvider::QmlImageProvider()
: QQuickImageProvider( QQuickImageProvider::Image )
}
QmlImageProvider::QmlImageProvider( const QImage& a_rImage, QQuickItem* a_pParent )
: QQuickPaintedItem( a_pParent )
, m_oImage( a_rImage )
{
}
void QmlImageProvider::AddToImagePool( QString a_strImageID, const QImage& a_rImage )
void QmlImageProvider::SetImage( const QImage& a_rImage )
{
m_aImagePool.insert( a_strImageID, a_rImage );
}
void QmlImageProvider::AddToImagePool( const QMap<QString, QImage>& a_aImages )
{
QMapIterator<QString,QImage> iter( a_aImages );
while( iter.hasNext() )
if ( a_rImage != m_oImage )
{
iter.next();
AddToImagePool( iter.key(), iter.value() );
m_oImage = QImage( a_rImage );
emit signalImageChanged();
}
}
QImage QmlImageProvider::requestImage( const QString& a_rImageID, QSize* a_pSize, const QSize& a_ra_rRequestedSize )
void QmlImageProvider::paint( QPainter* a_pPainter )
{
QImage oImage( m_aImagePool.value( a_rImageID ) );
if ( a_pSize )
if ( a_pPainter )
{
a_pSize->setWidth( oImage.width() );
a_pSize->setHeight( oImage.height() );
a_pPainter->drawImage( QPoint( 0, 0 ), m_oImage );
}
}
void QmlImageProvider::paintImage( const QImage& a_rImage, QPainter* a_pPainter )
{
SetImage( a_rImage );
if ( a_pPainter )
{
a_pPainter->drawImage( QPoint( 0, 0 ), m_oImage );
}
return oImage;
}

View File

@@ -1,28 +1,26 @@
#ifndef QMLIMAGEPROVIDER_H
#define QMLIMAGEPROVIDER_H
#include <QQuickImageProvider>
#include <QQuickPaintedItem>
#include <QImage>
#include <QPainter>
class QmlImageProvider : public QQuickImageProvider
class QmlImageProvider : public QQuickPaintedItem
{
Q_OBJECT
Q_PROPERTY( QImage p_oImage MEMBER m_oImage NOTIFY signalImageChanged )
public:
explicit QmlImageProvider();
explicit QmlImageProvider( QQuickItem* a_pParent = 0 );
explicit QmlImageProvider( const QImage& a_rImage, QQuickItem* a_pParent = 0 );
void AddToImagePool( QString a_strImageID, const QImage& a_rImage );
void AddToImagePool( const QMap<QString,QImage>& a_aImages );
virtual QImage requestImage
( const QString& a_rImageID
, QSize* a_pSize
, const QSize& a_rRequestedSize
);
void SetImage( const QImage& a_rImage );
virtual void paint( QPainter* a_pPainter );
void paintImage( const QImage& a_rImage, QPainter* a_pPainter );
signals:
public slots:
void signalImageChanged();
private:
QMap<QString,QImage> m_aImagePool;
QImage m_oImage;
};
#endif // QMLIMAGEPROVIDER_H

View File

@@ -46,11 +46,18 @@ GUIBannerListView
Image
{
id: id_advertisementImage
source: "image://advertImages/" + m_imageSource
source: m_imageSource
scale: ( id_listElement.width / width )
anchors.centerIn: id_listElement
}
// coming soon
// QmlImageProvider
// {
// id: id_advertisementImage
// scale: ( id_listElement.width / width )
// anchors.centerIn: id_listElement
// }
MouseArea
{
id: id_leftItemMouseArea