videocollection/videocollectionwrapper/src/videothumbnaildata_p.cpp
author hgs
Fri, 16 Apr 2010 18:13:14 +0300
changeset 36 8aed59de29f9
parent 35 3738fe97f027
child 37 4eb2df7f7cbe
permissions -rw-r--r--
201015
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2009 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:  VideoThumbnailDataPrivate class implementation
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
36
hgs
parents: 35
diff changeset
    18
// Version : %version: 20 %
hgs
parents: 35
diff changeset
    19
30
hgs
parents:
diff changeset
    20
// INCLUDE FILES
34
hgs
parents: 30
diff changeset
    21
#include <qapplication.h>
hgs
parents: 30
diff changeset
    22
#include <qpixmap.h>
hgs
parents: 30
diff changeset
    23
#include <qtimer.h>
30
hgs
parents:
diff changeset
    24
#include <mpxmediageneraldefs.h>
35
hgs
parents: 34
diff changeset
    25
#include <hbicon.h>
hgs
parents: 34
diff changeset
    26
34
hgs
parents: 30
diff changeset
    27
#include <vcxmyvideosdefs.h>
36
hgs
parents: 35
diff changeset
    28
#include <videocollectioncommon.h>
30
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
#include "videothumbnaildata_p.h"
hgs
parents:
diff changeset
    31
#include "videocollectionwrapper.h"
hgs
parents:
diff changeset
    32
#include "videosortfilterproxymodel.h"
34
hgs
parents: 30
diff changeset
    33
#include "videothumbnailfetcher.h"
36
hgs
parents: 35
diff changeset
    34
#include "videocollectiontrace.h"
30
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
// Maximum thumbnails kept in memory.
hgs
parents:
diff changeset
    37
const int THUMBNAIL_CACHE_SIZE = 60;
hgs
parents:
diff changeset
    38
// Maximum of thumbnail fetches done at one background fetch round.
hgs
parents:
diff changeset
    39
const int THUMBNAIL_BACKGROUND_FETCH_AMOUNT = 20;
hgs
parents:
diff changeset
    40
// Milliseconds for the background fetch timer.
hgs
parents:
diff changeset
    41
const int THUMBNAIL_BACKGROUND_TIMEOUT = 100;
hgs
parents:
diff changeset
    42
// Milliseconds while thumbnail ready events are gathered before they 
hgs
parents:
diff changeset
    43
// are signaled.
hgs
parents:
diff changeset
    44
const int THUMBNAIL_READY_SIGNAL_TIMEOUT = 50;
hgs
parents:
diff changeset
    45
// Priority for background thumbnail fetches.
hgs
parents:
diff changeset
    46
const int BACKGROUND_FETCH_PRIORITY = 3000;
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
/**
hgs
parents:
diff changeset
    49
 * global qHash function required fo creating hash values for TMPXItemId -keys
hgs
parents:
diff changeset
    50
 */
hgs
parents:
diff changeset
    51
inline uint qHash(TMPXItemId key) 
hgs
parents:
diff changeset
    52
{ 
hgs
parents:
diff changeset
    53
    QPair<uint, uint> keyPair(key.iId1, key.iId2); 
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
    return qHash(keyPair);
hgs
parents:
diff changeset
    56
}
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
// ================= MEMBER FUNCTIONS =======================
hgs
parents:
diff changeset
    59
//
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    62
// VideoThumbnailDataPrivate::VideoThumbnailDataPrivate()
hgs
parents:
diff changeset
    63
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    64
//
36
hgs
parents: 35
diff changeset
    65
VideoThumbnailDataPrivate::VideoThumbnailDataPrivate() 
hgs
parents: 35
diff changeset
    66
    : mThumbnailFetcher( 0 )
hgs
parents: 35
diff changeset
    67
    , mCurrentModel( 0 )
hgs
parents: 35
diff changeset
    68
    , mCurrentFetchIndex( 0 )
hgs
parents: 35
diff changeset
    69
    , mCurrentBackgroundFetchCount( 0 )
hgs
parents: 35
diff changeset
    70
    , mBgFetchTimer( 0 )
hgs
parents: 35
diff changeset
    71
    , mTbnReportTimer( 0 )
hgs
parents: 35
diff changeset
    72
    , mSignalsConnected( false )
hgs
parents: 35
diff changeset
    73
    , mBackgroundFetchingEnabled( true )
30
hgs
parents:
diff changeset
    74
{
36
hgs
parents: 35
diff changeset
    75
	FUNC_LOG;
30
hgs
parents:
diff changeset
    76
    initialize();
hgs
parents:
diff changeset
    77
}
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    80
// VideoThumbnailDataPrivate::~VideoThumbnailDataPrivate()
hgs
parents:
diff changeset
    81
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    82
//
hgs
parents:
diff changeset
    83
VideoThumbnailDataPrivate::~VideoThumbnailDataPrivate()
hgs
parents:
diff changeset
    84
{
36
hgs
parents: 35
diff changeset
    85
	FUNC_LOG;
30
hgs
parents:
diff changeset
    86
    cleanup();
hgs
parents:
diff changeset
    87
}
hgs
parents:
diff changeset
    88
hgs
parents:
diff changeset
    89
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    90
// VideoThumbnailDataPrivate::initialize()
hgs
parents:
diff changeset
    91
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    92
//
hgs
parents:
diff changeset
    93
int VideoThumbnailDataPrivate::initialize()
hgs
parents:
diff changeset
    94
{
36
hgs
parents: 35
diff changeset
    95
	FUNC_LOG;
30
hgs
parents:
diff changeset
    96
    mThumbnailData.setMaxCost(THUMBNAIL_CACHE_SIZE);
hgs
parents:
diff changeset
    97
    
34
hgs
parents: 30
diff changeset
    98
    if(!mThumbnailFetcher)
30
hgs
parents:
diff changeset
    99
    {
34
hgs
parents: 30
diff changeset
   100
        mThumbnailFetcher = new VideoThumbnailFetcher();        
30
hgs
parents:
diff changeset
   101
    }
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
    if(!mBgFetchTimer)
hgs
parents:
diff changeset
   104
    {
hgs
parents:
diff changeset
   105
        mBgFetchTimer = new QTimer();
hgs
parents:
diff changeset
   106
    }
hgs
parents:
diff changeset
   107
    
hgs
parents:
diff changeset
   108
    if(!mTbnReportTimer)
hgs
parents:
diff changeset
   109
    {
hgs
parents:
diff changeset
   110
        mTbnReportTimer = new QTimer();
hgs
parents:
diff changeset
   111
    }
hgs
parents:
diff changeset
   112
hgs
parents:
diff changeset
   113
    if(connectSignals() < 0)
hgs
parents:
diff changeset
   114
    {
36
hgs
parents: 35
diff changeset
   115
        ERROR(-1, "VideoThumbnailDataPrivate::initialize() failed to connect signals.");
30
hgs
parents:
diff changeset
   116
        cleanup();
hgs
parents:
diff changeset
   117
        return -1;
hgs
parents:
diff changeset
   118
    }
hgs
parents:
diff changeset
   119
    
hgs
parents:
diff changeset
   120
    return 0;
hgs
parents:
diff changeset
   121
}
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   124
// VideoThumbnailDataPrivate::cleanup()
hgs
parents:
diff changeset
   125
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   126
//
hgs
parents:
diff changeset
   127
void VideoThumbnailDataPrivate::cleanup()
hgs
parents:
diff changeset
   128
{
36
hgs
parents: 35
diff changeset
   129
	FUNC_LOG;
30
hgs
parents:
diff changeset
   130
    disconnectSignals();
hgs
parents:
diff changeset
   131
34
hgs
parents: 30
diff changeset
   132
    delete mThumbnailFetcher;
hgs
parents: 30
diff changeset
   133
    mThumbnailFetcher = 0;
hgs
parents: 30
diff changeset
   134
    
30
hgs
parents:
diff changeset
   135
    freeThumbnailData();
hgs
parents:
diff changeset
   136
    
hgs
parents:
diff changeset
   137
    if(mTbnReportTimer)
hgs
parents:
diff changeset
   138
    {
hgs
parents:
diff changeset
   139
        mTbnReportTimer->stop();
hgs
parents:
diff changeset
   140
        delete mTbnReportTimer;
hgs
parents:
diff changeset
   141
        mTbnReportTimer = 0;
hgs
parents:
diff changeset
   142
    }
hgs
parents:
diff changeset
   143
    
hgs
parents:
diff changeset
   144
    if(mBgFetchTimer)
hgs
parents:
diff changeset
   145
    {
hgs
parents:
diff changeset
   146
        mBgFetchTimer->stop();
hgs
parents:
diff changeset
   147
        delete mBgFetchTimer;
hgs
parents:
diff changeset
   148
        mBgFetchTimer = 0;
hgs
parents:
diff changeset
   149
    }
hgs
parents:
diff changeset
   150
}
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   153
// VideoThumbnailDataPrivate::disconnectSignals()
hgs
parents:
diff changeset
   154
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   155
//
hgs
parents:
diff changeset
   156
void VideoThumbnailDataPrivate::disconnectSignals()
hgs
parents:
diff changeset
   157
{
36
hgs
parents: 35
diff changeset
   158
	FUNC_LOG;
30
hgs
parents:
diff changeset
   159
    if(mSignalsConnected)
hgs
parents:
diff changeset
   160
    {
34
hgs
parents: 30
diff changeset
   161
        VideoSortFilterProxyModel *model = 
36
hgs
parents: 35
diff changeset
   162
                VideoCollectionWrapper::instance().getModel(VideoCollectionCommon::EModelTypeAllVideos);
34
hgs
parents: 30
diff changeset
   163
        if(model)
hgs
parents: 30
diff changeset
   164
            {
hgs
parents: 30
diff changeset
   165
            disconnect(model->sourceModel(), SIGNAL(modelReady()), this, SLOT(modelChangedSlot()));
hgs
parents: 30
diff changeset
   166
            disconnect(model->sourceModel(), SIGNAL(modelChanged()), this, SLOT(modelChangedSlot()));
hgs
parents: 30
diff changeset
   167
            }
hgs
parents: 30
diff changeset
   168
		disconnect(mThumbnailFetcher, SIGNAL(thumbnailReady( QPixmap , void *, int )),
hgs
parents: 30
diff changeset
   169
                    this, SLOT(thumbnailReadySlot( QPixmap , void *, int )));
hgs
parents: 30
diff changeset
   170
        disconnect(mThumbnailFetcher, SIGNAL(allThumbnailsFetched()),
hgs
parents: 30
diff changeset
   171
                 this, SLOT(allThumbnailsFetchedSlot()));          
30
hgs
parents:
diff changeset
   172
        disconnect(mBgFetchTimer, SIGNAL(timeout()), this, SLOT(doBackgroundFetching()));
hgs
parents:
diff changeset
   173
        disconnect(mTbnReportTimer, SIGNAL(timeout()), this, SLOT(reportThumbnailsReadySlot()));
hgs
parents:
diff changeset
   174
    }
hgs
parents:
diff changeset
   175
    mSignalsConnected = false;
hgs
parents:
diff changeset
   176
}
hgs
parents:
diff changeset
   177
hgs
parents:
diff changeset
   178
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   179
// VideoThumbnailDataPrivate::connectSignals()
hgs
parents:
diff changeset
   180
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   181
//
hgs
parents:
diff changeset
   182
int VideoThumbnailDataPrivate::connectSignals()
hgs
parents:
diff changeset
   183
{
36
hgs
parents: 35
diff changeset
   184
	FUNC_LOG;
30
hgs
parents:
diff changeset
   185
    if(!mSignalsConnected)
hgs
parents:
diff changeset
   186
    {
34
hgs
parents: 30
diff changeset
   187
        VideoSortFilterProxyModel *model = 
36
hgs
parents: 35
diff changeset
   188
                VideoCollectionWrapper::instance().getModel(VideoCollectionCommon::EModelTypeAllVideos);
34
hgs
parents: 30
diff changeset
   189
        if(!model)
hgs
parents: 30
diff changeset
   190
            return -1;
hgs
parents: 30
diff changeset
   191
        if(!connect(mThumbnailFetcher, SIGNAL(thumbnailReady( QPixmap , void *, int )),
hgs
parents: 30
diff changeset
   192
                    this, SLOT(thumbnailReadySlot( QPixmap , void *, int))) ||
hgs
parents: 30
diff changeset
   193
            !connect(mThumbnailFetcher, SIGNAL(allThumbnailsFetched()),
hgs
parents: 30
diff changeset
   194
                     this, SLOT(allThumbnailsFetchedSlot())) ||
hgs
parents: 30
diff changeset
   195
           !connect(model->sourceModel(), SIGNAL(modelReady()), this, SLOT(modelChangedSlot())) ||
hgs
parents: 30
diff changeset
   196
           !connect(model->sourceModel(), SIGNAL(modelChanged()), this, SLOT(modelChangedSlot())) ||
30
hgs
parents:
diff changeset
   197
           !connect(mBgFetchTimer, SIGNAL(timeout()), this, SLOT(doBackgroundFetching())) ||
hgs
parents:
diff changeset
   198
           !connect(mTbnReportTimer, SIGNAL(timeout()), this, SLOT(reportThumbnailsReadySlot())))
hgs
parents:
diff changeset
   199
        {
hgs
parents:
diff changeset
   200
            return -1;
hgs
parents:
diff changeset
   201
        }
hgs
parents:
diff changeset
   202
        
hgs
parents:
diff changeset
   203
        QApplication *app = qApp;
hgs
parents:
diff changeset
   204
        if(!connect(app, SIGNAL(aboutToQuit()), this, SLOT(aboutToQuitSlot())))
hgs
parents:
diff changeset
   205
        {
hgs
parents:
diff changeset
   206
            return -1;
hgs
parents:
diff changeset
   207
        }
hgs
parents:
diff changeset
   208
        
hgs
parents:
diff changeset
   209
        mSignalsConnected = true;
hgs
parents:
diff changeset
   210
    }
hgs
parents:
diff changeset
   211
    return 0;
hgs
parents:
diff changeset
   212
}
hgs
parents:
diff changeset
   213
hgs
parents:
diff changeset
   214
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   215
// VideoThumbnailDataPrivate::getThumbnail()
hgs
parents:
diff changeset
   216
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   217
//
hgs
parents:
diff changeset
   218
const QIcon* VideoThumbnailDataPrivate::getThumbnail(TMPXItemId mediaId)
hgs
parents:
diff changeset
   219
{
hgs
parents:
diff changeset
   220
    const QIcon *thumbnail = mThumbnailData[mediaId];
hgs
parents:
diff changeset
   221
    if(!thumbnail)
hgs
parents:
diff changeset
   222
    {
hgs
parents:
diff changeset
   223
        return defaultThumbnail(mediaId);
hgs
parents:
diff changeset
   224
    }
hgs
parents:
diff changeset
   225
    return thumbnail;
hgs
parents:
diff changeset
   226
}
hgs
parents:
diff changeset
   227
hgs
parents:
diff changeset
   228
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   229
// VideoThumbnailDataPrivate::startFetchingThumbnails()
hgs
parents:
diff changeset
   230
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   231
//
hgs
parents:
diff changeset
   232
int VideoThumbnailDataPrivate::startFetchingThumbnails(const QList<QModelIndex> &indexes, int priority)
hgs
parents:
diff changeset
   233
{
36
hgs
parents: 35
diff changeset
   234
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   235
    if(!mCurrentModel || !mThumbnailFetcher)
30
hgs
parents:
diff changeset
   236
    {
hgs
parents:
diff changeset
   237
        return -1;
hgs
parents:
diff changeset
   238
    }
hgs
parents:
diff changeset
   239
    if(indexes.count() == 0)
hgs
parents:
diff changeset
   240
    {
hgs
parents:
diff changeset
   241
        return 0;
hgs
parents:
diff changeset
   242
    }
hgs
parents:
diff changeset
   243
    
34
hgs
parents: 30
diff changeset
   244
    mThumbnailFetcher->pauseFetching();
hgs
parents: 30
diff changeset
   245
hgs
parents: 30
diff changeset
   246
    int fetchCountBefore = mThumbnailFetcher->fetchCount();
30
hgs
parents:
diff changeset
   247
    
34
hgs
parents: 30
diff changeset
   248
    // Fetch the thumbnails
30
hgs
parents:
diff changeset
   249
    for(int i = 0; i < indexes.count(); i++)
hgs
parents:
diff changeset
   250
    {
34
hgs
parents: 30
diff changeset
   251
        startFetchingThumbnail(mCurrentModel->getMediaIdAtIndex(indexes[i]), priority--);
30
hgs
parents:
diff changeset
   252
    }
hgs
parents:
diff changeset
   253
    
34
hgs
parents: 30
diff changeset
   254
    int started = mThumbnailFetcher->fetchCount() - fetchCountBefore;
hgs
parents: 30
diff changeset
   255
    
hgs
parents: 30
diff changeset
   256
    mThumbnailFetcher->continueFetching();
hgs
parents: 30
diff changeset
   257
    
hgs
parents: 30
diff changeset
   258
    return started;
30
hgs
parents:
diff changeset
   259
}
hgs
parents:
diff changeset
   260
hgs
parents:
diff changeset
   261
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   262
// VideoThumbnailDataPrivate::startFetchingThumbnail()
hgs
parents:
diff changeset
   263
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   264
//
hgs
parents:
diff changeset
   265
int VideoThumbnailDataPrivate::startFetchingThumbnail(TMPXItemId mediaId, int priority)
hgs
parents:
diff changeset
   266
{
34
hgs
parents: 30
diff changeset
   267
    if(!mCurrentModel || !mThumbnailFetcher)
30
hgs
parents:
diff changeset
   268
    {
hgs
parents:
diff changeset
   269
        return -1;
hgs
parents:
diff changeset
   270
    }
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
    // Check that it's not fetched before.
hgs
parents:
diff changeset
   273
    if(mThumbnailData.contains(mediaId))
hgs
parents:
diff changeset
   274
    {
hgs
parents:
diff changeset
   275
        return 0;
hgs
parents:
diff changeset
   276
    }
hgs
parents:
diff changeset
   277
34
hgs
parents: 30
diff changeset
   278
    QString fileName = mCurrentModel->getMediaFilePathForId(mediaId);
hgs
parents: 30
diff changeset
   279
    
hgs
parents: 30
diff changeset
   280
    // Thumbnail fetcher signals into thumbnailReadySlot when thumbnail ready
30
hgs
parents:
diff changeset
   281
    if(fileName.length() > 0)
hgs
parents:
diff changeset
   282
    {
36
hgs
parents: 35
diff changeset
   283
        // object containing media id to be passed throught
hgs
parents: 35
diff changeset
   284
        // thumbnail generation process.
hgs
parents: 35
diff changeset
   285
        TMPXItemId *internal = new TMPXItemId(mediaId.iId1, mediaId.iId2);
hgs
parents: 35
diff changeset
   286
34
hgs
parents: 30
diff changeset
   287
        mThumbnailFetcher->addFetch(fileName, internal, priority);
30
hgs
parents:
diff changeset
   288
    }
hgs
parents:
diff changeset
   289
34
hgs
parents: 30
diff changeset
   290
    return 0;
30
hgs
parents:
diff changeset
   291
}
hgs
parents:
diff changeset
   292
hgs
parents:
diff changeset
   293
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   294
// VideoThumbnailDataPrivate::doBackgroundFetching()
hgs
parents:
diff changeset
   295
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   296
//
hgs
parents:
diff changeset
   297
void VideoThumbnailDataPrivate::doBackgroundFetching()
hgs
parents:
diff changeset
   298
{
36
hgs
parents: 35
diff changeset
   299
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   300
    if(!mCurrentModel || !mThumbnailFetcher)
30
hgs
parents:
diff changeset
   301
    {
hgs
parents:
diff changeset
   302
        return;
hgs
parents:
diff changeset
   303
    }
hgs
parents:
diff changeset
   304
hgs
parents:
diff changeset
   305
    if(mCurrentBackgroundFetchCount >= THUMBNAIL_CACHE_SIZE)
hgs
parents:
diff changeset
   306
    {
hgs
parents:
diff changeset
   307
        return;
hgs
parents:
diff changeset
   308
    }
hgs
parents:
diff changeset
   309
    
34
hgs
parents: 30
diff changeset
   310
    int maxIndex = mCurrentModel->rowCount();
30
hgs
parents:
diff changeset
   311
    if(maxIndex == 0)
hgs
parents:
diff changeset
   312
    {
hgs
parents:
diff changeset
   313
        return;
hgs
parents:
diff changeset
   314
    }
hgs
parents:
diff changeset
   315
hgs
parents:
diff changeset
   316
    // Delta to UI index where fetch has been done already.  
hgs
parents:
diff changeset
   317
    int currentDelta = mCurrentBackgroundFetchCount/2;
hgs
parents:
diff changeset
   318
    
hgs
parents:
diff changeset
   319
    // How many will be fetched.  
hgs
parents:
diff changeset
   320
    const int fetchAmount = THUMBNAIL_BACKGROUND_FETCH_AMOUNT/2;
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
    QList<QModelIndex> indexes;
hgs
parents:
diff changeset
   323
34
hgs
parents: 30
diff changeset
   324
    // Items after the current fetch index.
hgs
parents: 30
diff changeset
   325
    int startIndex = mCurrentFetchIndex+currentDelta;
hgs
parents: 30
diff changeset
   326
    int endIndex = mCurrentFetchIndex+currentDelta+fetchAmount;
30
hgs
parents:
diff changeset
   327
    getModelIndexes(indexes, startIndex, endIndex);
hgs
parents:
diff changeset
   328
34
hgs
parents: 30
diff changeset
   329
    // Items before the current fetch index.
hgs
parents: 30
diff changeset
   330
    startIndex = mCurrentFetchIndex-currentDelta-fetchAmount;
hgs
parents: 30
diff changeset
   331
    endIndex = mCurrentFetchIndex-currentDelta;
30
hgs
parents:
diff changeset
   332
    getModelIndexes(indexes, startIndex, endIndex);
34
hgs
parents: 30
diff changeset
   333
    
30
hgs
parents:
diff changeset
   334
    mCurrentBackgroundFetchCount += THUMBNAIL_BACKGROUND_FETCH_AMOUNT;
hgs
parents:
diff changeset
   335
hgs
parents:
diff changeset
   336
    int fetchesStarted = startFetchingThumbnails(indexes, BACKGROUND_FETCH_PRIORITY);
hgs
parents:
diff changeset
   337
    
hgs
parents:
diff changeset
   338
    // No thumbnails to fetch, start again.
hgs
parents:
diff changeset
   339
    if(fetchesStarted == 0)
hgs
parents:
diff changeset
   340
    {
hgs
parents:
diff changeset
   341
        continueBackgroundFetch();
hgs
parents:
diff changeset
   342
    }
hgs
parents:
diff changeset
   343
}
hgs
parents:
diff changeset
   344
hgs
parents:
diff changeset
   345
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   346
// VideoThumbnailDataPrivate::getModelIndexes()
hgs
parents:
diff changeset
   347
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   348
//
hgs
parents:
diff changeset
   349
void VideoThumbnailDataPrivate::getModelIndexes(QList<QModelIndex> &indexes, int startIndex, int endIndex)
hgs
parents:
diff changeset
   350
{
36
hgs
parents: 35
diff changeset
   351
	FUNC_LOG;
30
hgs
parents:
diff changeset
   352
    QModelIndex index;
hgs
parents:
diff changeset
   353
    for(int i = startIndex; i < endIndex; i++)
hgs
parents:
diff changeset
   354
    {
hgs
parents:
diff changeset
   355
        if(i >= 0)
hgs
parents:
diff changeset
   356
        {
34
hgs
parents: 30
diff changeset
   357
            index = mCurrentModel->index(i, 0);
30
hgs
parents:
diff changeset
   358
            if(index.isValid())
hgs
parents:
diff changeset
   359
            {
hgs
parents:
diff changeset
   360
                indexes.append(index);
hgs
parents:
diff changeset
   361
            }
hgs
parents:
diff changeset
   362
        }
hgs
parents:
diff changeset
   363
    }
hgs
parents:
diff changeset
   364
}
hgs
parents:
diff changeset
   365
hgs
parents:
diff changeset
   366
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   367
// VideoThumbnailDataPrivate::thumbnailReadySlot()
hgs
parents:
diff changeset
   368
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   369
//
34
hgs
parents: 30
diff changeset
   370
void VideoThumbnailDataPrivate::thumbnailReadySlot(QPixmap tnData, void *internal, int error)
30
hgs
parents:
diff changeset
   371
{
hgs
parents:
diff changeset
   372
    TMPXItemId mediaId(0, 0);
hgs
parents:
diff changeset
   373
    if(internal)
hgs
parents:
diff changeset
   374
    {
hgs
parents:
diff changeset
   375
        mediaId = *(static_cast<TMPXItemId*>(internal));
hgs
parents:
diff changeset
   376
        delete internal;
hgs
parents:
diff changeset
   377
    }
hgs
parents:
diff changeset
   378
    else
hgs
parents:
diff changeset
   379
    {
hgs
parents:
diff changeset
   380
        return;
hgs
parents:
diff changeset
   381
    }
hgs
parents:
diff changeset
   382
hgs
parents:
diff changeset
   383
    if(!error && !tnData.isNull())
hgs
parents:
diff changeset
   384
    {
hgs
parents:
diff changeset
   385
        mThumbnailData.insert(mediaId, new QIcon(tnData));
hgs
parents:
diff changeset
   386
        
hgs
parents:
diff changeset
   387
        // Gather list of media ids and emit thumbnailReady signals in larger set
hgs
parents:
diff changeset
   388
        // when timer goes off.
hgs
parents:
diff changeset
   389
        if(mTbnReportTimer && !mTbnReportTimer->isActive())
hgs
parents:
diff changeset
   390
        {
hgs
parents:
diff changeset
   391
            mTbnReportTimer->setSingleShot(true);
hgs
parents:
diff changeset
   392
            mTbnReportTimer->start(THUMBNAIL_READY_SIGNAL_TIMEOUT);
hgs
parents:
diff changeset
   393
        }
hgs
parents:
diff changeset
   394
hgs
parents:
diff changeset
   395
        // Save the media id for the signal.  
hgs
parents:
diff changeset
   396
        mReadyThumbnailMediaIds.append(mediaId);
hgs
parents:
diff changeset
   397
    }
hgs
parents:
diff changeset
   398
}
hgs
parents:
diff changeset
   399
hgs
parents:
diff changeset
   400
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   401
// VideoThumbnailDataPrivate::reportThumbnailsReadySlot()
hgs
parents:
diff changeset
   402
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   403
//
hgs
parents:
diff changeset
   404
void VideoThumbnailDataPrivate::reportThumbnailsReadySlot()
hgs
parents:
diff changeset
   405
{
36
hgs
parents: 35
diff changeset
   406
	FUNC_LOG;
30
hgs
parents:
diff changeset
   407
    emit thumbnailsFetched(mReadyThumbnailMediaIds);
hgs
parents:
diff changeset
   408
    mReadyThumbnailMediaIds.clear();
hgs
parents:
diff changeset
   409
}
hgs
parents:
diff changeset
   410
hgs
parents:
diff changeset
   411
// -----------------------------------------------------------------------------
34
hgs
parents: 30
diff changeset
   412
// VideoThumbnailDataPrivate::allThumbnailsFetchedSlot()
30
hgs
parents:
diff changeset
   413
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   414
//
34
hgs
parents: 30
diff changeset
   415
void VideoThumbnailDataPrivate::allThumbnailsFetchedSlot()
30
hgs
parents:
diff changeset
   416
{
36
hgs
parents: 35
diff changeset
   417
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   418
    continueBackgroundFetch();
30
hgs
parents:
diff changeset
   419
}
hgs
parents:
diff changeset
   420
hgs
parents:
diff changeset
   421
// -----------------------------------------------------------------------------
34
hgs
parents: 30
diff changeset
   422
// VideoThumbnailDataPrivate::modelChangedSlot()
30
hgs
parents:
diff changeset
   423
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   424
//
34
hgs
parents: 30
diff changeset
   425
void VideoThumbnailDataPrivate::modelChangedSlot()
30
hgs
parents:
diff changeset
   426
{
36
hgs
parents: 35
diff changeset
   427
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   428
    startBackgroundFetching(mCurrentModel, mCurrentFetchIndex);
30
hgs
parents:
diff changeset
   429
}
hgs
parents:
diff changeset
   430
hgs
parents:
diff changeset
   431
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   432
// VideoThumbnailDataPrivate::defaultThumbnail()
hgs
parents:
diff changeset
   433
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   434
//
hgs
parents:
diff changeset
   435
const QIcon* VideoThumbnailDataPrivate::defaultThumbnail(TMPXItemId mediaId)
hgs
parents:
diff changeset
   436
{
35
hgs
parents: 34
diff changeset
   437
    const TMPXItemId defaultIdVideo(KMaxTUint32-1, KVcxMvcMediaTypeVideo);
hgs
parents: 34
diff changeset
   438
    const TMPXItemId defaultIdAlbum(KMaxTUint32-1, KVcxMvcMediaTypeAlbum);
hgs
parents: 34
diff changeset
   439
    const TMPXItemId defaultIdDownloads(KVcxMvcCategoryIdDownloads, KVcxMvcMediaTypeCategory);
hgs
parents: 34
diff changeset
   440
    const TMPXItemId defaultIdCaptured(KVcxMvcCategoryIdCaptured, KVcxMvcMediaTypeCategory);
hgs
parents: 34
diff changeset
   441
hgs
parents: 34
diff changeset
   442
    // Default thumbnail for video
34
hgs
parents: 30
diff changeset
   443
    if(mediaId.iId2 == KVcxMvcMediaTypeVideo) 
30
hgs
parents:
diff changeset
   444
    {
35
hgs
parents: 34
diff changeset
   445
        if(!mDefaultThumbnails.contains(defaultIdVideo))
hgs
parents: 34
diff changeset
   446
        {
hgs
parents: 34
diff changeset
   447
            mDefaultThumbnails[defaultIdVideo] = HbIcon(":/icons/default_thumbnail_video.svg");
hgs
parents: 34
diff changeset
   448
        }
hgs
parents: 34
diff changeset
   449
        return &mDefaultThumbnails[defaultIdVideo].qicon();
30
hgs
parents:
diff changeset
   450
    }
hgs
parents:
diff changeset
   451
    else
hgs
parents:
diff changeset
   452
    {
35
hgs
parents: 34
diff changeset
   453
        // Default thumbnail for user defined album.
hgs
parents: 34
diff changeset
   454
        if(mediaId.iId2 == KVcxMvcMediaTypeAlbum)
hgs
parents: 34
diff changeset
   455
        {
hgs
parents: 34
diff changeset
   456
            if(!mDefaultThumbnails.contains(defaultIdAlbum))
hgs
parents: 34
diff changeset
   457
            {
36
hgs
parents: 35
diff changeset
   458
                mDefaultThumbnails[defaultIdAlbum] = HbIcon("qtg_large_video_collection");
35
hgs
parents: 34
diff changeset
   459
            }
hgs
parents: 34
diff changeset
   460
            return &mDefaultThumbnails[defaultIdAlbum].qicon();
hgs
parents: 34
diff changeset
   461
        }
hgs
parents: 34
diff changeset
   462
hgs
parents: 34
diff changeset
   463
        // Thumbnails for default collections.
hgs
parents: 34
diff changeset
   464
        switch(mediaId.iId1)
hgs
parents: 34
diff changeset
   465
        {
hgs
parents: 34
diff changeset
   466
            case KVcxMvcCategoryIdDownloads:
hgs
parents: 34
diff changeset
   467
            {
hgs
parents: 34
diff changeset
   468
                if(!mDefaultThumbnails.contains(defaultIdDownloads))
hgs
parents: 34
diff changeset
   469
                {
hgs
parents: 34
diff changeset
   470
                    mDefaultThumbnails[defaultIdDownloads] = HbIcon("qtg_large_video_download");
hgs
parents: 34
diff changeset
   471
                }
hgs
parents: 34
diff changeset
   472
                return &mDefaultThumbnails[defaultIdDownloads].qicon();
hgs
parents: 34
diff changeset
   473
            }
hgs
parents: 34
diff changeset
   474
            
hgs
parents: 34
diff changeset
   475
            case KVcxMvcCategoryIdCaptured:
hgs
parents: 34
diff changeset
   476
            {
hgs
parents: 34
diff changeset
   477
                if(!mDefaultThumbnails.contains(defaultIdCaptured))
hgs
parents: 34
diff changeset
   478
                {
hgs
parents: 34
diff changeset
   479
                    mDefaultThumbnails[defaultIdCaptured] = HbIcon("qtg_large_video_capture");
hgs
parents: 34
diff changeset
   480
                }
hgs
parents: 34
diff changeset
   481
                return &mDefaultThumbnails[defaultIdCaptured].qicon();
hgs
parents: 34
diff changeset
   482
            }
hgs
parents: 34
diff changeset
   483
hgs
parents: 34
diff changeset
   484
            default:
hgs
parents: 34
diff changeset
   485
            {
hgs
parents: 34
diff changeset
   486
                if(!mDefaultThumbnails.contains(defaultIdAlbum))
hgs
parents: 34
diff changeset
   487
                {
36
hgs
parents: 35
diff changeset
   488
                    mDefaultThumbnails[defaultIdAlbum] = HbIcon("qtg_large_video_collection");
35
hgs
parents: 34
diff changeset
   489
                }
hgs
parents: 34
diff changeset
   490
                return &mDefaultThumbnails[defaultIdAlbum].qicon();
hgs
parents: 34
diff changeset
   491
            }
hgs
parents: 34
diff changeset
   492
        }
30
hgs
parents:
diff changeset
   493
    }
hgs
parents:
diff changeset
   494
}
hgs
parents:
diff changeset
   495
hgs
parents:
diff changeset
   496
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   497
// VideoThumbnailDataPrivate::removeThumbnail()
hgs
parents:
diff changeset
   498
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   499
//
hgs
parents:
diff changeset
   500
bool VideoThumbnailDataPrivate::removeThumbnail(TMPXItemId mediaId)
hgs
parents:
diff changeset
   501
{
36
hgs
parents: 35
diff changeset
   502
	FUNC_LOG;
30
hgs
parents:
diff changeset
   503
    return mThumbnailData.remove(mediaId);
hgs
parents:
diff changeset
   504
}
hgs
parents:
diff changeset
   505
hgs
parents:
diff changeset
   506
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   507
// VideoThumbnailDataPrivate::enableBackgroundFetching()
hgs
parents:
diff changeset
   508
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   509
//
hgs
parents:
diff changeset
   510
void VideoThumbnailDataPrivate::enableBackgroundFetching(bool enable)
hgs
parents:
diff changeset
   511
{
36
hgs
parents: 35
diff changeset
   512
	FUNC_LOG;
hgs
parents: 35
diff changeset
   513
    INFO_1("VideoThumbnailDataPrivate::enableBackgroundFetching() enable: %d", enable);
30
hgs
parents:
diff changeset
   514
    mBackgroundFetchingEnabled = enable;
34
hgs
parents: 30
diff changeset
   515
    startBackgroundFetching(mCurrentModel, 0);
hgs
parents: 30
diff changeset
   516
}
hgs
parents: 30
diff changeset
   517
hgs
parents: 30
diff changeset
   518
// -----------------------------------------------------------------------------
hgs
parents: 30
diff changeset
   519
// VideoThumbnailDataPrivate::enableThumbnailCreation()
hgs
parents: 30
diff changeset
   520
// -----------------------------------------------------------------------------
hgs
parents: 30
diff changeset
   521
//
hgs
parents: 30
diff changeset
   522
void VideoThumbnailDataPrivate::enableThumbnailCreation(bool enable)
hgs
parents: 30
diff changeset
   523
{
36
hgs
parents: 35
diff changeset
   524
	FUNC_LOG;
hgs
parents: 35
diff changeset
   525
	INFO_1("VideoThumbnailDataPrivate::enableThumbnailCreation() enable: %d", enable);
34
hgs
parents: 30
diff changeset
   526
    if(mThumbnailFetcher)
36
hgs
parents: 35
diff changeset
   527
    {
34
hgs
parents: 30
diff changeset
   528
        mThumbnailFetcher->enableThumbnailCreation(enable);
36
hgs
parents: 35
diff changeset
   529
    }
30
hgs
parents:
diff changeset
   530
}
hgs
parents:
diff changeset
   531
hgs
parents:
diff changeset
   532
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   533
// VideoThumbnailDataPrivate::freeThumbnailData()
hgs
parents:
diff changeset
   534
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   535
//
hgs
parents:
diff changeset
   536
void VideoThumbnailDataPrivate::freeThumbnailData()
hgs
parents:
diff changeset
   537
{
36
hgs
parents: 35
diff changeset
   538
	FUNC_LOG;
30
hgs
parents:
diff changeset
   539
    // Stop timers.
hgs
parents:
diff changeset
   540
    if(mBgFetchTimer)
36
hgs
parents: 35
diff changeset
   541
    {
30
hgs
parents:
diff changeset
   542
        mBgFetchTimer->stop();
36
hgs
parents: 35
diff changeset
   543
    }
30
hgs
parents:
diff changeset
   544
    
hgs
parents:
diff changeset
   545
    if(mTbnReportTimer)
36
hgs
parents: 35
diff changeset
   546
    {
30
hgs
parents:
diff changeset
   547
        mTbnReportTimer->stop();
36
hgs
parents: 35
diff changeset
   548
    }
30
hgs
parents:
diff changeset
   549
34
hgs
parents: 30
diff changeset
   550
    if(mThumbnailFetcher)
36
hgs
parents: 35
diff changeset
   551
    {
34
hgs
parents: 30
diff changeset
   552
        mThumbnailFetcher->cancelFetches();
36
hgs
parents: 35
diff changeset
   553
    }
34
hgs
parents: 30
diff changeset
   554
    
30
hgs
parents:
diff changeset
   555
    // Clear data.
hgs
parents:
diff changeset
   556
    mReadyThumbnailMediaIds.clear();
hgs
parents:
diff changeset
   557
    mThumbnailData.clear();
35
hgs
parents: 34
diff changeset
   558
    mDefaultThumbnails.clear();
30
hgs
parents:
diff changeset
   559
}
hgs
parents:
diff changeset
   560
hgs
parents:
diff changeset
   561
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   562
// VideoThumbnailDataPrivate::startBackgroundFetching()
hgs
parents:
diff changeset
   563
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   564
//
34
hgs
parents: 30
diff changeset
   565
void VideoThumbnailDataPrivate::startBackgroundFetching(VideoSortFilterProxyModel *model, int fetchIndex)
30
hgs
parents:
diff changeset
   566
{
36
hgs
parents: 35
diff changeset
   567
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   568
    if(!mBackgroundFetchingEnabled || !mThumbnailFetcher)
36
hgs
parents: 35
diff changeset
   569
    {
30
hgs
parents:
diff changeset
   570
        return;
36
hgs
parents: 35
diff changeset
   571
    }
34
hgs
parents: 30
diff changeset
   572
    
hgs
parents: 30
diff changeset
   573
    mThumbnailFetcher->cancelFetches();
hgs
parents: 30
diff changeset
   574
    
hgs
parents: 30
diff changeset
   575
    // If model is null, we continue using the current one. 
hgs
parents: 30
diff changeset
   576
    if(model)
36
hgs
parents: 35
diff changeset
   577
    {
34
hgs
parents: 30
diff changeset
   578
        mCurrentModel = model;
36
hgs
parents: 35
diff changeset
   579
    }
34
hgs
parents: 30
diff changeset
   580
    
30
hgs
parents:
diff changeset
   581
    mCurrentFetchIndex = fetchIndex;
hgs
parents:
diff changeset
   582
    mCurrentBackgroundFetchCount = 0;
hgs
parents:
diff changeset
   583
    doBackgroundFetching();
hgs
parents:
diff changeset
   584
}
hgs
parents:
diff changeset
   585
hgs
parents:
diff changeset
   586
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   587
// VideoThumbnailDataPrivate::continueBackgroundFetch()
hgs
parents:
diff changeset
   588
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   589
//
hgs
parents:
diff changeset
   590
void VideoThumbnailDataPrivate::continueBackgroundFetch()
hgs
parents:
diff changeset
   591
{
36
hgs
parents: 35
diff changeset
   592
	FUNC_LOG;
30
hgs
parents:
diff changeset
   593
    if(!mBackgroundFetchingEnabled)
36
hgs
parents: 35
diff changeset
   594
    {
30
hgs
parents:
diff changeset
   595
        return;
36
hgs
parents: 35
diff changeset
   596
    }
30
hgs
parents:
diff changeset
   597
hgs
parents:
diff changeset
   598
    if(mBgFetchTimer)
hgs
parents:
diff changeset
   599
    {
hgs
parents:
diff changeset
   600
        mBgFetchTimer->stop();
hgs
parents:
diff changeset
   601
        mBgFetchTimer->setSingleShot(true);
hgs
parents:
diff changeset
   602
        mBgFetchTimer->start(THUMBNAIL_BACKGROUND_TIMEOUT);
hgs
parents:
diff changeset
   603
    }
hgs
parents:
diff changeset
   604
}
hgs
parents:
diff changeset
   605
hgs
parents:
diff changeset
   606
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   607
// VideoThumbnailDataPrivate::aboutToQuitSlot()
hgs
parents:
diff changeset
   608
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   609
//
hgs
parents:
diff changeset
   610
void VideoThumbnailDataPrivate::aboutToQuitSlot()
hgs
parents:
diff changeset
   611
{
36
hgs
parents: 35
diff changeset
   612
	FUNC_LOG;
30
hgs
parents:
diff changeset
   613
    cleanup();
hgs
parents:
diff changeset
   614
}
hgs
parents:
diff changeset
   615
hgs
parents:
diff changeset
   616
// End of file