camerauis/cameraxui/cxengine/src/cxevideocapturecontroldesktop.cpp
author hgs
Fri, 03 Sep 2010 11:00:58 +0300
changeset 55 0da2a5b56583
parent 46 c826656d6714
permissions -rw-r--r--
201035_1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
46
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
#include <QTime>
hgs
parents:
diff changeset
    18
#include <QPixmap>
hgs
parents:
diff changeset
    19
hgs
parents:
diff changeset
    20
#include "cxevideocapturecontroldesktop.h"
hgs
parents:
diff changeset
    21
#include "cxeviewfindercontrol.h"
hgs
parents:
diff changeset
    22
#include "cxutils.h"
hgs
parents:
diff changeset
    23
#include "cxestate.h"
hgs
parents:
diff changeset
    24
#include "cxenamespace.h"
hgs
parents:
diff changeset
    25
#include "cxefilenamegeneratordesktop.h"
hgs
parents:
diff changeset
    26
#include "cxecameradevicedesktop.h"
hgs
parents:
diff changeset
    27
#include "cxeexception.h"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
namespace
hgs
parents:
diff changeset
    30
{
hgs
parents:
diff changeset
    31
    // Unit is milliseconds
hgs
parents:
diff changeset
    32
    static const int CXENGINE_ELAPSED_TIME_TIMEOUT = 1000; // 1 second
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
    33
    static const int VIEWFINDER_START_TIMEOUT      =  500; // 0.5 second
46
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
    // Unit is seconds
hgs
parents:
diff changeset
    36
    static const int CXENGINE_MAXIMUM_VIDEO_TIME = 90*60; // 90 minutes
hgs
parents:
diff changeset
    37
}
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
/*!
hgs
parents:
diff changeset
    41
* Constructor
hgs
parents:
diff changeset
    42
*/
hgs
parents:
diff changeset
    43
CxeVideoCaptureControlDesktop::CxeVideoCaptureControlDesktop(CxeCameraDeviceDesktop &cameraDevice,
hgs
parents:
diff changeset
    44
                                                             CxeViewfinderControl &viewfinderControl,
hgs
parents:
diff changeset
    45
                                                             CxeCameraDeviceControl &cameraDeviceControl,
hgs
parents:
diff changeset
    46
                                                             CxeFilenameGenerator &nameGenerator,
hgs
parents:
diff changeset
    47
                                                             CxeQualityPresets &qualityPresets) :
hgs
parents:
diff changeset
    48
    mCameraDevice(cameraDevice),
hgs
parents:
diff changeset
    49
    mCameraDeviceControl(cameraDeviceControl),
hgs
parents:
diff changeset
    50
    mViewfinderControl(viewfinderControl),
hgs
parents:
diff changeset
    51
    mFilenameGenerator(nameGenerator),
hgs
parents:
diff changeset
    52
    mQualityPresets(qualityPresets),
hgs
parents:
diff changeset
    53
    mSnapshot(),
hgs
parents:
diff changeset
    54
    mNewFileName(""),
hgs
parents:
diff changeset
    55
    mCurrentFilename(""),
hgs
parents:
diff changeset
    56
    mState(Idle),
hgs
parents:
diff changeset
    57
    mElapsedTime(0)
hgs
parents:
diff changeset
    58
{
hgs
parents:
diff changeset
    59
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
    60
hgs
parents:
diff changeset
    61
    qRegisterMetaType<CxeVideoCaptureControl::State> ();
hgs
parents:
diff changeset
    62
    initializeStates();
hgs
parents:
diff changeset
    63
    setupElapseTimer();
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
    64
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
    65
    mViewFinderStartTimer.setSingleShot(true);
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
    66
    mViewFinderStartTimer.setInterval(VIEWFINDER_START_TIMEOUT);
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
    67
    connect(&mViewFinderStartTimer, SIGNAL(timeout()), this, SLOT(startViewfinder()));
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
    68
46
hgs
parents:
diff changeset
    69
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
    70
}
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
/*!
hgs
parents:
diff changeset
    74
* Destructor
hgs
parents:
diff changeset
    75
*/
hgs
parents:
diff changeset
    76
CxeVideoCaptureControlDesktop::~CxeVideoCaptureControlDesktop()
hgs
parents:
diff changeset
    77
{
hgs
parents:
diff changeset
    78
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
    79
hgs
parents:
diff changeset
    80
    releaseResources();
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
    83
}
hgs
parents:
diff changeset
    84
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
/*!
hgs
parents:
diff changeset
    87
* Initializes resources for video recording.
hgs
parents:
diff changeset
    88
*/
hgs
parents:
diff changeset
    89
void CxeVideoCaptureControlDesktop::init()
hgs
parents:
diff changeset
    90
{
hgs
parents:
diff changeset
    91
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
    92
hgs
parents:
diff changeset
    93
    if (state() == Idle) {
hgs
parents:
diff changeset
    94
        // start initializing resources for video capture
hgs
parents:
diff changeset
    95
        initVideoRecorder();
hgs
parents:
diff changeset
    96
    } else if (state() == Initialized) {
hgs
parents:
diff changeset
    97
        // video recorder already initalized. Continue to prepare video reocording.
hgs
parents:
diff changeset
    98
        open();
hgs
parents:
diff changeset
    99
    }
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   102
}
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
/*!
hgs
parents:
diff changeset
   106
* Releases all resources
hgs
parents:
diff changeset
   107
*/
hgs
parents:
diff changeset
   108
void CxeVideoCaptureControlDesktop::deinit()
hgs
parents:
diff changeset
   109
{
hgs
parents:
diff changeset
   110
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
    if (state() == Idle) {
hgs
parents:
diff changeset
   113
        // nothing to do
hgs
parents:
diff changeset
   114
        CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   115
        return;
hgs
parents:
diff changeset
   116
    }
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   117
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   118
    mViewFinderStartTimer.stop();
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   119
    mViewfinderControl.stop();
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   120
46
hgs
parents:
diff changeset
   121
    // stop video-recording in-case if its ongoing.
hgs
parents:
diff changeset
   122
    stop();
hgs
parents:
diff changeset
   123
hgs
parents:
diff changeset
   124
    setState(Idle);
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   127
}
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
/*!
hgs
parents:
diff changeset
   131
* Intializes VideoRecorder for recording.
hgs
parents:
diff changeset
   132
*/
hgs
parents:
diff changeset
   133
void CxeVideoCaptureControlDesktop::initVideoRecorder()
hgs
parents:
diff changeset
   134
{
hgs
parents:
diff changeset
   135
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
    if (state() != Idle) {
hgs
parents:
diff changeset
   138
        // not valid state to start "open" operation
hgs
parents:
diff changeset
   139
        CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   140
        return;
hgs
parents:
diff changeset
   141
    }
hgs
parents:
diff changeset
   142
hgs
parents:
diff changeset
   143
    // update current video quality details from icm
hgs
parents:
diff changeset
   144
    CxeError::Id err = CxeError::None;
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
    setState(Initialized);
hgs
parents:
diff changeset
   147
    open();
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    if (err) {
hgs
parents:
diff changeset
   150
        // In case of error
hgs
parents:
diff changeset
   151
        emit videoPrepareComplete(err);
hgs
parents:
diff changeset
   152
        deinit();
hgs
parents:
diff changeset
   153
    }
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   156
}
hgs
parents:
diff changeset
   157
hgs
parents:
diff changeset
   158
/*!
hgs
parents:
diff changeset
   159
* Setup the timer for elapsed time
hgs
parents:
diff changeset
   160
*/
hgs
parents:
diff changeset
   161
void CxeVideoCaptureControlDesktop::setupElapseTimer()
hgs
parents:
diff changeset
   162
{
hgs
parents:
diff changeset
   163
    mRecordElapseTimer.setSingleShot(false);
hgs
parents:
diff changeset
   164
    mRecordElapseTimer.setInterval(CXENGINE_ELAPSED_TIME_TIMEOUT);
hgs
parents:
diff changeset
   165
    connect(&mRecordElapseTimer, SIGNAL(timeout()), this, SLOT(handleElapseTimeout()));
hgs
parents:
diff changeset
   166
}
hgs
parents:
diff changeset
   167
hgs
parents:
diff changeset
   168
hgs
parents:
diff changeset
   169
/*!
hgs
parents:
diff changeset
   170
* Opens file for video recording.
hgs
parents:
diff changeset
   171
*/
hgs
parents:
diff changeset
   172
void CxeVideoCaptureControlDesktop::open()
hgs
parents:
diff changeset
   173
{
hgs
parents:
diff changeset
   174
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
    if (state() != Initialized) {
hgs
parents:
diff changeset
   177
        // not valid state to start "open" operation
hgs
parents:
diff changeset
   178
        CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   179
        return;
hgs
parents:
diff changeset
   180
    }
hgs
parents:
diff changeset
   181
hgs
parents:
diff changeset
   182
    CxeError::Id err = CxeError::None;
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
    // generate video file name, if necessary
hgs
parents:
diff changeset
   185
    if (mNewFileName.isEmpty()) {
hgs
parents:
diff changeset
   186
        QString fileExt = ".mp4";
hgs
parents:
diff changeset
   187
hgs
parents:
diff changeset
   188
        // Generate new filename and open the file for writing video data
hgs
parents:
diff changeset
   189
        err = mFilenameGenerator.generateFilename(mNewFileName, fileExt);
hgs
parents:
diff changeset
   190
        if (err == CxeError::None) {
hgs
parents:
diff changeset
   191
            mCurrentFilename = mNewFileName;
hgs
parents:
diff changeset
   192
        } else {
hgs
parents:
diff changeset
   193
            // file name is not valid, re-initialize the value of current string
hgs
parents:
diff changeset
   194
            // back to empty string
hgs
parents:
diff changeset
   195
            mCurrentFilename = QString("");
hgs
parents:
diff changeset
   196
        }
hgs
parents:
diff changeset
   197
    }
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
    if (err) {
hgs
parents:
diff changeset
   200
        // error occured.
hgs
parents:
diff changeset
   201
        deinit();
hgs
parents:
diff changeset
   202
        emit videoPrepareComplete(err);
hgs
parents:
diff changeset
   203
    } else {
hgs
parents:
diff changeset
   204
        setState(Preparing);
hgs
parents:
diff changeset
   205
        prepare();
hgs
parents:
diff changeset
   206
    }
hgs
parents:
diff changeset
   207
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   208
}
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
hgs
parents:
diff changeset
   212
/*!
hgs
parents:
diff changeset
   213
* Prepare Video Recorder with necessary settings for video capture.
hgs
parents:
diff changeset
   214
*/
hgs
parents:
diff changeset
   215
void CxeVideoCaptureControlDesktop::prepare()
hgs
parents:
diff changeset
   216
{
hgs
parents:
diff changeset
   217
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   218
hgs
parents:
diff changeset
   219
    if (state() != Preparing) {
hgs
parents:
diff changeset
   220
        // not valid state to continue prepare.
hgs
parents:
diff changeset
   221
        CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   222
        return;
hgs
parents:
diff changeset
   223
    }
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
    int err = CxeError::None;
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
    if (!err) {
hgs
parents:
diff changeset
   228
        // prepare snapshot
hgs
parents:
diff changeset
   229
        err = prepareVideoSnapshot();
hgs
parents:
diff changeset
   230
    }
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
    if (!err) {
hgs
parents:
diff changeset
   233
        // prepare zoom only when there are no errors during prepare.
hgs
parents:
diff changeset
   234
        emit prepareZoomForVideo();
hgs
parents:
diff changeset
   235
    }
hgs
parents:
diff changeset
   236
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   237
    // Start viewfinder with delay.
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   238
    mViewFinderStartTimer.start();
46
hgs
parents:
diff changeset
   239
    setState(Ready);
hgs
parents:
diff changeset
   240
hgs
parents:
diff changeset
   241
    // emit video prepare status
hgs
parents:
diff changeset
   242
    emit videoPrepareComplete(CxeError::None);
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
hgs
parents:
diff changeset
   245
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   246
}
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
/*!
hgs
parents:
diff changeset
   249
 Prepare snapshot
hgs
parents:
diff changeset
   250
@Return symbian error code.
hgs
parents:
diff changeset
   251
 */
hgs
parents:
diff changeset
   252
int CxeVideoCaptureControlDesktop::prepareVideoSnapshot()
hgs
parents:
diff changeset
   253
{
hgs
parents:
diff changeset
   254
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
    int err = 0;
hgs
parents:
diff changeset
   258
    // Whether or not we have postcapture on, we need the snapshot for Thumbnail Manager.
hgs
parents:
diff changeset
   259
hgs
parents:
diff changeset
   260
    mSnapshot = mCameraDevice.currentSnaphot();
hgs
parents:
diff changeset
   261
    handleSnapshotEvent(CxeError::None);
hgs
parents:
diff changeset
   262
hgs
parents:
diff changeset
   263
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
    return err;
hgs
parents:
diff changeset
   266
}
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
/*!
hgs
parents:
diff changeset
   269
* Camera events coming from ecam.
hgs
parents:
diff changeset
   270
*/
hgs
parents:
diff changeset
   271
void CxeVideoCaptureControlDesktop::handleCameraEvent(int eventUid, int error)
hgs
parents:
diff changeset
   272
{
hgs
parents:
diff changeset
   273
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   274
hgs
parents:
diff changeset
   275
    Q_UNUSED(eventUid);
hgs
parents:
diff changeset
   276
    Q_UNUSED(error);
hgs
parents:
diff changeset
   277
hgs
parents:
diff changeset
   278
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   279
}
hgs
parents:
diff changeset
   280
hgs
parents:
diff changeset
   281
hgs
parents:
diff changeset
   282
/*!
hgs
parents:
diff changeset
   283
* Handle Snapshot event from ecam
hgs
parents:
diff changeset
   284
*/
hgs
parents:
diff changeset
   285
void CxeVideoCaptureControlDesktop::handleSnapshotEvent(CxeError::Id error)
hgs
parents:
diff changeset
   286
{
hgs
parents:
diff changeset
   287
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
    if (state() == Idle) {
hgs
parents:
diff changeset
   290
        // we ignore this event, when we are not in active state(s)
hgs
parents:
diff changeset
   291
        CX_DEBUG(( "wrong state, ignoring snapshot" ));
hgs
parents:
diff changeset
   292
        CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   293
        return;
hgs
parents:
diff changeset
   294
    }
hgs
parents:
diff changeset
   295
    emit snapshotReady(error, QImage(), filename());
hgs
parents:
diff changeset
   296
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   297
}
hgs
parents:
diff changeset
   298
hgs
parents:
diff changeset
   299
hgs
parents:
diff changeset
   300
/*!
hgs
parents:
diff changeset
   301
* Resets the video snapshot and current video filename
hgs
parents:
diff changeset
   302
*/
hgs
parents:
diff changeset
   303
void CxeVideoCaptureControlDesktop::reset()
hgs
parents:
diff changeset
   304
{
hgs
parents:
diff changeset
   305
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   306
hgs
parents:
diff changeset
   307
    // Snapshot will consume considerably memory.
hgs
parents:
diff changeset
   308
    // Replace it with null pixmap to have it freed.
hgs
parents:
diff changeset
   309
    mSnapshot = QPixmap();
hgs
parents:
diff changeset
   310
    // reset the current file name.
hgs
parents:
diff changeset
   311
    mCurrentFilename = QString("");
hgs
parents:
diff changeset
   312
hgs
parents:
diff changeset
   313
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   314
}
hgs
parents:
diff changeset
   315
hgs
parents:
diff changeset
   316
hgs
parents:
diff changeset
   317
/*!
hgs
parents:
diff changeset
   318
*@Return current video filename
hgs
parents:
diff changeset
   319
*/
hgs
parents:
diff changeset
   320
QString CxeVideoCaptureControlDesktop::filename() const
hgs
parents:
diff changeset
   321
{
hgs
parents:
diff changeset
   322
    // Simply return the current contents of mCurrentFilename.
hgs
parents:
diff changeset
   323
    // If video recording was started then it returns proper filename
hgs
parents:
diff changeset
   324
    // otherwise an empty string is returned.
hgs
parents:
diff changeset
   325
    return mCurrentFilename;
hgs
parents:
diff changeset
   326
}
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
hgs
parents:
diff changeset
   329
/*!
hgs
parents:
diff changeset
   330
* @Return current video snapshot
hgs
parents:
diff changeset
   331
*/
hgs
parents:
diff changeset
   332
QPixmap CxeVideoCaptureControlDesktop::snapshot() const
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   333
{
46
hgs
parents:
diff changeset
   334
    return mSnapshot;
hgs
parents:
diff changeset
   335
}
hgs
parents:
diff changeset
   336
hgs
parents:
diff changeset
   337
/*!
hgs
parents:
diff changeset
   338
* @Return QList of all supported video quality details based on the camera index
hgs
parents:
diff changeset
   339
*  (primary/secondary).
hgs
parents:
diff changeset
   340
*/
hgs
parents:
diff changeset
   341
QList<CxeVideoDetails> CxeVideoCaptureControlDesktop::supportedVideoQualities()
hgs
parents:
diff changeset
   342
{
hgs
parents:
diff changeset
   343
    return QList<CxeVideoDetails>();
hgs
parents:
diff changeset
   344
}
hgs
parents:
diff changeset
   345
hgs
parents:
diff changeset
   346
/*!
hgs
parents:
diff changeset
   347
* Starts video recording if we are in appropriate state.
hgs
parents:
diff changeset
   348
*/
hgs
parents:
diff changeset
   349
void CxeVideoCaptureControlDesktop::record()
hgs
parents:
diff changeset
   350
{
hgs
parents:
diff changeset
   351
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   352
hgs
parents:
diff changeset
   353
    if (state() == Ready || state() == Paused) {
hgs
parents:
diff changeset
   354
        //we skip the playing of the sound in the desktop state for now
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   355
        setState(Recording);
46
hgs
parents:
diff changeset
   356
        mRecordElapseTimer.start();
hgs
parents:
diff changeset
   357
    }
hgs
parents:
diff changeset
   358
hgs
parents:
diff changeset
   359
    CX_DEBUG_EXIT_FUNCTION();
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
* Pauses video recording.
hgs
parents:
diff changeset
   365
*/
hgs
parents:
diff changeset
   366
void CxeVideoCaptureControlDesktop::pause()
hgs
parents:
diff changeset
   367
{
hgs
parents:
diff changeset
   368
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   369
hgs
parents:
diff changeset
   370
    mRecordElapseTimer.stop();
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
    setState(Paused);
hgs
parents:
diff changeset
   373
hgs
parents:
diff changeset
   374
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   375
}
hgs
parents:
diff changeset
   376
hgs
parents:
diff changeset
   377
hgs
parents:
diff changeset
   378
/*!
hgs
parents:
diff changeset
   379
* Stops video recording.
hgs
parents:
diff changeset
   380
*/
hgs
parents:
diff changeset
   381
void CxeVideoCaptureControlDesktop::stop()
hgs
parents:
diff changeset
   382
{
hgs
parents:
diff changeset
   383
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   384
hgs
parents:
diff changeset
   385
    if (state() == Recording || state() == Paused) {
hgs
parents:
diff changeset
   386
        mFilenameGenerator.raiseCounterValue();
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   387
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   388
        mRecordElapseTimer.stop();
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   389
        mElapsedTime = 0;
46
hgs
parents:
diff changeset
   390
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   391
        setState(Stopping);
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   392
        setState(Initialized);
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   393
    }
46
hgs
parents:
diff changeset
   394
hgs
parents:
diff changeset
   395
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   396
}
hgs
parents:
diff changeset
   397
hgs
parents:
diff changeset
   398
hgs
parents:
diff changeset
   399
/*!
hgs
parents:
diff changeset
   400
* camera reference changing, release resources
hgs
parents:
diff changeset
   401
*/
hgs
parents:
diff changeset
   402
void CxeVideoCaptureControlDesktop::prepareForCameraDelete()
hgs
parents:
diff changeset
   403
{
hgs
parents:
diff changeset
   404
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   405
    releaseResources();
hgs
parents:
diff changeset
   406
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   407
}
hgs
parents:
diff changeset
   408
hgs
parents:
diff changeset
   409
/*!
hgs
parents:
diff changeset
   410
* prepare for camera release.
hgs
parents:
diff changeset
   411
*/
hgs
parents:
diff changeset
   412
void CxeVideoCaptureControlDesktop::prepareForRelease()
hgs
parents:
diff changeset
   413
{
hgs
parents:
diff changeset
   414
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   415
    deinit();
hgs
parents:
diff changeset
   416
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   417
}
hgs
parents:
diff changeset
   418
hgs
parents:
diff changeset
   419
hgs
parents:
diff changeset
   420
/*!
hgs
parents:
diff changeset
   421
* new camera available,
hgs
parents:
diff changeset
   422
*/
hgs
parents:
diff changeset
   423
void CxeVideoCaptureControlDesktop::handleCameraAllocated(CxeError::Id error)
hgs
parents:
diff changeset
   424
{
hgs
parents:
diff changeset
   425
    Q_UNUSED(error);
hgs
parents:
diff changeset
   426
    CX_DEBUG_IN_FUNCTION();
hgs
parents:
diff changeset
   427
}
hgs
parents:
diff changeset
   428
hgs
parents:
diff changeset
   429
hgs
parents:
diff changeset
   430
/*!
hgs
parents:
diff changeset
   431
* Initializes video recorder.
hgs
parents:
diff changeset
   432
*/
hgs
parents:
diff changeset
   433
void CxeVideoCaptureControlDesktop::createVideoRecorder()
hgs
parents:
diff changeset
   434
{
hgs
parents:
diff changeset
   435
    CX_DEBUG_IN_FUNCTION();
hgs
parents:
diff changeset
   436
}
hgs
parents:
diff changeset
   437
hgs
parents:
diff changeset
   438
hgs
parents:
diff changeset
   439
/*!
hgs
parents:
diff changeset
   440
* releases resources used by videocapture
hgs
parents:
diff changeset
   441
*/
hgs
parents:
diff changeset
   442
void CxeVideoCaptureControlDesktop::releaseResources()
hgs
parents:
diff changeset
   443
{
hgs
parents:
diff changeset
   444
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   445
hgs
parents:
diff changeset
   446
    // first de-init videocapture control
hgs
parents:
diff changeset
   447
    deinit();
hgs
parents:
diff changeset
   448
    reset();
hgs
parents:
diff changeset
   449
hgs
parents:
diff changeset
   450
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   451
}
hgs
parents:
diff changeset
   452
hgs
parents:
diff changeset
   453
hgs
parents:
diff changeset
   454
/*!
hgs
parents:
diff changeset
   455
@Returns current state of videocapture
hgs
parents:
diff changeset
   456
*/
hgs
parents:
diff changeset
   457
CxeVideoCaptureControl::State CxeVideoCaptureControlDesktop::state() const
hgs
parents:
diff changeset
   458
{
hgs
parents:
diff changeset
   459
    return mState;
hgs
parents:
diff changeset
   460
}
hgs
parents:
diff changeset
   461
hgs
parents:
diff changeset
   462
/*!
hgs
parents:
diff changeset
   463
* Initialize states for videocapturecontrol
hgs
parents:
diff changeset
   464
*/
hgs
parents:
diff changeset
   465
void CxeVideoCaptureControlDesktop::initializeStates()
hgs
parents:
diff changeset
   466
{
hgs
parents:
diff changeset
   467
    CX_DEBUG_IN_FUNCTION();
hgs
parents:
diff changeset
   468
}
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
/*!
hgs
parents:
diff changeset
   471
* calculates remaining video recording time.
hgs
parents:
diff changeset
   472
*/
hgs
parents:
diff changeset
   473
void CxeVideoCaptureControlDesktop::remainingTime(int &time)
hgs
parents:
diff changeset
   474
{
hgs
parents:
diff changeset
   475
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   476
hgs
parents:
diff changeset
   477
    time = CXENGINE_MAXIMUM_VIDEO_TIME - mElapsedTime;
hgs
parents:
diff changeset
   478
    if (time < 0) {
hgs
parents:
diff changeset
   479
        time = 0;
hgs
parents:
diff changeset
   480
    }
hgs
parents:
diff changeset
   481
hgs
parents:
diff changeset
   482
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   483
}
hgs
parents:
diff changeset
   484
hgs
parents:
diff changeset
   485
hgs
parents:
diff changeset
   486
/*!
hgs
parents:
diff changeset
   487
* Calculates elapsed recording time during video recording
hgs
parents:
diff changeset
   488
* @return Did fetching elapsed time succeed.
hgs
parents:
diff changeset
   489
*/
hgs
parents:
diff changeset
   490
bool CxeVideoCaptureControlDesktop::elapsedTime(int &time)
hgs
parents:
diff changeset
   491
{
hgs
parents:
diff changeset
   492
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   493
hgs
parents:
diff changeset
   494
    time = mElapsedTime;
hgs
parents:
diff changeset
   495
hgs
parents:
diff changeset
   496
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   497
hgs
parents:
diff changeset
   498
    return true;
hgs
parents:
diff changeset
   499
}
hgs
parents:
diff changeset
   500
hgs
parents:
diff changeset
   501
/*!
hgs
parents:
diff changeset
   502
* slot called when playing a sound has finished.
hgs
parents:
diff changeset
   503
*/
hgs
parents:
diff changeset
   504
void CxeVideoCaptureControlDesktop::handleSoundPlayed()
hgs
parents:
diff changeset
   505
{
hgs
parents:
diff changeset
   506
    // in case of video capture stop sound playing, nothing needs to be done
hgs
parents:
diff changeset
   507
    // meaning the state set elsewhere, and the video capture has been stopped already
hgs
parents:
diff changeset
   508
hgs
parents:
diff changeset
   509
    CX_DEBUG_IN_FUNCTION();
hgs
parents:
diff changeset
   510
}
hgs
parents:
diff changeset
   511
hgs
parents:
diff changeset
   512
hgs
parents:
diff changeset
   513
/*!
hgs
parents:
diff changeset
   514
* setting has changed, check if we are interested.
hgs
parents:
diff changeset
   515
*/
hgs
parents:
diff changeset
   516
void CxeVideoCaptureControlDesktop::handleSettingValueChanged(const QString& settingId,
hgs
parents:
diff changeset
   517
                                                              QVariant newValue)
hgs
parents:
diff changeset
   518
{
hgs
parents:
diff changeset
   519
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   520
hgs
parents:
diff changeset
   521
    Q_UNUSED(newValue);
hgs
parents:
diff changeset
   522
hgs
parents:
diff changeset
   523
    if (settingId == CxeSettingIds::VIDEO_QUALITY) {
hgs
parents:
diff changeset
   524
        // re-prepare for video
hgs
parents:
diff changeset
   525
       deinit();
hgs
parents:
diff changeset
   526
       init();
hgs
parents:
diff changeset
   527
    } else if (settingId == CxeSettingIds::VIDEO_MUTE_SETTING) {
hgs
parents:
diff changeset
   528
        // mute setting changed, apply the new setting and re-prepare.
hgs
parents:
diff changeset
   529
        prepare();
hgs
parents:
diff changeset
   530
    }
hgs
parents:
diff changeset
   531
hgs
parents:
diff changeset
   532
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   533
}
hgs
parents:
diff changeset
   534
hgs
parents:
diff changeset
   535
hgs
parents:
diff changeset
   536
hgs
parents:
diff changeset
   537
/*!
hgs
parents:
diff changeset
   538
* Video Scene mode changed, needs updated
hgs
parents:
diff changeset
   539
*/
hgs
parents:
diff changeset
   540
void CxeVideoCaptureControlDesktop::handleSceneChanged(CxeScene &scene)
hgs
parents:
diff changeset
   541
{
hgs
parents:
diff changeset
   542
    CX_DEBUG_ENTER_FUNCTION();
hgs
parents:
diff changeset
   543
    Q_UNUSED(scene);
hgs
parents:
diff changeset
   544
    CX_DEBUG_EXIT_FUNCTION();
hgs
parents:
diff changeset
   545
}
hgs
parents:
diff changeset
   546
hgs
parents:
diff changeset
   547
void CxeVideoCaptureControlDesktop::handleElapseTimeout()
hgs
parents:
diff changeset
   548
{
hgs
parents:
diff changeset
   549
    mElapsedTime++;
hgs
parents:
diff changeset
   550
hgs
parents:
diff changeset
   551
    CX_DEBUG( ("CxeVideoCaptureControlDesktop::handleElapseTimeout() <> mElapsedTime: %d", mElapsedTime ) );
hgs
parents:
diff changeset
   552
}
hgs
parents:
diff changeset
   553
55
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   554
/*!
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   555
* Slot for starting viewfinder after a delay.
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   556
* Delay helps viewfinder widget to find the right, visible transparent window to attach to.
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   557
*/
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   558
void CxeVideoCaptureControlDesktop::startViewfinder()
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   559
{
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   560
    CX_DEBUG_ENTER_FUNCTION();
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   561
    mViewfinderControl.start();
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   562
    CX_DEBUG_EXIT_FUNCTION();
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   563
}
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   564
0da2a5b56583 201035_1
hgs
parents: 46
diff changeset
   565
46
hgs
parents:
diff changeset
   566
void CxeVideoCaptureControlDesktop::setState(CxeVideoCaptureControl::State stateId, CxeError::Id error)
hgs
parents:
diff changeset
   567
{
hgs
parents:
diff changeset
   568
    mState = stateId;
hgs
parents:
diff changeset
   569
    CX_DEBUG( ("CxeVideoCaptureControlDesktop::setState <> mState: %d", mState ) );
hgs
parents:
diff changeset
   570
    emit stateChanged(mState, error);
hgs
parents:
diff changeset
   571
}
hgs
parents:
diff changeset
   572
// End of file