os/mm/imagingandcamerafws/camerafw/Include/ecamimageprocessing.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) 2005-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
 @publishedAll
sl@0
    19
 @released
sl@0
    20
*/
sl@0
    21
#ifndef  ECAMIMAGEPROCESSING_H
sl@0
    22
#define  ECAMIMAGEPROCESSING_H
sl@0
    23
sl@0
    24
#include <e32base.h>
sl@0
    25
#include <gdi.h>
sl@0
    26
#include <ecam.h>
sl@0
    27
#include <ecamadvsettingsuids.hrh>
sl@0
    28
#include <ecam/ecamconstants.h>
sl@0
    29
sl@0
    30
#ifndef SYMBIAN_ENABLE_SPLIT_HEADERS
sl@0
    31
#include <ecamimageprocessingconst.h>
sl@0
    32
#include <ecamimageprocessingdef.h>
sl@0
    33
#endif
sl@0
    34
sl@0
    35
sl@0
    36
class MCameraImageProcessing;
sl@0
    37
class MCameraImageProcessing2;
sl@0
    38
class MCameraImageProcessing3;
sl@0
    39
sl@0
    40
class MImplementationFactory;
sl@0
    41
sl@0
    42
/** 
sl@0
    43
The current Version of the TColorOperationCapabilities class.
sl@0
    44
sl@0
    45
*/
sl@0
    46
static const TUint KECamColorOperationCapabilitiesCurrentVersion = 1;
sl@0
    47
sl@0
    48
/** 
sl@0
    49
The current Version of the TBitsIgnore class.
sl@0
    50
sl@0
    51
*/
sl@0
    52
static const TUint KECamBitsIgnoreCurrentVersion = 1;
sl@0
    53
sl@0
    54
/** 
sl@0
    55
The current Version of the TColorOperationEntry class.
sl@0
    56
sl@0
    57
*/
sl@0
    58
static const TUint KECamColorOperationEntryCurrentVersion = 1;
sl@0
    59
sl@0
    60
sl@0
    61
/* General purpose constants */
sl@0
    62
sl@0
    63
/** 
sl@0
    64
	Uid used to identify the CCamera Post Processing API.
sl@0
    65
	Such image operations are performed on the acquired image by the camera itself. 
sl@0
    66
	@see CCamera::CCameraPresets
sl@0
    67
*/
sl@0
    68
static const TUid  KECamImageProcessingUid 	= {KECamImageProcessingUidValue};
sl@0
    69
sl@0
    70
/** Transformations */
sl@0
    71
/* Adjustments */
sl@0
    72
/** Brightness adjustment - recognized range [-100:100] */
sl@0
    73
static const TUid  KUidECamEventImageProcessingAdjustBrightness 	= {KUidECamEventImageProcessingAdjustBrightnessUidValue};
sl@0
    74
/** Contrast adjustment  - recognized range [-100:100] */
sl@0
    75
static const TUid  KUidECamEventImageProcessingAdjustContrast 		= {KUidECamEventImageProcessingAdjustContrastUidValue};
sl@0
    76
/** Gamma adjustment  - recognized range [0:1000] */
sl@0
    77
static const TUid  KUidECamEventImageProcessingAdjustGamma 			= {KUidECamEventImageProcessingAdjustGammaUidValue};
sl@0
    78
/** Sharpness adjustment - recognized range [-100:100] */
sl@0
    79
static const TUid  KUidECamEventImageProcessingAdjustSharpness 		= {KUidECamEventImageProcessingAdjustSharpnessUidValue};
sl@0
    80
/** Saturation adjustment  - recognized range [-100:100] */
sl@0
    81
static const TUid  KUidECamEventtImageProcessingAdjustSaturation 	= {KUidECamEventtImageProcessingAdjustSaturationUidValue};
sl@0
    82
static const TUid  KUidECamEventImageProcessingAdjustSaturation 	= {KUidECamEventtImageProcessingAdjustSaturationUidValue};
sl@0
    83
/** Hue adjustment  - recognized range [-100:100] */
sl@0
    84
static const TUid  KUidECamEventtImageProcessingAdjustHue 			= {KUidECamEventtImageProcessingAdjustHueUidValue};
sl@0
    85
static const TUid  KUidECamEventImageProcessingAdjustHue 			= {KUidECamEventtImageProcessingAdjustHueUidValue};
sl@0
    86
sl@0
    87
sl@0
    88
/** Effect value */
sl@0
    89
static const TUid  KUidECamEventImageProcessingEffect 				= {KUidECamEventImageProcessingEffectUidValue};
sl@0
    90
sl@0
    91
/* Transforms */
sl@0
    92
/** Crop */
sl@0
    93
static const TUid  KUidECamEventImageProcessingTransformCrop 		= {KUidECamEventImageProcessingTransformCropUidValue};
sl@0
    94
/** Rotation */
sl@0
    95
static const TUid  KUidECamEventImageProcessingTransformRotate 		= {KUidECamEventImageProcessingTransformRotateUidValue};
sl@0
    96
/** Mirroring */
sl@0
    97
static const TUid  KUidECamEventImageProcessingTransformMirror		= {KUidECamEventImageProcessingTransformMirrorUidValue};
sl@0
    98
/** Rescale */
sl@0
    99
static const TUid  KUidECamEventImageProcessingTransformScale		= {KUidECamEventImageProcessingTransformScaleUidValue};
sl@0
   100
/** origin subset */
sl@0
   101
static const TUid  KUidECamEventImageProcessingSourceRect 			= {KUidECamEventImageProcessingSourceRectUidValue};
sl@0
   102
/** Noise reduction */
sl@0
   103
static const TUid  KUidECamEventImageProcessingNoiseReduction		= {KUidECamEventImageProcessingNoiseReductionUidValue};
sl@0
   104
/** Glare removal */
sl@0
   105
static const TUid  KUidECamEventImageProcessingGlareRemoval			= {KUidECamEventImageProcessingGlareRemovalUidValue};
sl@0
   106
sl@0
   107
/** Default value for image processing */
sl@0
   108
static const TInt  KECamImageProcessingDefaultValue  = 0;
sl@0
   109
sl@0
   110
/**
sl@0
   111
Uid used to indicate completion of StartColorSwap
sl@0
   112
sl@0
   113
*/
sl@0
   114
static const TUid  KUidECamEventCIPStartColorSwap					= {KUidECamEventCIPStartColorSwapUidValue};
sl@0
   115
sl@0
   116
/**
sl@0
   117
Uid used to indicate completion of StartColorAccent
sl@0
   118
sl@0
   119
*/
sl@0
   120
static const TUid  KUidECamEventCIPStartColorAccent					= {KUidECamEventCIPStartColorAccentUidValue};
sl@0
   121
sl@0
   122
sl@0
   123
/** 
sl@0
   124
This class is used to perform image processing operations on the camera.
sl@0
   125
These include brightness, contrast, gamma, hue, sharpness and saturation adjustments. The client is also 
sl@0
   126
able to perform simple image transformations like cropping, rotation, mirroring, scaling, noise reduction and glare reduction. .  
sl@0
   127
When an operation selection is complete, all clients are notified with the respective event UID.
sl@0
   128
sl@0
   129
As often cameras may support only a subset of discrete values of the allowed range, 
sl@0
   130
the API allows the client to retrieve those and use them explicitly.   
sl@0
   131
sl@0
   132
@note This class is not intended for sub-classing and used to standardise existing
sl@0
   133
	  varieties of implementations.
sl@0
   134
sl@0
   135
@note it is assumed that setting a new value for a transformations(transform, adjust, effect) effectively
sl@0
   136
	  activates the transformations. Whilst for effects and adjustments there is always a value, transforms 
sl@0
   137
	  may have a dependency on other parameters and 
sl@0
   138
	  crop 	- requires setting of source rectangle.
sl@0
   139
	  scale - will use setting of source rectangle, and the magnification factor is 
sl@0
   140
	  		  determined by the source rectangle and the output size. This is always magnification.
sl@0
   141
	  		  if a value is set, it is assumed to be a scaling factor multiplied by KECamFineResolutionFactor
sl@0
   142
	  		  and set to integer.
sl@0
   143
	  mirror - values of TMirror type.
sl@0
   144
	  rotation - the angle in degrees.
sl@0
   145
	  noise reduction - TNoiseReduction.
sl@0
   146
	  glare removal - TGlareReduction.
sl@0
   147
sl@0
   148
	  	Example 
sl@0
   149
		
sl@0
   150
		@code
sl@0
   151
		// Lets assume that an application would need to check whether gamma correction is 
sl@0
   152
		// supported on a particular platform. After obtaining a valid pointer to the interface, 
sl@0
   153
		// it would call GetSupportedTransformationsL() to obtain the list of the supported 
sl@0
   154
		// transformations and check whether KUidECamEventImageProcessingAdjustGamma
sl@0
   155
		// is in the list. If it is then call SetTranformationValue(KUidECamEventImageProcessingAdjustGamma, 200);
sl@0
   156
		// to set the new value. A notification will be generated to the client to indicate success.
sl@0
   157
sl@0
   158
		RArray<TUid> suppTransforms; // array of supported transformations
sl@0
   159
		CleanupClosePushL(suppTransforms);
sl@0
   160
sl@0
   161
		imageProcess->GetSupportedTransformationsL(suppTransfUids);
sl@0
   162
		 ...
sl@0
   163
		// if the gamma is supported 
sl@0
   164
		TInt gammaCorrection = 200; // gamma correction of 2.0
sl@0
   165
		imageProcess->SetTranformationValue(KUidECamEventImageProcessingAdjustGamma, gammaCorrection);
sl@0
   166
		...
sl@0
   167
		// pop stack to close the RArray
sl@0
   168
		@endcode
sl@0
   169
		
sl@0
   170
@note   If the class methods leave, the output type parameter value is not guaranteed to be valid.
sl@0
   171
sl@0
   172
@publishedAll
sl@0
   173
@released	
sl@0
   174
*/
sl@0
   175
class CCamera::CCameraImageProcessing : public CBase
sl@0
   176
	{
sl@0
   177
	
sl@0
   178
	// so can use internal factory functions etc.
sl@0
   179
	friend class CCamera;
sl@0
   180
	
sl@0
   181
public: 
sl@0
   182
	
sl@0
   183
	/** Gamma settings */		
sl@0
   184
   	enum TGamma
sl@0
   185
	   	{
sl@0
   186
   		/** Sets the gamma adjustment automatically. */
sl@0
   187
	   	EGammaAuto						= KMinTInt
sl@0
   188
	   	};
sl@0
   189
	/** Sharpness Settings */	   	
sl@0
   190
	enum TSharpness
sl@0
   191
	   	{
sl@0
   192
   		/** Sets the sharpness adjustment automatically. */
sl@0
   193
	   	ESharpnessAuto					= KMinTInt
sl@0
   194
	   	};   	
sl@0
   195
	/** Saturation Settings */	 
sl@0
   196
	enum TSaturation
sl@0
   197
	   	{
sl@0
   198
   		/** Sets the saturation adjustment automatically. */
sl@0
   199
	   	ESaturationAuto					= KMinTInt
sl@0
   200
	   	};
sl@0
   201
	/** Hue Settings */	 
sl@0
   202
	enum THue
sl@0
   203
	   	{
sl@0
   204
   		/** Sets the hue adjustment automatically. */
sl@0
   205
	   	EHueAuto						= KMinTInt
sl@0
   206
	   	};	   	
sl@0
   207
	   	     	
sl@0
   208
	/** Settings for the supported effects */
sl@0
   209
	enum TEffect
sl@0
   210
	  	{
sl@0
   211
		/** Effects off is default, always supported */
sl@0
   212
		EEffectNone			     	= 0x00000000,
sl@0
   213
		/** Negative visual effect. */
sl@0
   214
		EEffectNegative		   		= 0x00000001,
sl@0
   215
		/** Black and white visual effect. */
sl@0
   216
		EEffectMonochrome 			= 0x00000002,
sl@0
   217
		/** Solarization visual effect. */
sl@0
   218
		EEffectSolarize		 		= 0x00000004,
sl@0
   219
		/** Sepia visual effect. */
sl@0
   220
		EEffectSepia		     	= 0x00000008,
sl@0
   221
		/** Emboss visual effect. */
sl@0
   222
		EEffectEmboss 				= 0x00000010,
sl@0
   223
		/** Red eye glare reduction visual effect. */
sl@0
   224
		EEffectRedEyeReduction 		= 0x00000020,
sl@0
   225
		/** Vivid colour visual effect. */ 
sl@0
   226
		EEffectVivid 				= 0x00000040,
sl@0
   227
		/** Neutral colour visual effect. */ 
sl@0
   228
		EEffectNeutral 				= 0x00000080,
sl@0
   229
		/** Selective sharpening visual effect. */ 
sl@0
   230
		EEffectLowSharpening		= 0x00000100,
sl@0
   231
		/** 
sl@0
   232
		Natural visual effect. 
sl@0
   233
		
sl@0
   234
		This enum value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or 
sl@0
   235
		CCamera::NewDuplicate2L().
sl@0
   236
		
sl@0
   237
		*/
sl@0
   238
		EEffectNatural 				= 0x00000200, 
sl@0
   239
		/** 
sl@0
   240
		Cine visual effect. 
sl@0
   241
		
sl@0
   242
		This enum value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or 
sl@0
   243
		CCamera::NewDuplicate2L().
sl@0
   244
		
sl@0
   245
		*/
sl@0
   246
		EEffectCine 				= 0x00000400, 
sl@0
   247
		/** 
sl@0
   248
		Old film visual effect. 
sl@0
   249
		
sl@0
   250
		This enum value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or 
sl@0
   251
		CCamera::NewDuplicate2L().
sl@0
   252
		
sl@0
   253
		*/
sl@0
   254
		EEffectOldFilm 				= 0x00000800,  
sl@0
   255
		/** 
sl@0
   256
		Color swap visual effect. 
sl@0
   257
		
sl@0
   258
		This enum value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or 
sl@0
   259
		CCamera::NewDuplicate2L().
sl@0
   260
		
sl@0
   261
		*/
sl@0
   262
		EEffectColorSwap 			= 0x00001000, 
sl@0
   263
		/** 
sl@0
   264
		Where a list of color can be kept as they are and the rest converted to gray. 
sl@0
   265
	
sl@0
   266
		This enum value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or 
sl@0
   267
		CCamera::NewDuplicate2L().
sl@0
   268
	
sl@0
   269
		*/
sl@0
   270
		EEffectColorAccent			= 0x00002000
sl@0
   271
 		};
sl@0
   272
		
sl@0
   273
	/** Mirror settings */		
sl@0
   274
	enum TMirror
sl@0
   275
		{
sl@0
   276
		/** Default value. Mirroring is disabled. */
sl@0
   277
		EMirrorNone			= 0x00000000, 
sl@0
   278
		/** Mirror along horizontal axis. */
sl@0
   279
		EMirrorHorizontal	= 0x00000001,
sl@0
   280
		/** Mirror along vertical axis. */
sl@0
   281
		EMirrorVertical		= 0x00000002,
sl@0
   282
		/** Mirror along horizontal and vertical axis. */
sl@0
   283
		EMirrorBoth			= 0x00000003
sl@0
   284
		};
sl@0
   285
	
sl@0
   286
	/** Noise filter settings */		
sl@0
   287
	enum TNoiseReduction
sl@0
   288
		{
sl@0
   289
		/** Default value. Noise reduction disabled. */
sl@0
   290
		ENoiseReductionNone			= 0x0000, 
sl@0
   291
		/** most basic noise reduction. */
sl@0
   292
		ENoiseReductionBasic		= 0x0001
sl@0
   293
		};
sl@0
   294
	
sl@0
   295
	/** Glare reduction settings */		
sl@0
   296
	enum TGlareReduction
sl@0
   297
		{
sl@0
   298
		/** Default value. Glare reduction disabled. */
sl@0
   299
		EGlareReductionNone			= 0x0000, 
sl@0
   300
		/** most basic glare reduction. */
sl@0
   301
		EGlareReductionBasic		= 0x0001
sl@0
   302
		};
sl@0
   303
	
sl@0
   304
	/** 
sl@0
   305
	Used for color swap and color accent feature in TEffect. It describes whether the given source 
sl@0
   306
	or target color represents itself or a group of color.
sl@0
   307
	
sl@0
   308
	*/
sl@0
   309
	enum TColorOperationRepresentation
sl@0
   310
		{
sl@0
   311
		/** Feature is not supported */
sl@0
   312
		ERepresentationNone         = 0x00,
sl@0
   313
		/** The given color is uniquely represented */
sl@0
   314
		ERepresentationSingle	    = 0x01,
sl@0
   315
		/** The given color represents a group of colors */
sl@0
   316
		ERepresentationMultiple     = 0x02
sl@0
   317
		};
sl@0
   318
sl@0
   319
	/**
sl@0
   320
	Used for color swap and color accent feature in TEffect. It describes the type of grouping for 
sl@0
   321
	source and target colors when they represent a group of color.
sl@0
   322
	
sl@0
   323
	*/
sl@0
   324
	enum TColorOperationRgbGroupingMode
sl@0
   325
		{
sl@0
   326
		/** Feature is not supported */
sl@0
   327
		ERgbGroupingNone			= 0x00,
sl@0
   328
		/** This means no neighbourhood colors are considered */
sl@0
   329
		ERgbGroupingFixed			= 0x01,
sl@0
   330
		/** This means neighbourhood colors are to be automatically decided by the implementation or hardware */
sl@0
   331
		ERgbGroupingAutomatic		= 0x02,
sl@0
   332
		/** This means neighbourhood colors for source have to be decided by ignoring few starting bits. Used for source only */
sl@0
   333
		ERgbGroupingSignificantBits = 0x04,
sl@0
   334
		/** This means colors in target are obtained as some uniform proportion using source. Used for target only */
sl@0
   335
		ERgbGroupingUniform			= 0x08
sl@0
   336
		};
sl@0
   337
	
sl@0
   338
	/**
sl@0
   339
	Used to provide different types of references for orientation of images retrieved. These references are the various 
sl@0
   340
	means by the orientation of an image can be defined. Client needs to choose a particular TOrientationReference and 
sl@0
   341
	specify any relative rotation, mirroring and flipping on top of it.	
sl@0
   342
	
sl@0
   343
	This enumeration has nothing to do with absolute rotation. Uid KUidECamEventImageProcessingTransformRotate is used 
sl@0
   344
	for absolute rotation purposes.
sl@0
   345
	
sl@0
   346
	The enumeration list may be extended in future.	
sl@0
   347
	
sl@0
   348
	@publishedPartner
sl@0
   349
	@prototype
sl@0
   350
	*/
sl@0
   351
	enum TOrientationReference
sl@0
   352
		{
sl@0
   353
		/** The retrieved images will follow the camera sensor orientation. This orientation would be relative 
sl@0
   354
		to the current screen mode as given by the reference screen. */
sl@0
   355
		EOrientationReferenceCameraSensorOrientation,
sl@0
   356
	
sl@0
   357
		/** The retrieved images will get oriented as per the tilt sensor information. 
sl@0
   358
		So,the orientation would be relative to the current screen mode as given by the reference screen. */
sl@0
   359
		EOrientationReferenceTiltOrientation
sl@0
   360
		};
sl@0
   361
	
sl@0
   362
	/**
sl@0
   363
	Used to describe the various relative rotation. The term 'relative' means that the rotation is applied after the 
sl@0
   364
	image undergoes orientation as given by TOrientationReference.
sl@0
   365
	
sl@0
   366
	The enumeration list may be extended in future.	
sl@0
   367
	
sl@0
   368
	@publishedPartner
sl@0
   369
	@prototype
sl@0
   370
	*/
sl@0
   371
	enum TRelativeRotation
sl@0
   372
		{
sl@0
   373
		/** Zero degree Rotation applied on top of orientation reference and is relative to current reference screen. */
sl@0
   374
		ERelativeRotation0Degrees				= 0x00,
sl@0
   375
		/** 90 degree clockwise Rotation applied on top of orientation reference and is relative to current reference screen. */
sl@0
   376
		ERelativeRotation90DegreesClockwise 	= 0x01,
sl@0
   377
		/** 180 degree clockwise Rotation applied on top of orientation reference and is relative to current reference screen. */
sl@0
   378
		ERelativeRotation180DegreesClockwise	= 0x02,
sl@0
   379
		/** 270 degree clockwise Rotation applied on top of orientation reference and is relative to current reference screen. */
sl@0
   380
		ERelativeRotation270DegreesClockwise 	= 0x04
sl@0
   381
		};
sl@0
   382
		
sl@0
   383
	/**
sl@0
   384
	Used to describe the various relative mirroring. The term 'relative' means that the mirroring is applied after the 
sl@0
   385
	image undergoes orientation as given by TOrientationReference.
sl@0
   386
		
sl@0
   387
	The enumeration list may be extended in future.	
sl@0
   388
	
sl@0
   389
	@publishedPartner
sl@0
   390
	@prototype
sl@0
   391
	*/
sl@0
   392
	enum TRelativeMirror
sl@0
   393
		{
sl@0
   394
		/** No mirroring. */
sl@0
   395
		ERelativeMirrorNone				= 0x00,
sl@0
   396
		/** Used to mirror an image about the horizontal axis. This is applied on top of orientation reference and is 
sl@0
   397
		relative to current reference screen. */
sl@0
   398
		ERelativeMirrorHorizontalAxis	= 0x10,
sl@0
   399
		/** Used to mirror an image about the vertical axis. This is applied on top of orientation reference and is 
sl@0
   400
		relative to current reference screen. */
sl@0
   401
		ERelativeMirrorVerticalAxis 	= 0x20 
sl@0
   402
		};
sl@0
   403
		
sl@0
   404
	/**
sl@0
   405
	Used to describe the various relative flipping. The term 'relative' means that the flipping is applied after the 
sl@0
   406
	image undergoes orientation as given by TOrientationReference.
sl@0
   407
	
sl@0
   408
	The enumeration list may be extended in future.
sl@0
   409
	
sl@0
   410
	@publishedPartner
sl@0
   411
	@prototype
sl@0
   412
	*/
sl@0
   413
	enum TRelativeFlipping
sl@0
   414
		{
sl@0
   415
		/** No flipping. */
sl@0
   416
		ERelativeFlippingNone			= 0x00,
sl@0
   417
		/** Used to flip an image horizontally. This is applied on top of orientation reference and is relative to current
sl@0
   418
		reference screen. */
sl@0
   419
		ERelativeFlippingHorizontal		= 0x10,
sl@0
   420
		/** Used to flip an image vertically. This is applied on top of orientation reference and is relative to current
sl@0
   421
		reference screen. */
sl@0
   422
		ERelativeFlippingVertical 		= 0x20 
sl@0
   423
		};
sl@0
   424
		
sl@0
   425
	/**
sl@0
   426
	Different types of contrast enhancement options.
sl@0
   427
	The enumeration list may be extended in future.
sl@0
   428
	
sl@0
   429
	@publishedPartner
sl@0
   430
	@prototype
sl@0
   431
	*/	
sl@0
   432
	enum TContrastEnhancement
sl@0
   433
		{
sl@0
   434
		/** Not Supported. */
sl@0
   435
		EContrastEnhancementNone				=0x00,
sl@0
   436
		/** Contrast Enhancement switched off. */
sl@0
   437
		EContrastEnhancementSwitchOff			=0x01,
sl@0
   438
		/** Contrast Enhacement switched On manually. */
sl@0
   439
		EContrastEnhancementManualSwitchOn		=0x02,
sl@0
   440
		/** Contrast Enhancement in auto mode. */
sl@0
   441
		EContrastEnhancementSwitchAuto			=0x04
sl@0
   442
		};
sl@0
   443
		
sl@0
   444
	/**
sl@0
   445
	Different types of software-based red eye reduction options.
sl@0
   446
	The enumeration list may be extended in future.
sl@0
   447
	
sl@0
   448
	@publishedPartner
sl@0
   449
	@prototype
sl@0
   450
	*/
sl@0
   451
	enum TRedEyeReduction
sl@0
   452
		{
sl@0
   453
		/** Not Supported. */
sl@0
   454
		ERedEyeReductionNone				=0x00,
sl@0
   455
		/** Software based Red Eye Reduction can be switched off(disabled). */
sl@0
   456
		ERedEyeReductionSwitchOff			=0x01,
sl@0
   457
		/** Software based Red Eye Reduction can be switched on (enabled). */
sl@0
   458
		ERedEyeReductionManualSwitchOn		=0x02,
sl@0
   459
		/** Software based Red Eye Reduction can be put to auto mode. */
sl@0
   460
		ERedEyeReductionSwitchAuto			=0x04
sl@0
   461
		};
sl@0
   462
sl@0
   463
	/** 
sl@0
   464
	Color operation capabilities characterizing both color swap and color accent feature 
sl@0
   465
	
sl@0
   466
	*/
sl@0
   467
	class TColorOperationCapabilities
sl@0
   468
		{
sl@0
   469
	public:
sl@0
   470
		/**
sl@0
   471
		Constructor.
sl@0
   472
		Sets the size of this class in iSize.
sl@0
   473
		*/
sl@0
   474
		IMPORT_C TColorOperationCapabilities();
sl@0
   475
		
sl@0
   476
		IMPORT_C TInt Size() const;
sl@0
   477
		IMPORT_C TUint Version() const;
sl@0
   478
	
sl@0
   479
	private:
sl@0
   480
		//for future expansion
sl@0
   481
		TUint iSize:24;
sl@0
   482
		TUint iVersion:8;
sl@0
   483
		
sl@0
   484
		// reserved for future expansion
sl@0
   485
		TInt    iReserved;
sl@0
   486
		
sl@0
   487
	public:
sl@0
   488
		/** The source color representation that the server supports.
sl@0
   489
	    The supported representations are held as a bitwise logical OR of the relevant individual modes
sl@0
   490
	    defined in CCamera::CCameraImageProcessing:: TColorOperationRepresentation. */
sl@0
   491
		TUint	iSupportedSourceRepresentation;
sl@0
   492
		
sl@0
   493
		/** The target color representation that the server supports.
sl@0
   494
	    The supported representations are held as a bitwise logical OR of the relevant individual modes
sl@0
   495
	    defined in CCamera::CCameraImageProcessing:: TColorOperationRepresentation.
sl@0
   496
	    Not applicable for color accent */
sl@0
   497
		TUint	iSupportedTargetRepresentation;
sl@0
   498
sl@0
   499
		/** The source color Rgb grouping modes that the server supports.
sl@0
   500
	    The modes are held as a bitwise logical OR of the relevant individual modes
sl@0
   501
	    defined in CCamera::CCameraImageProcessing:: TColorOperationRgbGroupingMode. */
sl@0
   502
		TUint   iSupportedSourceRgbGroupingMode;
sl@0
   503
sl@0
   504
		/** The target color Rgb grouping modes that the server supports.
sl@0
   505
	    The modes are held as a bitwise logical OR of the relevant individual modes
sl@0
   506
	    defined in CCamera::CCameraImageProcessing:: TColorOperationRgbGroupingMode. 
sl@0
   507
	    Not applicable for color accent */
sl@0
   508
		TUint   iSupportedTargetRgbGroupingMode;
sl@0
   509
		
sl@0
   510
		/** This indicates whether the mapping mode and Rgb grouping mode uniform for every color entry */
sl@0
   511
		TBool   iIsCapabilityUniform;
sl@0
   512
		};
sl@0
   513
sl@0
   514
	/** 
sl@0
   515
	Class used to control the number of bits to ignore for Red, Green, Blue or Alpha.
sl@0
   516
	This may be used when deciding for neighbourhood for source color in case of color swap and color accent feature
sl@0
   517
sl@0
   518
	*/
sl@0
   519
	class TBitsIgnore
sl@0
   520
		{
sl@0
   521
	public:
sl@0
   522
		/**
sl@0
   523
		Constructor.
sl@0
   524
		Sets the size of this class in iSize.
sl@0
   525
		*/
sl@0
   526
		IMPORT_C TBitsIgnore();
sl@0
   527
		
sl@0
   528
		IMPORT_C TInt Size() const;
sl@0
   529
		IMPORT_C TUint Version() const;
sl@0
   530
	
sl@0
   531
	private:
sl@0
   532
		//for future expansion
sl@0
   533
		TUint iSize:24;
sl@0
   534
		TUint iVersion:8;
sl@0
   535
		
sl@0
   536
		// for future use
sl@0
   537
		TUint iReservedBits:16;
sl@0
   538
			
sl@0
   539
	public:
sl@0
   540
		/** This gives the no. of bits to ignore for Red color. Varies from 0 to 8. 
sl@0
   541
		Any other value should be an error */
sl@0
   542
		TUint iRedBitsIgnore:4;
sl@0
   543
		
sl@0
   544
		/** This gives the no. of bits to ignore for Green color. Varies from 0 to 8. 
sl@0
   545
		Any other value should be an error */
sl@0
   546
		TUint iGreenBitsIgnore:4;
sl@0
   547
		
sl@0
   548
		/** This gives the no. of bits to ignore for Blue color. Varies from 0 to 8. 
sl@0
   549
		Any other value should be an error */
sl@0
   550
		TUint iBlueBitsIgnore:4;
sl@0
   551
sl@0
   552
		/** This gives the no. of bits to ignore for Alpha. Varies from 0 to 8. 
sl@0
   553
		Any other value should be an error */
sl@0
   554
		TUint iAlphaBitsIgnore:4;
sl@0
   555
		};
sl@0
   556
sl@0
   557
	/** 
sl@0
   558
	Color operation parameters characterizing both color swap and color accent feature; and for a particular entry.
sl@0
   559
	 
sl@0
   560
	*/
sl@0
   561
	class TColorOperationEntry
sl@0
   562
		{
sl@0
   563
	public:
sl@0
   564
		/**
sl@0
   565
		Constructor.
sl@0
   566
		Sets the size of this class in iSize.
sl@0
   567
		*/
sl@0
   568
		IMPORT_C TColorOperationEntry();
sl@0
   569
				
sl@0
   570
		IMPORT_C TInt Size() const;
sl@0
   571
		IMPORT_C TUint Version() const;
sl@0
   572
sl@0
   573
	private:
sl@0
   574
		//for future expansion
sl@0
   575
		TUint iSize:24;
sl@0
   576
		TUint iVersion:8;
sl@0
   577
		
sl@0
   578
		// reserved for future expansion
sl@0
   579
		TInt iReserved;
sl@0
   580
		
sl@0
   581
	public:
sl@0
   582
		/** The source color (rgb triplet) which is changed to target color in case of Color Swap operation 
sl@0
   583
		and remains unaffected in case of Color Accent operation */
sl@0
   584
		TRgb iSourceColor;
sl@0
   585
sl@0
   586
		/** The target color (rgb triplet) which replaces the source color in case of Color Swap operation. 
sl@0
   587
		Redundant for Color Accent operation */
sl@0
   588
		TRgb iTargetColor;
sl@0
   589
sl@0
   590
		/** This defines whether the given source color represents itself or a group of colors */
sl@0
   591
		TColorOperationRepresentation iSourceColorRepresentation;
sl@0
   592
sl@0
   593
		/** This defines whether the given target color represents itself or a group of colors in case of 
sl@0
   594
		Color Swap operation. Redundant for Color Accent operation */
sl@0
   595
		TColorOperationRepresentation iTargetColorRepresentation;
sl@0
   596
sl@0
   597
		/** This defines the type of grouping for multiple representation of source color */
sl@0
   598
		TColorOperationRgbGroupingMode iColorOperationSourceRgbGroupingMode;
sl@0
   599
sl@0
   600
		/** This defines the type of grouping for multiple representation of target color in case of 
sl@0
   601
		Color Swap operation. Redundant for Color Accent operation */
sl@0
   602
		TColorOperationRgbGroupingMode iColorOperationTargetRgbGroupingMode;  
sl@0
   603
sl@0
   604
		/** This gives the number of bits to ignore in case ERgbGroupingSignificantBits is used for 
sl@0
   605
		multiple representation of source color. For any other case, no. of bits ignored for red, green, 
sl@0
   606
		blue or alpha should be 0 */
sl@0
   607
		TBitsIgnore iNumBitsIgnored;
sl@0
   608
sl@0
   609
		/** This gives the entry status of every color operation entry. If entry is not set or removed, 
sl@0
   610
		this is ENotActive. And if entry is set, then this is EDiscreteSteps */
sl@0
   611
		TValueInfo iEntryStatus;
sl@0
   612
		};
sl@0
   613
sl@0
   614
public:
sl@0
   615
	
sl@0
   616
    IMPORT_C static CCameraImageProcessing* NewL(CCamera& aCamera);
sl@0
   617
    
sl@0
   618
    IMPORT_C static CCameraImageProcessing* CreateL(CCamera& aCamera, MImplementationFactory& aImplFactory);
sl@0
   619
    
sl@0
   620
	IMPORT_C void GetSupportedTransformationsL(RArray<TUid>& aTransformations) const;
sl@0
   621
sl@0
   622
	IMPORT_C void GetActiveTransformationsL(RArray<TUid>& aTransformations) const;
sl@0
   623
sl@0
   624
	IMPORT_C void GetTransformationSupportedValuesL(TUid aTransformation, RArray<TInt>& aValues, TValueInfo& aInfo) const;
sl@0
   625
sl@0
   626
	IMPORT_C TInt TransformationValue(TUid aTransformation) const;
sl@0
   627
	
sl@0
   628
	IMPORT_C TInt GetTransformationValue(TUid aTransformation, TInt& aTransformationValue) const;
sl@0
   629
sl@0
   630
	IMPORT_C void SetTransformationValue(TUid aTransformation, TInt aValue);
sl@0
   631
sl@0
   632
	IMPORT_C void GetActiveTransformSequenceL(RArray<TUid>& aTransformSequence) const;
sl@0
   633
sl@0
   634
	IMPORT_C void SetActiveTransformSequenceL(RArray<TUid>& aTransformSequence);
sl@0
   635
sl@0
   636
	IMPORT_C void SetSourceRect(const TRect& aRect);
sl@0
   637
sl@0
   638
	IMPORT_C void GetSourceRect(TRect& aRect) const;
sl@0
   639
sl@0
   640
	IMPORT_C ~CCameraImageProcessing();
sl@0
   641
	
sl@0
   642
	IMPORT_C void GetConcurrentColorSwappingsSupportedL(TInt& aConcurrentColorSwappingSupported) const; 
sl@0
   643
	
sl@0
   644
	IMPORT_C void GetColorSwapCapabilitiesL(TInt aIndex, TColorOperationCapabilities& aColorSwapCapabilities) const;
sl@0
   645
	
sl@0
   646
	IMPORT_C void SetColorSwapEntryL(TInt aIndex, const TColorOperationEntry& aColorSwapParameters); 
sl@0
   647
	
sl@0
   648
	IMPORT_C void RemoveColorSwapEntryL(TInt aIndex);
sl@0
   649
	
sl@0
   650
	IMPORT_C void GetColorSwapEntryL(TInt aIndex, TColorOperationEntry& aColorSwapParameters) const; 
sl@0
   651
	
sl@0
   652
	IMPORT_C void StartColorSwappingL();
sl@0
   653
	
sl@0
   654
	IMPORT_C void CancelColorSwappingL();
sl@0
   655
	
sl@0
   656
	IMPORT_C void GetConcurrentColorAccentSupportedL(TInt& aConcurrentColorAccentSupported) const; 
sl@0
   657
	
sl@0
   658
	IMPORT_C void GetColorAccentCapabilitiesL(TInt aIndex, TColorOperationCapabilities& aColorAccentCapabilities) const;
sl@0
   659
	
sl@0
   660
	IMPORT_C void SetColorAccentEntryL(TInt aIndex, const TColorOperationEntry& aColorAccentParameters); 
sl@0
   661
	
sl@0
   662
	IMPORT_C void RemoveColorAccentEntryL(TInt aIndex);
sl@0
   663
	
sl@0
   664
	IMPORT_C void GetColorAccentEntryL(TInt aIndex, TColorOperationEntry& aColorAccentParameters) const; 
sl@0
   665
	
sl@0
   666
	IMPORT_C void StartColorAccentL();
sl@0
   667
	
sl@0
   668
	IMPORT_C void CancelColorAccentL();
sl@0
   669
	
sl@0
   670
	IMPORT_C void GetSupportedRelativeOrientationOptionsL(TOrientationReference aOrientationReference, 
sl@0
   671
		TUint& aSupportedRelativeRotation, TUint& aSupportedRelativeMirroring, TUint& aSupportedRelativeFlipping) const;
sl@0
   672
																
sl@0
   673
	IMPORT_C void GetCurrentRelativeOrientationOptionsL(TOrientationReference& aOrientationReference, 
sl@0
   674
		TRelativeRotation& aRelativeRotation, TRelativeMirror& aRelativeMirror, TRelativeFlipping& aRelativeFlipping) const;
sl@0
   675
												
sl@0
   676
	IMPORT_C void SetRelativeOrientationOptionsL(TOrientationReference aOrientationReference, 
sl@0
   677
		TRelativeRotation aRelativeRotation, TRelativeMirror aRelativeMirror, TRelativeFlipping aRelativeFlipping);
sl@0
   678
	
sl@0
   679
private:
sl@0
   680
	IMPORT_C CCameraImageProcessing(CCamera& aOwner);
sl@0
   681
	IMPORT_C void ConstructL();
sl@0
   682
	IMPORT_C void ConstructL(const MImplementationFactory& aImplFactory);
sl@0
   683
	
sl@0
   684
private:
sl@0
   685
	CCamera& iOwner;
sl@0
   686
	MCameraImageProcessing* iImpl;  // not owned
sl@0
   687
	MCameraImageProcessing2* iImpl2;   //not owned
sl@0
   688
	MCameraImageProcessing3* iImpl3;   //not owned
sl@0
   689
	};
sl@0
   690
#endif//ECAMIMAGEPROCESSING_H
sl@0
   691
sl@0
   692
sl@0
   693