homescreenapp/hsutils/src/hsimagehandlingclient.cpp
author hgs
Wed, 20 Oct 2010 15:25:39 +0300
changeset 101 ba1b7e218624
parent 95 32e56106abf2
permissions -rw-r--r--
201042
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
95
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
    82
    mReq = mAppMgr.create(XQI_IMAGE_FETCH, XQOP_IMAGE_FETCH, true);
90
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&)));
95
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
    86
        mReq->setSynchronous(false);
90
hgs
parents:
diff changeset
    87
    } else {
hgs
parents:
diff changeset
    88
        qCritical() << "HsImageHandlingClient::fetch -> Create request failed";
hgs
parents:
diff changeset
    89
        return;
hgs
parents:
diff changeset
    90
    }
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
    if (!(mReq)->send()) {
hgs
parents:
diff changeset
    93
        qCritical() << "HsImageHandlingClient::fetch -> Send failed" << mReq->lastErrorMessage();;
hgs
parents:
diff changeset
    94
    }
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
    qDebug() << "HsImageHandlingClient::fetch END";
hgs
parents:
diff changeset
    97
#endif // Q_OS_SYMBIAN
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
//
hgs
parents:
diff changeset
   103
void HsImageHandlingClient::edit(const QString &imagePath)
hgs
parents:
diff changeset
   104
{
hgs
parents:
diff changeset
   105
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
   106
    qDebug() << "HsImageHandlingClient::edit START";
hgs
parents:
diff changeset
   107
    
hgs
parents:
diff changeset
   108
    const QString service = QLatin1String("PhotoEditor");
hgs
parents:
diff changeset
   109
    const QString interface = QLatin1String("com.nokia.symbian.imageeditor");
hgs
parents:
diff changeset
   110
    const QString operation = QLatin1String("view(QString,int)");
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
   //Connect to service provider
95
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   113
    if (mReq) {
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   114
        delete mReq;
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   115
        mReq = 0;
90
hgs
parents:
diff changeset
   116
    }
hgs
parents:
diff changeset
   117
95
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   118
   //Connect to service provider
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   119
   mReq = mAppMgr.create(service, interface, operation, true);
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   120
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   121
   if (mReq) {        
90
hgs
parents:
diff changeset
   122
        connect(mReq, SIGNAL(requestOk(const QVariant&)), this, SLOT(handleEditorOk(const QVariant&)));
hgs
parents:
diff changeset
   123
        connect(mReq, SIGNAL(requestError(int,const QString&)), this, SLOT(handleEditorError(int,const QString&)));
95
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   124
        mReq->setSynchronous(false);
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   125
90
hgs
parents:
diff changeset
   126
    } else {
hgs
parents:
diff changeset
   127
        qCritical() << "HsImageHandlingClient::edit -> Create request failed";
hgs
parents:
diff changeset
   128
        return;
hgs
parents:
diff changeset
   129
    }
hgs
parents:
diff changeset
   130
    QList<QVariant> args;
hgs
parents:
diff changeset
   131
    args << imagePath;
hgs
parents:
diff changeset
   132
    args << EEditorHighwayWallpaperCrop;
hgs
parents:
diff changeset
   133
    mReq->setArguments(args);
95
32e56106abf2 201038_02
hgs
parents: 90
diff changeset
   134
    if (!mReq->send()) {
90
hgs
parents:
diff changeset
   135
        qCritical() << "HsImageHandlingClient::edit -> Send failed" << mReq->lastErrorMessage();;
hgs
parents:
diff changeset
   136
    }
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
    qDebug() << "HsImageHandlingClient::edit END";
hgs
parents:
diff changeset
   139
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
   140
}
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
// Aiw request responses
hgs
parents:
diff changeset
   143
void HsImageHandlingClient::handleOk(const QVariant &result)
hgs
parents:
diff changeset
   144
{
hgs
parents:
diff changeset
   145
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
   146
    // disconnect error signal as it will give -4999 (EConnectionClosed) error afterwards even though image
hgs
parents:
diff changeset
   147
    // is fetched successfully
hgs
parents:
diff changeset
   148
    disconnect(mReq, SIGNAL(requestError(int,const QString&)), this, SLOT(handleError(int,const QString&)));
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
    XQAiwRequest *request = static_cast<XQAiwRequest *>(sender());
hgs
parents:
diff changeset
   151
    int implementationId=-1;
hgs
parents:
diff changeset
   152
    implementationId = (request->descriptor().property(XQAiwInterfaceDescriptor::ImplementationId)).toInt();
hgs
parents:
diff changeset
   153
hgs
parents:
diff changeset
   154
    if (result.canConvert<QString>()) {
hgs
parents:
diff changeset
   155
        qDebug("HsImageHandlingClient::%x:handleOk result=%s,%s",
hgs
parents:
diff changeset
   156
               implementationId,
hgs
parents:
diff changeset
   157
               result.typeName(),
hgs
parents:
diff changeset
   158
               qPrintable(result.value<QString>()));
hgs
parents:
diff changeset
   159
hgs
parents:
diff changeset
   160
        emit fetchCompleted(result.value<QString>());
hgs
parents:
diff changeset
   161
    } else if (result.canConvert<QStringList>()) {
hgs
parents:
diff changeset
   162
        QStringList resultList = result.value<QStringList>();
hgs
parents:
diff changeset
   163
	    if (resultList.size() > 0) {
hgs
parents:
diff changeset
   164
	        //for debug
hgs
parents:
diff changeset
   165
	        QString msg = QString("HsImageHandlingClient::handleOk, size=")+QString::number( resultList.size() )+QString("\n");
hgs
parents:
diff changeset
   166
	        for (int i(0), size(resultList.size()); i < size; ++i) {
hgs
parents:
diff changeset
   167
                msg += QString::number(i) + QString(":") + resultList[i] + QString("\n");
hgs
parents:
diff changeset
   168
	        }
hgs
parents:
diff changeset
   169
	        qDebug()<<msg;
hgs
parents:
diff changeset
   170
		}
hgs
parents:
diff changeset
   171
        emit fetchCompleted(resultList[0]);
hgs
parents:
diff changeset
   172
	} else {
hgs
parents:
diff changeset
   173
        qCritical("AppMgrClient::%x:handleOk result=%s. Not displayable",
hgs
parents:
diff changeset
   174
            implementationId,
hgs
parents:
diff changeset
   175
            result.typeName());
hgs
parents:
diff changeset
   176
        emit fetchFailed(-1, QString());
hgs
parents:
diff changeset
   177
    }
hgs
parents:
diff changeset
   178
#else
hgs
parents:
diff changeset
   179
	Q_UNUSED(result)
hgs
parents:
diff changeset
   180
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
   181
}
hgs
parents:
diff changeset
   182
hgs
parents:
diff changeset
   183
void HsImageHandlingClient::handleError(int errorCode, const QString &errorMessage)
hgs
parents:
diff changeset
   184
{
hgs
parents:
diff changeset
   185
#ifdef Q_OS_SYMBIAN
hgs
parents:
diff changeset
   186
    XQAiwRequest *request = static_cast<XQAiwRequest *>(sender());
hgs
parents:
diff changeset
   187
    int implementationId = -1;
hgs
parents:
diff changeset
   188
    implementationId = (request->descriptor().property(XQAiwInterfaceDescriptor::ImplementationId)).toInt();
hgs
parents:
diff changeset
   189
hgs
parents:
diff changeset
   190
    qCritical("HsImageHandlingClient::%x:handleError code=%d, errorMessage:%s",
hgs
parents:
diff changeset
   191
        implementationId, errorCode, qPrintable(errorMessage));
hgs
parents:
diff changeset
   192
    emit fetchFailed(errorCode, errorMessage);
hgs
parents:
diff changeset
   193
#else
hgs
parents:
diff changeset
   194
	Q_UNUSED(errorCode)
hgs
parents:
diff changeset
   195
	Q_UNUSED(errorMessage)
hgs
parents:
diff changeset
   196
#endif // Q_OS_SYMBIAN
hgs
parents:
diff changeset
   197
}
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
void HsImageHandlingClient::handleEditorOk(const QVariant& result)
hgs
parents:
diff changeset
   200
{
hgs
parents:
diff changeset
   201
    Q_UNUSED(result)
hgs
parents:
diff changeset
   202
    emit editorCompleted();
hgs
parents:
diff changeset
   203
}
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
void HsImageHandlingClient::handleEditorError(int errorCode,
hgs
parents:
diff changeset
   206
                                             const QString& errorMessage)
hgs
parents:
diff changeset
   207
{
hgs
parents:
diff changeset
   208
    emit editorFailed(errorCode, errorMessage);
hgs
parents:
diff changeset
   209
}
hgs
parents:
diff changeset
   210
#ifdef COVERAGE_MEASUREMENT
hgs
parents:
diff changeset
   211
#pragma CTC ENDSKIP
hgs
parents:
diff changeset
   212
#endif //COVERAGE_MEASUREMENT