os/mm/imagingandcamerafws/camerafw/Include/ECam/ecamcapturecontrolintf.h
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     2
// All rights reserved.
sl@0
     3
// This component and the accompanying materials are made available
sl@0
     4
// under the terms of "Eclipse Public License v1.0"
sl@0
     5
// which accompanies this distribution, and is available
sl@0
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     7
//
sl@0
     8
// Initial Contributors:
sl@0
     9
// Nokia Corporation - initial contribution.
sl@0
    10
//
sl@0
    11
// Contributors:
sl@0
    12
//
sl@0
    13
// Description:
sl@0
    14
//
sl@0
    15
sl@0
    16
/**
sl@0
    17
 @file
sl@0
    18
 @publishedPartner
sl@0
    19
 @released
sl@0
    20
*/
sl@0
    21
sl@0
    22
#ifndef  ECAMCAPTURECONTROLINTF_H
sl@0
    23
#define  ECAMCAPTURECONTROLINTF_H
sl@0
    24
sl@0
    25
#include <ecamcapturecontrol.h>
sl@0
    26
#include <ecam/ecamadvsettingsintfuids.hrh>
sl@0
    27
sl@0
    28
class MImplementationFactory;
sl@0
    29
sl@0
    30
/** 
sl@0
    31
This is the UID which is used to obtain the interface MCameraPreImageCaptureControl, via the 
sl@0
    32
CCamera::CustomInterface() call, which provides implementation of the M-class interface.
sl@0
    33
 
sl@0
    34
@publishedPartner
sl@0
    35
@prototype
sl@0
    36
*/   
sl@0
    37
static const TUid KECamMCameraPreImageCaptureControlUid		=  {KECamMCameraPreImageCaptureControlUidValue};
sl@0
    38
sl@0
    39
/** 
sl@0
    40
This is the UID which is used to obtain the interface MCameraImageCapture, via the 
sl@0
    41
CCamera::CustomInterface() call, which provides implementation of the M-class interface.
sl@0
    42
 
sl@0
    43
@publishedPartner
sl@0
    44
@prototype
sl@0
    45
*/   
sl@0
    46
static const TUid KECamMCameraImageCaptureUid		=  {KECamMCameraImageCaptureUidValue};
sl@0
    47
sl@0
    48
/** 
sl@0
    49
This is the UID which is used to obtain the interface MCameraPostImageCaptureControl, via the 
sl@0
    50
CCamera::CustomInterface() call, which provides implementation of the M-class interface.
sl@0
    51
 
sl@0
    52
@publishedPartner
sl@0
    53
@prototype 
sl@0
    54
*/   
sl@0
    55
static const TUid KECamMCameraPostImageCaptureControlUid	=  {KECamMCameraPostImageCaptureControlUidValue};
sl@0
    56
sl@0
    57
/** 
sl@0
    58
This is the UID which is used to obtain the interface MCameraVideoCaptureControl, via the 
sl@0
    59
CCamera::CustomInterface() call, which provides implementation of the M-class interface. 
sl@0
    60
@publishedPartner
sl@0
    61
@prototype
sl@0
    62
*/   
sl@0
    63
static const TUid KECamMCameraVideoCaptureControlUid 	=  {KECamMCameraVideoCaptureControlUidValue};
sl@0
    64
sl@0
    65
/** 
sl@0
    66
Mixin class for implementation by providers of the PreImageCaptureControl Camera Extension API.
sl@0
    67
PreImageCaptureControl class exposes an API for controlling advanced still image related settings and control prior
sl@0
    68
to capturing the images.
sl@0
    69
sl@0
    70
@publishedPartner
sl@0
    71
@prototype 
sl@0
    72
*/	
sl@0
    73
class MCameraPreImageCaptureControl
sl@0
    74
	{
sl@0
    75
	
sl@0
    76
public:
sl@0
    77
	
sl@0
    78
	/** 
sl@0
    79
	Releases the interface. 
sl@0
    80
	*/
sl@0
    81
	virtual void Release()=0;
sl@0
    82
	
sl@0
    83
	/**
sl@0
    84
	The observer for the pre image capture control is passed to the implementation for passing callbacks on it.
sl@0
    85
	
sl@0
    86
	@param  aPreImageCaptureControlObserver
sl@0
    87
			The reference to the pre image capture control observer.
sl@0
    88
	*/
sl@0
    89
	virtual void SetPreImageCaptureControlObserver(MPreImageCaptureControlObserver& aPreImageCaptureControlObserver)=0;
sl@0
    90
	
sl@0
    91
	/**
sl@0
    92
	Retrieves information regarding the direct snapshot feature support. Direct Snapshot, if supported, can be created
sl@0
    93
	out of version2 direct viewfinder object only.
sl@0
    94
sl@0
    95
	@param  aDirectSnapshotSupportInfo
sl@0
    96
			This is a bit field providing supported direct snapshot of type TDirectSnapshotType
sl@0
    97
sl@0
    98
	@leave  May leave with any error code.
sl@0
    99
	*/
sl@0
   100
	virtual void GetDirectSnapshotSupportInfoL(TUint& aDirectSnapshotSupportInfo) const=0;
sl@0
   101
	
sl@0
   102
	/**
sl@0
   103
	Retrieves the settings supported for embedded still captures. Possibilty exists that not all the settings supported for
sl@0
   104
	normal still image captures are supported for embedded still captures as well.
sl@0
   105
sl@0
   106
	@param  aSupportedEmbeddedStillCaptureSettings
sl@0
   107
			Array of TUid which retrieves the supported embedded still captures. Empty list indicated that no settings are
sl@0
   108
			supported for embedded still captures.
sl@0
   109
			
sl@0
   110
	@leave  May leave with any error code.
sl@0
   111
	*/
sl@0
   112
	virtual void GetSupportedEmbeddedStillCaptureSettingsL(RArray<TUid>& aSupportedEmbeddedStillCaptureSettings) const=0;
sl@0
   113
	
sl@0
   114
	/**
sl@0
   115
	Retrieves information regarding the supported direct saving state. If used, still images are saved in files rather than 
sl@0
   116
	providing clients the MCameraImageBuffer. Direct saving to file will continue even if the client application gets closed
sl@0
   117
	for any reasons.
sl@0
   118
sl@0
   119
	@param  aSupportedDirectSavingType
sl@0
   120
			Retrieves the enum specifying supported TDirectSavingType.
sl@0
   121
			If EDirectSavingNotUsed, direct saving not supported. Images will be received in buffer MCameraImageBuffer.
sl@0
   122
			
sl@0
   123
			If EDirectSavingHighResolutionFileOnly, direct saving to file is supported. But no cut down version of the image 
sl@0
   124
			will be saved to file. Callback used is MCaptureImageObserver::ImageDirectSavingCompleted().
sl@0
   125
			
sl@0
   126
			If EDirectSavingWithLowerResolutionFile, Direct saving to file is supported. Also, a cut down version of the image 
sl@0
   127
			will be saved to another specified file. Callbacks used are MCaptureImageObserver::ImageDirectSavingCompleted()
sl@0
   128
			for actual image and MCaptureImageObserver::CutDownImageDirectSavingCompleted() for lower resolution image.
sl@0
   129
sl@0
   130
	@leave  May leave with any error code.	
sl@0
   131
	*/
sl@0
   132
	virtual void GetSupportedDirectSavingTypeL(CCamera::CCameraPreImageCaptureControl::TDirectSavingType& aSupportedDirectSavingType) const=0;
sl@0
   133
sl@0
   134
	/**
sl@0
   135
	Provides the base name for file used to save images. If there are sequential images, files will be created by 
sl@0
   136
	implementation with names appearing as base name and appended by increasing integers which would start from 
sl@0
   137
	aStartingSequenceNumber. This is used for the original image only, but not for the cut down version of the original
sl@0
   138
	image.
sl@0
   139
sl@0
   140
	@param  aFilename
sl@0
   141
			A const TDesC8&: Base name for files which ECam implementation needs to create in order to collect every sequential
sl@0
   142
			image.
sl@0
   143
			
sl@0
   144
	@param  aStartingSequenceNumber
sl@0
   145
			The starting sequence number which will be appended to the base name 'aFilename'. The sequence number will keep
sl@0
   146
			on increasing for every individual still image capture.
sl@0
   147
			
sl@0
   148
	@leave  May leave with any error code.
sl@0
   149
sl@0
   150
	@note   It is upto the implementation how many digits it uses for sequence number. Accordingly, padding will be done with 
sl@0
   151
			zeroes.
sl@0
   152
	*/
sl@0
   153
	virtual void SetSequentialImageFilenameL(const TDesC8& aFilename, TInt aStartingSequenceNumber)=0;
sl@0
   154
	
sl@0
   155
	/**
sl@0
   156
	Provides the base name for file used to save cut down version of the original images. If there are sequential images, 
sl@0
   157
	files will be created by implementation with names appearing as base name and appended by increasing integers which would 
sl@0
   158
	start from aStartingSequenceNumber. This is used for the cut down version of the original image.
sl@0
   159
sl@0
   160
	@param  aLowerResolutionFilename
sl@0
   161
			A const TDesC8&: Base name for files which ECam implementation needs to create in order to collect the cut down version
sl@0
   162
			of every sequential image.
sl@0
   163
			
sl@0
   164
	@param  aStartingSequenceNumber
sl@0
   165
			The starting sequence number which will be appended to the base name 'aFilename'. The sequence number will keep
sl@0
   166
			on increasing for every individual still image capture.
sl@0
   167
			
sl@0
   168
	@leave  May leave with any error code.
sl@0
   169
sl@0
   170
	@note   It is upto the implementation how many digits it uses for sequence number. Accordingly, padding will be done with 
sl@0
   171
			zeroes.
sl@0
   172
	*/
sl@0
   173
	virtual void SetLowerResolutionSequentialImageFilenameL(const TDesC8& aLowerResolutionFilename, TInt aStartingSequenceNumber)=0;
sl@0
   174
sl@0
   175
	/**
sl@0
   176
	Retrieves the type of direct saving currently used. This will be represented as a direct saving state as given by 
sl@0
   177
	TDirectSavingType. 
sl@0
   178
sl@0
   179
	Whether or not the direct saving option is used, client will receive the MCaptureImageObserver::ImageCaptureComplete() 
sl@0
   180
	callback to mark the completion of the image capture operation.
sl@0
   181
sl@0
   182
	@param  aDirectSavingType
sl@0
   183
			Current type of the direct saving. 
sl@0
   184
			
sl@0
   185
			If EDirectSavingNotUsed, direct saving is not used. Images will be received in buffer MCameraImageBuffer through
sl@0
   186
			callback MCaptureImageObserver::ImageBufferReady().
sl@0
   187
			
sl@0
   188
			If EDirectSavingHighResolutionFileOnly, direct saving to file option is currently used. But no cut down version of
sl@0
   189
			the image will be saved to file. Callback used is MCaptureImageObserver::ImageDirectSavingCompleted().
sl@0
   190
			
sl@0
   191
			If EDirectSavingWithLowerResolutionFile, apart from direct saving to file option for the actual image, a cut down 
sl@0
   192
			version of the image will be saved to another specified file. Callbacks used are MCaptureImageObserver::
sl@0
   193
			ImageDirectSavingCompleted() for actual image and MCaptureImageObserver::CutDownImageDirectSavingCompleted() 
sl@0
   194
			for lower resolution image.
sl@0
   195
			
sl@0
   196
	@leave  May leave with any error code.
sl@0
   197
	
sl@0
   198
	@note   Direct saving to file will continue even if the client application gets closed for any reasons.
sl@0
   199
	*/
sl@0
   200
	virtual void GetDirectSavingTypeL(CCamera::CCameraPreImageCaptureControl::TDirectSavingType& aDirectSavingType) const=0;
sl@0
   201
sl@0
   202
	/**
sl@0
   203
	Instructs the ECam implementation to use the desired type of direct saving option as specifed by its state.
sl@0
   204
sl@0
   205
	Whether or not the direct saving option is used, client will receive the MCaptureImageObserver::ImageCaptureComplete() 
sl@0
   206
	callback to mark the completion of the image capture operation.
sl@0
   207
sl@0
   208
	@param  aDirectSavingType
sl@0
   209
			The desired type of the direct saving. 
sl@0
   210
			
sl@0
   211
			If EDirectSavingNotUsed, direct saving will not be used. Images will be received in buffer MCameraImageBuffer 
sl@0
   212
			through	callback MCaptureImageObserver::ImageBufferReady().
sl@0
   213
			
sl@0
   214
			If EDirectSavingHighResolutionFileOnly, direct saving to file option will be used. But no cut down version of
sl@0
   215
			the image will be saved to file. Callback to be used is MCaptureImageObserver::ImageDirectSavingCompleted().
sl@0
   216
			
sl@0
   217
			If EDirectSavingWithLowerResolutionFile, apart from direct saving to file option for the actual image, a cut down 
sl@0
   218
			version of the image will be saved to another specified file. Callbacks to be used are MCaptureImageObserver::
sl@0
   219
			ImageDirectSavingCompleted() for actual image and MCaptureImageObserver::CutDownImageDirectSavingCompleted()
sl@0
   220
			for lower resolution image.
sl@0
   221
			
sl@0
   222
	@leave  May leave with any error code.
sl@0
   223
sl@0
   224
	@note   Clients need to provide the filename before capturing still images under direct saving option. Callback 
sl@0
   225
			MCaptureImageObserver::ImageDirectSavingCompleted() may provide error KErrNotReady if filenames are not 
sl@0
   226
			provided before images are captured for direct saving. Similarly, if cut down version of image is also to be 
sl@0
   227
			saved to file, MCaptureImageObserver::CutDownImageDirectSavingCompleted() may provide error KErrNotReady if 
sl@0
   228
			filenames are not provided before hand.
sl@0
   229
			
sl@0
   230
	@note   Direct saving to file will continue even if the client application gets closed for any reasons.
sl@0
   231
	*/
sl@0
   232
	virtual void SetDirectSavingTypeL(CCamera::CCameraPreImageCaptureControl::TDirectSavingType aDirectSavingType)=0;
sl@0
   233
    
sl@0
   234
 	/**
sl@0
   235
	Retrieves whether the camera device is capable of providing capture event notification to the client. Client may take
sl@0
   236
	the responsibility of playing the capture sound after receiving the notification. 
sl@0
   237
sl@0
   238
	@param  aSupportedDriveModes
sl@0
   239
			A reference to bit-field of TUint which indicates the drive modes in which the capture event notification is
sl@0
   240
			supported. If aSupportedDriveModes =0, capture event notification is not supported.
sl@0
   241
			
sl@0
   242
	@note   If capture event notification is supported, ECam implementation will use KUidECamEventImageCaptureEvent to notify 
sl@0
   243
			clients that the image has been exposed to the camera sensor. Clients may play capture sound if they desire to do so.
sl@0
   244
sl@0
   245
	@leave  May leave with any error code.
sl@0
   246
	
sl@0
   247
	@see    CCamera::CCameraAdvancedSettings::TDriveMode	
sl@0
   248
	*/
sl@0
   249
	virtual void GetCaptureEventSupportInfoL(TUint& aSupportedDriveModes) const=0;
sl@0
   250
	
sl@0
   251
	/**
sl@0
   252
	Retrieves the supported image formats for a given resolution.
sl@0
   253
	
sl@0
   254
	@param  aImageFormatsSupported
sl@0
   255
			A bit field which retrieves the supported image formats for a given resolution.
sl@0
   256
			Formats have been defined as CCamera::TFormat
sl@0
   257
			
sl@0
   258
	@param  aSize
sl@0
   259
			The resolution (or size) for which the total number of supported image formats have to be retrieved.
sl@0
   260
	
sl@0
   261
	@leave  May leave with any error code.
sl@0
   262
	*/
sl@0
   263
	virtual void GetImageFormatsSupportedL(TUint& aImageFormatsSupported, const TSize& aSize) const=0;
sl@0
   264
	
sl@0
   265
	/**
sl@0
   266
	Retrieves the supported pixel aspect ratio for a given resolution in case of still image.
sl@0
   267
	
sl@0
   268
	@param  aPixelAspectsSupported
sl@0
   269
			A bit field which retrieves the supported pixel aspect ratio for a given resolution.
sl@0
   270
			Pixel aspect ratio have been defined as CCamera::CCameraAdvancedSettings::TPixelAspectRatio
sl@0
   271
	
sl@0
   272
	@param  aImageFormat
sl@0
   273
			The image format for which the supported pixel aspect ratio have to be retrieved.
sl@0
   274
sl@0
   275
	@param  aSize
sl@0
   276
			The resolution (or size) for which the supported pixel aspect ratio have to be retrieved.
sl@0
   277
	
sl@0
   278
	@leave  May leave with any error code.
sl@0
   279
	*/
sl@0
   280
	virtual void GetPixelAspectsSupportedL(TUint& aPixelAspectsSupported, CCamera::TFormat aImageFormat, const TSize& aSize) const=0;
sl@0
   281
	
sl@0
   282
	/**
sl@0
   283
	Performs setup and allocation of memory for image capture operation. Implementation creates a new CCameraImageCapture*
sl@0
   284
	object which reflects the prepare image parameters passed by the client. The callback MPreImageCaptureControlObserver::
sl@0
   285
	PrepareImageComplete() passes the ownership of the CCameraImageCapture* object to the client.
sl@0
   286
sl@0
   287
	This needs to be called every time client wishes to change prepare image parameters or if the client wishes to create
sl@0
   288
	a new CCameraImageCapture* object. 
sl@0
   289
sl@0
   290
	@param  aPrepareImageParameters 
sl@0
   291
	        The desired image parameters to be used for capturing still images using the CCameraImageCapture instance
sl@0
   292
	        which would be passed by the implementation.
sl@0
   293
	        
sl@0
   294
	@param  aCaptureImageObserver
sl@0
   295
			The Capture image observer which is needed by the implementation in order to pass it to the 
sl@0
   296
			CCameraImageCapture while creating it.
sl@0
   297
sl@0
   298
	@note 	Next PrepareImageCapture can be called only after receiving the notification KUidECamEventReadyForNextPrepare.
sl@0
   299
sl@0
   300
	@note   Implementation will call CCameraImageCapture::CreateL(CCamera& aCamera, MCaptureImageObserver& 
sl@0
   301
			aCaptureImageObserver) method and pass the CCameraImageCapture* to the client through the 
sl@0
   302
			MPreImageCaptureControlObserver::PrepareImageComplete() callback.
sl@0
   303
sl@0
   304
	@note	If drive mode is EDriveModeTimeNudgeCapture the ECam implementation will immediately begin capturing images after
sl@0
   305
			creating a new CCameraImageCapture object. Once the client initiates image capture, the total amount of images
sl@0
   306
			requested by the client	(specified by the client in	TDriveModeDependentAttributes) will be returned to the client
sl@0
   307
			(via MCaptureImageObserver::ImageBufferReady())	or saved to file. The implementation should not create another
sl@0
   308
			instance of CCameraImageCapture whilst using this drive mode until the first instance is destroyed by the client.
sl@0
   309
sl@0
   310
	@see 	CCamera::PrepareImageCaptureL(TFormat aImageFormat,TInt aSizeIndex)
sl@0
   311
	*/
sl@0
   312
	virtual void PrepareImageCapture(const CCamera::CCameraPreImageCaptureControl::TPrepareImageParameters& 
sl@0
   313
											aPrepareImageParameters, MCaptureImageObserver& aCaptureImageObserver)=0;
sl@0
   314
		
sl@0
   315
	/**
sl@0
   316
	Informs whether or not the setting of maximum memory size when encoding to the current format is supported.
sl@0
   317
sl@0
   318
	@param  aIsImageMaxMemorySizeSettingSupported
sl@0
   319
			ETrue indicates that setting of maximum memory size is supported.
sl@0
   320
			EFalse indicates that setting of maximum memory size is not supported.
sl@0
   321
sl@0
   322
	@leave  May leave with any error code.
sl@0
   323
	*/
sl@0
   324
	virtual void GetImageMaxMemorySizeSettingSupportInfoL(TBool& aIsImageMaxMemorySizeSettingSupported) const=0;
sl@0
   325
sl@0
   326
	/**
sl@0
   327
	Get the maximum memory size in kilo bytes when encoding to the current format.
sl@0
   328
	
sl@0
   329
	@param  aMemorySize
sl@0
   330
			Retrieves the maximum memory size in kilo bytes.
sl@0
   331
	
sl@0
   332
	@note   In case of JPEG, the maximum memory size will take preference over JPEG quality if the maximum memory size is 
sl@0
   333
			not sufficient to achieve the desired quality. Refer CCamera::JpegQuality()
sl@0
   334
			
sl@0
   335
	@leave  May leave with any error code.
sl@0
   336
	*/
sl@0
   337
	virtual void GetImageMaxMemorySizeL(TUint& aMemorySize) const=0;
sl@0
   338
sl@0
   339
	/**
sl@0
   340
	Retrieves the supported processing options.
sl@0
   341
sl@0
   342
	@param  aEcamProcessingOptionsSupported
sl@0
   343
			Bitfield containing the available processing options.
sl@0
   344
sl@0
   345
	@leave  May leave with error code.
sl@0
   346
	*/
sl@0
   347
	virtual void GetSupportedProcessingOptionsL(TUint& aEcamProcessingOptionsSupported) const=0;
sl@0
   348
	};
sl@0
   349
sl@0
   350
/** 
sl@0
   351
Mixin class for implementation by providers of the ImageCapture Camera Extension API. 
sl@0
   352
CameraImageCapture class exposes an API for capturing the image and controlling the overall capture.
sl@0
   353
sl@0
   354
This class also provides concrete implementation of API exposed by CCameraPostImageCaptureControl.
sl@0
   355
CameraPostImageCaptureControl class exposes an API for retrieving the image data from individual images (in case 
sl@0
   356
continuous drive mode is used for capturing the images) and also to apply control on the captured images individually.
sl@0
   357
sl@0
   358
@publishedPartner
sl@0
   359
@prototype 
sl@0
   360
*/	
sl@0
   361
class MCameraImageCapture
sl@0
   362
	{
sl@0
   363
	
sl@0
   364
public:
sl@0
   365
	
sl@0
   366
	/** 
sl@0
   367
	Releases the interface. 
sl@0
   368
	
sl@0
   369
	@param  aCameraImageCapture
sl@0
   370
			The pointer to the image capture class object which would be destroyed by the client.
sl@0
   371
	*/
sl@0
   372
	virtual void Release(CCamera::CCameraImageCapture* aCameraImageCapture)=0;
sl@0
   373
	
sl@0
   374
	/**
sl@0
   375
	Retrieves the concrete factory handle for the histogram implementation in order to use it specifically for a
sl@0
   376
	specific still image capture.
sl@0
   377
		   
sl@0
   378
	@param  aImplFactoryPtr
sl@0
   379
		    The concrete factory handle for the histogram implementation specific to the still image capture.
sl@0
   380
		   
sl@0
   381
	@leave  May leave with any error code.
sl@0
   382
	*/
sl@0
   383
	virtual void CreateHistogramImplFactoryL(MImplementationFactory*& aImplFactoryPtr) const=0;
sl@0
   384
	
sl@0
   385
	/**
sl@0
   386
	Retrieves the concrete factory handle for the snapshot implementation in order to 
sl@0
   387
	use it specifically for a specific still image capture.
sl@0
   388
		   
sl@0
   389
	@param  aImplFactoryPtr
sl@0
   390
		    The concrete factory handle for the snapshot implementation specific to the still image capture.
sl@0
   391
		   
sl@0
   392
	@leave  May leave with any error code.
sl@0
   393
	*/
sl@0
   394
	virtual void GetSnapshotImplFactoryL(MImplementationFactory*& aImplFactoryPtr) const=0;
sl@0
   395
	
sl@0
   396
	/**
sl@0
   397
	Retrieves the concrete factory handle for the image processing implementation in order to use it specifically for 
sl@0
   398
	a specific still image capture.
sl@0
   399
		   
sl@0
   400
	@param  aImplFactoryPtr
sl@0
   401
		    The concrete factory handle for the image processing implementation specific to the still image capture.
sl@0
   402
		   
sl@0
   403
	@leave  May leave with any error code.
sl@0
   404
	*/
sl@0
   405
	virtual void GetImageProcessingImplFactoryL(MImplementationFactory*& aImplFactoryPtr) const=0;
sl@0
   406
	
sl@0
   407
	/**
sl@0
   408
	The observer for the image capture is passed to the implementation for passing callbacks on it.
sl@0
   409
	
sl@0
   410
	@param  aCaptureImageObserver
sl@0
   411
			The reference to the capture image observer.
sl@0
   412
	*/
sl@0
   413
	virtual void SetCaptureImageObserver(MCaptureImageObserver& aCaptureImageObserver)=0;	
sl@0
   414
	
sl@0
   415
	/**
sl@0
   416
	Retrieves the prepare image parameters tied with this image capture class object.
sl@0
   417
sl@0
   418
	@param aPrepareImageParameters
sl@0
   419
		   TPrepareImageParameters tied with this image capture class object.
sl@0
   420
		   
sl@0
   421
	@leave May leave with any error code
sl@0
   422
	*/
sl@0
   423
	virtual void GetPrepareImageParametersL(CCamera::CCameraPreImageCaptureControl::TPrepareImageParameters& aPrepareImageParameters) const=0;
sl@0
   424
	
sl@0
   425
	/**
sl@0
   426
	The prepare image parameters needed to capture images using the particular capture image class object.
sl@0
   427
	
sl@0
   428
	@param aPrepareImageParameters
sl@0
   429
		   The prepare image parameters used to capture images.
sl@0
   430
	*/
sl@0
   431
	virtual void SetPrepareImageParameters(const CCamera::CCameraPreImageCaptureControl::TPrepareImageParameters& aPrepareImageParameters)=0;
sl@0
   432
		
sl@0
   433
	/**
sl@0
   434
	Provides the interface pointers for the concrete implementation of CCameraPostImageCaptureControl.
sl@0
   435
	Every time this method is called, a newly created interface is provided since it represents the individual image.
sl@0
   436
	The ID maps the individual image with the CCameraPostImageCaptureControl instance and may also be stored by the 
sl@0
   437
	concrete implementation of CCameraPostImageCaptureControl.	
sl@0
   438
	
sl@0
   439
	@param  aInterface
sl@0
   440
			The uid representing the interface required.
sl@0
   441
	
sl@0
   442
	@param  aPostCaptureControlId
sl@0
   443
			The ID which maps the individual image with the CCameraPostImageCaptureControl object. This may be stored
sl@0
   444
			by the concrete implementation of CCameraPostImageCaptureControl.
sl@0
   445
			
sl@0
   446
	@return Interface pointer. 
sl@0
   447
	
sl@0
   448
	@note   It is this implementation which creates/owns CCameraPostImageCaptureControl class object after receiving image
sl@0
   449
			capture	requests by the client. Implementation may store all such mappings between aPostCaptureControlId and 
sl@0
   450
			CCameraPostImageCaptureControl* for a particular instance of CCameraImageCapture. 
sl@0
   451
	*/
sl@0
   452
	virtual TAny* CreatePostImageCaptureControlImpl(TUid aInterface, TPostCaptureControlId aPostCaptureControlId)=0;
sl@0
   453
sl@0
   454
	/**
sl@0
   455
	Performant image capture. This postpones the processing options involved with current image captured in order to 
sl@0
   456
	capture/prepare for next images. 
sl@0
   457
	
sl@0
   458
	Previously created CCameraPostImageCaptureControl objects for this CCameraImageCapture object will become unavailable 
sl@0
   459
	after this call.
sl@0
   460
sl@0
   461
	@param  aCameraImageCapture
sl@0
   462
			Pointer to aCameraImageCapture. This will be used by the implementation in order to pass in callbacks and to
sl@0
   463
			create CCameraPostImageCaptureControl object for every image and pass it to the client. Implementation is not
sl@0
   464
			supposed to not destroy this object.
sl@0
   465
sl@0
   466
	@note   Further images (either still or video) can be captured only after receiving the notification 
sl@0
   467
			KUidECamEventReadyForNextCapture. Current image may be outstanding in order to undergo any processing options.
sl@0
   468
sl@0
   469
	@note   Callback MCaptureImageObserver::ImageCaptureComplete() informs the client that the image capture operation has 
sl@0
   470
			been completed. The CCameraImageCapture& can be further used for next image captures.
sl@0
   471
			In case of continuous drive modes, this callback will be received by the client only once in order to provide the 
sl@0
   472
			result of the whole image capture operation. 
sl@0
   473
			
sl@0
   474
	@note   Callback MCaptureImageObserver::ImageBufferReady() provides client the link to CCameraPostImageCaptureControl& 
sl@0
   475
			which helps retrieving the image buffer. In case of continuous drive modes, this callback will be received by the
sl@0
   476
			client for every individual image. In case of single shots, this will be received by the client only once in 
sl@0
   477
			order to retrieve the image buffer.
sl@0
   478
	*/	
sl@0
   479
	virtual void CaptureImage(CCamera::CCameraImageCapture* aCameraImageCapture)=0;
sl@0
   480
	
sl@0
   481
	/**
sl@0
   482
	Cancels the outstanding Capture Image operation. This will also cancel any outstanding processing options associated
sl@0
   483
	with the concerned Capture Image operation. This method is synchronous. Hence, no callback shall be issued for the 
sl@0
   484
	concerned capture image operation.
sl@0
   485
	*/
sl@0
   486
	virtual void CancelCaptureImage()=0;
sl@0
   487
	
sl@0
   488
	/**
sl@0
   489
	Retrieves the number of images exposed to sensor with respect to a specific image capture command. Any Processing
sl@0
   490
	options associated with these images may be pending.
sl@0
   491
sl@0
   492
	@param  aNumImagesExposed
sl@0
   493
			Retrieves the number of images exposed to sensor till now. For single shot type of drive modes, this value will
sl@0
   494
			be one after the image gets exposed to sensor. For multiple shot type of drive modes, this value will be the 
sl@0
   495
			number of images exposed till now.
sl@0
   496
			
sl@0
   497
	@note   May leave with any error code.
sl@0
   498
	*/
sl@0
   499
	virtual void GetNumImagesExposedL(TUint& aNumImagesExposed) const=0;
sl@0
   500
sl@0
   501
	/**
sl@0
   502
	Retrieves the total number of images which is supposed to be captured with respect to a specific image capture command. 
sl@0
   503
sl@0
   504
	@param  aNumTotalImages
sl@0
   505
			Retrieves the total number of images supposed to be captured. For single shot type of drive modes, this value 
sl@0
   506
			will be	always be one. For multiple shot type of drive modes, this value will be greater than one.
sl@0
   507
			
sl@0
   508
	@note   May leave with any error code.
sl@0
   509
	*/
sl@0
   510
	virtual void GetNumTotalImagesL(TUint& aNumTotalImages) const=0;
sl@0
   511
sl@0
   512
	/**
sl@0
   513
	Retrieves the post capture control handle based on the ID passed to it. Client may use this handle for post capture 
sl@0
   514
	operations of the image identified by the ID. The ID is received by the clients through MCaptureImageObserver callbacks.
sl@0
   515
sl@0
   516
	@param  aPostCaptureControlHandle
sl@0
   517
			Retrieves pointer to the post capture control class object.
sl@0
   518
			
sl@0
   519
	@param  aPostCaptureControlId
sl@0
   520
			The ID used to retrieve the post capture control handle of the captured image.
sl@0
   521
			
sl@0
   522
	@note   May leave with any error code.
sl@0
   523
	
sl@0
   524
	@note   It is this implementation which creates/owns CCameraPostImageCaptureControl class object after receiving image
sl@0
   525
			capture	requests by the client. Implementation may store all such mappings between aPostCaptureControlId and 
sl@0
   526
			CCameraPostImageCaptureControl* for a particular instance of CCameraImageCapture. 
sl@0
   527
	*/	
sl@0
   528
	virtual void GetPostCaptureControlHandleL(CCamera::CCameraPostImageCaptureControl*& aPostCaptureControlHandle, 
sl@0
   529
																TPostCaptureControlId aPostCaptureControlId) const=0;
sl@0
   530
	/**
sl@0
   531
	Prioritises the Capture Image operation. This implies that the processing options associated with the concerned 
sl@0
   532
	Capture	Image operation will be prioritised over other pending processing options.
sl@0
   533
sl@0
   534
	@param  aCaptureImagePriority
sl@0
   535
			The desired level of priority.
sl@0
   536
sl@0
   537
	@leave  May leave with any error code.
sl@0
   538
	*/
sl@0
   539
	virtual void SetCaptureImagePriorityL(TECamImagePriority aCaptureImagePriority)=0;
sl@0
   540
		
sl@0
   541
	/**
sl@0
   542
	Retrieves the priority of the Capture Image operation.
sl@0
   543
sl@0
   544
	@param  aCaptureImagePriority
sl@0
   545
			Retrieves the current level of priority.
sl@0
   546
sl@0
   547
	@leave  May leave with any error code.
sl@0
   548
	*/
sl@0
   549
	virtual void GetCaptureImagePriorityL(TECamImagePriority& aCaptureImagePriority) const=0;
sl@0
   550
sl@0
   551
	/**
sl@0
   552
	Pauses processing options associated with the concerned Capture Image operation.
sl@0
   553
sl@0
   554
	@param  aProcessingTypes
sl@0
   555
			The processing options which need to be paused.
sl@0
   556
	*/
sl@0
   557
	virtual void PauseProcessing(TUint aProcessingTypes)=0;
sl@0
   558
sl@0
   559
	/**
sl@0
   560
	Resumes processing options associated with the concerned Capture Image operation.
sl@0
   561
sl@0
   562
	@param  aProcessingTypes
sl@0
   563
			The processing options which need to be resumed.
sl@0
   564
sl@0
   565
	@leave May leave with any error code.
sl@0
   566
	*/
sl@0
   567
	virtual void ResumeProcessingL(TUint aProcessingTypes)=0;
sl@0
   568
	};
sl@0
   569
	
sl@0
   570
/** 
sl@0
   571
This mixin class provides concrete implementation of API exposed by CCameraPostImageCaptureControl.
sl@0
   572
CameraPostImageCaptureControl class exposes an API for retrieving the image data from individual images (in case 
sl@0
   573
continuous drive mode is used for capturing the images) and also to apply control on the captured images individually.
sl@0
   574
sl@0
   575
@publishedPartner
sl@0
   576
@prototype 
sl@0
   577
*/	
sl@0
   578
class MCameraPostImageCaptureControl
sl@0
   579
	{
sl@0
   580
	
sl@0
   581
public:
sl@0
   582
	
sl@0
   583
	/** 
sl@0
   584
	Releases the interface. 
sl@0
   585
	
sl@0
   586
	@param  aPostCaptureControlId
sl@0
   587
			The ID useful to indentify the post capture control handle of the captured image being deleted.
sl@0
   588
	*/
sl@0
   589
	virtual void Release(TPostCaptureControlId aPostCaptureControlId)=0;
sl@0
   590
	
sl@0
   591
	/**
sl@0
   592
	Retrieves the sequence number of the image being represented by this post capture control object. The sequence number
sl@0
   593
	specifies the index of the individual image if, in case, the multiple shot type of drive mode is being used. The first 
sl@0
   594
	individual image which is exposed to the sensor has a sequence number of zero. In case of single shot type of drive mode,
sl@0
   595
	the sequence number will be zero.
sl@0
   596
sl@0
   597
	@param  aSequenceNumber
sl@0
   598
			Retrieves the sequence number of the image.
sl@0
   599
sl@0
   600
	@leave  May leave with any error code.
sl@0
   601
	*/
sl@0
   602
	virtual void GetImageSequenceNumberL(TUint& aSequenceNumber) const=0;
sl@0
   603
	
sl@0
   604
	/**
sl@0
   605
	CCancels the outstanding individual image which the object of this class is referring to. This will also cancel any outstanding 
sl@0
   606
	processing options associated with this individual image. This method is synchronous. Hence, no callback shall be 
sl@0
   607
	issued for this individual image.
sl@0
   608
	*/
sl@0
   609
	virtual void CancelImage()=0;
sl@0
   610
	
sl@0
   611
	/**
sl@0
   612
	Prioritises the individual image which the object of this class is referring to. This implies that any processing
sl@0
   613
	options associated with this individual image will be prioritised over other pending processings options.
sl@0
   614
sl@0
   615
	@param  aImagePriority
sl@0
   616
			The desired level of priority.
sl@0
   617
			
sl@0
   618
	@leave  May leave with any error code.
sl@0
   619
	*/
sl@0
   620
	virtual void SetImagePriorityL(TECamImagePriority aImagePriority)=0;
sl@0
   621
		
sl@0
   622
	/**
sl@0
   623
	Retrieves the priority of the individual image which the object of this class is referring to.
sl@0
   624
sl@0
   625
	@param  aImagePriority
sl@0
   626
			The current level of priority.
sl@0
   627
			
sl@0
   628
	@leave  May leave with any error code.
sl@0
   629
	*/
sl@0
   630
	virtual void GetImagePriorityL(TECamImagePriority& aImagePriority) const=0;
sl@0
   631
	
sl@0
   632
	/**
sl@0
   633
	Pauses processing options associated with the concerned Capture Image operation.
sl@0
   634
sl@0
   635
	@param  aProcessingTypes
sl@0
   636
			The processing options which need to be paused.
sl@0
   637
	*/
sl@0
   638
	virtual void PauseProcessing(TUint aProcessingTypes)=0;
sl@0
   639
sl@0
   640
	/**
sl@0
   641
	Resumes processing options associated with the concerned Capture Image operation.
sl@0
   642
sl@0
   643
	@param  aProcessingTypes
sl@0
   644
			The processing options which need to be resumed.
sl@0
   645
sl@0
   646
	@leave May leave with any error code.
sl@0
   647
	*/
sl@0
   648
	virtual void ResumeProcessingL(TUint aProcessingTypes)=0;
sl@0
   649
	
sl@0
   650
	/**
sl@0
   651
	Retrieves the image buffer which contains the individual image captured. This method should be called by the client as a 
sl@0
   652
	result of receiving the callback MCaptureImageObserver::ImageBufferReady(), if the 
sl@0
   653
	error information received is satisfactory.
sl@0
   654
sl@0
   655
	@param  aCameraImageBuffer
sl@0
   656
			A reference to an MCameraImageBuffer if successful, or NULL if not successful.
sl@0
   657
sl@0
   658
	@leave  May leave with any error code.
sl@0
   659
	*/
sl@0
   660
	virtual void GetImageBufferL(MCameraImageBuffer& aCameraImageBuffer) const=0;
sl@0
   661
	
sl@0
   662
	/**
sl@0
   663
	Retrieves the state of the individual image which the object of this class is referring to.
sl@0
   664
sl@0
   665
	@param  aImageState
sl@0
   666
			Retrieves the current state of the individual image.
sl@0
   667
			
sl@0
   668
	@leave  May leave with any error code.
sl@0
   669
	*/	
sl@0
   670
	virtual void GetImageStateL(CCamera::CCameraPostImageCaptureControl::TImageState& aImageState) const=0;
sl@0
   671
	
sl@0
   672
	/**
sl@0
   673
	Retrieves the state of the individual image buffer.
sl@0
   674
sl@0
   675
	@param  aBufferState
sl@0
   676
			Retrieves the current state of the individual image buffer.
sl@0
   677
			
sl@0
   678
	@leave  May leave with any error code.
sl@0
   679
	*/	
sl@0
   680
	virtual void GetBufferStateL(CCamera::CCameraPostImageCaptureControl::TBufferState& aBufferState) const=0;
sl@0
   681
	};
sl@0
   682
sl@0
   683
/** 
sl@0
   684
Mixin class for implementation by providers of the Video Capture Control Camera Extension API.
sl@0
   685
CCamera Video Capture Control class exposes an API for controlling advanced video capture related settings and control.
sl@0
   686
sl@0
   687
@publishedPartner
sl@0
   688
@prototype 	
sl@0
   689
*/	
sl@0
   690
class MCameraVideoCaptureControl
sl@0
   691
	{
sl@0
   692
	
sl@0
   693
public:
sl@0
   694
	
sl@0
   695
	/** 
sl@0
   696
	Releases the interface. 
sl@0
   697
	*/
sl@0
   698
	virtual void Release()=0;
sl@0
   699
	
sl@0
   700
	/**
sl@0
   701
	Retrieves the concrete factory handle for the histogram implementation in order to 
sl@0
   702
	use it specifically for the video capture.
sl@0
   703
		   
sl@0
   704
	@param aImplFactoryPtr
sl@0
   705
		   The concrete factory handle for the histogram implementation specific to the video capture.
sl@0
   706
		   
sl@0
   707
	@leave  May leave with any error code.
sl@0
   708
	*/
sl@0
   709
	virtual void CreateHistogramImplFactoryL(MImplementationFactory*& aImplFactoryPtr) const=0;
sl@0
   710
    	
sl@0
   711
	/**
sl@0
   712
	Retrieves the concrete factory handle for the snapshot implementation in order to 
sl@0
   713
	use it specifically for the video capture.
sl@0
   714
		   
sl@0
   715
	@param  aImplFactoryPtr
sl@0
   716
		    The concrete factory handle for the snapshot implementation specific to the video capture.
sl@0
   717
		   
sl@0
   718
	@leave  May leave with any error code.
sl@0
   719
	*/
sl@0
   720
	virtual void GetSnapshotImplFactoryL(MImplementationFactory*& aImplFactoryPtr) const=0;
sl@0
   721
	
sl@0
   722
	/**
sl@0
   723
	Retrieves the concrete factory handle for the image processing implementation in order to 
sl@0
   724
	use it specifically for the video capture.
sl@0
   725
	
sl@0
   726
	@param aImplFactoryPtr
sl@0
   727
		   The concrete factory handle for the image processing implementation specific to the video capture.
sl@0
   728
		   
sl@0
   729
	@leave  May leave with any error code.
sl@0
   730
	*/
sl@0
   731
	virtual void GetImageProcessingImplFactoryL(MImplementationFactory*& aImplFactoryPtr) const=0;
sl@0
   732
	
sl@0
   733
	/**
sl@0
   734
	The observer for the video capture is passed to the implementation for passing callbacks on it.
sl@0
   735
	
sl@0
   736
	@param  aCaptureVideoObserver
sl@0
   737
			The reference to the capture video observer.
sl@0
   738
	*/
sl@0
   739
	virtual void SetCaptureVideoObserver(MCaptureVideoObserver& aCaptureVideoObserver)=0;
sl@0
   740
	
sl@0
   741
    /**
sl@0
   742
	Retrieves the supported video formats for a given resolution.
sl@0
   743
	
sl@0
   744
	@param  aVideoFormatsSupported
sl@0
   745
			A bit field which retrieves the supported video formats for a given resolution.
sl@0
   746
			Formats have been defined as CCamera::TFormat
sl@0
   747
			
sl@0
   748
	@param  aSize
sl@0
   749
			The resolution (or size) for which the total number of supported video formats have to be retrieved.
sl@0
   750
	
sl@0
   751
	@leave  May leave with any error code.
sl@0
   752
	*/
sl@0
   753
	virtual void GetVideoFormatsSupportedL(TUint& aVideoFormatsSupported, const TSize& aSize) const=0;
sl@0
   754
sl@0
   755
	/**
sl@0
   756
	Retrieves the supported pixel aspect ratio for a given resolution in case of video.
sl@0
   757
	
sl@0
   758
	@param  aPixelAspectsSupported
sl@0
   759
			A bit field which retrieves the supported pixel aspect ratio for a given resolution.
sl@0
   760
			Pixel aspect ratio have been defined as CCamera::CCameraAdvancedSettings::TPixelAspectRatio
sl@0
   761
	
sl@0
   762
	@param	aVideoFormat
sl@0
   763
			The video format for which the supported pixel aspect ratio have to be retrieved.
sl@0
   764
		
sl@0
   765
	@param  aSize
sl@0
   766
			The resolution (or size) for which the supported pixel aspect ratio have to be retrieved.
sl@0
   767
	
sl@0
   768
	@leave  May leave with any error code.
sl@0
   769
	*/
sl@0
   770
	virtual void GetPixelAspectsSupportedL(TUint& aPixelAspectsSupported, CCamera::TFormat aVideoFormat, const TSize& aSize) const=0;
sl@0
   771
sl@0
   772
	/**
sl@0
   773
	Informs whether or not the 'embedded still capture' feature is supported. Allowing still image capture in between 
sl@0
   774
	on-going video capture is referred to as embedded still capture.
sl@0
   775
sl@0
   776
	@param  aSupportedEmbeddedStillCaptureTypes
sl@0
   777
			Retrieves the supported embedded still capture. The TInt is retrieved as a bit field of supported 
sl@0
   778
			TEmbeddedStillCaptureTypes.
sl@0
   779
sl@0
   780
			
sl@0
   781
	@leave  May leave with any error code.
sl@0
   782
	*/
sl@0
   783
	virtual void GetEmbeddedStillCaptureSupportInfoL(TInt& aSupportedEmbeddedStillCaptureTypes) const=0;
sl@0
   784
sl@0
   785
	/**
sl@0
   786
	Asynchronous method to prepare for video capture.
sl@0
   787
sl@0
   788
	Performs setup and allocation of memory prior to calling StartVideoCapture()
sl@0
   789
	to keep the latency of that function to a minimum.
sl@0
   790
sl@0
   791
	@param  aPrepareVideoParameters 
sl@0
   792
	 		Parameters necessary to prepare for video capture.
sl@0
   793
	 		
sl@0
   794
	@note   Event KUidECamEventVideoCaptureControlPrepareComplete is used to notify clients about completing the preparation
sl@0
   795
			for video capture.
sl@0
   796
			
sl@0
   797
	@note 	Next PrepareVideoCapture can be called only after receiving the notification KUidECamEventReadyForNextPrepare.
sl@0
   798
			
sl@0
   799
	@note   If some camera settings get affected because of desired video settings such as frame rate/frame size, 
sl@0
   800
			specific notifications will be sent to the client about camera settings being affected.
sl@0
   801
			
sl@0
   802
	@note	Event KUidECamEventVideoCaptureControlSettingsRangeChanged: informs that range of certain camera settings have been changed.
sl@0
   803
			Client may call GetRangeAffectedSettingsL(RArray<TUid>& aRangeAffectedSettings) const to get the list of affected camera settings.
sl@0
   804
sl@0
   805
	@note	Event KUidECamEventVideoCaptureControlSettingsValueChanged: informs that value of certain camera settings have been changed. 
sl@0
   806
			Client may call GetValueAffectedSettingsL(RArray<TUid>& aValueAffectedSettings) const to get the list of affected camera settings.
sl@0
   807
sl@0
   808
	@note	Event KUidECamEventVideoCaptureControlSettingsDisabled: informs that certain camera settings have been disabled. 
sl@0
   809
			Client may call GetDisabledSettingsL(RArray<TUid>& aDisabledSettings) const to get the list of affected camera settings.
sl@0
   810
sl@0
   811
	@see 	CCamera::PrepareVideoCaptureL(TFormat aFormat,TInt aSizeIndex,TInt aRateIndex,TInt aBuffersToUse,TInt aFramesPerBuffer)
sl@0
   812
	
sl@0
   813
	@see	ReleaseVideoResource()
sl@0
   814
	*/
sl@0
   815
	virtual void PrepareVideoCapture(const CCamera::CCameraVideoCaptureControl::TPrepareVideoParameters& aPrepareVideoParameters)=0;
sl@0
   816
	
sl@0
   817
	/**
sl@0
   818
	Retrieves the camera settings whose range got affected once the desired video settings (frame rate/frame size) are in place. 
sl@0
   819
	This method may be called by the client after receiving the notification KUidECamEventVideoCaptureControlSettingsRangeChanged.
sl@0
   820
sl@0
   821
	@param  aRangeAffectedSettings
sl@0
   822
			Retrieves the list of range affected settings
sl@0
   823
			
sl@0
   824
	@leave  May leave with any error code.  
sl@0
   825
sl@0
   826
	@see 	PrepareVideoCapture(const TPrepareVideoParameters& aPrepareVideoParameters)
sl@0
   827
	*/
sl@0
   828
	virtual void GetRangeAffectedSettingsL(RArray<TUid>& aRangeAffectedSettings) const=0;
sl@0
   829
	
sl@0
   830
	/**
sl@0
   831
	Retrieves the camera settings whose value got affected once the desired video settings (frame rate/frame size) are in place. 
sl@0
   832
	This method may be called by the client after receiving the notification KUidECamEventVideoCaptureControlSettingsValueChanged.
sl@0
   833
sl@0
   834
	@param  aValueAffectedSettings
sl@0
   835
			Retrieves the list of value affected settings
sl@0
   836
sl@0
   837
	@leave  May leave with any error code.
sl@0
   838
sl@0
   839
	@see 	PrepareVideoCapture(const TPrepareVideoParameters& aPrepareVideoParameters)	
sl@0
   840
	*/
sl@0
   841
	virtual void GetValueAffectedSettingsL(RArray<TUid>& aValueAffectedSettings) const=0;
sl@0
   842
	
sl@0
   843
	/**
sl@0
   844
	Retrieves the camera settings whose value got affected once the desired video settings (frame rate/frame size) are in place. 
sl@0
   845
	This method may be called by the client after receiving the notification KUidECamEventVideoCaptureControlSettingsDisabled.
sl@0
   846
sl@0
   847
	@param  aDisabledSettings
sl@0
   848
			Retrieves the list of disabled settings
sl@0
   849
sl@0
   850
	@leave  May leave with any error code.
sl@0
   851
sl@0
   852
	@see 	PrepareVideoCapture(const TPrepareVideoParameters& aPrepareVideoParameters)
sl@0
   853
	*/
sl@0
   854
	virtual void GetDisabledSettingsL(RArray<TUid>& aDisabledSettings) const=0;
sl@0
   855
	
sl@0
   856
	/**
sl@0
   857
	Frees the video resources which were set up as a result of CCameraVideoCaptureControl::PrepareVideoCapture call.
sl@0
   858
	If this methid is called while PrepareVideoCapture call is outstanding, then this will be equivalent to cancelling the
sl@0
   859
	PrepareVideoCapture call and release any allocated resources.
sl@0
   860
	*/
sl@0
   861
	virtual void ReleaseVideoResource()=0;
sl@0
   862
	
sl@0
   863
	/**
sl@0
   864
	Starts the video capture. This operation gives priority to the low latency aspects.
sl@0
   865
sl@0
   866
	Video frames are send to client via MCaptureVideoObserver::VideoBufferReady(MCameraBuffer2& aVideoBuffer, TInt aErrorCode).
sl@0
   867
sl@0
   868
	@leave  May leave with any error code.
sl@0
   869
sl@0
   870
	@note	This method is recommended to be used rather than CCamera::StartVideoCaptureL().
sl@0
   871
	*/												
sl@0
   872
	virtual void StartVideoCaptureL()=0;
sl@0
   873
sl@0
   874
	/**
sl@0
   875
	Stops the video capture. This operation gives priority to the low latency aspects.
sl@0
   876
sl@0
   877
	@note	This method is recommended to be used rather than CCamera::StopVideoCapture().
sl@0
   878
	*/												
sl@0
   879
	virtual void StopVideoCapture()=0;
sl@0
   880
	
sl@0
   881
	/**
sl@0
   882
	Pauses the on-going video capture. MCaptureVideoObserver::VideoBufferReady(MCameraBuffer2& aVideoBuffer, TInt aErrorCode) 
sl@0
   883
	callback will not be received by the client until the video capture is resumed.
sl@0
   884
	*/
sl@0
   885
	virtual void PauseVideoCapture()=0;
sl@0
   886
		
sl@0
   887
	/**
sl@0
   888
	Resumes the on-going video capture. MCaptureVideoObserver::VideoBufferReady(MCameraBuffer2& aVideoBuffer, TInt aErrorCode) 
sl@0
   889
	callback will again be received by the client.
sl@0
   890
sl@0
   891
	@leave  May leave with any error code.
sl@0
   892
	*/
sl@0
   893
	virtual void ResumeVideoCaptureL()=0;
sl@0
   894
	
sl@0
   895
	/**
sl@0
   896
	Retrieves the fading effect state for video capture.
sl@0
   897
sl@0
   898
	@param  aFadingEffectState
sl@0
   899
			Retrieves the current fading effect state for video capture.
sl@0
   900
sl@0
   901
	@leave  May leave with any error code.
sl@0
   902
	
sl@0
   903
	@internalTechnology
sl@0
   904
	*/
sl@0
   905
	virtual void GetFadingEffectStateL(CCamera::CCameraVideoCaptureControl::TFadingEffectState& aFadingEffectState) const=0;
sl@0
   906
		
sl@0
   907
	/**
sl@0
   908
	Sets the fading effect state for video capture.
sl@0
   909
sl@0
   910
	@param  aFadingEffectState
sl@0
   911
			The desired fading effect state for video capture.
sl@0
   912
			
sl@0
   913
	@note   Triggers a KUidECamEventVideoCaptureControlFadingEffect event notification.
sl@0
   914
	
sl@0
   915
	@internalTechnology
sl@0
   916
	*/	
sl@0
   917
	virtual void SetFadingEffectState(CCamera::CCameraVideoCaptureControl::TFadingEffectState aFadingEffectState)=0;
sl@0
   918
		
sl@0
   919
	/**
sl@0
   920
	Retrieves the current video capture state.
sl@0
   921
	
sl@0
   922
	@param aVideoCaptureState
sl@0
   923
		   Retrieves the current video capture state.
sl@0
   924
	
sl@0
   925
	@leave  May leave with any error code.
sl@0
   926
	*/
sl@0
   927
	virtual void GetVideoCaptureStateL(CCamera::CCameraVideoCaptureControl::TVideoCaptureState& aVideoCaptureState) const=0;
sl@0
   928
	
sl@0
   929
	/**
sl@0
   930
	Retrieves the various types of video capture supported. 
sl@0
   931
	@param  aSupportedVideoCaptureTypes
sl@0
   932
			Retrieves the supported video capture type. The TInt is retrieved as a bit field of supported 
sl@0
   933
			TVideoCaptureType.
sl@0
   934
			
sl@0
   935
	@leave  May leave with any error code.
sl@0
   936
	*/
sl@0
   937
	virtual void GetVideoCaptureSupportInfoL(TInt& aSupportedVideoCaptureTypes) const=0;
sl@0
   938
	
sl@0
   939
	/**
sl@0
   940
	Retrieves the current prepare video parameters.
sl@0
   941
	
sl@0
   942
	@param aPrepareVideoParameters
sl@0
   943
		   Retrieves the current prepare video parameters.
sl@0
   944
		   	
sl@0
   945
	@leave  May leave with any error code.
sl@0
   946
	*/
sl@0
   947
	virtual void GetPrepareVideoParametersL(CCamera::CCameraVideoCaptureControl::TPrepareVideoParameters& aPrepareVideoParameters) const=0;
sl@0
   948
	};
sl@0
   949
	
sl@0
   950
#endif // ECAMCAPTURECONTROLINTF_H