homescreenapp/hsutils/src/hsimagehandlingclient.cpp
author hgs
Mon, 20 Sep 2010 10:19:07 +0300
changeset 90 3ac3aaebaee5
child 95 32e56106abf2
permissions -rw-r--r--
201037
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
90
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Photos image handling client.
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#include "hsimagehandlingclient.h"
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <QDir>
hgs
parents:
diff changeset
    22
#include <QDebug>
hgs
parents:
diff changeset
    23
#include <QVariant>
hgs
parents:
diff changeset
    24
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
    25
#include <xqaiwinterfacedescriptor.h>
hgs
parents:
diff changeset
    26
#include <xqaiwdecl.h>
hgs
parents:
diff changeset
    27
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
    28
#ifdef FF_IMAGE_EDITOR
hgs
parents:
diff changeset
    29
#include <photoeditor_highway.hrh>
hgs
parents:
diff changeset
    30
#endif //FF_IMAGE_EDITOR
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
#ifdef COVERAGE_MEASUREMENT
hgs
parents:
diff changeset
    33
#pragma CTC SKIP
hgs
parents:
diff changeset
    34
#endif //COVERAGE_MEASUREMENT
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
/*!
hgs
parents:
diff changeset
    38
    \class HsImageHandlingClient
hgs
parents:
diff changeset
    39
    \ingroup group_hsutils
hgs
parents:
diff changeset
    40
    \brief 
hgs
parents:
diff changeset
    41
*/
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    44
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    45
//
hgs
parents:
diff changeset
    46
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
    47
HsImageHandlingClient::HsImageHandlingClient(QObject *parent)
hgs
parents:
diff changeset
    48
  : QObject(parent),
hgs
parents:
diff changeset
    49
    mReq(0)
hgs
parents:
diff changeset
    50
{
hgs
parents:
diff changeset
    51
}
hgs
parents:
diff changeset
    52
#else
hgs
parents:
diff changeset
    53
HsImageHandlingClient::HsImageHandlingClient(QObject *parent)
hgs
parents:
diff changeset
    54
  : QObject(parent)
hgs
parents:
diff changeset
    55
{
hgs
parents:
diff changeset
    56
}
hgs
parents:
diff changeset
    57
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    60
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    61
//
hgs
parents:
diff changeset
    62
HsImageHandlingClient::~HsImageHandlingClient()
hgs
parents:
diff changeset
    63
{
hgs
parents:
diff changeset
    64
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
    65
    delete mReq;
hgs
parents:
diff changeset
    66
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
    67
}
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    70
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    71
//
hgs
parents:
diff changeset
    72
void HsImageHandlingClient::fetch()
hgs
parents:
diff changeset
    73
{
hgs
parents:
diff changeset
    74
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
    75
    qDebug() << "HsImageHandlingClient::fetch START";
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
    if (mReq) {
hgs
parents:
diff changeset
    78
        delete mReq;
hgs
parents:
diff changeset
    79
        mReq = 0;
hgs
parents:
diff changeset
    80
    }
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    mReq = mAppMgr.create(XQI_IMAGE_FETCH, XQOP_IMAGE_FETCH, false);
hgs
parents:
diff changeset
    83
    if (mReq) {        
hgs
parents:
diff changeset
    84
        connect(mReq, SIGNAL(requestOk(const QVariant&)), this, SLOT(handleOk(const QVariant&)));
hgs
parents:
diff changeset
    85
        connect(mReq, SIGNAL(requestError(int,const QString&)), this, SLOT(handleError(int,const QString&)));
hgs
parents:
diff changeset
    86
    } else {
hgs
parents:
diff changeset
    87
        qCritical() << "HsImageHandlingClient::fetch -> Create request failed";
hgs
parents:
diff changeset
    88
        return;
hgs
parents:
diff changeset
    89
    }
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
    if (!(mReq)->send()) {
hgs
parents:
diff changeset
    92
        qCritical() << "HsImageHandlingClient::fetch -> Send failed" << mReq->lastErrorMessage();;
hgs
parents:
diff changeset
    93
    }
hgs
parents:
diff changeset
    94
hgs
parents:
diff changeset
    95
    qDebug() << "HsImageHandlingClient::fetch END";
hgs
parents:
diff changeset
    96
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
    97
}
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   100
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   101
//
hgs
parents:
diff changeset
   102
void HsImageHandlingClient::edit(const QString &imagePath)
hgs
parents:
diff changeset
   103
{
hgs
parents:
diff changeset
   104
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
   105
    qDebug() << "HsImageHandlingClient::edit START";
hgs
parents:
diff changeset
   106
    
hgs
parents:
diff changeset
   107
    const QString service = QLatin1String("PhotoEditor");
hgs
parents:
diff changeset
   108
    const QString interface = QLatin1String("com.nokia.symbian.imageeditor");
hgs
parents:
diff changeset
   109
    const QString operation = QLatin1String("view(QString,int)");
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
   //Connect to service provider
hgs
parents:
diff changeset
   112
    if(mReq == NULL){
hgs
parents:
diff changeset
   113
        mReq = mAppMgr.create(service, interface, operation, true);
hgs
parents:
diff changeset
   114
        mReq->setEmbedded(true);
hgs
parents:
diff changeset
   115
        mReq->setSynchronous(false);
hgs
parents:
diff changeset
   116
    }
hgs
parents:
diff changeset
   117
    
hgs
parents:
diff changeset
   118
    if(mReq == NULL){
hgs
parents:
diff changeset
   119
        return;
hgs
parents:
diff changeset
   120
    } 
hgs
parents:
diff changeset
   121
hgs
parents:
diff changeset
   122
    if (mReq) {        
hgs
parents:
diff changeset
   123
        connect(mReq, SIGNAL(requestOk(const QVariant&)), this, SLOT(handleEditorOk(const QVariant&)));
hgs
parents:
diff changeset
   124
        connect(mReq, SIGNAL(requestError(int,const QString&)), this, SLOT(handleEditorError(int,const QString&)));
hgs
parents:
diff changeset
   125
    } else {
hgs
parents:
diff changeset
   126
        qCritical() << "HsImageHandlingClient::edit -> Create request failed";
hgs
parents:
diff changeset
   127
        return;
hgs
parents:
diff changeset
   128
    }
hgs
parents:
diff changeset
   129
    QList<QVariant> args;
hgs
parents:
diff changeset
   130
    args << imagePath;
hgs
parents:
diff changeset
   131
    args << EEditorHighwayWallpaperCrop;
hgs
parents:
diff changeset
   132
    mReq->setArguments(args);
hgs
parents:
diff changeset
   133
    if (!(mReq)->send()) {
hgs
parents:
diff changeset
   134
        qCritical() << "HsImageHandlingClient::edit -> Send failed" << mReq->lastErrorMessage();;
hgs
parents:
diff changeset
   135
    }
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
    qDebug() << "HsImageHandlingClient::edit END";
hgs
parents:
diff changeset
   138
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
   139
}
hgs
parents:
diff changeset
   140
hgs
parents:
diff changeset
   141
// Aiw request responses
hgs
parents:
diff changeset
   142
void HsImageHandlingClient::handleOk(const QVariant &result)
hgs
parents:
diff changeset
   143
{
hgs
parents:
diff changeset
   144
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
   145
    // disconnect error signal as it will give -4999 (EConnectionClosed) error afterwards even though image
hgs
parents:
diff changeset
   146
    // is fetched successfully
hgs
parents:
diff changeset
   147
    disconnect(mReq, SIGNAL(requestError(int,const QString&)), this, SLOT(handleError(int,const QString&)));
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    XQAiwRequest *request = static_cast<XQAiwRequest *>(sender());
hgs
parents:
diff changeset
   150
    int implementationId=-1;
hgs
parents:
diff changeset
   151
    implementationId = (request->descriptor().property(XQAiwInterfaceDescriptor::ImplementationId)).toInt();
hgs
parents:
diff changeset
   152
hgs
parents:
diff changeset
   153
    if (result.canConvert<QString>()) {
hgs
parents:
diff changeset
   154
        qDebug("HsImageHandlingClient::%x:handleOk result=%s,%s",
hgs
parents:
diff changeset
   155
               implementationId,
hgs
parents:
diff changeset
   156
               result.typeName(),
hgs
parents:
diff changeset
   157
               qPrintable(result.value<QString>()));
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
        emit fetchCompleted(result.value<QString>());
hgs
parents:
diff changeset
   160
    } else if (result.canConvert<QStringList>()) {
hgs
parents:
diff changeset
   161
        QStringList resultList = result.value<QStringList>();
hgs
parents:
diff changeset
   162
	    if (resultList.size() > 0) {
hgs
parents:
diff changeset
   163
	        //for debug
hgs
parents:
diff changeset
   164
	        QString msg = QString("HsImageHandlingClient::handleOk, size=")+QString::number( resultList.size() )+QString("\n");
hgs
parents:
diff changeset
   165
	        for (int i(0), size(resultList.size()); i < size; ++i) {
hgs
parents:
diff changeset
   166
                msg += QString::number(i) + QString(":") + resultList[i] + QString("\n");
hgs
parents:
diff changeset
   167
	        }
hgs
parents:
diff changeset
   168
	        qDebug()<<msg;
hgs
parents:
diff changeset
   169
		}
hgs
parents:
diff changeset
   170
        emit fetchCompleted(resultList[0]);
hgs
parents:
diff changeset
   171
	} else {
hgs
parents:
diff changeset
   172
        qCritical("AppMgrClient::%x:handleOk result=%s. Not displayable",
hgs
parents:
diff changeset
   173
            implementationId,
hgs
parents:
diff changeset
   174
            result.typeName());
hgs
parents:
diff changeset
   175
        emit fetchFailed(-1, QString());
hgs
parents:
diff changeset
   176
    }
hgs
parents:
diff changeset
   177
#else
hgs
parents:
diff changeset
   178
	Q_UNUSED(result)
hgs
parents:
diff changeset
   179
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
   180
}
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
void HsImageHandlingClient::handleError(int errorCode, const QString &errorMessage)
hgs
parents:
diff changeset
   183
{
hgs
parents:
diff changeset
   184
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
   185
    XQAiwRequest *request = static_cast<XQAiwRequest *>(sender());
hgs
parents:
diff changeset
   186
    int implementationId = -1;
hgs
parents:
diff changeset
   187
    implementationId = (request->descriptor().property(XQAiwInterfaceDescriptor::ImplementationId)).toInt();
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
    qCritical("HsImageHandlingClient::%x:handleError code=%d, errorMessage:%s",
hgs
parents:
diff changeset
   190
        implementationId, errorCode, qPrintable(errorMessage));
hgs
parents:
diff changeset
   191
    emit fetchFailed(errorCode, errorMessage);
hgs
parents:
diff changeset
   192
#else
hgs
parents:
diff changeset
   193
	Q_UNUSED(errorCode)
hgs
parents:
diff changeset
   194
	Q_UNUSED(errorMessage)
hgs
parents:
diff changeset
   195
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
   196
}
hgs
parents:
diff changeset
   197
hgs
parents:
diff changeset
   198
void HsImageHandlingClient::handleEditorOk(const QVariant& result)
hgs
parents:
diff changeset
   199
{
hgs
parents:
diff changeset
   200
    Q_UNUSED(result)
hgs
parents:
diff changeset
   201
    emit editorCompleted();
hgs
parents:
diff changeset
   202
}
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
void HsImageHandlingClient::handleEditorError(int errorCode,
hgs
parents:
diff changeset
   205
                                             const QString& errorMessage)
hgs
parents:
diff changeset
   206
{
hgs
parents:
diff changeset
   207
    emit editorFailed(errorCode, errorMessage);
hgs
parents:
diff changeset
   208
}
hgs
parents:
diff changeset
   209
#ifdef COVERAGE_MEASUREMENT
hgs
parents:
diff changeset
   210
#pragma CTC ENDSKIP
hgs
parents:
diff changeset
   211
#endif //COVERAGE_MEASUREMENT