Update contrib.
2 * Copyright (c) 2004 Nokia Corporation and/or its subsidiary(-ies).
4 * This component and the accompanying materials are made available
5 * under the terms of "Eclipse Public License v1.0"
6 * which accompanies this distribution, and is available
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
9 * Initial Contributors:
10 * Nokia Corporation - initial contribution.
14 * Description: This file contains definitions of GlobalAudioSettings.
20 #ifndef GLOBALAUDIOSETTINGS_H
21 #define GLOBALAUDIOSETTINGS_H
25 class CGlobalAudioSettingsImpl;
26 class MAudioSettingsObserver;
27 class MAudioClientsListObserver;
30 * API for accessing global settings that affects Audio behavior.
32 * This is API is intended to be used by Adaptation to read system attributes
33 * that affect audio behavior. This API also provides notification when any
34 * of these attribute values change.
36 * @lib GlobalAudioSettings.lib
39 class CGlobalAudioSettings : public CBase
42 enum TAudioClientListType
50 /** The tone is played in a loop.
52 EGASRingingTypeRinging = 0,
54 * The tone is played in a loop. On the 1st round, the volume is gradually
55 * increment from the lowest level to the set level.
57 EGASRingingTypeAscending = 1,
58 /** The tone is played only once.
60 EGASRingingTypeRingingOnce = 2,
62 * The phone only beeps once instead of playing the tone if one has been set.
64 EGASRingingTypeBeepOnce = 3,
65 /** The phone is silent.
66 * This Ringing type is set when the phone is in silence mode.
68 EGASRingingTypeSilent = 4
73 EGASKeypadVolumeOff = 0,
74 EGASKeypadVolumeLevel1 = 1,
75 EGASKeypadVolumeLevel2 = 2,
76 EGASKeypadVolumeLevel3 = 3
80 * function for creating the GlobalAudioSettings
83 IMPORT_C static CGlobalAudioSettings* NewL(MAudioSettingsObserver& aAudioSettingsObserver);
89 IMPORT_C ~CGlobalAudioSettings();
92 * Returns warning tones status set in the current profile.
94 * If warning tones are disabled in the current profile, Adaptation
95 * should reject play requests having preferences mapped to warning tones.
98 * @return TBool aEnable. ETrue if warning tones are enabled else EFalse.
100 IMPORT_C TBool IsWarningTonesEnabled();
103 * Returns message tones status set in the current profile.
105 * If message tones are disabled in the current profile, Adaptation
106 * should reject play requests having preferences mapped to message tones.
109 * @return TBool aEnable. ETrue if message tones are enabled else EFalse.
111 IMPORT_C TBool IsMessageTonesEnabled();
114 * Returns current silent profile status.
117 * @return TBool aEnable. ETrue if current profile is silent profile
120 IMPORT_C TBool IsSilentProfileEnabled();
123 * Returns vibra status set in the current profile..
125 * If vibra is enabled in the current profile and vibra is not part of the
126 * content, Adaptation should play vibra periodically for play requests
127 * having preferences mapped to vibra settings.
130 * @return TBool aEnable. ETrue if current profile vibra active else EFalse.
132 IMPORT_C TBool IsVibraEnabled();
135 * Returns PublicSilence feature.
137 * If PublicSilence feature is enabled and if current profile is Silent
138 * Profile, For all play requests having preferences mapped to Public
139 * Silence setting, audio should only be played out via private accessory.
140 * If no private accessory is connected, then playback should be rejected.
143 * @return TBool aEnable. ETrue if PublicSilentMode is set else EFalse.
145 IMPORT_C TBool IsPublicSilenceEnabled();
148 * Returns Message Alert Tone
151 * The filename selected as the message alert tone in the
156 * @return TDesC& aMessageAlertToneName. z:\\resource\\No_Sound.wav is returned if sound is off,else selected filename
159 IMPORT_C TDesC& MessageAlertTone();
162 * Returns Email Alert Tone status
165 * The filename selected as the email alert tone in the
170 * @return TBool aEnable. ETrue if current profile message tone is on else EFalse.
172 IMPORT_C TBool IsMessageAlertToneEnabled();
174 * Returns Email Alert Tone
177 * The filename selected as the email alert tone in the
182 * @return TDesC& aEmailAlertToneName. z:\\resource\\No_Sound.wav is returned if sound is off,else selected filename
185 IMPORT_C TDesC& EmailAlertTone();
188 * Returns Email Alert Tone status
191 * The filename selected as the email alert tone in the
196 * @return TBool aEnable. ETrue if current profile email alert tone is on else EFalse.
198 IMPORT_C TBool IsEmailAlertToneEnabled();
200 * Returns the RingingType
203 * Ringing type set in the current profile
208 * @return TGASRingingType aRingingType.
211 IMPORT_C TGASRingingType RingingType();
214 * Returns Videocall Alert Tone
217 * The filename selected as the video call alert tone in the
222 * @return TDesC& aVideoCallAlertToneName. z:\\resource\\No_Sound.wav is returned if sound is off,else selected filename
226 IMPORT_C TDesC& VideoCallAlertTone();
228 * Returns Videocall Alert Tone status
231 * The filename selected as the video call alert tone in the
236 * @return TBool aEnable. ETrue if current profile videocall alert tone is on else EFalse.
238 IMPORT_C TBool IsVideoCallAlertToneEnabled();
240 * Returns Ringing Alert Tone
243 * The filename selected as the ringing alert tone in the
247 * @return TDesC& aRingingAlertTone1Name. z:\\resource\\No_Sound.wav is returned if sound is off,else selected filename
252 IMPORT_C TDesC& RingingAlertTone1();
254 * Returns Ringing Alert Tone1 status
257 * The filename selected as the ringing alert tone in the
262 * @return TBool aEnable. ETrue if current profile ringing alert tone is on else EFalse.
264 IMPORT_C TBool IsRingingAlertTone1Enabled();
267 * Returns Ringing Alert Tone 2
270 * The filename selected as the ringing alert tone in the
271 * current profile for the alternate line
275 * @return TDesC& aRingingAlertTone2Name. z:\\resource\\No_Sound.wav is returned if sound is off,else selected filename
279 IMPORT_C TDesC& RingingAlertTone2();
281 * Returns Ringing Alert Tone 2
284 * The filename selected as the ringing alert tone in the
285 * current profile for the alternate line
289 * @return TBool aEnable. ETrue if current profile ringing alert tone of alternate line is on else EFalse.
291 IMPORT_C TBool IsRingingAlertTone2Enabled();
294 * Returns Ringing Keypad Volume
297 * The key tone volume selected in the
302 * @return TGASKeypadVolume aKeypadToneVolume.returns EGASKeypadVolumeOff sound is off,else selected volume level
306 IMPORT_C TGASKeypadVolume KeyPadToneVolume();
309 * Returns silent mode status.
312 * @return TBool aEnable. ETrue if the silent mode is enabled else EFalse.
313 * Ringingtype is set to EGASRingingTypeSilent when silence mode is enabled
316 IMPORT_C TBool IsSilenceModeEnabled();
318 * Registers audio clients list observer.
320 * When registered successfully, the observer will start receiveing
321 * callback defined in MAudioClientsListObserver when audio clients list
325 * @param MAudioClientsListObserver& aObserver. A reference to class
326 * implementing MAudioClientsListObserver interface.
327 * @return TInt. KErrNone if successful. KErrAlreadyExists if the observer
328 * is already registered. Otherwise a systemwide error code.
330 IMPORT_C TInt RegisterAudioClientsListObserver(
331 MAudioClientsListObserver& aObserver );
334 * Unregisters audio clients list observer.
336 * When unregistered, the observer will no longer receive callback when
337 * audio clients list changes.
340 * @param MAudioClientsListObserver& aObserver. A reference to class
341 * implementing MAudioClientsListObserver interface.
342 * @return TInt. KErrNone if successful. KErrNotFound if the observer
345 IMPORT_C TInt UnregisterAudioClientsListObserver(
346 MAudioClientsListObserver& aObserver);
349 * Gets audio clients list.
351 * On return of this function, the parameter aList will contain active
352 * audio client application process ids.
354 * The parameter aList will be reset in the case
357 * @param TAudioClientListType aFilter. Type of client list.
358 * @param RArray<TProcessId>& aList. A reference to RArray.
359 * @return TInt. KErrNone if successful. KErrBadName if
360 * aType is not one of the TAudioClientListType enumeration.
361 * Otherwise a systemwide error code.
362 * In case of error, the array aList will be reset.
364 IMPORT_C TInt GetAudioClientsList(
365 TAudioClientListType aType,
366 RArray<TProcessId>& aList );
369 CGlobalAudioSettings();
371 * Second Phase Costructor for GlobalAudioSettings Instance
375 void ConstructL( MAudioSettingsObserver& aAudioSettingsObserver );
378 CGlobalAudioSettingsImpl* iBody;