camerauis/cameraxui/cxengine/src/cxefilesavethreaddesktop.cpp
author hgs
Fri, 23 Jul 2010 11:35:41 +0300
changeset 45 24fd82631616
permissions -rw-r--r--
201029
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45
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:
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 "cxefilesavethreaddesktop.h"
hgs
parents:
diff changeset
    20
#include "cxeimagedataitem.h"  // item
hgs
parents:
diff changeset
    21
#include "cxutils.h" // debug
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
/*!
hgs
parents:
diff changeset
    24
    \class CxeFileSaveThreadDesktop
hgs
parents:
diff changeset
    25
    \brief Still image saving thread    
hgs
parents:
diff changeset
    26
*/
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// ======== MEMBER FUNCTIONS ========
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
CxeFileSaveThreadDesktop::CxeFileSaveThreadDesktop(QObject *parent)
hgs
parents:
diff changeset
    32
    : CxeFileSaveThread(parent), mExitThread(false), mExit(false)
hgs
parents:
diff changeset
    33
{
hgs
parents:
diff changeset
    34
    start(IdlePriority);
hgs
parents:
diff changeset
    35
}
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
CxeFileSaveThreadDesktop::~CxeFileSaveThreadDesktop()
hgs
parents:
diff changeset
    38
{
hgs
parents:
diff changeset
    39
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
    40
    mMutex.lock();
hgs
parents:
diff changeset
    41
    mExitThread = true;
hgs
parents:
diff changeset
    42
    mDataToSave.wakeOne();
hgs
parents:
diff changeset
    43
    mMutex.unlock();
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
    wait(); // until the thread has finished execution.
hgs
parents:
diff changeset
    46
    qDeleteAll(mDataList);  // Ensure destruction
hgs
parents:
diff changeset
    47
    mDataList.clear();
hgs
parents:
diff changeset
    48
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
    49
}
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
void CxeFileSaveThreadDesktop::save(CxeImageDataItem *data)
hgs
parents:
diff changeset
    52
{
hgs
parents:
diff changeset
    53
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
    // Ensure safe data adding. 
hgs
parents:
diff changeset
    56
    // Saving thread will wait if needed, in read method, until mutex is unlocked
hgs
parents:
diff changeset
    57
    mMutex.lock();
hgs
parents:
diff changeset
    58
    mDataList.append(data);
hgs
parents:
diff changeset
    59
    // Wake up saving thread if it's sleeping
hgs
parents:
diff changeset
    60
    mDataToSave.wakeOne(); 
hgs
parents:
diff changeset
    61
    mMutex.unlock();
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
    64
}
hgs
parents:
diff changeset
    65
hgs
parents:
diff changeset
    66
void CxeFileSaveThreadDesktop::handleVideoSaved(CxeError::Id status, const QString &filename)
hgs
parents:
diff changeset
    67
{
hgs
parents:
diff changeset
    68
    Q_UNUSED(status);
hgs
parents:
diff changeset
    69
    Q_UNUSED(filename);
hgs
parents:
diff changeset
    70
}
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
void CxeFileSaveThreadDesktop::handleSnapshotReady(CxeError::Id status, const QImage &snapshot, const QString &filename)
hgs
parents:
diff changeset
    73
{
hgs
parents:
diff changeset
    74
    Q_UNUSED(status);
hgs
parents:
diff changeset
    75
    Q_UNUSED(snapshot);
hgs
parents:
diff changeset
    76
    Q_UNUSED(filename);
hgs
parents:
diff changeset
    77
}
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
void CxeFileSaveThreadDesktop::handleSnapshotReady(CxeError::Id status, const QImage &snapshot, int id)
hgs
parents:
diff changeset
    80
{
hgs
parents:
diff changeset
    81
    Q_UNUSED(status);
hgs
parents:
diff changeset
    82
    Q_UNUSED(snapshot);
hgs
parents:
diff changeset
    83
    Q_UNUSED(id);
hgs
parents:
diff changeset
    84
}
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
void CxeFileSaveThreadDesktop::read()
hgs
parents:
diff changeset
    87
{
hgs
parents:
diff changeset
    88
    mMutex.lock();
hgs
parents:
diff changeset
    89
    mCount = mDataList.count();
hgs
parents:
diff changeset
    90
    mExit = mExitThread;
hgs
parents:
diff changeset
    91
    mMutex.unlock();
hgs
parents:
diff changeset
    92
}
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
void CxeFileSaveThreadDesktop::run()
hgs
parents:
diff changeset
    95
{
hgs
parents:
diff changeset
    96
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
    97
    
hgs
parents:
diff changeset
    98
    CxeImageDataItem *item = NULL;
hgs
parents:
diff changeset
    99
    int i = 0;
hgs
parents:
diff changeset
   100
    // Check if there is data to save.
hgs
parents:
diff changeset
   101
    // There should not be any, because the thread is just contructed
hgs
parents:
diff changeset
   102
    read();
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
    while (!mExit || i < mCount) { // Complete save before exit
hgs
parents:
diff changeset
   105
        CX_DEBUG(("CxeFileSaveThreadDesktop: index %d", i));
hgs
parents:
diff changeset
   106
        // Wait data
hgs
parents:
diff changeset
   107
        if (!mExit && i >= mCount) {
hgs
parents:
diff changeset
   108
            // If there isn't any data to save, put the thread sleeping
hgs
parents:
diff changeset
   109
            CX_DEBUG(("CxeFileSaveThreadDesktop: set thread sleeping"));
hgs
parents:
diff changeset
   110
            mMutex.lock();
hgs
parents:
diff changeset
   111
            //! @todo: read datalist count here before clearing, because there is some machine cycles after previous read 
hgs
parents:
diff changeset
   112
            // Clear the datalist, since all items are saved
hgs
parents:
diff changeset
   113
            mDataList.clear();
hgs
parents:
diff changeset
   114
            i = 0;
hgs
parents:
diff changeset
   115
            mDataToSave.wait(&mMutex); // waiting "wakeOne"
hgs
parents:
diff changeset
   116
            mMutex.unlock();
hgs
parents:
diff changeset
   117
            CX_DEBUG(("CxeFileSaveThreadDesktop: woken up"));
hgs
parents:
diff changeset
   118
        }
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
        // There should be data now, because the thread is woken up
hgs
parents:
diff changeset
   121
        read();
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
        if (i < mCount) { 
hgs
parents:
diff changeset
   124
            item = mDataList[i];
hgs
parents:
diff changeset
   125
        } else {
hgs
parents:
diff changeset
   126
            CX_DEBUG(("CxeFileSaveThreadDesktop: ERROR - woke up without data"));
hgs
parents:
diff changeset
   127
            continue;
hgs
parents:
diff changeset
   128
        }
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
        // Check that item is not saved already
hgs
parents:
diff changeset
   131
        if (item && item->state() == CxeImageDataItem::SavePending) {
hgs
parents:
diff changeset
   132
            item->save();// Error ignored since it is emitted from CxeImageDataItemSymbian
hgs
parents:
diff changeset
   133
            // Delete item, since we own it
hgs
parents:
diff changeset
   134
            delete item; 
hgs
parents:
diff changeset
   135
            item = NULL;
hgs
parents:
diff changeset
   136
        }
hgs
parents:
diff changeset
   137
hgs
parents:
diff changeset
   138
        // Saving takes some seconds, there might be new data available.
hgs
parents:
diff changeset
   139
        read();
hgs
parents:
diff changeset
   140
        ++i;
hgs
parents:
diff changeset
   141
    }
hgs
parents:
diff changeset
   142
  
hgs
parents:
diff changeset
   143
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   144
}