1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/os/mm/imagingandcamerafws/camerafw/Include/ecamadvsettings.h Fri Jun 15 03:10:57 2012 +0200
1.3 @@ -0,0 +1,1655 @@
1.4 +// Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
1.5 +// All rights reserved.
1.6 +// This component and the accompanying materials are made available
1.7 +// under the terms of "Eclipse Public License v1.0"
1.8 +// which accompanies this distribution, and is available
1.9 +// at the URL "http://www.eclipse.org/legal/epl-v10.html".
1.10 +//
1.11 +// Initial Contributors:
1.12 +// Nokia Corporation - initial contribution.
1.13 +//
1.14 +// Contributors:
1.15 +//
1.16 +// Description:
1.17 +//
1.18 +
1.19 +/**
1.20 + @file
1.21 + @publishedAll
1.22 + @released
1.23 +*/
1.24 +#ifndef ECAMADVSETTINGS_H
1.25 +#define ECAMADVSETTINGS_H
1.26 +
1.27 +#include <e32base.h>
1.28 +#include <ecam.h>
1.29 +#include <ecamadvsettingsuids.hrh>
1.30 +#include <gdi.h>
1.31 +#include <s32strm.h>
1.32 +#include <ecam/ecamconstants.h>
1.33 +#include <ecamimageprocessing.h>
1.34 +#ifndef SYMBIAN_ENABLE_SPLIT_HEADERS
1.35 +#include <ecamadvsettingsconst.h>
1.36 +#include <ecamadvsettingsdef.h>
1.37 +#endif
1.38 +
1.39 +class MCameraPresets;
1.40 +class MCameraAdvancedSettings;
1.41 +class MCameraAdvancedSettings2;
1.42 +class MCameraAdvancedSettings3;
1.43 +class MCameraAdvancedSettings4;
1.44 +class MCameraPresets2;
1.45 +class MCameraContinuousZoom;
1.46 +
1.47 +/* General purpose constants */
1.48 +
1.49 +
1.50 +/**
1.51 + UID used to identify the CCamera Advanced Settings API.
1.52 + This API is used to control specific individual advanced settings of camera hardware.
1.53 + These settings directly relate to the image acquisition phase.
1.54 +
1.55 + @see CCamera::CCameraAdvancedSettings
1.56 +*/
1.57 +static const TUid KECamAdvancedSettingUid = {KECamAdvancedSettingUidValue};
1.58 +
1.59 +/**
1.60 + UID used to identify the CCamera Presets API.
1.61 + This API is used to simplify user - camera interaction by allowing simultaneous
1.62 + setting of various advanced camera hardware settings using a single predefined parameter.
1.63 + @see CCamera::CCameraPresets
1.64 +*/
1.65 +static const TUid KECamPresetsUid = {KECamPresetsUidValue};
1.66 +
1.67 +/** All clients receive these events, irrespective of camera index. */
1.68 +/** Camera slots in for 8 cameras. */
1.69 +/** Camera with index 0 Plugged-in */
1.70 +static const TUid KUidECamEventGlobalCamera00PluggedIn = {KUidECamEventGlobalCamera00PluggedInUidValue};
1.71 +/** Camera with index 1 Plugged-in */
1.72 +static const TUid KUidECamEventGlobalCamera01PluggedIn = {KUidECamEventGlobalCamera01PluggedInUidValue};
1.73 +/** Camera with index 2 Plugged-in */
1.74 +static const TUid KUidECamEventGlobalCamera02PluggedIn = {KUidECamEventGlobalCamera02PluggedInUidValue};
1.75 +/** Camera with index 3 Plugged-in */
1.76 +static const TUid KUidECamEventGlobalCamera03PluggedIn = {KUidECamEventGlobalCamera03PluggedInUidValue};
1.77 +/** Camera with index 4 Plugged-in */
1.78 +static const TUid KUidECamEventGlobalCamera04PluggedIn = {KUidECamEventGlobalCamera04PluggedInUidValue};
1.79 +/** Camera with index 5 Plugged-in */
1.80 +static const TUid KUidECamEventGlobalCamera05PluggedIn = {KUidECamEventGlobalCamera05PluggedInUidValue};
1.81 +/** Camera with index 6 Plugged-in */
1.82 +static const TUid KUidECamEventGlobalCamera06PluggedIn = {KUidECamEventGlobalCamera06PluggedInUidValue};
1.83 +/** Camera with index 7 Plugged-in */
1.84 +static const TUid KUidECamEventGlobalCamera07PluggedIn = {KUidECamEventGlobalCamera07PluggedInUidValue};
1.85 +
1.86 +/** Camera slots plugged out for 8 cameras. */
1.87 +/** Camera with index 0 Plugged-out */
1.88 +static const TUid KUidECamEventGlobalCamera00PluggedOut = {KUidECamEventGlobalCamera00PluggedOutUidValue};
1.89 +/** Camera with index 1 Plugged-out */
1.90 +static const TUid KUidECamEventGlobalCamera01PluggedOut = {KUidECamEventGlobalCamera01PluggedOutUidValue};
1.91 +/** Camera with index 2 Plugged-out */
1.92 +static const TUid KUidECamEventGlobalCamera02PluggedOut = {KUidECamEventGlobalCamera02PluggedOutUidValue};
1.93 +/** Camera with index 3 Plugged-out */
1.94 +static const TUid KUidECamEventGlobalCamera03PluggedOut = {KUidECamEventGlobalCamera03PluggedOutUidValue};
1.95 +/** Camera with index 4 Plugged-out */
1.96 +static const TUid KUidECamEventGlobalCamera04PluggedOut = {KUidECamEventGlobalCamera04PluggedOutUidValue};
1.97 +/** Camera with index 5 Plugged-out */
1.98 +static const TUid KUidECamEventGlobalCamera05PluggedOut = {KUidECamEventGlobalCamera05PluggedOutUidValue};
1.99 +/** Camera with index 6 Plugged-out */
1.100 +static const TUid KUidECamEventGlobalCamera06PluggedOut = {KUidECamEventGlobalCamera06PluggedOutUidValue};
1.101 +/** Camera with index 7 Plugged-out */
1.102 +static const TUid KUidECamEventGlobalCamera07PluggedOut = {KUidECamEventGlobalCamera07PluggedOutUidValue};
1.103 +
1.104 +/** Camera slots available for 8 cameras. */
1.105 +/** Signals a camera previously has been reserved and then released again.
1.106 + In this way available clients may attempt to reserve the camera */
1.107 +/** Camera with index 0 Available. */
1.108 +static const TUid KUidECamEventGlobalCamera00Available = {KUidECamEventGlobalCamera00AvailableUidValue};
1.109 +/** Camera with index 1 Available. */
1.110 +static const TUid KUidECamEventGlobalCamera01Available = {KUidECamEventGlobalCamera01AvailableUidValue};
1.111 +/** Camera with index 2 Available. */
1.112 +static const TUid KUidECamEventGlobalCamera02Available = {KUidECamEventGlobalCamera02AvailableUidValue};
1.113 +/** Camera with index 3 Available. */
1.114 +static const TUid KUidECamEventGlobalCamera03Available = {KUidECamEventGlobalCamera03AvailableUidValue};
1.115 +/** Camera with index 4 Available. */
1.116 +static const TUid KUidECamEventGlobalCamera04Available = {KUidECamEventGlobalCamera04AvailableUidValue};
1.117 +/** Camera with index 5 Available. */
1.118 +static const TUid KUidECamEventGlobalCamera05Available = {KUidECamEventGlobalCamera05AvailableUidValue};
1.119 +/** Camera with index 6 Available. */
1.120 +static const TUid KUidECamEventGlobalCamera06Available = {KUidECamEventGlobalCamera06AvailableUidValue};
1.121 +/** Camera with index 7 Available. */
1.122 +static const TUid KUidECamEventGlobalCamera07Available = {KUidECamEventGlobalCamera07AvailableUidValue};
1.123 +
1.124 +/** Individual camera events. These are used by the camera to signal its observers. */
1.125 +/** Lens changed. */
1.126 +static const TUid KUidECamEventLensChanged = {KUidECamEventLensChangedUidValue};
1.127 +/** Flash source added. */
1.128 +static const TUid KUidECamEventFlashSourceAdded = {KUidECamEventFlashSourceAddedUidValue};
1.129 +/** Flash source removed. */
1.130 +static const TUid KUidECamEventFlashSourceRemoved = {KUidECamEventFlashSourceRemovedUidValue};
1.131 +/** Image resolution changed. */
1.132 +static const TUid KUidECamEventCameraSettingImageSize = {KUidECamEventCameraSettingImageSizeUidValue};
1.133 +/** Image Format changed. */
1.134 +static const TUid KUidECamEventCameraSettingImageFormat = {KUidECamEventCameraSettingImageFormatUidValue};
1.135 +/** Camera orientation changed. */
1.136 +static const TUid KUidECamEventCameraSettingCameraOrientation = {KUidECamEventCameraSettingCameraOrientationUidValue};
1.137 +/** Optimal focus */
1.138 +static const TUid KUidECamEventCameraSettingsOptimalFocus = {KUidECamEventCameraSettingsOptimalFocusUidValue};
1.139 +
1.140 +/** Advanced settings. */
1.141 +/** Stabilization mode. */
1.142 +static const TUid KUidECamEventCameraSettingStabilizationMode = {KUidECamEventCameraSettingStabilizationModeUidValue};
1.143 +/** Focus mode. */
1.144 +static const TUid KUidECamEventCameraSettingFocusMode = {KUidECamEventCameraSettingFocusModeUidValue};
1.145 +/** Focus range.
1.146 +@deprecated
1.147 +
1.148 +Replaced by KUidECamEventCameraSettingFocusRange2
1.149 +
1.150 +In the first release of this event, KUidECamEventCameraSettingFocusRange was incorrectly given an already existing uid.
1.151 +In order to preserve compatibility this event is marked as deprecated and has been replaced by KUidECamEventCameraSettingFocusRange2.
1.152 +Camera servers predating this API change will continue to send the original event which is indistinguishable by value.
1.153 +Caching the old value and comparing it with the current value, will allow the client to determine that the value has changed.
1.154 +Camera servers which have been updated should send both KUidECamEventCameraSettingFocusRange and KUidECamEventCameraSettingFocusRange2 on a focus range change.
1.155 +Camera clients should therefore process both events(old and new).
1.156 +
1.157 +@see KUidECamEventCameraSettingFocusRange2
1.158 +*/
1.159 +static const TUid KUidECamEventCameraSettingFocusRange = {KUidECamEventCameraSettingFocusRangeUidValue};
1.160 +/** Autofocus type.
1.161 +@deprecated
1.162 +
1.163 +Replaced by KUidECamEventCameraSettingAutoFocusType2
1.164 +
1.165 +In the first release of this event, KUidECamEventCameraSettingAutoFocusType was incorrectly given an already existing uid.
1.166 +In order to preserve compatibility this event is marked as deprecated and has been replaced by KUidECamEventCameraSettingAutoFocusType2.
1.167 +Camera servers predating this API change will continue to send the original event which is indistinguishable by value.
1.168 +Caching the old value and comparing it with the current value, will allow the client to determine that the value has changed.
1.169 +Camera servers which have been updated should send both KUidECamEventCameraSettingAutoFocusType and KUidECamEventCameraSettingAutoFocusType2 on a focus range change.
1.170 +Camera clients should therefore process both events(old and new).
1.171 +
1.172 +@see KUidECamEventCameraSettingAutoFocusType2*/
1.173 +static const TUid KUidECamEventCameraSettingAutoFocusType = {KUidECamEventCameraSettingAutoFocusTypeUidValue};
1.174 +/** Autofocus area. */
1.175 +static const TUid KUidECamEventCameraSettingAutoFocusArea = {KUidECamEventCameraSettingAutoFocusAreaUidValue};
1.176 +/** Autofocus lock state. */
1.177 +static const TUid KUidECamEventCameraSettingAutoFocusLock = {KUidECamEventCameraSettingAutoFocusLockUidValue};
1.178 +/** Focus distance */
1.179 +static const TUid KUidECamEventCameraSettingFocusDistance = {KUidECamEventCameraSettingFocusDistanceUidValue};
1.180 +/** Sensitivity - ISO rate. */
1.181 +static const TUid KUidECamEventCameraSettingIsoRate = {KUidECamEventCameraSettingIsoRateUidValue};
1.182 +/** Aperture. */
1.183 +static const TUid KUidECamEventCameraSettingAperture = {KUidECamEventCameraSettingApertureUidValue};
1.184 +/** Aperture range. */
1.185 +static const TUid KUidECamEventCameraSettingApertureRange = {KUidECamEventCameraSettingApertureRangeUidValue};
1.186 +/** Shutter speed. */
1.187 +static const TUid KUidECamEventCameraSettingShutterSpeed = {KUidECamEventCameraSettingShutterSpeedUidValue};
1.188 +/** Shutter speed range. */
1.189 +static const TUid KUidECamEventCameraSettingShutterSpeedRange = {KUidECamEventCameraSettingShutterSpeedRangeUidValue};
1.190 +/** Metering mode. */
1.191 +static const TUid KUidECamEventCameraSettingMeteringMode = {KUidECamEventCameraSettingMeteringModeUidValue};
1.192 +/** Drive mode. */
1.193 +static const TUid KUidECamEventCameraSettingDriveMode = {KUidECamEventCameraSettingDriveModeUidValue};
1.194 +/** Braket mode. */
1.195 +static const TUid KUidECamEventCameraSettingBracketMode = {KUidECamEventCameraSettingBracketModeUidValue};
1.196 +/** Bracket step. */
1.197 +static const TUid KUidECamEventCameraSettingBracketStep = {KUidECamEventCameraSettingBracketStepUidValue};
1.198 +/** Bracket parameter. */
1.199 +static const TUid KUidECamEventCameraSettingBracketParameter = {KUidECamEventCameraSettingBracketParameterUidValue};
1.200 +/** Bracket merge. */
1.201 +static const TUid KUidECamEventBracketMerge = {KUidECamEventBracketMergeUidValue};
1.202 +/** Picture orientation. */
1.203 +static const TUid KUidECamEventCameraSettingPictureOrientation = {KUidECamEventCameraSettingPictureOrientationUidValue};
1.204 +/** Automatic size selection option */
1.205 +static const TUid KUidECamEventCameraSettingAutomaticSizeSelection = {KUidECamEventCameraSettingAutomaticSizeSelectionUidValue};
1.206 +/** Flash setting. */
1.207 +static const TUid KUidECamEventCameraSettingFlashMode = {KUidECamEventCameraSettingFlashModeUidValue};
1.208 +/** Flash compensation step. */
1.209 +static const TUid KUidECamEventCameraSettingFlashCompensationStep = {KUidECamEventCameraSettingFlashCompensationStepUidValue};
1.210 +/** Flash compensation. */
1.211 +static const TUid KUidECamEventCameraSettingFlashCompensation = {KUidECamEventCameraSettingFlashCompensationUidValue};
1.212 +/** Manual flash power. */
1.213 +static const TUid KUidECamEventCameraSettingFlashManualPower = {KUidECamEventCameraSettingFlashManualPowerUidValue};
1.214 +/** Red eye reduce mode. */
1.215 +static const TUid KUidECamEventCameraSettingFlashRedEyeReduce = {KUidECamEventCameraSettingFlashRedEyeReduceUidValue};
1.216 +/** Exposure mode setting. */
1.217 +static const TUid KUidECamEventCameraSettingExposureMode = {KUidECamEventCameraSettingExposureModeUidValue};
1.218 +/** Exposure compensation step. */
1.219 +static const TUid KUidECamEventCameraSettingExposureCompensationStep = {KUidECamEventCameraSettingExposureCompensationStepUidValue};
1.220 +/** Exposure compensation. */
1.221 +static const TUid KUidECamEventCameraSettingExposureCompensation = {KUidECamEventCameraSettingExposureCompensationUidValue};
1.222 +/** Exposure lock state. */
1.223 +static const TUid KUidECamEventCameraSettingExposureLock = {KUidECamEventCameraSettingExposureLockUidValue};
1.224 +/** AE lock option. */
1.225 +static const TUid KUidECamEventAELock = {KUidECamEventAELockUidValue};
1.226 +/** White balance. */
1.227 +static const TUid KUidECamEventCameraSettingWhiteBalanceMode = {KUidECamEventCameraSettingWhiteBalanceModeUidValue};
1.228 +/** Timer changed. */
1.229 +static const TUid KUidECamEventCameraSettingTimerInterval = {KUidECamEventCameraSettingTimerIntervalUidValue};
1.230 +/** Timer lapse period. */
1.231 +static const TUid KUidECamEventCameraSettingTimeLapse = {KUidECamEventCameraSettingTimeLapseUidValue};
1.232 +/** Optical zoom. */
1.233 +static const TUid KUidECamEventCameraSettingOpticalZoom = {KUidECamEventCameraSettingOpticalZoomUidValue};
1.234 +/** Optical zoom range. */
1.235 +static const TUid KUidECamEventCameraSettingOpticalZoomRange = {KUidECamEventCameraSettingOpticalZoomRangeUidValue};
1.236 +/** Digital zoom. */
1.237 +static const TUid KUidECamEventCameraSettingDigitalZoom = {KUidECamEventCameraSettingDigitalZoomUidValue};
1.238 +/** Digital zoom range. */
1.239 +static const TUid KUidECamEventCameraSettingDigitalZoomRange = {KUidECamEventCameraSettingDigitalZoomRangeUidValue};
1.240 +/** Clicking sound state. */
1.241 +static const TUid KUidECamEventSoundClick = {KUidECamEventSoundClickUidValue};
1.242 +/** Pixel aspect ratio. */
1.243 +static const TUid KUidECamEventPixelAspectRatio = {KUidECamEventPixelAspectRatioUidValue};
1.244 +/** Yuv range. */
1.245 +static const TUid KUidECamEventYuvRange = {KUidECamEventYuvRangeUidValue};
1.246 +/** Burst images. */
1.247 +static const TUid KUidECamEventBurstImages = {KUidECamEventBurstImagesUidValue};
1.248 +/** Stabilization effect - magnitude of stabilization */
1.249 +static const TUid KUidECamEventCameraSettingsStabilizationEffect = {KUidECamEventCameraSettingsStabilizationEffectUidValue};
1.250 +/** Stabilization algorithm */
1.251 +static const TUid KUidECamEventSettingsStabilizationAlgorithmComplexity = {KUidECamEventSettingsStabilizationAlgorithmComplexityUidValue};
1.252 +/** Continuous Autofocus timeout */
1.253 +static const TUid KUidECamEventCameraSettingsContinuousAutoFocusTimeout = {KUidECamEventCameraSettingsContinuousAutoFocusTimeoutUidValue};
1.254 +/** White Balance manual setting */
1.255 +static const TUid KUidECamEventCameraSettingsWBValue = {KUidECamEventCameraSettingsWBValueUidValue};
1.256 +/** Flash ready */
1.257 +static const TUid KUidECamEventFlashReady = {KUidECamEventFlashReadyUidValue};
1.258 +/** Flash not ready */
1.259 +static const TUid KUidECamEventFlashNotReady = {KUidECamEventFlashNotReadyUidValue};
1.260 +/** Focus range.
1.261 +This is the new UID value to notify change on focus range and takes immediate effect as previous UID KUidECamEventCameraSettingFocusRange has been deprecated.
1.262 +@see KUidECamEventCameraSettingFocusRange */
1.263 +static const TUid KUidECamEventCameraSettingFocusRange2 = {KUidECamEventCameraSettingFocusRange2UidValue};
1.264 +/** Autofocus type.
1.265 +This is the new UID value to notify change on autofocus type and takes immediate effect as previous UID KUidECamEventCameraSettingAutoFocusType has been deprecated.
1.266 +@see KUidECamEventCameraSettingAutoFocusType */
1.267 +static const TUid KUidECamEventCameraSettingAutoFocusType2 = {KUidECamEventCameraSettingAutoFocusType2UidValue};
1.268 +
1.269 +/**
1.270 +ISO Rate type.
1.271 +
1.272 +This TUid is available from the following methods only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L():
1.273 +void CCamera::CCameraAdvancedSettings::GetSupportedSettingsL(RArray<TUid>& aSettings) const;
1.274 +void CCamera::CCameraAdvancedSettings::GetActiveSettingsL(RArray<TUid>& aActiveSettings) const;
1.275 +void CCamera::CCameraAdvancedSettings::GetDisabledSettingsL(RArray<TUid>& aDisabledSettings) const;
1.276 +
1.277 +*/
1.278 +static const TUid KUidECamEventCameraSettingIsoRateType = {KUidECamEventCameraSettingIsoRateTypeUidValue};
1.279 +
1.280 +/**
1.281 +Reference Screen setting.
1.282 +
1.283 +This TUid is available from the following methods only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L():
1.284 +void CCamera::CCameraAdvancedSettings::GetSupportedSettingsL(RArray<TUid>& aSettings) const;
1.285 +void CCamera::CCameraAdvancedSettings::GetActiveSettingsL(RArray<TUid>& aActiveSettings) const;
1.286 +void CCamera::CCameraAdvancedSettings::GetDisabledSettingsL(RArray<TUid>& aDisabledSettings) const;
1.287 +
1.288 +*/
1.289 +static const TUid KUidECamEventCameraSettingReferenceScreen = {KUidECamEventCameraSettingReferenceScreenUidValue};
1.290 +
1.291 +/**
1.292 +Pre Capture Warning indication.
1.293 +
1.294 +This TUid is available from the following methods only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L():
1.295 +void CCamera::CCameraAdvancedSettings::GetSupportedSettingsL(RArray<TUid>& aSettings) const;
1.296 +void CCamera::CCameraAdvancedSettings::GetActiveSettingsL(RArray<TUid>& aActiveSettings) const;
1.297 +void CCamera::CCameraAdvancedSettings::GetDisabledSettingsL(RArray<TUid>& aDisabledSettings) const;
1.298 +
1.299 +*/
1.300 +static const TUid KUidECamEventCameraSettingAFAssistantLight = {KUidECamEventCameraSettingAFAssistantLightUidValue};
1.301 +
1.302 +
1.303 +
1.304 +class CCameraContinuousZoom;
1.305 +/**
1.306 +A mixin class to be implemented by the client in order to use the Continuous Zoom API. The callbacks are invoked by the implementation
1.307 +whenever the continuous zoom operations are ready to be notified.
1.308 +
1.309 +@see CCameraContinuousZoom
1.310 +
1.311 +@internalTechnology
1.312 +@prototype
1.313 +*/
1.314 +class MContinuousZoomObserver
1.315 + {
1.316 +public:
1.317 +
1.318 + /**
1.319 + This callback is sent when a new zoom factor is achieved. Client may not receive a callback for every new zoom factor as it is up
1.320 + to the implementation to choose the zoom factors for which it will issue this callback. Should an error occur, this implies that the
1.321 + continuous zoom operation has been stopped.
1.322 +
1.323 + @param aContinuousZoomHandle
1.324 + Reference to CCameraContinuousZoom class object which was used to start the continuous zoom operation.
1.325 +
1.326 + @param aZoomFactor
1.327 + The new zoom factor value, multiplied by KECamFineResolutionFactor, which has been achieved.
1.328 +
1.329 + @param aError
1.330 + Appropriate error code.
1.331 + */
1.332 + virtual void ContinuousZoomProgress(CCamera::CCameraContinuousZoom& aContinuousZoomHandle, TInt aZoomFactor, TInt aError)=0;
1.333 +
1.334 + /**
1.335 + Implementation sends this callback when the Continuous Zoom operation has been completed. This callback will be sent when
1.336 + target zoom factor is achieved. This zoom factor may in some cases be less than the target zoom factor due to the complexity
1.337 + of the continuous zoom operation. Once this callback is received, client need not issue StopContinuousZoom() and can call
1.338 + StartContinuousZoom() again.
1.339 +
1.340 + @param aContinuousZoomHandle
1.341 + Reference to CCameraContinuousZoom class object which was used to start the continuous zoom operation.
1.342 +
1.343 + @param aFinalZoomFactor
1.344 + The final zoom factor value once the continuous zoom operation has completed. This zoom factor may in some cases be
1.345 + less than the target zoom factor due to the complexity of the continuous zoom operation.
1.346 +
1.347 + @param aErrorCode
1.348 + Appropriate error code.
1.349 + */
1.350 + virtual void ContinuousZoomCompleted(CCamera::CCameraContinuousZoom& aContinuousZoomHandle, TInt aFinalZoomFactor, TInt aError)=0;
1.351 +
1.352 + /**
1.353 + Gets a custom interface for future callbacks. This method will be called by the implementation to get a new interface
1.354 + which would support future callbacks.
1.355 +
1.356 + @param aInterface
1.357 + The Uid of the particular interface function required for callbacks.
1.358 +
1.359 + @param aPtrInterface
1.360 + The implementation has to type-cast the retrieved custom interface pointer to the appropriate type.
1.361 +
1.362 + @return The error code.
1.363 + */
1.364 + virtual TInt CustomInterface(TUid aInterface, TAny*& aPtrInterface)=0;
1.365 + };
1.366 +
1.367 +
1.368 +/**
1.369 +CCamera advanced settings class exposes an API for controlling individually
1.370 +digital camera advanced settings. These settings directly relate to the
1.371 +image acquisition phase both for still images and video.
1.372 +
1.373 +@note This class is not intended for sub-classing and used to standardise existing
1.374 + varieties of implementations.
1.375 +
1.376 +@note If the class methods leave, the output type parameter value is not guaranteed to be valid.
1.377 +
1.378 +@publishedAll
1.379 +@released
1.380 +*/
1.381 +class CCamera::CCameraAdvancedSettings : public CBase
1.382 + {
1.383 + /* so can use internal factory functions etc. */
1.384 + friend class CCamera;
1.385 +
1.386 +public:
1.387 +
1.388 + /** Specifies camera type. */
1.389 + enum TCameraType
1.390 + {
1.391 + /** Unable to identify. */
1.392 + ECameraUnknown = 0x00,
1.393 + /** Camera is non-detachable from device. Camera is always present. */
1.394 + ECameraOnBoard = 0x01,
1.395 + /** Camera is detachable from device. Camera is not always present. */
1.396 + ECameraPluggable = 0x02
1.397 + };
1.398 +
1.399 + /** Specifies stabilization mode of the camera. */
1.400 + enum TStabilizationMode
1.401 + {
1.402 + /** Not present or switched off, default */
1.403 + EStabilizationModeOff = 0x00,
1.404 + /** Stabilization only in horizontal direction. */
1.405 + EStabilizationModeHorizontal = 0x01,
1.406 + /** Stabilization only in vertical direction. */
1.407 + EStabilizationModeVertical = 0x02,
1.408 + /** Rotational stabilization. */
1.409 + EStabilizationModeRotation = 0x04,
1.410 + /** Automatic stabilization. */
1.411 + EStabilizationModeAuto = 0x08,
1.412 + /** Manual stabilization. */
1.413 + EStabilizationModeManual = 0x10
1.414 + };
1.415 +
1.416 + /** Supported magnitudes of stabilization effect when in manual mode. */
1.417 + enum TStabilizationEffect
1.418 + {
1.419 + /** Stabilization effect is off. */
1.420 + EStabilizationOff = 0x00,
1.421 + /** Stabilization effect is automatic, default. */
1.422 + EStabilizationAuto = 0x01,
1.423 + /** Stabilization effect is very small in magnitude. */
1.424 + EStabilizationFine = 0x02,
1.425 + /** Stabilization effect is average in magnitude. */
1.426 + EStabilizationMedium = 0x04,
1.427 + /** Stabilization effect is large in magnitude. */
1.428 + EStabilizationStrong = 0x08
1.429 + };
1.430 +
1.431 + /** Supported stabilization algorithms, graded on complexity. */
1.432 + enum TStabilizationAlgorithmComplexity
1.433 + {
1.434 + /** Stabilization algorithm selection is automatic, default. */
1.435 + EStabilizationComplexityAuto = 0x00,
1.436 + /** Stabilization algorithm is simple - less precise but fast. */
1.437 + EStabilizationComplexityLow = 0x01,
1.438 + /** Stabilization algorithm is of medium complexity. */
1.439 + EStabilizationComplexityMedium = 0x02,
1.440 + /** Stabilization algorithm is of high complexity. */
1.441 + EStabilizationComplexityHigh = 0x04
1.442 + };
1.443 +
1.444 + /** Supported focus modes. */
1.445 + enum TFocusMode
1.446 + {
1.447 + /** Focus mode is unknown. */
1.448 + EFocusModeUnknown = 0x00,
1.449 + /** Focus is automatic, default. */
1.450 + EFocusModeAuto = 0x01,
1.451 + /** Focus is fixed. */
1.452 + EFocusModeFixed = 0x02,
1.453 + /** Focus is manually set. */
1.454 + EFocusModeManual = 0x04
1.455 + };
1.456 +
1.457 + /** Supported focus ranges. */
1.458 + enum TFocusRange
1.459 + {
1.460 + /** Auto. Default */
1.461 + EFocusRangeAuto = 0x00,
1.462 + /** Focus operates in close range (macro). */
1.463 + EFocusRangeMacro = 0x01,
1.464 + /** Normal operation. */
1.465 + EFocusRangeNormal = 0x02,
1.466 + /** Extended (tele) operation. */
1.467 + EFocusRangeTele = 0x04,
1.468 + /** Focus at larger areas at short to medium distance. */
1.469 + EFocusRangePortrait = 0x08,
1.470 + /** Optimised macro operation,
1.471 + where depth of field is very shallow and observation area changes quickly. */
1.472 + EFocusRangeSuperMacro = 0x10,
1.473 + /**
1.474 + All objects at distances from half of the hyperfocal distance out to infinity will be in focus.
1.475 + This gives gives maximum depth of field.
1.476 +
1.477 + This enum value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.478 + CCamera::NewDuplicate2L().
1.479 +
1.480 + */
1.481 + EFocusRangeHyperfocal = 0x20,
1.482 + /**
1.483 + When there is a near obstacle or better focus wanted for far away objects.
1.484 +
1.485 + This enum value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.486 + CCamera::NewDuplicate2L().
1.487 +
1.488 + */
1.489 + EFocusRangeInfinite = 0x40
1.490 + };
1.491 +
1.492 + /** Specifies the supported autofocus types. */
1.493 + enum TAutoFocusType
1.494 + {
1.495 + /** Autofocus is switched off. */
1.496 + EAutoFocusTypeOff = 0x00,
1.497 + /** Operates on a single shot, consumes less power. */
1.498 + EAutoFocusTypeSingle = 0x01,
1.499 + /** Continious autofocus, more precise but consumes more power.
1.500 + also known as AF Servo. */
1.501 + EAutoFocusTypeContinuous = 0x02
1.502 + };
1.503 +
1.504 + /** Specifies the autofocus area. */
1.505 + enum TAutoFocusArea
1.506 + {
1.507 + /** Automatic. Default value */
1.508 + EAutoFocusTypeAuto = 0x00,
1.509 + /** Single area, suitable for relatively flat surfaces and portrait. */
1.510 + EAutoFocusTypeSingleArea = 0x01,
1.511 + /** Multiple points of an object, more weighting for centre points. */
1.512 + EAutoFocusTypeMultiAreaCentered = 0x02
1.513 + };
1.514 +
1.515 + /** Specifies the Metering mode for the camera.
1.516 + EMeteringModeAuto is the default value. */
1.517 + enum TMeteringMode
1.518 + {
1.519 + /** Automatic mode, default. */
1.520 + EMeteringModeAuto = 0x0000,
1.521 + /** Metering in which the center is given a weighted priority. */
1.522 + EMeteringModeCenterWeighted = 0x0001,
1.523 + /** Metering of a central area/spot only, also known as partial. */
1.524 + EMeteringModeSpot = 0x0002,
1.525 + /** Metering is evaluated over a matrix(several spots) and calculated
1.526 + as a function of that. Usually best but with increased
1.527 + power consumption. Alternative name multi-metering mode. */
1.528 + EMeteringModeEvaluative = 0x0004
1.529 + };
1.530 +
1.531 + /** Specifies the drive mode for the camera. This determines how and in what sucession are images
1.532 + shot. EDriveModeSingleShot is the default.*/
1.533 + enum TDriveMode
1.534 + {
1.535 + /** Automatic. Default */
1.536 + EDriveModeAuto = 0x0000,
1.537 + /** Camera takes a single image/shot. */
1.538 + EDriveModeSingleShot = 0x0001,
1.539 + /** Camera continuously captures images (as fast as it can) until stopped or out of storage medium. */
1.540 + EDriveModeContinuous = 0x0002,
1.541 + /** Camera is in bracketing mode, producing individual frames. @see TBracketMode */
1.542 + EDriveModeBracket = 0x0004,
1.543 + /** Camera is in bracketing mode, but producing a single image. @see TBracketMode */
1.544 + EDriveModeBracketMerge = 0x0008,
1.545 + /** camera captures a single shot after specified time period. @see Timer() */
1.546 + EDriveModeTimed = 0x0010,
1.547 + /** Camera captures a set of images with an uniform interval between them. @see TimeLapse() */
1.548 + EDriveModeTimeLapse = 0x0020,
1.549 + /** Camera captures a set of images as fast as it can, but in batches(bursts). */
1.550 + EDriveModeBurst = 0x0040,
1.551 + /** Camera captures a set of images before and after camera capture key press event. Client can specify
1.552 + the amount of pre-capture and post-capture images to be saved via TDriveModeDependentAttributes.
1.553 + The total amount of images to be saved will be pre-capture images + 1 + post-capture images.
1.554 +
1.555 + @note This drive mode is only available to clients using the CCamera::New2L() or CCamera::NewDuplicate2L()
1.556 + in addition to the new image capture APIs ie. CCameraPreImageCaptureControl, CCameraImageCapture and
1.557 + CCameraPostImageCaptureControl.
1.558 +
1.559 + @publishedPartner
1.560 + @prototype
1.561 + */
1.562 + EDriveModeTimeNudgeCapture = 0x0080
1.563 + };
1.564 +
1.565 + /** Specifies Bracket mode. */
1.566 + enum TBracketMode
1.567 + {
1.568 + /** Bracket mode is switched off. Default value. */
1.569 + EBracketModeOff = 0x0000,
1.570 + /** Bracket mode on. Three consecutive pictures are taken in order
1.571 + under (-1), on (0), over (+1), where correction magnitude
1.572 + is defined by bracket step size and by TBracketParameter
1.573 + @see TBracketStep
1.574 + @see TBracketParameter */
1.575 + EBracketMode3Image = 0x0001,
1.576 + /** Bracket mode on. Five consecutive pictures are taken in order
1.577 + under (-2),under (-1), on (0), over (+1), over (+2), where correction magnitude
1.578 + is defined by bracket step size and by TBracketParameter
1.579 + @see TBracketStep
1.580 + @see TBracketParameter */
1.581 + EBracketMode5Image = 0x0002
1.582 + };
1.583 +
1.584 + /** Supported parameters used for bracketing.
1.585 + @note Bracket mode parameter value changes by
1.586 + a selected uniform step between successive image shots.
1.587 + @see TBracketStep
1.588 + @see TBracketMode. */
1.589 + enum TBracketParameter
1.590 + {
1.591 + /** None. */
1.592 + EBracketParameterNone = 0x0000,
1.593 + /** Exposure settings change. */
1.594 + EBracketParameterExposure = 0x0001,
1.595 + /** Flash power change. */
1.596 + EBracketParameterFlashPower = 0x0002,
1.597 + /** Colour balance settings change. */
1.598 + EBracketParameterColourBalance = 0x0004,
1.599 + /** Aperture settings change. */
1.600 + BracketParameterAperture = 0x0008,
1.601 + /** Autofocus settings change. */
1.602 + BracketParameterAutoFocus = 0x0010
1.603 + };
1.604 +
1.605 + /** Specifies the magnitude of bracketing step.
1.606 + The actual value and availability is parameter dependent.
1.607 + @see TBracketParameter
1.608 + */
1.609 + enum TBracketStep
1.610 + {
1.611 + /** Not supported. */
1.612 + EBracketStepNonConfig = 0x00,
1.613 + /** Small value. */
1.614 + EBracketStepSmall = 0x01,
1.615 + /** Medium value. */
1.616 + EBracketStepMedium = 0x02,
1.617 + /** Large value. */
1.618 + EBracketStepLarge = 0x04
1.619 + };
1.620 +
1.621 + /** Specifies the orientation of the picture. */
1.622 + enum TPictureOrientation
1.623 + {
1.624 + /** No information about picture orientation. */
1.625 + EPictureOrientationUnknown = 0x00,
1.626 + /** Portrait - height larger than width. */
1.627 + EPictureOrientationPortrait = 0x01,
1.628 + /** Landscape width larger than height. */
1.629 + EPictureOrientationLandscape = 0x02,
1.630 + /** Square width equals the height. */
1.631 + EPictureOrientationSquare = 0x04
1.632 + };
1.633 +
1.634 + /** Specifies the pixel aspect ratio
1.635 + @note It is specified as a fraction of
1.636 + (x) horizontal pixel size divided by vertical (y) pixel size.
1.637 + The pixel aspect ratio for square pixels is 1/1.
1.638 + */
1.639 + enum TPixelAspectRatio
1.640 + {
1.641 + /** Pixel ratio undetermined */
1.642 + EPixelAspectUnknown = 0x00,
1.643 + /** Pixel Ratio 1:1. */
1.644 + EPixelAspect1To1 = 0x01,
1.645 + /** Pixel Ratio 12:11 */
1.646 + EPixelAspect12To11 = 0x02,
1.647 + /** Pixel Ratio 11:10. */
1.648 + EEPixelAspect11To10 = 0x04,
1.649 + /** Pixel Ratio 59:54. */
1.650 + EEPixelAspect59To54 = 0x08,
1.651 + /** Pixel Ratio 16:11.
1.652 + @note This value is available only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L()
1.653 + */
1.654 + EEPixelAspect16To11 = 0x10,
1.655 + /** Pixel Ratio 10:11.
1.656 + @note This value is available only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L()
1.657 + */
1.658 + EEPixelAspect10To11 = 0x20,
1.659 + /** Pixel Ratio 40:33.
1.660 + @note This value is available only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L()
1.661 + */
1.662 + EEPixelAspect40To33 = 0x40
1.663 + };
1.664 +
1.665 + /** Specifies YUV colour space dynamic range.
1.666 + @note video compressors often use narrower than the default range.
1.667 + The nominal Y range is [16:235] and the U and V ranges [16:240].
1.668 + */
1.669 + enum TYuvRange
1.670 + {
1.671 + /** Yuv range undetermined */
1.672 + EYuvRangeUnknown = 0x00,
1.673 + /** Yuv Full Range. The nominal Y,U and V colours range is [0:255]. */
1.674 + EYuvRangeFull = 0x01,
1.675 + /** Yuv Cropped Range. The nominal Y range is [16:235] and the U and V ranges [16:240]. */
1.676 + EYuvRangeVideoCropped = 0x02
1.677 + };
1.678 +
1.679 + /** Specifies the units supported by the camera for manual white balance setting.
1.680 + */
1.681 + enum TWBUnits
1.682 + {
1.683 + /** The units type is undetermined or not supported. */
1.684 + EWBUnknown,
1.685 + /** The white balance is represented as temperature degrees in Kelvin. */
1.686 + EWBColorTemperature,
1.687 + /** The white balance is represented as RGB triples. */
1.688 + EWBRgb
1.689 + };
1.690 +
1.691 + /**
1.692 + Specifies the ISO type supported by the camera. ISO refers to the sensivity of the
1.693 + image sensor and is one of the factors influencing the exposure.
1.694 +
1.695 + */
1.696 + enum TISORateType
1.697 + {
1.698 + /** ISO Not supported. Camera uses a fixed ISO rate internally and never reveals this information. */
1.699 + EISONone = 0x00,
1.700 + /** Camera gives a list of manual ISO rates to the user to set. Recommendation is to start camera in the manual ISO mode, by default. */
1.701 + EISOManual = 0x01,
1.702 + /** Camera chooses the ISO on its own without prioritising any particular exposure parameters. */
1.703 + EISOAutoUnPrioritised = 0x02,
1.704 + /** Camera chooses the ISO on its own by prioritising ISO. */
1.705 + EISOAutoISOPrioritised = 0x04,
1.706 + /** Camera chooses the ISO on its own after prioritising shutter speed. */
1.707 + EISOAutoShutterSpeedPrioritised = 0x08,
1.708 + /** Camera chooses the ISO on its own after prioritising aperture opening. */
1.709 + EISOAutoAperturePrioritised = 0x10
1.710 + };
1.711 +
1.712 + /**
1.713 + Specifies the unfavourable circumstances as pre capture warnings which may be issued before image/video capture.
1.714 +
1.715 + */
1.716 + enum TPreCaptureWarning
1.717 + {
1.718 + /** No warnings */
1.719 + EPCWNone = 0x0000,
1.720 + /** warning to indicate that camera sensor is over exposed */
1.721 + EPCWOverExposure = 0x0001,
1.722 + /** warning to indicate that camera sensor is under exposed */
1.723 + EPCWUnderExposure = 0x0002,
1.724 + /** warning to indicate that camera operates under insufficient lightning conditions */
1.725 + EPCWLowLight = 0x0004,
1.726 + /** warning to indicate that focussing is not optimum. This is valid for manual/fixed focus only */
1.727 + EPCWBadFocus = 0x0008,
1.728 + /** warning to indicate that camera might not be firmly gripped (Tripod required). This is same as long exposure */
1.729 + EPCWHandShakePossible = 0x0010,
1.730 + /** warning to indicate that camera has not enough power to survive the flash operations (battery discharged) */
1.731 + EPCWNotEnoughPowerForFlash = 0x0020,
1.732 + /** warning to indicate that the current white balance is not the desired one */
1.733 + EPCWWrongWhiteBalanceValue = 0x0040,
1.734 + /** warning to indicate that the current flash value is not the desired one */
1.735 + EPCWWrongFlashValue = 0x0080,
1.736 + /** warning to indicate that the current digital zoom value is not the desired one */
1.737 + EPCWWrongDigiZoomValue = 0x0100,
1.738 + /** warning to indicate that the desired digital zoom affects the quality of image */
1.739 + EPCWDigiZoomBadQuality = 0x0200,
1.740 + /** warning to indicate that flash is not ready. Recommendation: user may subscribe for this warning or issue
1.741 + IsFlashReady() also. Using both options is not encouraged */
1.742 + EPCWFlashNotReady = 0x0400,
1.743 + /** unknown reason */
1.744 + EPCWGeneralWarning = 0x0800,
1.745 + /** warning to indicate that flash has been overheated.
1.746 +
1.747 + @note This value is available only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L()
1.748 +
1.749 + @publishedPartner
1.750 + @prototype
1.751 + */
1.752 + EPCWFlashOverheated = 0x1000,
1.753 + /** warning to indicate that flash will not be fired because of enough ambient light.
1.754 +
1.755 + @note This value is available only to the API clients using CCamera::New2L() or CCamera::NewDuplicate2L()
1.756 +
1.757 + @publishedPartner
1.758 + @prototype
1.759 + */
1.760 + EPCWFlashNotNeeded = 0x2000
1.761 + };
1.762 +
1.763 + /**
1.764 + Describes the camera mode.
1.765 +
1.766 + */
1.767 + enum TCameraMode
1.768 + {
1.769 + /** Camera is Idle */
1.770 + EModeIdle = 0x00,
1.771 + /** DSA based Viewfinder runs */
1.772 + EModeDSAViewFinder = 0x01,
1.773 + /** Client based Viewfinder runs */
1.774 + EModeClientViewFinder = 0x02
1.775 + };
1.776 +
1.777 + /**
1.778 + Specifies the different types of auto focus assistant light
1.779 + */
1.780 + enum TAFAssistantLight
1.781 + {
1.782 + /** switch off the AF assistant light from either of 'manual on' or 'auto' mode */
1.783 + EAFAssistantLightOff = 0x00,
1.784 + /** switch on the AF assistant light manually */
1.785 + EAFAssistantLightManualOn = 0x01,
1.786 + /** Put the AF assistant light in auto mode. It will be automatically decided when to switch on or off. */
1.787 + EAFAssistantLightAuto = 0x02
1.788 + };
1.789 +
1.790 + /**
1.791 + Specifies the different types of continuous zoom supported.
1.792 + The enumeration list may be extended in future.
1.793 +
1.794 + @publishedPartner
1.795 + @prototype
1.796 + */
1.797 + enum TContinuousZoomType
1.798 + {
1.799 + /** Continuous zoom not supported */
1.800 + EContinuousZoomNotSupported = 0x00,
1.801 + /** Continuous zoom 'Optical' only, No 'Digital' */
1.802 + EContinuousZoomOpticalOnly = 0x01,
1.803 + /** Continuous zoom 'Optical' and 'Digital' */
1.804 + EContinuousZoomMixed = 0x02,
1.805 + /** Continuous zoom 'Digital' only, No 'Optical' */
1.806 + EContinuousZoomDigitalOnly = 0x04
1.807 + };
1.808 +
1.809 + /**
1.810 + Specifies the zoom direction for continuous zoom operation.
1.811 + The enumeration list may be extended in future.
1.812 +
1.813 + @publishedPartner
1.814 + @prototype
1.815 + */
1.816 + enum TZoomDirection
1.817 + {
1.818 + /** Implies that feature not supported. */
1.819 + EZoomDirectionNone =0x00,
1.820 + /** Implies zooming out. */
1.821 + EZoomDirectionWide =0x01,
1.822 + /** Implies zooming in. */
1.823 + EZoomDirectionTele =0x02
1.824 + };
1.825 +
1.826 + /**
1.827 + Different levels for performance vectors like speed, quality, low memory consumption and low power consumption.
1.828 + The enumeration list may be extended in future.
1.829 +
1.830 + @publishedPartner
1.831 + @prototype
1.832 + */
1.833 + enum TPerformanceLevel
1.834 + {
1.835 + /** High level preference. */
1.836 + ELevelHigh = 1,
1.837 + /** Medium level preference. */
1.838 + ELevelMedium = 2,
1.839 + /** Low level preference. */
1.840 + ELevelLow = 3,
1.841 + /** Dont care (No preference). */
1.842 + ELevelDontCare = 4
1.843 + };
1.844 +
1.845 + /**
1.846 + Specifies flicker removal options.
1.847 + The enumeration list may be extended in future.
1.848 +
1.849 + @internalTechnology
1.850 + */
1.851 + enum TFlickerRemoval
1.852 + {
1.853 + /** Not Supported. */
1.854 + EFlickerRemovalNone = 0x00,
1.855 + /** Flicker removal for Field frequency of 50Hz. */
1.856 + EFlickerRemoval50Hz = 0x01,
1.857 + /** Flicker removal for Field frequency of 60Hz. */
1.858 + EFlickerRemoval60Hz = 0x02,
1.859 + /** Auto flicker removal. */
1.860 + EFlickerRemovalAuto = 0x04,
1.861 + /** Switch Off flicker removal. */
1.862 + EFlickerRemovalSwitchOff = 0x08
1.863 + };
1.864 +
1.865 + /**
1.866 + Specifes the type of neutral density filters available.
1.867 + The enumeration list may be extended in future.
1.868 +
1.869 + @internalTechnology
1.870 + */
1.871 + enum TNDFilter
1.872 + {
1.873 + /** Not Supported. */
1.874 + ENDFilterNone = 0x00,
1.875 + /** Auto ND Filter. */
1.876 + ENDFilterAuto = 0x01,
1.877 + /** Switched off ND Filter. */
1.878 + ENDFilterSwitchedOff = 0x02,
1.879 + /** High level ND Filter. */
1.880 + ENDFilterHigh = 0x04,
1.881 + /** Medium level ND Filter. */
1.882 + ENDFilterMedium = 0x08,
1.883 + /** Low level ND Filter. */
1.884 + ENDFilterLow = 0x10,
1.885 + /** General ND Filter. */
1.886 + ENDFilterGeneral = 0x20
1.887 + };
1.888 +
1.889 + /**
1.890 + Specifies the various events for which the LED effects could be used.
1.891 + The enumeration list may be extended in future.
1.892 +
1.893 + @internalTechnology
1.894 + */
1.895 + enum TLEDEvent
1.896 + {
1.897 + /** Not supported. */
1.898 + ELEDEventNone = 0x00,
1.899 + /** LED effect needed for self timer. */
1.900 + ELEDEventSelfTimer = 0x01,
1.901 + /** LED effect needed for starting of viewfinder. */
1.902 + ELEDEventViewfinderStart = 0x02,
1.903 + /** LED effect needed for stoping of viewfinder. */
1.904 + ELEDEventViewfinderStop = 0x04,
1.905 + /** LED effect needed for still image capture. */
1.906 + ELEDEventStillImageCapture = 0x08,
1.907 + /** LED effect needed for video recording. */
1.908 + ELEDEventVideoRecording = 0x10
1.909 + };
1.910 +
1.911 + /**
1.912 + Specifes the type of LED effects available.
1.913 + The enumeration list may be extended in future.
1.914 +
1.915 + @internalTechnology
1.916 + */
1.917 + enum TLEDEffect
1.918 + {
1.919 + /** Not supported. */
1.920 + ELEDEffectNone =0x00,
1.921 + /** LED always on. */
1.922 + ELEDEffectHardwired =0x01,
1.923 + /** LED auto. */
1.924 + ELEDEffectAuto =0x02,
1.925 + /** LED Effect manually switched on. */
1.926 + ELEDEffectManualSwitchOn =0x04,
1.927 + /** LED Effect switched off. */
1.928 + ELEDEffectSwitchOff =0x08,
1.929 + /** LED Custom Effect. */
1.930 + ELEDEffectCustom =0x10
1.931 + };
1.932 +
1.933 + /**
1.934 + Color channels on which manual gain can be selectively applied.
1.935 + The enumeration list may be extended in future.
1.936 +
1.937 + @internalTechnology
1.938 + */
1.939 + enum TColorChannel
1.940 + {
1.941 + /** Red Color Channel (RGB model). */
1.942 + EColorChannelRed,
1.943 + /** Green Color Channel (RGB model). */
1.944 + EColorChannelGreen,
1.945 + /** Blue Color Channel (RGB model). */
1.946 + EColorChannelBlue,
1.947 + /** Luminance Y component (YUV model). */
1.948 + EChannelLumaY,
1.949 + /** Chrominance U component (YUV model). */
1.950 + EChannelChromaU,
1.951 + /** Chrominance V component (YUV model). */
1.952 + EChannelChromaV
1.953 + };
1.954 +
1.955 + /**
1.956 + Class used to provide a particular custom LED effect.
1.957 +
1.958 + @internalTechnology
1.959 + */
1.960 + class TECamLEDSpecialEffectStep
1.961 + {
1.962 + public:
1.963 + TECamLEDSpecialEffectStep();
1.964 +
1.965 + TUint Size() const;
1.966 + TUint Version() const;
1.967 +
1.968 + private:
1.969 + //for future expansion
1.970 + TUint iSize:24;
1.971 + TUint iVersion:8;
1.972 +
1.973 + // reserved for future expansion.
1.974 + TInt iReserved1;
1.975 + TInt iReserved2;
1.976 + TInt iReserved3;
1.977 +
1.978 + public:
1.979 + /** Blinking frequency of LED in Hertz. */
1.980 + TUint iBlinkingFrequency;
1.981 + /** Represents the intensity of LED in millicandela. */
1.982 + TUint iIntensity;
1.983 + /** Frequency step with which the blinking frequency changes with time. May be positive as well as negative. */
1.984 + TInt iFrequencyStep;
1.985 + /** Time duration for which the particular LED special effect step would be valid. */
1.986 + TTimeIntervalMicroSeconds32 iDuration;
1.987 + };
1.988 +
1.989 + /**
1.990 + Class used to provide supported continuous zoom information.
1.991 +
1.992 + @internalTechnology
1.993 + @prototype
1.994 + */
1.995 + class TContinuousZoomSupportInfo
1.996 + {
1.997 + public:
1.998 + IMPORT_C TContinuousZoomSupportInfo();
1.999 +
1.1000 + IMPORT_C TUint Size() const;
1.1001 + IMPORT_C TUint Version() const;
1.1002 +
1.1003 + private:
1.1004 + //for future expansion
1.1005 + TUint iSize:24;
1.1006 + TUint iVersion:8;
1.1007 +
1.1008 + // reserved for future expansion
1.1009 + TInt iReserved1;
1.1010 + TInt iReserved2;
1.1011 + TInt iReserved3;
1.1012 +
1.1013 + public:
1.1014 + /** Maximum continuous zoom speed supported. Minimum speed is 0. */
1.1015 + TInt iMaxSpeedSupported;
1.1016 + /** Minimum continuous zoom acceleration supported. A negative value signifies deceleration. */
1.1017 + TInt iMinAccelerationSupported;
1.1018 + /** Maximum continuous zoom acceleration supported. */
1.1019 + TInt iMaxAccelerationSupported;
1.1020 + /** Minimum continuous zoom value. For digital zoom, this could be 0 unless viewfinder frames are not cropped and scaled up by default.
1.1021 + Represented as a concrete value multiplied by KECamFineResolutionFactor. */
1.1022 + TInt iContinuousZoomMinLimit;
1.1023 + /** Maximum continuous zoom value. Represented as a concrete value multiplied by KECamFineResolutionFactor. */
1.1024 + TInt iContinuousZoomMaxLimit;
1.1025 + };
1.1026 +
1.1027 + /**
1.1028 + Class used to provide essential parameters for continuous zoom operation.
1.1029 +
1.1030 + @internalTechnology
1.1031 + @prototype
1.1032 + */
1.1033 + class TContinuousZoomParameters
1.1034 + {
1.1035 + public:
1.1036 + IMPORT_C TContinuousZoomParameters();
1.1037 +
1.1038 + IMPORT_C TUint Size() const;
1.1039 + IMPORT_C TUint Version() const;
1.1040 +
1.1041 + private:
1.1042 + //for future expansion
1.1043 + TUint iSize:24;
1.1044 + TUint iVersion:8;
1.1045 +
1.1046 + // reserved for future expansion
1.1047 + TInt iReserved1;
1.1048 + TInt iReserved2;
1.1049 + TInt iReserved3;
1.1050 +
1.1051 + public:
1.1052 + /** Type of continuous zoom to be used. */
1.1053 + TContinuousZoomType iContinuousZoomType;
1.1054 + /** Zoom direction to be used. */
1.1055 + TZoomDirection iZoomDirection;
1.1056 + /** Continuous zoom speed to be used. Represented as a concrete value multiplied by KECamFineResolutionFactor. */
1.1057 + TInt iContinuousZoomSpeed;
1.1058 + /** Continuous zoom acceleration to be used. Represented as a concrete value multiplied by KECamFineResolutionFactor. */
1.1059 + TInt iContinuousZoomAcceleration;
1.1060 + /** Limit of continuous zoom range. Represented as a concrete value multiplied by KECamFineResolutionFactor. */
1.1061 + TInt iContinuousZoomLimit;
1.1062 + };
1.1063 +
1.1064 +public:
1.1065 +
1.1066 + IMPORT_C static CCameraAdvancedSettings* NewL(CCamera& aCamera);
1.1067 +
1.1068 + IMPORT_C TCameraType CameraType() const;
1.1069 +
1.1070 + IMPORT_C TCameraType CameraType(TInt aCameraIndex);
1.1071 +
1.1072 + IMPORT_C TBool IsCameraPresent() const;
1.1073 +
1.1074 + IMPORT_C TBool IsCameraPresent(TInt aCameraIndex);
1.1075 +
1.1076 + IMPORT_C TInt CameraIndex() const;
1.1077 +
1.1078 + IMPORT_C TInt SupportedStabilizationModes() const;
1.1079 +
1.1080 + IMPORT_C TStabilizationMode StabilizationMode() const;
1.1081 +
1.1082 + IMPORT_C void SetStabilizationMode(TStabilizationMode aStabilizationMode);
1.1083 +
1.1084 + IMPORT_C TInt SupportedFocusModes() const;
1.1085 +
1.1086 + IMPORT_C TFocusMode FocusMode() const;
1.1087 +
1.1088 + IMPORT_C void SetFocusMode(TFocusMode aFocusMode);
1.1089 +
1.1090 + IMPORT_C TInt SupportedFocusRanges() const;
1.1091 +
1.1092 + IMPORT_C TFocusRange FocusRange() const;
1.1093 +
1.1094 + IMPORT_C void SetFocusRange(TFocusRange aFocusRange);
1.1095 +
1.1096 + IMPORT_C TInt SupportedAutoFocusTypes() const;
1.1097 +
1.1098 + IMPORT_C TAutoFocusType AutoFocusType() const;
1.1099 +
1.1100 + IMPORT_C void SetAutoFocusType(TAutoFocusType aAutoFocusType);
1.1101 +
1.1102 + IMPORT_C TInt SupportedAutoFocusAreas() const;
1.1103 +
1.1104 + IMPORT_C TAutoFocusArea AutoFocusArea() const;
1.1105 +
1.1106 + IMPORT_C void SetAutoFocusArea(TAutoFocusArea aAutoFocusArea);
1.1107 +
1.1108 + IMPORT_C TInt FocusDistance() const;
1.1109 +
1.1110 + IMPORT_C void SetFocusDistance(TInt aDistance);
1.1111 +
1.1112 + IMPORT_C TInt GetMinFocalLength() const;
1.1113 +
1.1114 + IMPORT_C void GetSupportedIsoRatesL(RArray<TInt>& aSupportedIsoRates) const;
1.1115 +
1.1116 + IMPORT_C TInt IsoRate() const;
1.1117 +
1.1118 + IMPORT_C void SetIsoRate(TInt aRate);
1.1119 +
1.1120 + IMPORT_C void GetAperturesL(RArray<TInt>& aFStops, TValueInfo& aInfo) const;
1.1121 +
1.1122 + IMPORT_C TInt Aperture() const;
1.1123 +
1.1124 + IMPORT_C void SetAperture(TInt aFStop);
1.1125 +
1.1126 + IMPORT_C void GetShutterSpeedsL(RArray<TInt>& aShutterSpeeds, TValueInfo& aInfo) const;
1.1127 +
1.1128 + IMPORT_C TInt ShutterSpeed() const;
1.1129 +
1.1130 + IMPORT_C void SetShutterSpeed(TInt aShutterSpeed);
1.1131 +
1.1132 + IMPORT_C TInt SupportedMeteringModes() const;
1.1133 +
1.1134 + IMPORT_C TMeteringMode MeteringMode() const;
1.1135 +
1.1136 + IMPORT_C void SetMeteringMode(TMeteringMode aMeteringMode);
1.1137 +
1.1138 + IMPORT_C TInt SupportedDriveModes() const;
1.1139 +
1.1140 + IMPORT_C TDriveMode DriveMode() const;
1.1141 +
1.1142 + IMPORT_C void SetDriveMode(TDriveMode aDriveMode);
1.1143 +
1.1144 + IMPORT_C TInt SupportedBracketModes() const;
1.1145 +
1.1146 + IMPORT_C TBracketMode BracketMode() const;
1.1147 +
1.1148 + IMPORT_C void SetBracketMode(TBracketMode aBracketMode);
1.1149 +
1.1150 + IMPORT_C TInt SupportedBracketParameters() const;
1.1151 +
1.1152 + IMPORT_C TBracketParameter BracketParameter() const;
1.1153 +
1.1154 + IMPORT_C void SetBracketParameter(TBracketParameter aBracketParameter);
1.1155 +
1.1156 + IMPORT_C TInt SupportedBracketSteps() const;
1.1157 +
1.1158 + IMPORT_C TBracketStep BracketStep() const;
1.1159 +
1.1160 + IMPORT_C void SetBracketStep(TBracketStep aBracketStep);
1.1161 +
1.1162 + IMPORT_C void GetBracketMerge(TInt& aStartIndex, TInt& aFrames) const;
1.1163 +
1.1164 + IMPORT_C void SetBracketMerge(TInt aStartIndex, TInt aFrames);
1.1165 +
1.1166 + IMPORT_C TInt SupportedFlashModes() const;
1.1167 +
1.1168 + IMPORT_C CCamera::TFlash FlashMode() const;
1.1169 +
1.1170 + IMPORT_C void SetFlashMode(CCamera::TFlash aMode);
1.1171 +
1.1172 + IMPORT_C TBool RedEyeReduceOn() const;
1.1173 +
1.1174 + IMPORT_C void SetRedEyeReduceOn(TBool aState);
1.1175 +
1.1176 + IMPORT_C void GetFlashCompensationStepsL(RArray<TInt>& aFlashCompensationSteps, TValueInfo& aInfo) const;
1.1177 +
1.1178 + IMPORT_C TInt FlashCompensationStep() const;
1.1179 +
1.1180 + IMPORT_C TInt GetFlashCompensationStep(TInt& aFlashCompensationStep) const;
1.1181 +
1.1182 + IMPORT_C void SetFlashCompensationStep(TInt aFlashCompensationStep);
1.1183 +
1.1184 + IMPORT_C void GetFlashCompensationRangeInSteps(TInt& aNegativeCompensation, TInt& aPositiveCompensation) const;
1.1185 +
1.1186 + IMPORT_C TInt FlashCompensation() const;
1.1187 +
1.1188 + IMPORT_C TInt GetFlashCompensation(TInt& aFlashCompensation) const;
1.1189 +
1.1190 + IMPORT_C void SetFlashCompensation(TInt aFlashCompensationInSteps);
1.1191 +
1.1192 + IMPORT_C TBool IsExternalFlashPresent() const;
1.1193 +
1.1194 + IMPORT_C void GetManualFlashPowerLevelsL(RArray<TInt>& aManualFlashPowerLevels, TValueInfo& aInfo) const;
1.1195 +
1.1196 + IMPORT_C TInt ManualFlashPowerLevel() const;
1.1197 +
1.1198 + IMPORT_C void SetManualFlashPowerLevel(TInt aManualFlashPowerLevel);
1.1199 +
1.1200 + IMPORT_C TInt SupportedExposureModes() const;
1.1201 +
1.1202 + IMPORT_C CCamera::TExposure ExposureMode() const;
1.1203 +
1.1204 + IMPORT_C void SetExposureMode(CCamera::TExposure aExposureMode);
1.1205 +
1.1206 + IMPORT_C void GetExposureCompensationStepsL(RArray<TInt>& aExposureCompensationSteps, TValueInfo& aInfo) const;
1.1207 +
1.1208 + IMPORT_C TInt ExposureCompensationStep() const;
1.1209 +
1.1210 + IMPORT_C TInt GetExposureCompensationStep(TInt& aExposureCompensationStep) const;
1.1211 +
1.1212 + IMPORT_C void SetExposureCompensationStep(TInt aExposureCompensationStep);
1.1213 +
1.1214 + IMPORT_C void GetExposureCompensationRangeInSteps(TInt& aNegativeCompensation, TInt& aPositiveCompensation) const;
1.1215 +
1.1216 + IMPORT_C TInt ExposureCompensation() const;
1.1217 +
1.1218 + IMPORT_C TInt GetExposureCompensation(TInt& aExposureCompensation) const;
1.1219 +
1.1220 + IMPORT_C void SetExposureCompensation(TInt aExposureCompensationInSteps);
1.1221 +
1.1222 + IMPORT_C TInt SupportedWhiteBalanceModes() const;
1.1223 +
1.1224 + IMPORT_C CCamera::TWhiteBalance WhiteBalanceMode() const;
1.1225 +
1.1226 + IMPORT_C void SetWhiteBalanceMode(CCamera::TWhiteBalance aWhiteBalanceMode);
1.1227 +
1.1228 + IMPORT_C TBool ApertureExposureLockOn() const;
1.1229 +
1.1230 + IMPORT_C void SetApertureExposureLockOn(TBool aAELock);
1.1231 +
1.1232 + IMPORT_C TBool ShootClickOn() const;
1.1233 +
1.1234 + IMPORT_C void SetShootClickOn(TBool aShootClickOn);
1.1235 +
1.1236 + IMPORT_C void GetTimerIntervalsL(RArray<TInt>& aTimerIntervals, TValueInfo& aInfo) const;
1.1237 +
1.1238 + IMPORT_C TInt TimerInterval() const;
1.1239 +
1.1240 + IMPORT_C void SetTimerInterval(TInt aTimerInterval);
1.1241 +
1.1242 + IMPORT_C void GetTimeLapsePeriodRange(TTime& aTimeLapseMin, TTime& aTimeLapseMax) const;
1.1243 +
1.1244 + IMPORT_C void GetTimeLapse(TTime& aStart, TTime& aEnd, TTime& aInterval) const;
1.1245 +
1.1246 + IMPORT_C void SetTimeLapse(const TTime& aStart, const TTime& aEnd, const TTime& aInterval);
1.1247 +
1.1248 + IMPORT_C TPictureOrientation PictureOrientation() const;
1.1249 +
1.1250 + IMPORT_C void SetPictureOrientation(TPictureOrientation aOrientation);
1.1251 +
1.1252 + IMPORT_C TInt SupportedPixelAspectRatios() const;
1.1253 +
1.1254 + IMPORT_C TPixelAspectRatio PixelAspectRatio() const;
1.1255 +
1.1256 + IMPORT_C void SetPixelAspectRatio(TPixelAspectRatio aPixelAspectRatio);
1.1257 +
1.1258 + IMPORT_C TInt SupportedYuvRanges() const;
1.1259 +
1.1260 + IMPORT_C TYuvRange YuvRange() const;
1.1261 +
1.1262 + IMPORT_C void SetYuvRange(TYuvRange aYuvRange);
1.1263 +
1.1264 + IMPORT_C TInt BurstImages() const;
1.1265 +
1.1266 + IMPORT_C void SetBurstImages(TInt aImages);
1.1267 +
1.1268 + IMPORT_C void GetOpticalZoomStepsL(RArray<TInt>& aOpticalZoomSteps, TValueInfo& aInfo) const;
1.1269 +
1.1270 + IMPORT_C TInt OpticalZoom() const;
1.1271 +
1.1272 + IMPORT_C void SetOpticalZoom(TInt aOpticalZoom);
1.1273 +
1.1274 + IMPORT_C void GetDigitalZoomStepsL(RArray<TInt>& aDigitalZoomSteps, TValueInfo& aInfo) const;
1.1275 +
1.1276 + IMPORT_C TInt DigitalZoom() const;
1.1277 +
1.1278 + IMPORT_C void SetDigitalZoom(TInt aDigitalZoom);
1.1279 +
1.1280 + IMPORT_C TBool ExposureLockOn() const;
1.1281 +
1.1282 + IMPORT_C void SetExposureLockOn(TBool aState);
1.1283 +
1.1284 + IMPORT_C TBool AutoFocusLockOn() const;
1.1285 +
1.1286 + IMPORT_C void SetAutoFocusLockOn(TBool aState);
1.1287 +
1.1288 + IMPORT_C void GetSupportedSettingsL(RArray<TUid>& aSettings) const;
1.1289 +
1.1290 + IMPORT_C void GetActiveSettingsL(RArray<TUid>& aActiveSettings) const;
1.1291 +
1.1292 + IMPORT_C void GetDisabledSettingsL(RArray<TUid>& aDisabledSettings) const;
1.1293 +
1.1294 + IMPORT_C TBool AutomaticSizeSelectionChangeOn() const;
1.1295 +
1.1296 + IMPORT_C void SetAutomaticSizeSelectionChangeOn(TBool aSetOn);
1.1297 +
1.1298 + IMPORT_C void GetSupportedContinuousAutoFocusTimeoutsL(RArray<TInt>& aTimeouts, TValueInfo& aInfo) const;
1.1299 +
1.1300 + IMPORT_C TInt ContinuousAutoFocusTimeout() const;
1.1301 +
1.1302 + IMPORT_C void SetContinuousAutoFocusTimeout(TInt aTimeout);
1.1303 +
1.1304 + IMPORT_C TInt SupportedStabilizationEffects() const;
1.1305 +
1.1306 + IMPORT_C TStabilizationEffect StabilizationEffect() const;
1.1307 +
1.1308 + IMPORT_C void SetStabilizationEffect(TStabilizationEffect aEffect);
1.1309 +
1.1310 + IMPORT_C TInt SupportedStabilizationComplexityValues() const;
1.1311 +
1.1312 + IMPORT_C TStabilizationAlgorithmComplexity StabilizationComplexity() const;
1.1313 +
1.1314 + IMPORT_C void SetStabilizationComplexity(TStabilizationAlgorithmComplexity aComplexity);
1.1315 +
1.1316 + IMPORT_C TWBUnits SupportedWBUnits() const;
1.1317 +
1.1318 + IMPORT_C void GetWBRgbValue(TRgb& aValue) const;
1.1319 +
1.1320 + IMPORT_C void SetWBRgbValue(const TRgb& aValue);
1.1321 +
1.1322 + IMPORT_C void GetWBSupportedColorTemperaturesL(RArray<TInt>& aWBColorTemperatures, TValueInfo& aInfo) const;
1.1323 +
1.1324 + IMPORT_C TInt WBColorTemperature() const;
1.1325 +
1.1326 + IMPORT_C void SetWBColorTemperature(TInt aWBColorTemperature);
1.1327 +
1.1328 + IMPORT_C ~CCameraAdvancedSettings();
1.1329 +
1.1330 + IMPORT_C TInt IsFlashReady(TBool& aReady) const;
1.1331 +
1.1332 + IMPORT_C void GetCurrentFocusModeStepsL(RArray<TInt>& aFocusModeSteps, TValueInfo& aInfo) const;
1.1333 +
1.1334 + IMPORT_C void GetSupportedISORateTypeL(TInt& aSupportedISORateTypes) const;
1.1335 +
1.1336 + IMPORT_C void SetISORateL(TISORateType aISORateType, TInt aParam);
1.1337 +
1.1338 + IMPORT_C void GetISORateL(TISORateType& aISORateType, TInt& aParam, TInt& aISORate) const;
1.1339 +
1.1340 + IMPORT_C void SetReferenceScreenL(CWsScreenDevice& aScreenDevice);
1.1341 +
1.1342 + IMPORT_C void GetDigitalZoomStepsForStillL(RArray<TInt>& aDigitalZoomSteps, TValueInfo& aInfo, TInt aSizeIndex,
1.1343 + CCamera::TFormat aFormat, TBool& aIsInfluencePossible) const;
1.1344 +
1.1345 + IMPORT_C void GetDigitalZoomStepsForVideoL(RArray<TInt>& aDigitalZoomSteps, TValueInfo& aInfo, TInt aFrameRateIndex,
1.1346 + TInt aSizeIndex, CCamera::TFormat aFormat, TBool& aIsInfluencePossible, CCamera::TExposure aExposure) const;
1.1347 +
1.1348 + IMPORT_C void GetPreCaptureWarningSupportedL(TCameraMode aCameraMode, TInt& aPreCaptureWarningSupported) const;
1.1349 +
1.1350 + IMPORT_C void SubscribeToPreCaptureWarningL(TInt aPreCaptureWarning);
1.1351 +
1.1352 + IMPORT_C void UnSubscribePreCaptureWarningL();
1.1353 +
1.1354 + IMPORT_C void GetPreCaptureWarningL(TInt& aPreCaptureWarning) const;
1.1355 +
1.1356 + IMPORT_C void GetSupportedAFAssistantLightL(TInt& aSupportedAFAssistantLight) const;
1.1357 +
1.1358 + IMPORT_C void GetAFAssistantLightL(TAFAssistantLight& aAFAssistantLight) const;
1.1359 +
1.1360 + IMPORT_C void SetAFAssistantLightL(TAFAssistantLight aAFAssistantLight);
1.1361 +
1.1362 + IMPORT_C void GetSupportedContinuousZoomTypeL(TUint& aSupportedContinuousZoomType) const;
1.1363 +
1.1364 + IMPORT_C void GetFocalLengthInfoL(TInt& aMinFocalLength, TInt& aCurrentFocalLength, TInt& aMaxFocalLength) const;
1.1365 +
1.1366 + IMPORT_C void GetNumOperationPreferenceL(TUint& aNumOperationPreferenceSupported) const;
1.1367 +
1.1368 + IMPORT_C void EnumerateOperationPreferenceL(TUint aOperationPreferenceIndex, TPerformanceLevel& aSpeedLevel,
1.1369 + TPerformanceLevel& aQualityLevel, TPerformanceLevel& aLowMemoryConsumptionLevel,
1.1370 + TPerformanceLevel& aLowPowerConsumptionLevel) const;
1.1371 +
1.1372 + IMPORT_C void SetOperationPreferenceL(TUint aOperationPreferenceIndex);
1.1373 +
1.1374 + IMPORT_C void GetOperationPreferenceL(TInt& aOperationPreferenceIndex) const;
1.1375 +
1.1376 + IMPORT_C void GetSupportedEventsL(RArray<TUid>& aSupportedEvents) const;
1.1377 +
1.1378 + IMPORT_C void GetIndirectFeatureChangesL(TUid aRequestedSetting, RArray<TUid>& aIndirectFeatureChanges) const;
1.1379 +
1.1380 + IMPORT_C void CreateContinuousZoomL(MContinuousZoomObserver& aObserver, TContinuousZoomType aContinuousZoomType, CCameraContinuousZoom*& aContinuousZoom);
1.1381 +
1.1382 +private:
1.1383 + IMPORT_C CCameraAdvancedSettings(CCamera& aOwner);
1.1384 + IMPORT_C void ConstructL();
1.1385 +
1.1386 +private:
1.1387 + enum TECAMEventFilterScheme
1.1388 + {
1.1389 + /** Black listing will mean not to receive specific events */
1.1390 + EECAMEventFilterSchemeBlackList,
1.1391 + /** White listing will mean to receive only specific events */
1.1392 + EECAMEventFilterSchemeWhiteList
1.1393 + };
1.1394 +
1.1395 + void RegisterEventsL(TECAMEventFilterScheme aEventFilter, const RArray<TUid>& aEvents);
1.1396 + void GetRegisterEventsL(TECAMEventFilterScheme aEventFilter, RArray<TUid>& aEvents, TValueInfo& aInfo) const;
1.1397 +
1.1398 + void GetSupportedFlickerRemovalValueL(TUint& aSupportedFlickerRemovalValue) const;
1.1399 + void GetFlickerRemovalValueL(TFlickerRemoval& aFlickerRemovalValue) const;
1.1400 + void SetFlickerRemovalValueL(TFlickerRemoval aFlickerRemovalValue);
1.1401 +
1.1402 + void GetSupportedNDFilterL(TUint& aSupportedNDFilter) const;
1.1403 + void GetNDFilterL(TNDFilter& aNDFilter) const;
1.1404 + void SetNDFilterL(TNDFilter aNDFilter);
1.1405 +
1.1406 + void GetLEDEffectL(TLEDEvent aLEDEvent, TLEDEffect& aLEDEffect) const;
1.1407 + void SetLEDEffectL(TLEDEvent aLEDEvent, TLEDEffect aLEDEffect);
1.1408 + void SetLEDCustomEffectL(TLEDEvent aLEDEvent, const RArray<TECamLEDSpecialEffectStep>& aLEDSpecialEffectSteps);
1.1409 +
1.1410 + void ReserveL(const TTimeIntervalMicroSeconds32& aMaxTimeToWait, TBool aKickOut);
1.1411 + void SetClientPriorityL(TInt aPriority);
1.1412 + void RestoreClientPriorityL();
1.1413 +
1.1414 + void GetSupportedManualGainL(RArray<TInt>& aSupportedManualGain, TColorChannel aColorChannel) const;
1.1415 + void GetManualGainL(TInt& aManualGain, TColorChannel aColorChannel) const;
1.1416 + void SetManualGainL(TInt aManualGain, TColorChannel aColorChannel);
1.1417 +
1.1418 + void SetWhiteBalanceLockL(TBool aEnableLock);
1.1419 + void GetWhiteBalanceLockStateL(TBool& aIsLocked) const;
1.1420 +
1.1421 + void EnableStateSavingL(RWriteStream& aLatestCameraState);
1.1422 + void DisableStateSavingL();
1.1423 + void RestoreLatestStateL(RReadStream& aLatestCameraState);
1.1424 + void SaveCameraStateL(RWriteStream& aCustomCameraState);
1.1425 + void DisableCameraStateSavingL(RWriteStream& aCustomCameraState);
1.1426 + void RestoreCameraStateL(RReadStream& aCustomCameraState);
1.1427 +
1.1428 +private:
1.1429 + CCamera& iOwner;
1.1430 + MCameraAdvancedSettings* iImpl; // not owned
1.1431 + MCameraAdvancedSettings2* iImpl2; // not owned
1.1432 +
1.1433 + MCameraAdvancedSettings3* iImpl3; // not owned
1.1434 +
1.1435 + MCameraAdvancedSettings4* iImpl4; // not owned
1.1436 + };
1.1437 +
1.1438 +/**
1.1439 +Supported presets with the assumption for scope and outcome
1.1440 +*/
1.1441 +
1.1442 +/** Default settings */
1.1443 +static const TUid KUidECamPresetFactoryDefault = {KUidECamPresetFactoryDefaultUidValue};
1.1444 +/** Daytime shot with normal exposure time, one shot autofocus,
1.1445 +medium ISO rating and no flash. */
1.1446 +static const TUid KUidECamPresetOutdoor = {KUidECamPresetOutdoorUidValue};
1.1447 +/** Daytime shot with short exposure time, continuous autofocus,
1.1448 +high Iso rating and no flash. */
1.1449 +static const TUid KUidECamPresetOutdoorSport = {KUidECamPresetOutdoorSportUidValue};
1.1450 +/** Daytime shot with very short exposure time, high shutter speed,
1.1451 +high Iso rating and no flash. */
1.1452 +static const TUid KUidECamPresetSnow = {KUidECamPresetSnowUidValue};
1.1453 +/** Daytime shot with very short exposure time, high shutter speed,
1.1454 +high contrast, reflections and no flash. */
1.1455 +static const TUid KUidECamPresetBeach = {KUidECamPresetBeachUidValue};
1.1456 +/** Night time shot with long central exposure time and high flash power. */
1.1457 +static const TUid KUidECamPresetNightPortrait = {KUidECamPresetNightPortraitUidValue};
1.1458 +/** Night time shot with long exposure time and no flash. */
1.1459 +static const TUid KUidECamPresetNightFireworks = {KUidECamPresetNightFireworksUidValue};
1.1460 +/** Daytime shot with medium exposure time, medium to high Iso rating,
1.1461 +overcast daylight, low contrast, fill-in flash. */
1.1462 +static const TUid KUidECamPresetFog = {KUidECamPresetFogUidValue};
1.1463 +/** Fluorescent lightning with medium exposure time,
1.1464 +medium to low shutter speed with flash. */
1.1465 +static const TUid KUidECamPresetIndoor = {KUidECamPresetIndoorUidValue};
1.1466 +/** Fluorescent lightning with continuous autofocus, wide aperture,
1.1467 +high Iso rating with flash. */
1.1468 +static const TUid KUidECamPresetIndoorSport = {KUidECamPresetIndoorSportUidValue};
1.1469 +/**
1.1470 +Used in low light situations. Tries to capture all the photons from a low light scene.
1.1471 +The image may be processed longer to achieve this. This case may cause blurring, but that could be a
1.1472 +wanted effect.
1.1473 +
1.1474 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1475 +CCamera::NewDuplicate2L().
1.1476 +
1.1477 +*/
1.1478 +static const TUid KUidECamPresetNightPartyIndoor = {KUidECamPresetNightPartyIndoorUidValue};
1.1479 +/**
1.1480 +Used to capture images of things which can't be seen by eye.
1.1481 +For example: snowflakes, underwater photography, small insect photos
1.1482 +
1.1483 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1484 +CCamera::NewDuplicate2L().
1.1485 +
1.1486 +*/
1.1487 +static const TUid KUidECamPresetNightCloseUp = {KUidECamPresetNightCloseUpUidValue};
1.1488 +/**
1.1489 +Used for revealing assumed details. For example: business card photos, small written text photos,
1.1490 +underwater photography, insect photos.
1.1491 +
1.1492 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1493 +CCamera::NewDuplicate2L().
1.1494 +
1.1495 +*/
1.1496 +static const TUid KUidECamPresetNightMacro = {KUidECamPresetNightMacroUidValue};
1.1497 +/**
1.1498 +Used for taking clear pictures of text or drawings. Also used to capture business cards or of a whiteboard.
1.1499 +Aim is to optimise text and drawing readability and user expectation of "white" paper.
1.1500 +Camera shake may reduce quality in case no flash available or not adequate(distance too much from subject).
1.1501 +
1.1502 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1503 +CCamera::NewDuplicate2L().
1.1504 +
1.1505 +*/
1.1506 +static const TUid KUidECamPresetTextDocument = {KUidECamPresetTextDocumentUidValue};
1.1507 +/**
1.1508 +Used for providing clear pictures of barcode. Aim is to convert barcode into some form which can be easily decoded.
1.1509 +Camera shake may reduce this barcode readability and hence, barcode conversion accuracy and reliability.
1.1510 +
1.1511 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1512 +CCamera::NewDuplicate2L().
1.1513 +
1.1514 +*/
1.1515 +static const TUid KUidECamPresetBarcode = {KUidECamPresetBarcodeUidValue};
1.1516 +/**
1.1517 +Used when factory default preset in certain cases may not be available or is too restrictive.
1.1518 +Automatic preset expects the hardware to use automatic detection for most of the features.
1.1519 +
1.1520 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1521 +CCamera::NewDuplicate2L().
1.1522 +
1.1523 +*/
1.1524 +static const TUid KUidECamPresetAuto = {KUidECamPresetAutoUidValue};
1.1525 +/**
1.1526 +Used for portraits of human subjects in good lighting conditions. Focuses on the people and captures natural
1.1527 +skin tones. Background details may not be softened.
1.1528 +
1.1529 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1530 +CCamera::NewDuplicate2L().
1.1531 +
1.1532 +*/
1.1533 +static const TUid KUidECamPresetPortrait = {KUidECamPresetPortraitUidValue};
1.1534 +/**
1.1535 +Used for sharp landscape shots with clear outlines, colours and contrast, for example forest, sky.
1.1536 +The main aim is to get the details of the scene.
1.1537 +
1.1538 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1539 +CCamera::NewDuplicate2L().
1.1540 +
1.1541 +*/
1.1542 +static const TUid KUidECamPresetLandscape = {KUidECamPresetLandscapeUidValue};
1.1543 +/**
1.1544 +Used to retain the ambience/mood produced by, for example, warm lighting conditions like sunset, candlelight etc.
1.1545 +
1.1546 +This uid value is available from the 'supported' or 'getter' methods only to the API clients using CCamera::New2L() or
1.1547 +CCamera::NewDuplicate2L().
1.1548 +
1.1549 +*/
1.1550 +static const TUid KUidECamPresetAmbienceMood = {KUidECamPresetAmbienceMoodUidValue};
1.1551 +
1.1552 +/**
1.1553 +This API is used to simplify user - camera interaction by allowing simultaneous
1.1554 +setting of various advanced camera hardware settings using a single parameter.
1.1555 +
1.1556 +Preset is identified by a single UID and relates to a known predefined outcome.
1.1557 +For example the 'Night' Preset will be used to set the camera into a night mode
1.1558 +so that the user can take night photos.
1.1559 +
1.1560 +The particular set of settings associated with the specific preset and their specific values
1.1561 +and ranges are camera hardware specific and outside the scope of this API.
1.1562 +
1.1563 +@note This class is not intended for sub-classing and used to standardise existing
1.1564 + varieties of implementations.
1.1565 +
1.1566 +@note If the class methods leave, the output type parameter value is not guaranteed to be valid.
1.1567 +
1.1568 +@publishedAll
1.1569 +@released
1.1570 +*/
1.1571 +class CCamera::CCameraPresets : public CBase
1.1572 + {
1.1573 + /** allow access to private constructors. */
1.1574 + friend class CCamera;
1.1575 +
1.1576 +public:
1.1577 +
1.1578 + IMPORT_C static CCameraPresets* NewL(CCamera& aCamera);
1.1579 +
1.1580 + IMPORT_C void GetSupportedPresetsL(RArray<TUid>& aPresets) const;
1.1581 +
1.1582 + IMPORT_C void SetPreset(TUid aPreset);
1.1583 +
1.1584 + IMPORT_C TUid Preset() const;
1.1585 +
1.1586 + IMPORT_C void GetAffectedSettingsL(RArray<TUid>& aSettings) const;
1.1587 +
1.1588 + IMPORT_C void GetAssociatedSettingsL(TUid aPreset, RArray<TUid>& aSettings) const;
1.1589 +
1.1590 + IMPORT_C ~CCameraPresets();
1.1591 +
1.1592 + IMPORT_C void GetRangeRestrictedSettingsL(RArray<TUid>& aRangeRestrictedSettings) const;
1.1593 +
1.1594 + IMPORT_C void GetFeatureRestrictedSettingsL(RArray<TUid>& aFeatureRestrictedSettings) const;
1.1595 +
1.1596 + IMPORT_C void IsPresetUnlockSupportedL(TBool& aUnlockSupported) const;
1.1597 +
1.1598 + IMPORT_C void LockPresetL();
1.1599 +
1.1600 + IMPORT_C void UnlockPresetL();
1.1601 +
1.1602 +private:
1.1603 + IMPORT_C CCameraPresets(CCamera& aOwner);
1.1604 + IMPORT_C void ConstructL();
1.1605 +
1.1606 + void FilterUnrecognisedUids(RArray<TUid>& aUids, const TInt aBaselineUid) const;
1.1607 +
1.1608 +private:
1.1609 + CCamera& iOwner;
1.1610 + MCameraPresets* iImpl; // not owned
1.1611 + MCameraPresets2* iImpl2; // not owned
1.1612 + };
1.1613 +
1.1614 +
1.1615 +/**
1.1616 +This API is used to provide advanced continuous zoom support to the user.
1.1617 +
1.1618 +This class is not directly created by the client but instead created via
1.1619 +CCameraAdvancedSettings::CreateContinuousZoomL(). Ownership of the object
1.1620 +is passed back to the client.
1.1621 +
1.1622 +@note This class is not intended for sub-classing and used to standardise existing
1.1623 + varieties of implementations.
1.1624 +
1.1625 +@note If the class methods leave, the output type parameter value is not guaranteed to be valid.
1.1626 +
1.1627 +@internalTechnology
1.1628 +@prototype
1.1629 +*/
1.1630 +class CCamera::CCameraContinuousZoom : public CBase
1.1631 + {
1.1632 + friend void CCamera::CCameraAdvancedSettings::CreateContinuousZoomL(MContinuousZoomObserver& aObserver, TContinuousZoomType aContinuousZoomType, CCameraContinuousZoom*& aContinuousZoom);
1.1633 +
1.1634 +public:
1.1635 + IMPORT_C void StartContinuousZoomL(CCamera::CCameraAdvancedSettings::TContinuousZoomParameters aContinuousZoomParameters);
1.1636 +
1.1637 + IMPORT_C void StopContinuousZoom();
1.1638 +
1.1639 + IMPORT_C void GetContinuousZoomSupportInfoL(CCamera::CCameraAdvancedSettings::TContinuousZoomSupportInfo& aContinuousZoomInfo) const;
1.1640 +
1.1641 + IMPORT_C void GetContinuousZoomId(TInt& aZoomId) const;
1.1642 +
1.1643 + IMPORT_C ~CCameraContinuousZoom();
1.1644 +
1.1645 +private:
1.1646 + static CCameraContinuousZoom* CreateL(MContinuousZoomObserver& aObserver, CCamera::CCameraAdvancedSettings::TContinuousZoomType aContinuousZoomType, const MImplementationFactory& aImplFactory);
1.1647 +
1.1648 + CCameraContinuousZoom();
1.1649 + void ConstructL(MContinuousZoomObserver& aObserver, CCamera::CCameraAdvancedSettings::TContinuousZoomType aContinuousZoomType, const MImplementationFactory& aImplFactory);
1.1650 +
1.1651 +private:
1.1652 + MCameraContinuousZoom* iImpl;
1.1653 + };
1.1654 +
1.1655 +#endif // ECAMADVSETTINGS_H
1.1656 +
1.1657 +
1.1658 +