Update contrib.
2 * Copyright (c) 2006 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 class provides an interface for accessing the Radio Data System (RDS)
15 * for FM sound broadcasting. CRadioRdsUtility can also be used with
16 * Radio Broadcast Data System (RDBS). Client must first instantiate
17 * a tuner control implementing this interface before this class can be used.
24 #ifndef M_RADIORDSCONTROL_H
25 #define M_RADIORDSCONTROL_H
30 * RDS control error definitions.
31 * In addition to the standard system error code, the following error codes may
34 typedef TInt TRdsControlError;
35 const TRdsControlError KRdsErrHardwareFaulty = -13050;
36 const TRdsControlError KRdsErrNotPermittedInCurrentState = -13051;
37 const TRdsControlError KRdsErrDuplicateRequest = -13052;
42 * The interpretation of values of this type depends on the origin of the RDS
43 * broadcast: in North America, a slightly different standard, RBDS, is used.
44 * These PTY codes are defined by static values KRbdsPtyXxxxx, for example
47 * Elsewhere, including Europe, the RDS standard is used. In these areas, the
48 * PTY codes are defined by static values KRdsPtyXxxxx, for example
49 * KRdsPtyChildrensProgrammes.
51 * In all other important aspects, the European RDS and North American RBDS
52 * standards are identical.
54 typedef TInt TRdsProgrammeType;
56 const TRdsProgrammeType KRdsPtyNone = 0;
57 const TRdsProgrammeType KRdsPtyNews = 1;
58 const TRdsProgrammeType KRdsPtyCurrentAffairs = 2;
59 const TRdsProgrammeType KRdsPtyInformation = 3;
60 const TRdsProgrammeType KRdsPtySport = 4;
61 const TRdsProgrammeType KRdsPtyEducation = 5;
62 const TRdsProgrammeType KRdsPtyDrama = 6;
63 const TRdsProgrammeType KRdsPtyCulture = 7;
64 const TRdsProgrammeType KRdsPtyScience = 8;
65 const TRdsProgrammeType KRdsPtyVariedSpeech = 9;
66 const TRdsProgrammeType KRdsPtyPopMusic = 10;
67 const TRdsProgrammeType KRdsPtyRockMusic = 11;
68 const TRdsProgrammeType KRdsPtyEasyListening = 12;
69 const TRdsProgrammeType KRdsPtyLightClassical = 13;
70 const TRdsProgrammeType KRdsPtySeriousClassical = 14;
71 const TRdsProgrammeType KRdsPtyOtherMusic = 15;
72 const TRdsProgrammeType KRdsPtyWeather = 16;
73 const TRdsProgrammeType KRdsPtyFinance = 17;
74 const TRdsProgrammeType KRdsPtyChildrensProgrammes = 18;
75 const TRdsProgrammeType KRdsPtySocialAffairs = 19;
76 const TRdsProgrammeType KRdsPtyReligion = 20;
77 const TRdsProgrammeType KRdsPtyPhoneIn = 21;
78 const TRdsProgrammeType KRdsPtyTravel = 22;
79 const TRdsProgrammeType KRdsPtyLeisure = 23;
80 const TRdsProgrammeType KRdsPtyJazzMusic = 24;
81 const TRdsProgrammeType KRdsPtyCountryMusic = 25;
82 const TRdsProgrammeType KRdsPtyNationalMusic = 26;
83 const TRdsProgrammeType KRdsPtyOldiesMusic = 27;
84 const TRdsProgrammeType KRdsPtyFolkMusic = 28;
85 const TRdsProgrammeType KRdsPtyDocumentary = 29;
86 const TRdsProgrammeType KRdsPtyAlarmTest = 30;
87 const TRdsProgrammeType KRdsPtyAlarm = 31;
89 const TRdsProgrammeType KRbdsPtyNone = 0;
90 const TRdsProgrammeType KRbdsPtyNews = 1;
91 const TRdsProgrammeType KRbdsPtyInformation = 2;
92 const TRdsProgrammeType KRbdsPtySports = 3;
93 const TRdsProgrammeType KRbdsPtyTalk = 4;
94 const TRdsProgrammeType KRbdsPtyRock = 5;
95 const TRdsProgrammeType KRbdsPtyClassicRock = 6;
96 const TRdsProgrammeType KRbdsPtyAdultHits = 7;
97 const TRdsProgrammeType KRbdsPtySoftRock = 8;
98 const TRdsProgrammeType KRbdsPtyTop40 = 9;
99 const TRdsProgrammeType KRbdsPtyCountry = 10;
100 const TRdsProgrammeType KRbdsPtyOldies = 11;
101 const TRdsProgrammeType KRbdsPtySoft = 12;
102 const TRdsProgrammeType KRbdsPtyNostalgia = 13;
103 const TRdsProgrammeType KRbdsPtyJazz = 14;
104 const TRdsProgrammeType KRbdsPtyClassical = 15;
105 const TRdsProgrammeType KRbdsPtyRhythmAndBlues = 16;
106 const TRdsProgrammeType KRbdsPtySoftRhythmAndBlues = 17;
107 const TRdsProgrammeType KRbdsPtyLanguage = 18;
108 const TRdsProgrammeType KRbdsPtyReligiousMusic = 19;
109 const TRdsProgrammeType KRbdsPtyReligiousTalk = 20;
110 const TRdsProgrammeType KRbdsPtyPersonality = 21;
111 const TRdsProgrammeType KRbdsPtyPublic = 22;
112 const TRdsProgrammeType KRbdsPtyCollege = 23;
113 const TRdsProgrammeType KRbdsPtyUnassigned1 = 24;
114 const TRdsProgrammeType KRbdsPtyUnassigned2 = 25;
115 const TRdsProgrammeType KRbdsPtyUnassigned3 = 26;
116 const TRdsProgrammeType KRbdsPtyUnassigned4 = 27;
117 const TRdsProgrammeType KRbdsPtyUnassigned5 = 28;
118 const TRdsProgrammeType KRbdsPtyWeather = 29;
119 const TRdsProgrammeType KRbdsPtyEmergencyTest = 30;
120 const TRdsProgrammeType KRbdsPtyEmergency = 31;
124 * Table 1: Class codes for RTplus content types
125 * Defined in Radiotext plus (RTplus) Specification Version 2.1
126 * RDS Forum 2006-07-21 - R06/040_1
130 // Category: Item (0 - 10)
131 ERTplusItemDummy = 0,
134 ERTplusItemTrackNumber,
136 ERTplusItemComposition,
138 ERTplusItemConductor,
143 // Category: Info (12 - 30)
145 ERTplusInfoNewsLocal,
146 ERTplusInfoStockMarket,
149 ERTplusInfoHoroscope,
150 ERTplusInfoDailyDiversion,
160 ERTplusInfoAdvisertisement,
163 // Category: Programme (31 - 40)
164 ERTplusStationNameShort,
165 ERTplusStationNameLong,
170 ERTplusProgramEditorialStaff,
171 ERTplusStationFrequency,
172 ERTplusProgramHomepage,
173 ERTplusProgramSubChannel,
174 // Category: Interactivity (41 - 53)
188 // Category: Reserved for future (54 - 55)
191 // Category: Private classes (56 - 58)
192 ERTplusPrivateClass56,
193 ERTplusPrivateClass57,
194 ERTplusPrivateClass58,
195 // Category: Descriptor (59 - 63)
205 * RDS Function Bit Flags used by TRdsCapabilities and TRdsData.
211 ERdsProgrammeIdentification = 0x001,
212 ERdsProgrammeType = 0x002,
213 ERdsProgrammeService = 0x004,
214 ERdsRadioText = 0x008,
215 ERdsRadioTextPlus = 0x010,
216 ERdsClockTime = 0x020,
217 ERdsTrafficProgramme = 0x040,
218 ERdsTrafficAnnouncement = 0x080,
219 ERdsAlternateFrequency = 0x100
224 * The RDS Capabilities class defines the capabilities of the RDS control on the
225 * device, as retrieved using the function GetCapabilities.
229 class TRdsCapabilities
232 // Bitfield as defined by TRdsFeatures with the bits of the supported functions set
233 // Valid bitfieds are:
234 // ERdsProgrammeIdentification | ERdsProgrammeType | ERdsProgrammeService |
235 // ERdsRadioText | ERdsRadioTextPlus | ERdsClockTime | ERdsTrafficProgramme |
236 // ERdsTrafficAnnouncement | ERdsAlternateFrequency
237 TUint32 iRdsFunctions;
238 // Reserved for future
239 TUint32 iAdditionalFunctions1;
240 // Reserved for future
241 TUint32 iAdditionalFunctions2;
246 * This class provides RDS features that can be enabled or disabled. Used in
247 * function NotifyRdsDataChange.
254 // A value indicating a set containing all RDS data encapsulated by class TRdsData.
255 static const TUint32 KAllRdsData = ( ERdsProgrammeIdentification | ERdsProgrammeType |
256 ERdsProgrammeService | ERdsRadioText | ERdsClockTime | ERdsTrafficAnnouncement );
259 // Bitfield as defined by TRdsDataFeatures with the bits of the supported functions set
260 // Valid bitfieds are:
261 // ERdsProgrammeIdentification | ERdsProgrammeType | ERdsProgrammeService |
262 // ERdsRadioText | ERdsClockTime | ERdsTrafficAnnouncement
263 TUint32 iRdsFunctions;
264 // Reserved for future
265 TUint32 iAdditionalFunctions1;
266 // Reserved for future
267 TUint32 iAdditionalFunctions2;
272 * This class provides RT+ tags.
279 // Specifies the content type according to the class code
280 TRdsRTplusClass iContentType;
281 // Indicates the position of the first character within the Radio Text
282 // (Start marker 0: means first character in RT)
284 // Length (number of characters) of the RTplus tag.
289 /** Programme Service name, 8 characters */
290 typedef TBuf8<8> TRdsPSName;
291 /** Radio Text, 64 characters */
292 typedef TBuf8<64> TRdsRadioText;
296 * This class provides the interface class to be implemented by object receiving request
297 * complete notification from RDS control. These functions are called once the asynchronous
298 * request completes successfully or with an error.
300 * In addition, this class provides the interface for receiving events from RDS control.
304 class MRdsControlObserver
309 * Station seek by Programme Type(PTY) complete event. This event is asynchronous and
310 * is received after a call to MRdsControl::StationSeekByPTY.
313 * @param aError A standard system error code or RDS control error (TRdsControlError).
314 * @param aFrequency The frequency(Hz) of the radio station that was found.
316 virtual void StationSeekByPTYComplete( TInt aError, TInt aFrequency ) = 0;
319 * Station seek by Traffic Announcement(TA) complete event. This event is asynchronous
320 * and is received after a call to MRdsControl::StationSeekByTA.
323 * @param aError A standard system error code or RDS control error (TRdsControlError).
324 * @param aFrequency The frequency(Hz) of the radio station that was found.
326 virtual void StationSeekByTAComplete( TInt aError, TInt aFrequency ) = 0;
329 * Station seek by Traffic Programme(TP) complete event. This event is asynchronous and
330 * is received after a call to MRdsControl::StationSeekByTP.
333 * @param aError A standard system error code or RDS control error (TRdsControlError).
334 * @param aFrequency The frequency(Hz) of the radio station that was found.
336 virtual void StationSeekByTPComplete( TInt aError, TInt aFrequency ) = 0;
339 * Get frequencies by Programme Type(PTY) complete event. This event is asynchronous
340 * and is received after a call to MRdsControl::GetFreqByPTY.
342 * Client takes ownership of the array and therefore is responsible for deallocating it.
345 * @param aError A standard system error code or RDS control error (TRdsControlError).
346 * @param aFreqList Array of frequencies (Hz), valid only if aError is KErrNone.
348 virtual void GetFreqByPTYComplete( TInt aError, RArray<TInt>& aFreqList ) = 0;
351 * Get frequencies by Traffic Announcement(TA) complete event. This event is asynchronous
352 * and is received after a call to MRdsControl::GetFreqByTA.
354 * Client takes ownership of the array and therefore is responsible for deallocating it.
357 * @param aError A standard system error code or RDS control error (TRdsControlError).
358 * @param aFreqList Array of frequencies (Hz), valid only if aError is KErrNone.
360 virtual void GetFreqByTAComplete( TInt aError, RArray<TInt>& aFreqList ) = 0;
363 * Get Programme Service names (PS) by Programme Type(PTY) complete event. This event is
364 * asynchronous and is received after a call to MRdsControl::GetPSByPTY.
366 * Client takes ownership of the array and therefore is responsible for deallocating it.
369 * @param aError A standard system error code or RDS control error (TRdsControlError).
370 * @param aPsList Array of programme service names, valid only if aError is KErrNone.
372 virtual void GetPSByPTYComplete( TInt aError, RArray<TRdsPSName>& aPsList ) = 0;
375 * Get Programme Service names (PS) by Traffic Announcement(TA) complete event. This event is
376 * asynchronous and is received after a call to MRdsControl::GetPSByTA.
378 * Client takes ownership of the array and therefore is responsible for deallocating it.
381 * @param aError A standard system error code or RDS control error (TRdsControlError).
382 * @param aPsList Array of programme service names, valid only if aError is KErrNone.
384 virtual void GetPSByTAComplete( TInt aError, RArray<TRdsPSName>& aPsList ) = 0;
387 * New Programme Identification(PI) is available. This event is asynchronous and is
388 * received after a call to MRdsControl::NotifyRdsDataChange. Client will continue to
389 * receive this notification whenever new PI is available until clients unsubscribes.
392 * @param aPi Programme identification
394 virtual void RdsDataPI( TInt aPi ) = 0;
397 * New Programme Type (PTY) is available. This event is asynchronous and is received after
398 * a call to MRdsControl::NotifyRdsDataChange. Client will continue to receive this
399 * notification whenever new PTY is available until client cancels notification request.
402 * @param aPty Programme type
404 virtual void RdsDataPTY( TRdsProgrammeType aPty ) = 0;
407 * New Programme Service name (PS) is available. This event is asynchronous and is received
408 * after a call to MRdsControl::NotifyRdsDataChange. Client will continue to receive this
409 * notification whenever new PS is available until client cancels notification request.
412 * @param aPs Programme service
414 virtual void RdsDataPS( TRdsPSName& aPs ) = 0;
417 * New Radio Text (RT) is available. This event is asynchronous and is received after
418 * a call to MRdsControl::NotifyRdsDataChange. Client will continue to receive this
419 * notification whenever new RT is available until client cancels notification request.
421 * If RT+ is supported, RT+ tags information is sent along with the RT. Client takes
422 * ownership of the array and therefore is responsible to deallocate it.
425 * @param aRt Radio text
426 * @param aRTplusTags RTplus tags
428 virtual void RdsDataRT( TRdsRadioText& aRt, RArray<TRdsRTplusTag>& aRTplusTags ) = 0;
431 * Clock Time (CT) is available. This event is asynchronous and is received after a call
432 * to MRdsControl::NotifyRdsDataChange. Client will continue to receive this notification
433 * whenever new CT is available until client cancels notification request.
436 * @param aCt Clock time
438 virtual void RdsDataCT( TDateTime& aCt ) = 0;
441 * Called when Traffice Announcement (TA) status changes. This event is asynchronous
442 * and is received after a call to MRdsControl::NotifyRdsDataChange. Client will continue
443 * to receive this notification whenever TA status changes until client cancels notification request.
446 * @param aTaOn ETrue indicates that Traffic Announcement is on.
448 virtual void RdsDataTA( TBool aTaOn ) = 0;
451 * Called when tuner starts to search for an Alternate Frequency (AF) with stronger signal.
452 * This event is asynchronous and is received after a call to MRdsControl::SetAutomaticSwitching.
453 * Client will continue to receive this notification whenever new search is started
454 * until clients turns automatic switching off.
458 virtual void RdsSearchBeginAF() = 0;
461 * Called when search for an Alternate Frequency (AF) ends. This event is asynchronous and
462 * is received after a call to MRdsControl::SetAutomaticSwitching. Client will continue
463 * to receive this notification until clients turns automatic switching off.
465 * Most common error codes:
466 * KErrNone - Successful, new frequency found
467 * KErrNotFound - Ended, but frequency hasn't changed
468 * KErrCancel - Cancelled
471 * @param aError A standard system error code or RDS control error (TRdsControlError).
472 * @param aFrequency The frequency (Hz) of the radio station that was found.
474 virtual void RdsSearchEndAF( TInt aError, TInt aFrequency ) = 0;
477 * Called when the tuner has re-tuned to another frequency that is broadcasting
478 * Traffic Announcement (TA). This notification sent only when the client has turned the
479 * automatic traffic announcement on.
482 * @param aFrequency The frequency (Hz) of the radio station that was found.
484 virtual void RdsStationChangeTA( TInt aFrequency ) = 0;
487 * Called when RDS signal status change (i.e. signal is lost/restored).
490 * @param aSignal ETrue indicates that RDS signal is available in the tuned frequency.
492 virtual void RdsEventSignalChange( TBool aSignal ) = 0;
497 * This class provides the interface class to be implemented by object implementing RDS control.
506 * Get the capabilities of the RDS control on the device.
509 * @param aCaps The capabilities object to fill
510 * @return A standard system error code or RDS control error (TRdsControlError).
512 IMPORT_C virtual TInt GetCapabilities( TRdsCapabilities& aCaps ) const = 0;
515 * Get the status of the RDS reception.
518 * @param aRdsSignal On return, will be ETrue if RDS signal can be recepted, EFalse otherwise.
519 * @return A standard system error code or RDS control error (TRdsControlError).
521 IMPORT_C virtual TInt GetRdsSignalStatus( TBool& aRdsSignal ) const = 0;
524 * Subscribe for notification for the specified RDS data. Client should first check
525 * the capabilities to see if a feature is supported.
526 * Request for notification for non-supported features will simply be ignored.
528 * For example, if the client wishes to be notified when new Programme Type and
529 * Traffic Announcement is available:
530 * iRdsData = ERdsProgrammeType | ERdsTrafficAnnouncement;
531 * iRdsUtility->NotifyRdsDataChange(iRdsData);
534 * @param aRdsData Bitfield indicating notification request.
535 * @see MRdsControlObserver::RdsDataPI
536 * @see MRdsControlObserver::RdsDataPTY
537 * @see MRdsControlObserver::RdsDataPS
538 * @see MRdsControlObserver::RdsDataRT
539 * @see MRdsControlObserver::RdsDataCT
540 * @see MRdsControlObserver::RdsDataTA
542 IMPORT_C virtual TInt NotifyRdsDataChange( TRdsData aRdsData ) = 0;
545 * Cancel NotifyRdsDataChange request.
549 IMPORT_C virtual void CancelNotifyRdsDataChange() = 0;
552 * Turn on/off automatic switching of frequency based on Alternate Frequency.
553 * This will cause RDS device to search for alternate frequency when the signal strength
554 * deteriorates. User should be ready to receive RdsSearchBeginAF and RdsSearchEndAF.
555 * Automatic switching is off by default.
557 * Client should first check the capabilities to see if ERdsAlternateFrequency is
558 * supported. Will return KErrNotSupported if this feature is not supported.
561 * @param aAuto ETrue to turn automatic switching on, EFalse to turn it off.
562 * @return A standard system error code or RDS control error (TRdsControlError).
563 * @see MRdsControlObserver::RdsSearchBeginAF
564 * @see MRdsControlObserver::RdsSearchEndAF
566 IMPORT_C virtual TInt SetAutomaticSwitching( TBool aAuto ) = 0;
569 * Find out whether automatic switching is on or off.
572 * @param aAuto ETrue indicates that automatic switching is enabled.
573 * @return A standard system error code or RDS control error (TRdsControlError).
575 IMPORT_C virtual TInt GetAutomaticSwitching( TBool& aAuto ) = 0;
578 * Cancel ongoing search for an Alternate Frequency (AF) with stronger signal.
580 * Client can issue this request to interrupt the search indicated with
581 * MRdsControlObserver::RdsSearchBeginAF.
585 IMPORT_C virtual void CancelAFSearch() = 0;
588 * Turns on/off automatic switching of frequency based on Traffic Announcement.
589 * This will cause RDS device to search for frequencies broadcasting traffic announcement.
590 * This feature is based on TP/TA fields and/or EON. It is up to the client to return to
591 * the previous frequency when the traffic announcement is finished.
593 * NOTE: This is only supported in dual tuner configuration since the secondary tuner
594 * needs to perform continuous scanning for frequencies broadcasting traffic announcement,
595 * while the primary tuner is used for normal tuner activities.
596 * Client should first check the tuner capabilities. Will return KErrNotSupported if
597 * this feature is not supported.
600 * @param aAuto ETrue indicates that automatic switching is on.
601 * @return A standard system error code or RDS control error (TRdsControlError).
603 IMPORT_C virtual TInt SetAutomaticTrafficAnnouncement( TBool aAuto ) = 0;
606 * Find out whether automatic traffic announcement is enabled.
609 * @param aAuto ETrue indicates that automatic traffic announcement is on.
610 * @return A standard system error code or RDS control error (TRdsControlError).
612 IMPORT_C virtual TInt GetAutomaticTrafficAnnouncement( TBool& aAuto ) = 0;
615 * Asynchronous request to find a radio station with the specified Programme Type (PTY),
616 * starting from the currently tuned frequency and searching in the direction specified
617 * (i.e. up or down). User must be ready to receive callback method StationSeekByPTYComplete
618 * The station found is returned in the callback.
621 * @param aPty The type of programme to search for.
622 * @param aSeekUp The direction to search in. Searches upwards if set to ETrue.
623 * @see MRdsControlObserver::StationSeekByPTYComplete
625 IMPORT_C virtual void StationSeekByPTY( TRdsProgrammeType aPty, TBool aSeekUp ) = 0;
628 * Asynchronous request to find a radio station with Traffic Announcement (TA),
629 * starting from the currently tuned frequency and searching in the direction specified
630 * (i.e. up or down). User must be ready to receive callback method StationSeekByTAComplete
631 * The station found is returned in the callback.
634 * @param aSeekUp The direction to search in. Searches upwards if set to ETrue.
635 * @see MRdsControlObserver::StationSeekByTAComplete
637 IMPORT_C virtual void StationSeekByTA( TBool aSeekUp ) = 0;
640 * Asynchronous request to find a radio station with Traffic Programme (TP),
641 * starting from the currently tuned frequency and searching in the direction specified
642 * (i.e. up or down). User must be ready to receive callback method StationSeekByTPComplete
643 * The station found is returned in the callback.
646 * @param aSeekUp The direction to search in. Searches upwards if set to ETrue.
647 * @see MRdsControlObserver::StationSeekByTPComplete
649 IMPORT_C virtual void StationSeekByTP( TBool aSeekUp ) = 0;
652 * Cancels an ongoing retune operation, as initiated by a call to StationSeekByPTY,
653 * StationSeekByTA, or StationSeekByTP.
654 * The usual callback will not occur if this has been called.
658 IMPORT_C virtual void CancelRdsStationSeek() = 0;
661 * Asynchronous request to find all frequencies sending the given Programme Type (PTY).
662 * User must be ready to receive callback method GetFreqByPTYComplete.
664 * NOTE: This is only supported in dual tuner configuration since the secondary tuner
665 * needs to perform continuous scanning for frequencies broadcasting given Programme Type
666 * while the primary tuner is used for normal tuner activities.
667 * Client should first check the tuner capabilities. Will return KErrNotSupported in
668 * callback method if this feature is not supported.
671 * @param aPty The type of programme to search for
672 * @see MRdsControlObserver::GetFreqByPTYComplete
674 IMPORT_C virtual void GetFreqByPTY( TRdsProgrammeType aPty ) = 0;
677 * Cancels an ongoing request to find all frequencies sending a given Programme Type (PTY).
678 * The usual callback will not occur if this has been called.
682 IMPORT_C virtual void CancelGetFreqByPTY() = 0;
685 * Asynchronous request to find all frequencies sending Traffic Announcement (TA). User must
686 * be ready to receive callback method GetFreqByTAComplete.
688 * NOTE: This is only supported in dual tuner configuration since the secondary tuner
689 * needs to perform continuous scanning for frequencies broadcasting given Traffic Announcement
690 * while the primary tuner is used for normal tuner activities.
691 * Client should first check the tuner capabilities. Will return KErrNotSupported in
692 * callback method if this feature is not supported.
695 * @see MRdsControlObserver::GetFreqByTAComplete
697 IMPORT_C virtual void GetFreqByTA() = 0;
700 * Cancels an ongoing request to find all frequencies sending Traffic Announcement.
701 * The usual callback will not occur if this has been called.
705 IMPORT_C virtual void CancelGetFreqByTA() = 0;
708 * Asynchronous request to find all Programme Service names (PS) sending the given Programme
709 * Type (PTY). User must be ready to receive callback method GetPSByPTYComplete.
711 * NOTE: This is only supported in dual tuner configuration since the secondary tuner
712 * needs to perform continuous scanning for frequencies broadcasting given Programme Type
713 * while the primary tuner is used for normal tuner activities.
714 * Client should first check the tuner capabilities. Will return KErrNotSupported in
715 * callback method if this feature is not supported.
718 * @param aPty The type of programme to search for
719 * @see MRdsControlObserver::GetPSByPTYComplete
721 IMPORT_C virtual void GetPSByPTY( TRdsProgrammeType aPty ) = 0;
724 * Cancels an ongoing request to find all Programme Service names (PS) sending a given
725 * Programme Type (PTY). The usual callback will not occur if this has been called.
729 IMPORT_C virtual void CancelGetPSByPTY() = 0;
732 * Asynchronous request to find all Programme Service names (PS) sending Traffic Announcement (TA).
733 * User must be ready to receive callback method GetPSByTAComplete.
735 * NOTE: This is only supported in dual tuner configuration since the secondary tuner
736 * needs to perform continuous scanning for frequencies broadcasting given Traffic Announcement
737 * while the primary tuner is used for normal tuner activities.
738 * Client should first check the tuner capabilities. Will return KErrNotSupported in
739 * callback method if this feature is not supported.
742 * @see MRdsControlObserver::GetPSByTAComplete
744 IMPORT_C virtual void GetPSByTA() = 0;
747 * Cancels an ongoing request to find all Programme Service names (PS) sending Traffic Announcement.
748 * The usual callback will not occur if this has been called.
752 IMPORT_C virtual void CancelGetPSByTA() = 0;
755 * Get the current Programme Identification code.
756 * RDS data is received over the air and may not be available immediately following
757 * tune operation. If a value is returned, this is the last known value, which may
759 * To be notified of the most recent value, client should use NotifyRdsDataChange.
762 * @param aPi On return contains Programme Identification code
763 * @return A standard system error code or RDS control error (TRdsControlError).
765 IMPORT_C virtual TInt GetProgrammeIdentification( TInt& aPi ) = 0;
768 * Get the current Programme Type.
769 * RDS data is received over the air and may not be available immediately following
770 * tune operation. If a value is returned, this is the last known value, which may
772 * To be notified of the most recent value, client should use NotifyRdsDataChange.
775 * @param aPty On return contains Programme Type
776 * @return A standard system error code or RDS control error (TRdsControlError).
778 IMPORT_C virtual TInt GetProgrammeType( TRdsProgrammeType& aPty ) = 0;
781 * Get the current Programme Service name.
782 * RDS data is received over the air and may not be available immediately following
783 * tune operation. If a value is returned, this is the last known value, which may
785 * To be notified of the most recent value, client should use NotifyRdsDataChange.
787 * The maximum possible length for Programme Service name is 8 characters.
790 * @param aPs On return contains Programme Service name
791 * @return A standard system error code or RDS control error (TRdsControlError).
793 IMPORT_C virtual TInt GetProgrammeService( TRdsPSName& aPs ) = 0;
796 * Get the current Radio Text.
797 * RDS data is received over the air and may not be available immediately following
798 * tune operation. If a value is returned, this is the last known value, which may
800 * To be notified of the most recent value, client should use NotifyRdsDataChange.
802 * The maximum possible length for radio text is 64 characters.
804 * If RT+ is supported, RT+ tags information is returned along with the RT. Array is
805 * owned by the client.
808 * @param aRt On return contains Radio Text
809 * @param aRTplusTags RTplus tags
810 * @return A standard system error code or RDS control error (TRdsControlError).
812 IMPORT_C virtual TInt GetRadioText( TRdsRadioText& aRt, RArray<TRdsRTplusTag>& aRTplusTags ) = 0;
815 * Get the current Clock Time and date.
816 * RDS data is received over the air and may not be available immediately following
817 * tune operation. If a value is returned, this is the last known value, which may
819 * To be notified of the most recent value, client should use NotifyRdsDataChange.
821 * The RDS standard states that this is broadcast within 0.1s of the start of a minute,
822 * and is accurate to one minute. The latency of the notification reaching the application
823 * cannot be guaranteed.
826 * @param aCt On return contains current time and date
827 * @return A standard system error code or RDS control error (TRdsControlError).
829 IMPORT_C virtual TInt GetClockTime( TDateTime& aCt ) = 0;
832 * Get Traffic Announcement status at the current station.
835 * @param aTaStatus On return, will be ETrue if current station has ongoing traffic announcement
836 * @return A standard system error code or RDS control error (TRdsControlError).
838 IMPORT_C virtual TInt GetTrafficAnnouncementStatus( TBool& aTaStatus ) = 0;
841 * Get Traffic Programme status at the current station.
844 * @param aTpStatus On return, will be ETrue if current station supports traffic programme
845 * @return A standard system error code or RDS control error (TRdsControlError).
847 IMPORT_C virtual TInt GetTrafficProgrammeStatus( TBool& aTpStatus ) = 0;
850 #endif // M_RADIORDSCONTROL_H