videocollection/videocollectionwrapper/src/videothumbnaildata_p.cpp
author hgs
Fri, 30 Apr 2010 09:52:11 +0300
changeset 37 4eb2df7f7cbe
parent 36 8aed59de29f9
child 38 ff53afa8ad05
permissions -rw-r--r--
201017
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
37
hgs
parents: 36
diff changeset
    18
// Version : %version: 21 %
36
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;
37
hgs
parents: 36
diff changeset
    76
	initialize();
30
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
    }
37
hgs
parents: 36
diff changeset
   119
30
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
            }
37
hgs
parents: 36
diff changeset
   168
		disconnect(mThumbnailFetcher, SIGNAL(thumbnailReady(QPixmap , const TMPXItemId &, int )),
hgs
parents: 36
diff changeset
   169
                    this, SLOT(thumbnailReadySlot(QPixmap , const TMPXItemId &, int )));
34
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;
37
hgs
parents: 36
diff changeset
   191
        if(!connect(mThumbnailFetcher, SIGNAL(thumbnailReady( QPixmap , const TMPXItemId &, int )),
hgs
parents: 36
diff changeset
   192
                    this, SLOT(thumbnailReadySlot( QPixmap , const TMPXItemId &, int))) ||
34
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
    
37
hgs
parents: 36
diff changeset
   256
	// Start the fetches and cancel previous ones.
hgs
parents: 36
diff changeset
   257
    mThumbnailFetcher->continueFetching(true);
34
hgs
parents: 30
diff changeset
   258
    
hgs
parents: 30
diff changeset
   259
    return started;
30
hgs
parents:
diff changeset
   260
}
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   263
// VideoThumbnailDataPrivate::startFetchingThumbnail()
hgs
parents:
diff changeset
   264
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   265
//
hgs
parents:
diff changeset
   266
int VideoThumbnailDataPrivate::startFetchingThumbnail(TMPXItemId mediaId, int priority)
hgs
parents:
diff changeset
   267
{
34
hgs
parents: 30
diff changeset
   268
    if(!mCurrentModel || !mThumbnailFetcher)
30
hgs
parents:
diff changeset
   269
    {
hgs
parents:
diff changeset
   270
        return -1;
hgs
parents:
diff changeset
   271
    }
hgs
parents:
diff changeset
   272
hgs
parents:
diff changeset
   273
    // Check that it's not fetched before.
hgs
parents:
diff changeset
   274
    if(mThumbnailData.contains(mediaId))
hgs
parents:
diff changeset
   275
    {
hgs
parents:
diff changeset
   276
        return 0;
hgs
parents:
diff changeset
   277
    }
hgs
parents:
diff changeset
   278
34
hgs
parents: 30
diff changeset
   279
    QString fileName = mCurrentModel->getMediaFilePathForId(mediaId);
hgs
parents: 30
diff changeset
   280
    
hgs
parents: 30
diff changeset
   281
    // Thumbnail fetcher signals into thumbnailReadySlot when thumbnail ready
30
hgs
parents:
diff changeset
   282
    if(fileName.length() > 0)
hgs
parents:
diff changeset
   283
    {
37
hgs
parents: 36
diff changeset
   284
        mThumbnailFetcher->addFetch(fileName, mediaId, priority);
30
hgs
parents:
diff changeset
   285
    }
hgs
parents:
diff changeset
   286
34
hgs
parents: 30
diff changeset
   287
    return 0;
30
hgs
parents:
diff changeset
   288
}
hgs
parents:
diff changeset
   289
hgs
parents:
diff changeset
   290
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   291
// VideoThumbnailDataPrivate::doBackgroundFetching()
hgs
parents:
diff changeset
   292
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   293
//
hgs
parents:
diff changeset
   294
void VideoThumbnailDataPrivate::doBackgroundFetching()
hgs
parents:
diff changeset
   295
{
36
hgs
parents: 35
diff changeset
   296
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   297
    if(!mCurrentModel || !mThumbnailFetcher)
30
hgs
parents:
diff changeset
   298
    {
hgs
parents:
diff changeset
   299
        return;
hgs
parents:
diff changeset
   300
    }
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
    if(mCurrentBackgroundFetchCount >= THUMBNAIL_CACHE_SIZE)
hgs
parents:
diff changeset
   303
    {
hgs
parents:
diff changeset
   304
        return;
hgs
parents:
diff changeset
   305
    }
hgs
parents:
diff changeset
   306
    
34
hgs
parents: 30
diff changeset
   307
    int maxIndex = mCurrentModel->rowCount();
30
hgs
parents:
diff changeset
   308
    if(maxIndex == 0)
hgs
parents:
diff changeset
   309
    {
hgs
parents:
diff changeset
   310
        return;
hgs
parents:
diff changeset
   311
    }
hgs
parents:
diff changeset
   312
hgs
parents:
diff changeset
   313
    // Delta to UI index where fetch has been done already.  
hgs
parents:
diff changeset
   314
    int currentDelta = mCurrentBackgroundFetchCount/2;
hgs
parents:
diff changeset
   315
    
hgs
parents:
diff changeset
   316
    // How many will be fetched.  
hgs
parents:
diff changeset
   317
    const int fetchAmount = THUMBNAIL_BACKGROUND_FETCH_AMOUNT/2;
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
    QList<QModelIndex> indexes;
hgs
parents:
diff changeset
   320
34
hgs
parents: 30
diff changeset
   321
    // Items after the current fetch index.
hgs
parents: 30
diff changeset
   322
    int startIndex = mCurrentFetchIndex+currentDelta;
hgs
parents: 30
diff changeset
   323
    int endIndex = mCurrentFetchIndex+currentDelta+fetchAmount;
30
hgs
parents:
diff changeset
   324
    getModelIndexes(indexes, startIndex, endIndex);
hgs
parents:
diff changeset
   325
34
hgs
parents: 30
diff changeset
   326
    // Items before the current fetch index.
hgs
parents: 30
diff changeset
   327
    startIndex = mCurrentFetchIndex-currentDelta-fetchAmount;
hgs
parents: 30
diff changeset
   328
    endIndex = mCurrentFetchIndex-currentDelta;
30
hgs
parents:
diff changeset
   329
    getModelIndexes(indexes, startIndex, endIndex);
34
hgs
parents: 30
diff changeset
   330
    
30
hgs
parents:
diff changeset
   331
    mCurrentBackgroundFetchCount += THUMBNAIL_BACKGROUND_FETCH_AMOUNT;
hgs
parents:
diff changeset
   332
hgs
parents:
diff changeset
   333
    int fetchesStarted = startFetchingThumbnails(indexes, BACKGROUND_FETCH_PRIORITY);
hgs
parents:
diff changeset
   334
    
hgs
parents:
diff changeset
   335
    // No thumbnails to fetch, start again.
hgs
parents:
diff changeset
   336
    if(fetchesStarted == 0)
hgs
parents:
diff changeset
   337
    {
hgs
parents:
diff changeset
   338
        continueBackgroundFetch();
hgs
parents:
diff changeset
   339
    }
hgs
parents:
diff changeset
   340
}
hgs
parents:
diff changeset
   341
hgs
parents:
diff changeset
   342
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   343
// VideoThumbnailDataPrivate::getModelIndexes()
hgs
parents:
diff changeset
   344
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   345
//
hgs
parents:
diff changeset
   346
void VideoThumbnailDataPrivate::getModelIndexes(QList<QModelIndex> &indexes, int startIndex, int endIndex)
hgs
parents:
diff changeset
   347
{
36
hgs
parents: 35
diff changeset
   348
	FUNC_LOG;
30
hgs
parents:
diff changeset
   349
    QModelIndex index;
hgs
parents:
diff changeset
   350
    for(int i = startIndex; i < endIndex; i++)
hgs
parents:
diff changeset
   351
    {
hgs
parents:
diff changeset
   352
        if(i >= 0)
hgs
parents:
diff changeset
   353
        {
34
hgs
parents: 30
diff changeset
   354
            index = mCurrentModel->index(i, 0);
30
hgs
parents:
diff changeset
   355
            if(index.isValid())
hgs
parents:
diff changeset
   356
            {
hgs
parents:
diff changeset
   357
                indexes.append(index);
hgs
parents:
diff changeset
   358
            }
hgs
parents:
diff changeset
   359
        }
hgs
parents:
diff changeset
   360
    }
hgs
parents:
diff changeset
   361
}
hgs
parents:
diff changeset
   362
hgs
parents:
diff changeset
   363
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   364
// VideoThumbnailDataPrivate::thumbnailReadySlot()
hgs
parents:
diff changeset
   365
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   366
//
37
hgs
parents: 36
diff changeset
   367
void VideoThumbnailDataPrivate::thumbnailReadySlot(QPixmap tnData, const TMPXItemId &mediaId, int error)
30
hgs
parents:
diff changeset
   368
{
hgs
parents:
diff changeset
   369
    if(!error && !tnData.isNull())
hgs
parents:
diff changeset
   370
    {
hgs
parents:
diff changeset
   371
        mThumbnailData.insert(mediaId, new QIcon(tnData));
hgs
parents:
diff changeset
   372
        
hgs
parents:
diff changeset
   373
        // Gather list of media ids and emit thumbnailReady signals in larger set
hgs
parents:
diff changeset
   374
        // when timer goes off.
hgs
parents:
diff changeset
   375
        if(mTbnReportTimer && !mTbnReportTimer->isActive())
hgs
parents:
diff changeset
   376
        {
hgs
parents:
diff changeset
   377
            mTbnReportTimer->setSingleShot(true);
hgs
parents:
diff changeset
   378
            mTbnReportTimer->start(THUMBNAIL_READY_SIGNAL_TIMEOUT);
hgs
parents:
diff changeset
   379
        }
hgs
parents:
diff changeset
   380
hgs
parents:
diff changeset
   381
        // Save the media id for the signal.  
hgs
parents:
diff changeset
   382
        mReadyThumbnailMediaIds.append(mediaId);
hgs
parents:
diff changeset
   383
    }
hgs
parents:
diff changeset
   384
}
hgs
parents:
diff changeset
   385
hgs
parents:
diff changeset
   386
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   387
// VideoThumbnailDataPrivate::reportThumbnailsReadySlot()
hgs
parents:
diff changeset
   388
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   389
//
hgs
parents:
diff changeset
   390
void VideoThumbnailDataPrivate::reportThumbnailsReadySlot()
hgs
parents:
diff changeset
   391
{
36
hgs
parents: 35
diff changeset
   392
	FUNC_LOG;
30
hgs
parents:
diff changeset
   393
    emit thumbnailsFetched(mReadyThumbnailMediaIds);
hgs
parents:
diff changeset
   394
    mReadyThumbnailMediaIds.clear();
hgs
parents:
diff changeset
   395
}
hgs
parents:
diff changeset
   396
hgs
parents:
diff changeset
   397
// -----------------------------------------------------------------------------
34
hgs
parents: 30
diff changeset
   398
// VideoThumbnailDataPrivate::allThumbnailsFetchedSlot()
30
hgs
parents:
diff changeset
   399
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   400
//
34
hgs
parents: 30
diff changeset
   401
void VideoThumbnailDataPrivate::allThumbnailsFetchedSlot()
30
hgs
parents:
diff changeset
   402
{
36
hgs
parents: 35
diff changeset
   403
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   404
    continueBackgroundFetch();
30
hgs
parents:
diff changeset
   405
}
hgs
parents:
diff changeset
   406
hgs
parents:
diff changeset
   407
// -----------------------------------------------------------------------------
34
hgs
parents: 30
diff changeset
   408
// VideoThumbnailDataPrivate::modelChangedSlot()
30
hgs
parents:
diff changeset
   409
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   410
//
34
hgs
parents: 30
diff changeset
   411
void VideoThumbnailDataPrivate::modelChangedSlot()
30
hgs
parents:
diff changeset
   412
{
36
hgs
parents: 35
diff changeset
   413
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   414
    startBackgroundFetching(mCurrentModel, mCurrentFetchIndex);
30
hgs
parents:
diff changeset
   415
}
hgs
parents:
diff changeset
   416
hgs
parents:
diff changeset
   417
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   418
// VideoThumbnailDataPrivate::defaultThumbnail()
hgs
parents:
diff changeset
   419
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   420
//
hgs
parents:
diff changeset
   421
const QIcon* VideoThumbnailDataPrivate::defaultThumbnail(TMPXItemId mediaId)
hgs
parents:
diff changeset
   422
{
35
hgs
parents: 34
diff changeset
   423
    const TMPXItemId defaultIdVideo(KMaxTUint32-1, KVcxMvcMediaTypeVideo);
hgs
parents: 34
diff changeset
   424
    const TMPXItemId defaultIdAlbum(KMaxTUint32-1, KVcxMvcMediaTypeAlbum);
hgs
parents: 34
diff changeset
   425
    const TMPXItemId defaultIdDownloads(KVcxMvcCategoryIdDownloads, KVcxMvcMediaTypeCategory);
hgs
parents: 34
diff changeset
   426
    const TMPXItemId defaultIdCaptured(KVcxMvcCategoryIdCaptured, KVcxMvcMediaTypeCategory);
hgs
parents: 34
diff changeset
   427
hgs
parents: 34
diff changeset
   428
    // Default thumbnail for video
34
hgs
parents: 30
diff changeset
   429
    if(mediaId.iId2 == KVcxMvcMediaTypeVideo) 
30
hgs
parents:
diff changeset
   430
    {
35
hgs
parents: 34
diff changeset
   431
        if(!mDefaultThumbnails.contains(defaultIdVideo))
hgs
parents: 34
diff changeset
   432
        {
hgs
parents: 34
diff changeset
   433
            mDefaultThumbnails[defaultIdVideo] = HbIcon(":/icons/default_thumbnail_video.svg");
hgs
parents: 34
diff changeset
   434
        }
hgs
parents: 34
diff changeset
   435
        return &mDefaultThumbnails[defaultIdVideo].qicon();
30
hgs
parents:
diff changeset
   436
    }
hgs
parents:
diff changeset
   437
    else
hgs
parents:
diff changeset
   438
    {
35
hgs
parents: 34
diff changeset
   439
        // Default thumbnail for user defined album.
hgs
parents: 34
diff changeset
   440
        if(mediaId.iId2 == KVcxMvcMediaTypeAlbum)
hgs
parents: 34
diff changeset
   441
        {
hgs
parents: 34
diff changeset
   442
            if(!mDefaultThumbnails.contains(defaultIdAlbum))
hgs
parents: 34
diff changeset
   443
            {
36
hgs
parents: 35
diff changeset
   444
                mDefaultThumbnails[defaultIdAlbum] = HbIcon("qtg_large_video_collection");
35
hgs
parents: 34
diff changeset
   445
            }
hgs
parents: 34
diff changeset
   446
            return &mDefaultThumbnails[defaultIdAlbum].qicon();
hgs
parents: 34
diff changeset
   447
        }
hgs
parents: 34
diff changeset
   448
hgs
parents: 34
diff changeset
   449
        // Thumbnails for default collections.
hgs
parents: 34
diff changeset
   450
        switch(mediaId.iId1)
hgs
parents: 34
diff changeset
   451
        {
hgs
parents: 34
diff changeset
   452
            case KVcxMvcCategoryIdDownloads:
hgs
parents: 34
diff changeset
   453
            {
hgs
parents: 34
diff changeset
   454
                if(!mDefaultThumbnails.contains(defaultIdDownloads))
hgs
parents: 34
diff changeset
   455
                {
hgs
parents: 34
diff changeset
   456
                    mDefaultThumbnails[defaultIdDownloads] = HbIcon("qtg_large_video_download");
hgs
parents: 34
diff changeset
   457
                }
hgs
parents: 34
diff changeset
   458
                return &mDefaultThumbnails[defaultIdDownloads].qicon();
hgs
parents: 34
diff changeset
   459
            }
hgs
parents: 34
diff changeset
   460
            
hgs
parents: 34
diff changeset
   461
            case KVcxMvcCategoryIdCaptured:
hgs
parents: 34
diff changeset
   462
            {
hgs
parents: 34
diff changeset
   463
                if(!mDefaultThumbnails.contains(defaultIdCaptured))
hgs
parents: 34
diff changeset
   464
                {
hgs
parents: 34
diff changeset
   465
                    mDefaultThumbnails[defaultIdCaptured] = HbIcon("qtg_large_video_capture");
hgs
parents: 34
diff changeset
   466
                }
hgs
parents: 34
diff changeset
   467
                return &mDefaultThumbnails[defaultIdCaptured].qicon();
hgs
parents: 34
diff changeset
   468
            }
hgs
parents: 34
diff changeset
   469
hgs
parents: 34
diff changeset
   470
            default:
hgs
parents: 34
diff changeset
   471
            {
hgs
parents: 34
diff changeset
   472
                if(!mDefaultThumbnails.contains(defaultIdAlbum))
hgs
parents: 34
diff changeset
   473
                {
36
hgs
parents: 35
diff changeset
   474
                    mDefaultThumbnails[defaultIdAlbum] = HbIcon("qtg_large_video_collection");
35
hgs
parents: 34
diff changeset
   475
                }
hgs
parents: 34
diff changeset
   476
                return &mDefaultThumbnails[defaultIdAlbum].qicon();
hgs
parents: 34
diff changeset
   477
            }
hgs
parents: 34
diff changeset
   478
        }
30
hgs
parents:
diff changeset
   479
    }
hgs
parents:
diff changeset
   480
}
hgs
parents:
diff changeset
   481
hgs
parents:
diff changeset
   482
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   483
// VideoThumbnailDataPrivate::removeThumbnail()
hgs
parents:
diff changeset
   484
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   485
//
hgs
parents:
diff changeset
   486
bool VideoThumbnailDataPrivate::removeThumbnail(TMPXItemId mediaId)
hgs
parents:
diff changeset
   487
{
36
hgs
parents: 35
diff changeset
   488
	FUNC_LOG;
30
hgs
parents:
diff changeset
   489
    return mThumbnailData.remove(mediaId);
hgs
parents:
diff changeset
   490
}
hgs
parents:
diff changeset
   491
hgs
parents:
diff changeset
   492
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   493
// VideoThumbnailDataPrivate::enableBackgroundFetching()
hgs
parents:
diff changeset
   494
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   495
//
hgs
parents:
diff changeset
   496
void VideoThumbnailDataPrivate::enableBackgroundFetching(bool enable)
hgs
parents:
diff changeset
   497
{
36
hgs
parents: 35
diff changeset
   498
	FUNC_LOG;
hgs
parents: 35
diff changeset
   499
    INFO_1("VideoThumbnailDataPrivate::enableBackgroundFetching() enable: %d", enable);
30
hgs
parents:
diff changeset
   500
    mBackgroundFetchingEnabled = enable;
34
hgs
parents: 30
diff changeset
   501
    startBackgroundFetching(mCurrentModel, 0);
hgs
parents: 30
diff changeset
   502
}
hgs
parents: 30
diff changeset
   503
hgs
parents: 30
diff changeset
   504
// -----------------------------------------------------------------------------
hgs
parents: 30
diff changeset
   505
// VideoThumbnailDataPrivate::enableThumbnailCreation()
hgs
parents: 30
diff changeset
   506
// -----------------------------------------------------------------------------
hgs
parents: 30
diff changeset
   507
//
hgs
parents: 30
diff changeset
   508
void VideoThumbnailDataPrivate::enableThumbnailCreation(bool enable)
hgs
parents: 30
diff changeset
   509
{
36
hgs
parents: 35
diff changeset
   510
	FUNC_LOG;
hgs
parents: 35
diff changeset
   511
	INFO_1("VideoThumbnailDataPrivate::enableThumbnailCreation() enable: %d", enable);
34
hgs
parents: 30
diff changeset
   512
    if(mThumbnailFetcher)
36
hgs
parents: 35
diff changeset
   513
    {
34
hgs
parents: 30
diff changeset
   514
        mThumbnailFetcher->enableThumbnailCreation(enable);
36
hgs
parents: 35
diff changeset
   515
    }
30
hgs
parents:
diff changeset
   516
}
hgs
parents:
diff changeset
   517
hgs
parents:
diff changeset
   518
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   519
// VideoThumbnailDataPrivate::freeThumbnailData()
hgs
parents:
diff changeset
   520
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   521
//
hgs
parents:
diff changeset
   522
void VideoThumbnailDataPrivate::freeThumbnailData()
hgs
parents:
diff changeset
   523
{
36
hgs
parents: 35
diff changeset
   524
	FUNC_LOG;
30
hgs
parents:
diff changeset
   525
    // Stop timers.
37
hgs
parents: 36
diff changeset
   526
	if(mBgFetchTimer)
36
hgs
parents: 35
diff changeset
   527
    {
30
hgs
parents:
diff changeset
   528
        mBgFetchTimer->stop();
36
hgs
parents: 35
diff changeset
   529
    }
30
hgs
parents:
diff changeset
   530
    
hgs
parents:
diff changeset
   531
    if(mTbnReportTimer)
36
hgs
parents: 35
diff changeset
   532
    {
30
hgs
parents:
diff changeset
   533
        mTbnReportTimer->stop();
36
hgs
parents: 35
diff changeset
   534
    }
30
hgs
parents:
diff changeset
   535
34
hgs
parents: 30
diff changeset
   536
    if(mThumbnailFetcher)
36
hgs
parents: 35
diff changeset
   537
    {
34
hgs
parents: 30
diff changeset
   538
        mThumbnailFetcher->cancelFetches();
36
hgs
parents: 35
diff changeset
   539
    }
34
hgs
parents: 30
diff changeset
   540
    
30
hgs
parents:
diff changeset
   541
    // Clear data.
hgs
parents:
diff changeset
   542
    mReadyThumbnailMediaIds.clear();
hgs
parents:
diff changeset
   543
    mThumbnailData.clear();
35
hgs
parents: 34
diff changeset
   544
    mDefaultThumbnails.clear();
30
hgs
parents:
diff changeset
   545
}
hgs
parents:
diff changeset
   546
hgs
parents:
diff changeset
   547
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   548
// VideoThumbnailDataPrivate::startBackgroundFetching()
hgs
parents:
diff changeset
   549
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   550
//
34
hgs
parents: 30
diff changeset
   551
void VideoThumbnailDataPrivate::startBackgroundFetching(VideoSortFilterProxyModel *model, int fetchIndex)
30
hgs
parents:
diff changeset
   552
{
36
hgs
parents: 35
diff changeset
   553
	FUNC_LOG;
37
hgs
parents: 36
diff changeset
   554
hgs
parents: 36
diff changeset
   555
    // If model is null, we continue using the current one. Model and index are kept up to date even
hgs
parents: 36
diff changeset
   556
	// fetching is not enabled.
34
hgs
parents: 30
diff changeset
   557
    if(model)
36
hgs
parents: 35
diff changeset
   558
    {
34
hgs
parents: 30
diff changeset
   559
        mCurrentModel = model;
36
hgs
parents: 35
diff changeset
   560
    }
34
hgs
parents: 30
diff changeset
   561
    
30
hgs
parents:
diff changeset
   562
    mCurrentFetchIndex = fetchIndex;
hgs
parents:
diff changeset
   563
    mCurrentBackgroundFetchCount = 0;
37
hgs
parents: 36
diff changeset
   564
	
hgs
parents: 36
diff changeset
   565
	if(!mBackgroundFetchingEnabled || !mThumbnailFetcher)
hgs
parents: 36
diff changeset
   566
    {
hgs
parents: 36
diff changeset
   567
        INFO("VideoThumbnailDataPrivate::startBackgroundFetching() fetching is disabled.");
hgs
parents: 36
diff changeset
   568
        return;
hgs
parents: 36
diff changeset
   569
    }
hgs
parents: 36
diff changeset
   570
    
30
hgs
parents:
diff changeset
   571
    doBackgroundFetching();
hgs
parents:
diff changeset
   572
}
hgs
parents:
diff changeset
   573
hgs
parents:
diff changeset
   574
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   575
// VideoThumbnailDataPrivate::continueBackgroundFetch()
hgs
parents:
diff changeset
   576
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   577
//
hgs
parents:
diff changeset
   578
void VideoThumbnailDataPrivate::continueBackgroundFetch()
hgs
parents:
diff changeset
   579
{
36
hgs
parents: 35
diff changeset
   580
	FUNC_LOG;
30
hgs
parents:
diff changeset
   581
    if(!mBackgroundFetchingEnabled)
36
hgs
parents: 35
diff changeset
   582
    {
37
hgs
parents: 36
diff changeset
   583
        INFO("VideoThumbnailDataPrivate::continueBackgroundFetch() fetching is disabled.")
30
hgs
parents:
diff changeset
   584
        return;
36
hgs
parents: 35
diff changeset
   585
    }
30
hgs
parents:
diff changeset
   586
hgs
parents:
diff changeset
   587
    if(mBgFetchTimer)
hgs
parents:
diff changeset
   588
    {
hgs
parents:
diff changeset
   589
        mBgFetchTimer->stop();
hgs
parents:
diff changeset
   590
        mBgFetchTimer->setSingleShot(true);
hgs
parents:
diff changeset
   591
        mBgFetchTimer->start(THUMBNAIL_BACKGROUND_TIMEOUT);
hgs
parents:
diff changeset
   592
    }
hgs
parents:
diff changeset
   593
}
hgs
parents:
diff changeset
   594
hgs
parents:
diff changeset
   595
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   596
// VideoThumbnailDataPrivate::aboutToQuitSlot()
hgs
parents:
diff changeset
   597
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   598
//
hgs
parents:
diff changeset
   599
void VideoThumbnailDataPrivate::aboutToQuitSlot()
hgs
parents:
diff changeset
   600
{
36
hgs
parents: 35
diff changeset
   601
	FUNC_LOG;
30
hgs
parents:
diff changeset
   602
    cleanup();
hgs
parents:
diff changeset
   603
}
hgs
parents:
diff changeset
   604
hgs
parents:
diff changeset
   605
// End of file