1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000
1.2 +++ b/os/mm/imagingandcamerafws/camerafw/Include/ECam/ECamInfoPlugin.h Fri Jun 15 03:10:57 2012 +0200
1.3 @@ -0,0 +1,180 @@
1.4 +// Copyright (c) 2004-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 + @publishedPartner
1.22 + @released
1.23 +*/
1.24 +
1.25 +#ifndef ECAMINFOPLUGIN_H
1.26 +#define ECAMINFOPLUGIN_H
1.27 +
1.28 +#include <ecam.h>
1.29 +
1.30 +class CCameraPlugin;
1.31 +
1.32 +/**
1.33 +Plugin used to supply static data for CCamera.
1.34 +*/
1.35 +class CCameraInfoPlugin : public CBase
1.36 + {
1.37 + friend class CCameraPlugin;
1.38 +
1.39 +public:
1.40 +
1.41 + /**
1.42 + Default destructor for this class.
1.43 + */
1.44 + IMPORT_C ~CCameraInfoPlugin();
1.45 +
1.46 + /**
1.47 + Determines the number of cameras on the device.
1.48 +
1.49 + @return Count of cameras present on the device.
1.50 + */
1.51 + virtual TInt CamerasAvailable()=0;
1.52 +
1.53 +protected:
1.54 +
1.55 + /**
1.56 + Default constructor for this class.
1.57 + */
1.58 + IMPORT_C CCameraInfoPlugin();
1.59 +
1.60 +private:
1.61 + /**
1.62 + Loads the plugin and returns a pointer to it.
1.63 +
1.64 + @return Pointer to the plugin.
1.65 + */
1.66 + static CCameraInfoPlugin* NewL();
1.67 +
1.68 +private:
1.69 + TUid iDestructorKey;
1.70 +
1.71 + };
1.72 +
1.73 +/**
1.74 +@publishedPartner
1.75 +@prototype
1.76 +
1.77 +'Property' in the Publish/Subscribe API.
1.78 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.79 +current process's secureID.
1.80 +*/
1.81 +static const TUint KUidECamPropertyCameraIndex0ReservedStatus = 0x102831F1;
1.82 +
1.83 +/**
1.84 +@publishedPartner
1.85 +@prototype
1.86 +
1.87 +'Property' in the Publish/Subscribe API.
1.88 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.89 +current process's secureID.
1.90 +*/
1.91 +static const TUint KUidECamPropertyCameraIndex1ReservedStatus = 0x102831FA;
1.92 +
1.93 +/**
1.94 +@publishedPartner
1.95 +@prototype
1.96 +
1.97 +'Property' in the Publish/Subscribe API.
1.98 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.99 +current process's secureID.
1.100 +*/
1.101 +static const TUint KUidECamPropertyCameraIndex2ReservedStatus = 0x102831FB;
1.102 +
1.103 +/**
1.104 +@publishedPartner
1.105 +@prototype
1.106 +
1.107 +'Property' in the Publish/Subscribe API.
1.108 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.109 +current process's secureID.
1.110 +*/
1.111 +static const TUint KUidECamPropertyCameraIndex3ReservedStatus = 0x102831FC;
1.112 +
1.113 +/**
1.114 +@publishedPartner
1.115 +@prototype
1.116 +
1.117 +'Property' in the Publish/Subscribe API.
1.118 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.119 +current process's secureID.
1.120 +*/
1.121 +static const TUint KUidECamPropertyCameraIndex4ReservedStatus = 0x102831FD;
1.122 +
1.123 +/**
1.124 +@publishedPartner
1.125 +@prototype
1.126 +
1.127 +'Property' in the Publish/Subscribe API.
1.128 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.129 +current process's secureID.
1.130 +*/
1.131 +static const TUint KUidECamPropertyCameraIndex5ReservedStatus = 0x102831FE;
1.132 +
1.133 +/**
1.134 +@publishedPartner
1.135 +@prototype
1.136 +
1.137 +'Property' in the Publish/Subscribe API.
1.138 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.139 +current process's secureID.
1.140 +*/
1.141 +static const TUint KUidECamPropertyCameraIndex6ReservedStatus = 0x102831FF;
1.142 +
1.143 +/**
1.144 +@publishedPartner
1.145 +@prototype
1.146 +
1.147 +'Property' in the Publish/Subscribe API.
1.148 +Used by the ECAM implementation as property sub-keys while defining the property within the category given by
1.149 +current process's secureID.
1.150 +*/
1.151 +static const TUint KUidECamPropertyCameraIndex7ReservedStatus = 0x10283200;
1.152 +
1.153 +/**
1.154 +Plugin used to retrieve the secure ID of the process where serialized part of the ECam implementation runs.
1.155 +
1.156 +Meant for implementation by the ECam implementers.
1.157 +
1.158 +Implementation has to define and publish the properties as given by the keys KUidECamPropertyCameraIndex0ReservedStatus
1.159 +to KUidECamPropertyCameraIndex7ReservedStatus. Client's responsibility is to subscribe to these properties using
1.160 +TReservedInfo::SubscribeReserveInfoL and hence implement the interface MReserveObserver.
1.161 +
1.162 +@publishedPartner
1.163 +@prototype
1.164 +*/
1.165 +class MSecureIdPlugin
1.166 + {
1.167 +public:
1.168 + virtual void Release() =0;
1.169 + /**
1.170 + Used to retrieve the Secure ID of the process where serialized part of the ECam implementation runs. Secure ID will be
1.171 + internally used to attach to the Properties for which the Reserve notification will be subscribed for.
1.172 +
1.173 + @param aSecureId
1.174 + The secure ID of the process where serialized part of the ECam implementation runs.
1.175 +
1.176 + @leave May leave with any error code.
1.177 +
1.178 + @note Serialized part of the ECam implementation is supposed to define and publish those Properties.
1.179 + */
1.180 + virtual void GetSecureIdL(TInt& aSecureId) const =0;
1.181 + };
1.182 +
1.183 +#endif // ECAMINFOPLUGIN_H