sl@0: /* sl@0: * Copyright (c) 2006 Nokia Corporation and/or its subsidiary(-ies). sl@0: * All rights reserved. sl@0: * This component and the accompanying materials are made available sl@0: * under the terms of "Eclipse Public License v1.0" sl@0: * which accompanies this distribution, and is available sl@0: * at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: * sl@0: * Initial Contributors: sl@0: * Nokia Corporation - initial contribution. sl@0: * sl@0: * Contributors: sl@0: * sl@0: * Description: This class provides an interface for accessing the Radio Data System (RDS) sl@0: * for FM sound broadcasting. CRadioRdsUtility can also be used with sl@0: * Radio Broadcast Data System (RDBS). Client must first instantiate sl@0: * a tuner control implementing this interface before this class can be used. sl@0: * sl@0: * sl@0: */ sl@0: sl@0: sl@0: sl@0: #ifndef M_RADIORDSCONTROL_H sl@0: #define M_RADIORDSCONTROL_H sl@0: sl@0: #include sl@0: sl@0: /** sl@0: * RDS control error definitions. sl@0: * In addition to the standard system error code, the following error codes may sl@0: * be returned. sl@0: */ sl@0: typedef TInt TRdsControlError; sl@0: const TRdsControlError KRdsErrHardwareFaulty = -13050; sl@0: const TRdsControlError KRdsErrNotPermittedInCurrentState = -13051; sl@0: const TRdsControlError KRdsErrDuplicateRequest = -13052; sl@0: sl@0: /** sl@0: * RDS Programme Type. sl@0: * sl@0: * The interpretation of values of this type depends on the origin of the RDS sl@0: * broadcast: in North America, a slightly different standard, RBDS, is used. sl@0: * These PTY codes are defined by static values KRbdsPtyXxxxx, for example sl@0: * KRbdsPtySoftRock. sl@0: * sl@0: * Elsewhere, including Europe, the RDS standard is used. In these areas, the sl@0: * PTY codes are defined by static values KRdsPtyXxxxx, for example sl@0: * KRdsPtyChildrensProgrammes. sl@0: * sl@0: * In all other important aspects, the European RDS and North American RBDS sl@0: * standards are identical. sl@0: */ sl@0: typedef TInt TRdsProgrammeType; sl@0: sl@0: const TRdsProgrammeType KRdsPtyNone = 0; sl@0: const TRdsProgrammeType KRdsPtyNews = 1; sl@0: const TRdsProgrammeType KRdsPtyCurrentAffairs = 2; sl@0: const TRdsProgrammeType KRdsPtyInformation = 3; sl@0: const TRdsProgrammeType KRdsPtySport = 4; sl@0: const TRdsProgrammeType KRdsPtyEducation = 5; sl@0: const TRdsProgrammeType KRdsPtyDrama = 6; sl@0: const TRdsProgrammeType KRdsPtyCulture = 7; sl@0: const TRdsProgrammeType KRdsPtyScience = 8; sl@0: const TRdsProgrammeType KRdsPtyVariedSpeech = 9; sl@0: const TRdsProgrammeType KRdsPtyPopMusic = 10; sl@0: const TRdsProgrammeType KRdsPtyRockMusic = 11; sl@0: const TRdsProgrammeType KRdsPtyEasyListening = 12; sl@0: const TRdsProgrammeType KRdsPtyLightClassical = 13; sl@0: const TRdsProgrammeType KRdsPtySeriousClassical = 14; sl@0: const TRdsProgrammeType KRdsPtyOtherMusic = 15; sl@0: const TRdsProgrammeType KRdsPtyWeather = 16; sl@0: const TRdsProgrammeType KRdsPtyFinance = 17; sl@0: const TRdsProgrammeType KRdsPtyChildrensProgrammes = 18; sl@0: const TRdsProgrammeType KRdsPtySocialAffairs = 19; sl@0: const TRdsProgrammeType KRdsPtyReligion = 20; sl@0: const TRdsProgrammeType KRdsPtyPhoneIn = 21; sl@0: const TRdsProgrammeType KRdsPtyTravel = 22; sl@0: const TRdsProgrammeType KRdsPtyLeisure = 23; sl@0: const TRdsProgrammeType KRdsPtyJazzMusic = 24; sl@0: const TRdsProgrammeType KRdsPtyCountryMusic = 25; sl@0: const TRdsProgrammeType KRdsPtyNationalMusic = 26; sl@0: const TRdsProgrammeType KRdsPtyOldiesMusic = 27; sl@0: const TRdsProgrammeType KRdsPtyFolkMusic = 28; sl@0: const TRdsProgrammeType KRdsPtyDocumentary = 29; sl@0: const TRdsProgrammeType KRdsPtyAlarmTest = 30; sl@0: const TRdsProgrammeType KRdsPtyAlarm = 31; sl@0: sl@0: const TRdsProgrammeType KRbdsPtyNone = 0; sl@0: const TRdsProgrammeType KRbdsPtyNews = 1; sl@0: const TRdsProgrammeType KRbdsPtyInformation = 2; sl@0: const TRdsProgrammeType KRbdsPtySports = 3; sl@0: const TRdsProgrammeType KRbdsPtyTalk = 4; sl@0: const TRdsProgrammeType KRbdsPtyRock = 5; sl@0: const TRdsProgrammeType KRbdsPtyClassicRock = 6; sl@0: const TRdsProgrammeType KRbdsPtyAdultHits = 7; sl@0: const TRdsProgrammeType KRbdsPtySoftRock = 8; sl@0: const TRdsProgrammeType KRbdsPtyTop40 = 9; sl@0: const TRdsProgrammeType KRbdsPtyCountry = 10; sl@0: const TRdsProgrammeType KRbdsPtyOldies = 11; sl@0: const TRdsProgrammeType KRbdsPtySoft = 12; sl@0: const TRdsProgrammeType KRbdsPtyNostalgia = 13; sl@0: const TRdsProgrammeType KRbdsPtyJazz = 14; sl@0: const TRdsProgrammeType KRbdsPtyClassical = 15; sl@0: const TRdsProgrammeType KRbdsPtyRhythmAndBlues = 16; sl@0: const TRdsProgrammeType KRbdsPtySoftRhythmAndBlues = 17; sl@0: const TRdsProgrammeType KRbdsPtyLanguage = 18; sl@0: const TRdsProgrammeType KRbdsPtyReligiousMusic = 19; sl@0: const TRdsProgrammeType KRbdsPtyReligiousTalk = 20; sl@0: const TRdsProgrammeType KRbdsPtyPersonality = 21; sl@0: const TRdsProgrammeType KRbdsPtyPublic = 22; sl@0: const TRdsProgrammeType KRbdsPtyCollege = 23; sl@0: const TRdsProgrammeType KRbdsPtyUnassigned1 = 24; sl@0: const TRdsProgrammeType KRbdsPtyUnassigned2 = 25; sl@0: const TRdsProgrammeType KRbdsPtyUnassigned3 = 26; sl@0: const TRdsProgrammeType KRbdsPtyUnassigned4 = 27; sl@0: const TRdsProgrammeType KRbdsPtyUnassigned5 = 28; sl@0: const TRdsProgrammeType KRbdsPtyWeather = 29; sl@0: const TRdsProgrammeType KRbdsPtyEmergencyTest = 30; sl@0: const TRdsProgrammeType KRbdsPtyEmergency = 31; sl@0: sl@0: sl@0: /** sl@0: * Table 1: Class codes for RTplus content types sl@0: * Defined in Radiotext plus (RTplus) Specification Version 2.1 sl@0: * RDS Forum 2006-07-21 - R06/040_1 sl@0: */ sl@0: enum TRdsRTplusClass sl@0: { sl@0: // Category: Item (0 - 10) sl@0: ERTplusItemDummy = 0, sl@0: ERTplusItemTitle, sl@0: ERTplusItemAlbum, sl@0: ERTplusItemTrackNumber, sl@0: ERTplusItemArtist, sl@0: ERTplusItemComposition, sl@0: ERTplusItemMovement, sl@0: ERTplusItemConductor, sl@0: ERTplusItemComposer, sl@0: ERTplusItemBand, sl@0: ERTplusItemComment, sl@0: ERTplusItemGenre, sl@0: // Category: Info (12 - 30) sl@0: ERTplusInfoNews, sl@0: ERTplusInfoNewsLocal, sl@0: ERTplusInfoStockMarket, sl@0: ERTplusInfoSport, sl@0: ERTplusInfoLottery, sl@0: ERTplusInfoHoroscope, sl@0: ERTplusInfoDailyDiversion, sl@0: ERTplusInfoHealth, sl@0: ERTplusInfoEvent, sl@0: ERTplusInfoSzene, sl@0: ERTplusInfoCinema, sl@0: ERTplusInfoTV, sl@0: ERTplusInfoDateTime, sl@0: ERTplusInfoWeather, sl@0: ERTplusInfoTraffic, sl@0: ERTplusInfoAlarm, sl@0: ERTplusInfoAdvisertisement, sl@0: ERTplusInfoURL, sl@0: ERTplusInfoOther, sl@0: // Category: Programme (31 - 40) sl@0: ERTplusStationNameShort, sl@0: ERTplusStationNameLong, sl@0: ERTplusProgramNow, sl@0: ERTplusProgramNext, sl@0: ERTplusProgramPart, sl@0: ERTplusProgramHost, sl@0: ERTplusProgramEditorialStaff, sl@0: ERTplusStationFrequency, sl@0: ERTplusProgramHomepage, sl@0: ERTplusProgramSubChannel, sl@0: // Category: Interactivity (41 - 53) sl@0: ERTplusPhoneHotline, sl@0: ERTplusPhoneStudio, sl@0: ERTplusPhoneOther, sl@0: ERTplusSmsStudio, sl@0: ERTplusSmsOther, sl@0: ERTplusEmailHotline, sl@0: ERTplusEmailStudio, sl@0: ERTplusEmailOther, sl@0: ERTplusMmsOther, sl@0: ERTplusChat, sl@0: ERTplusChatCenter, sl@0: ERTplusVoteQuestion, sl@0: ERTplusVoteCenter, sl@0: // Category: Reserved for future (54 - 55) sl@0: ERTplusRfuClass54, sl@0: ERTplusRfuClass55, sl@0: // Category: Private classes (56 - 58) sl@0: ERTplusPrivateClass56, sl@0: ERTplusPrivateClass57, sl@0: ERTplusPrivateClass58, sl@0: // Category: Descriptor (59 - 63) sl@0: ERTplusPlace, sl@0: ERTplusAppointment, sl@0: ERTplusIdentifier, sl@0: ERTplusPurchase, sl@0: ERTplusGetData sl@0: }; sl@0: sl@0: sl@0: /** sl@0: * RDS Function Bit Flags used by TRdsCapabilities and TRdsData. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: enum TRdsFeatures sl@0: { sl@0: ERdsProgrammeIdentification = 0x001, sl@0: ERdsProgrammeType = 0x002, sl@0: ERdsProgrammeService = 0x004, sl@0: ERdsRadioText = 0x008, sl@0: ERdsRadioTextPlus = 0x010, sl@0: ERdsClockTime = 0x020, sl@0: ERdsTrafficProgramme = 0x040, sl@0: ERdsTrafficAnnouncement = 0x080, sl@0: ERdsAlternateFrequency = 0x100 sl@0: }; sl@0: sl@0: sl@0: /** sl@0: * The RDS Capabilities class defines the capabilities of the RDS control on the sl@0: * device, as retrieved using the function GetCapabilities. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: class TRdsCapabilities sl@0: { sl@0: public: sl@0: // Bitfield as defined by TRdsFeatures with the bits of the supported functions set sl@0: // Valid bitfieds are: sl@0: // ERdsProgrammeIdentification | ERdsProgrammeType | ERdsProgrammeService | sl@0: // ERdsRadioText | ERdsRadioTextPlus | ERdsClockTime | ERdsTrafficProgramme | sl@0: // ERdsTrafficAnnouncement | ERdsAlternateFrequency sl@0: TUint32 iRdsFunctions; sl@0: // Reserved for future sl@0: TUint32 iAdditionalFunctions1; sl@0: // Reserved for future sl@0: TUint32 iAdditionalFunctions2; sl@0: }; sl@0: sl@0: sl@0: /** sl@0: * This class provides RDS features that can be enabled or disabled. Used in sl@0: * function NotifyRdsDataChange. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: class TRdsData sl@0: { sl@0: public: sl@0: // A value indicating a set containing all RDS data encapsulated by class TRdsData. sl@0: static const TUint32 KAllRdsData = ( ERdsProgrammeIdentification | ERdsProgrammeType | sl@0: ERdsProgrammeService | ERdsRadioText | ERdsClockTime | ERdsTrafficAnnouncement ); sl@0: sl@0: public: sl@0: // Bitfield as defined by TRdsDataFeatures with the bits of the supported functions set sl@0: // Valid bitfieds are: sl@0: // ERdsProgrammeIdentification | ERdsProgrammeType | ERdsProgrammeService | sl@0: // ERdsRadioText | ERdsClockTime | ERdsTrafficAnnouncement sl@0: TUint32 iRdsFunctions; sl@0: // Reserved for future sl@0: TUint32 iAdditionalFunctions1; sl@0: // Reserved for future sl@0: TUint32 iAdditionalFunctions2; sl@0: }; sl@0: sl@0: sl@0: /** sl@0: * This class provides RT+ tags. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: class TRdsRTplusTag sl@0: { sl@0: public: sl@0: // Specifies the content type according to the class code sl@0: TRdsRTplusClass iContentType; sl@0: // Indicates the position of the first character within the Radio Text sl@0: // (Start marker 0: means first character in RT) sl@0: TUint32 iStart; sl@0: // Length (number of characters) of the RTplus tag. sl@0: TUint32 iLength; sl@0: }; sl@0: sl@0: sl@0: /** Programme Service name, 8 characters */ sl@0: typedef TBuf8<8> TRdsPSName; sl@0: /** Radio Text, 64 characters */ sl@0: typedef TBuf8<64> TRdsRadioText; sl@0: sl@0: sl@0: /** sl@0: * This class provides the interface class to be implemented by object receiving request sl@0: * complete notification from RDS control. These functions are called once the asynchronous sl@0: * request completes successfully or with an error. sl@0: * sl@0: * In addition, this class provides the interface for receiving events from RDS control. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: class MRdsControlObserver sl@0: { sl@0: public: sl@0: sl@0: /** sl@0: * Station seek by Programme Type(PTY) complete event. This event is asynchronous and sl@0: * is received after a call to MRdsControl::StationSeekByPTY. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aFrequency The frequency(Hz) of the radio station that was found. sl@0: */ sl@0: virtual void StationSeekByPTYComplete( TInt aError, TInt aFrequency ) = 0; sl@0: sl@0: /** sl@0: * Station seek by Traffic Announcement(TA) complete event. This event is asynchronous sl@0: * and is received after a call to MRdsControl::StationSeekByTA. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aFrequency The frequency(Hz) of the radio station that was found. sl@0: */ sl@0: virtual void StationSeekByTAComplete( TInt aError, TInt aFrequency ) = 0; sl@0: sl@0: /** sl@0: * Station seek by Traffic Programme(TP) complete event. This event is asynchronous and sl@0: * is received after a call to MRdsControl::StationSeekByTP. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aFrequency The frequency(Hz) of the radio station that was found. sl@0: */ sl@0: virtual void StationSeekByTPComplete( TInt aError, TInt aFrequency ) = 0; sl@0: sl@0: /** sl@0: * Get frequencies by Programme Type(PTY) complete event. This event is asynchronous sl@0: * and is received after a call to MRdsControl::GetFreqByPTY. sl@0: * sl@0: * Client takes ownership of the array and therefore is responsible for deallocating it. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aFreqList Array of frequencies (Hz), valid only if aError is KErrNone. sl@0: */ sl@0: virtual void GetFreqByPTYComplete( TInt aError, RArray& aFreqList ) = 0; sl@0: sl@0: /** sl@0: * Get frequencies by Traffic Announcement(TA) complete event. This event is asynchronous sl@0: * and is received after a call to MRdsControl::GetFreqByTA. sl@0: * sl@0: * Client takes ownership of the array and therefore is responsible for deallocating it. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aFreqList Array of frequencies (Hz), valid only if aError is KErrNone. sl@0: */ sl@0: virtual void GetFreqByTAComplete( TInt aError, RArray& aFreqList ) = 0; sl@0: sl@0: /** sl@0: * Get Programme Service names (PS) by Programme Type(PTY) complete event. This event is sl@0: * asynchronous and is received after a call to MRdsControl::GetPSByPTY. sl@0: * sl@0: * Client takes ownership of the array and therefore is responsible for deallocating it. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aPsList Array of programme service names, valid only if aError is KErrNone. sl@0: */ sl@0: virtual void GetPSByPTYComplete( TInt aError, RArray& aPsList ) = 0; sl@0: sl@0: /** sl@0: * Get Programme Service names (PS) by Traffic Announcement(TA) complete event. This event is sl@0: * asynchronous and is received after a call to MRdsControl::GetPSByTA. sl@0: * sl@0: * Client takes ownership of the array and therefore is responsible for deallocating it. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aPsList Array of programme service names, valid only if aError is KErrNone. sl@0: */ sl@0: virtual void GetPSByTAComplete( TInt aError, RArray& aPsList ) = 0; sl@0: sl@0: /** sl@0: * New Programme Identification(PI) is available. This event is asynchronous and is sl@0: * received after a call to MRdsControl::NotifyRdsDataChange. Client will continue to sl@0: * receive this notification whenever new PI is available until clients unsubscribes. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPi Programme identification sl@0: */ sl@0: virtual void RdsDataPI( TInt aPi ) = 0; sl@0: sl@0: /** sl@0: * New Programme Type (PTY) is available. This event is asynchronous and is received after sl@0: * a call to MRdsControl::NotifyRdsDataChange. Client will continue to receive this sl@0: * notification whenever new PTY is available until client cancels notification request. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPty Programme type sl@0: */ sl@0: virtual void RdsDataPTY( TRdsProgrammeType aPty ) = 0; sl@0: sl@0: /** sl@0: * New Programme Service name (PS) is available. This event is asynchronous and is received sl@0: * after a call to MRdsControl::NotifyRdsDataChange. Client will continue to receive this sl@0: * notification whenever new PS is available until client cancels notification request. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPs Programme service sl@0: */ sl@0: virtual void RdsDataPS( TRdsPSName& aPs ) = 0; sl@0: sl@0: /** sl@0: * New Radio Text (RT) is available. This event is asynchronous and is received after sl@0: * a call to MRdsControl::NotifyRdsDataChange. Client will continue to receive this sl@0: * notification whenever new RT is available until client cancels notification request. sl@0: * sl@0: * If RT+ is supported, RT+ tags information is sent along with the RT. Client takes sl@0: * ownership of the array and therefore is responsible to deallocate it. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aRt Radio text sl@0: * @param aRTplusTags RTplus tags sl@0: */ sl@0: virtual void RdsDataRT( TRdsRadioText& aRt, RArray& aRTplusTags ) = 0; sl@0: sl@0: /** sl@0: * Clock Time (CT) is available. This event is asynchronous and is received after a call sl@0: * to MRdsControl::NotifyRdsDataChange. Client will continue to receive this notification sl@0: * whenever new CT is available until client cancels notification request. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aCt Clock time sl@0: */ sl@0: virtual void RdsDataCT( TDateTime& aCt ) = 0; sl@0: sl@0: /** sl@0: * Called when Traffice Announcement (TA) status changes. This event is asynchronous sl@0: * and is received after a call to MRdsControl::NotifyRdsDataChange. Client will continue sl@0: * to receive this notification whenever TA status changes until client cancels notification request. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aTaOn ETrue indicates that Traffic Announcement is on. sl@0: */ sl@0: virtual void RdsDataTA( TBool aTaOn ) = 0; sl@0: sl@0: /** sl@0: * Called when tuner starts to search for an Alternate Frequency (AF) with stronger signal. sl@0: * This event is asynchronous and is received after a call to MRdsControl::SetAutomaticSwitching. sl@0: * Client will continue to receive this notification whenever new search is started sl@0: * until clients turns automatic switching off. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: virtual void RdsSearchBeginAF() = 0; sl@0: sl@0: /** sl@0: * Called when search for an Alternate Frequency (AF) ends. This event is asynchronous and sl@0: * is received after a call to MRdsControl::SetAutomaticSwitching. Client will continue sl@0: * to receive this notification until clients turns automatic switching off. sl@0: * sl@0: * Most common error codes: sl@0: * KErrNone - Successful, new frequency found sl@0: * KErrNotFound - Ended, but frequency hasn't changed sl@0: * KErrCancel - Cancelled sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aError A standard system error code or RDS control error (TRdsControlError). sl@0: * @param aFrequency The frequency (Hz) of the radio station that was found. sl@0: */ sl@0: virtual void RdsSearchEndAF( TInt aError, TInt aFrequency ) = 0; sl@0: sl@0: /** sl@0: * Called when the tuner has re-tuned to another frequency that is broadcasting sl@0: * Traffic Announcement (TA). This notification sent only when the client has turned the sl@0: * automatic traffic announcement on. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aFrequency The frequency (Hz) of the radio station that was found. sl@0: */ sl@0: virtual void RdsStationChangeTA( TInt aFrequency ) = 0; sl@0: sl@0: /** sl@0: * Called when RDS signal status change (i.e. signal is lost/restored). sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aSignal ETrue indicates that RDS signal is available in the tuned frequency. sl@0: */ sl@0: virtual void RdsEventSignalChange( TBool aSignal ) = 0; sl@0: }; sl@0: sl@0: sl@0: /** sl@0: * This class provides the interface class to be implemented by object implementing RDS control. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: class MRdsControl sl@0: { sl@0: public: sl@0: sl@0: /** sl@0: * Get the capabilities of the RDS control on the device. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aCaps The capabilities object to fill sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetCapabilities( TRdsCapabilities& aCaps ) const = 0; sl@0: sl@0: /** sl@0: * Get the status of the RDS reception. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aRdsSignal On return, will be ETrue if RDS signal can be recepted, EFalse otherwise. sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetRdsSignalStatus( TBool& aRdsSignal ) const = 0; sl@0: sl@0: /** sl@0: * Subscribe for notification for the specified RDS data. Client should first check sl@0: * the capabilities to see if a feature is supported. sl@0: * Request for notification for non-supported features will simply be ignored. sl@0: * sl@0: * For example, if the client wishes to be notified when new Programme Type and sl@0: * Traffic Announcement is available: sl@0: * iRdsData = ERdsProgrammeType | ERdsTrafficAnnouncement; sl@0: * iRdsUtility->NotifyRdsDataChange(iRdsData); sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aRdsData Bitfield indicating notification request. sl@0: * @see MRdsControlObserver::RdsDataPI sl@0: * @see MRdsControlObserver::RdsDataPTY sl@0: * @see MRdsControlObserver::RdsDataPS sl@0: * @see MRdsControlObserver::RdsDataRT sl@0: * @see MRdsControlObserver::RdsDataCT sl@0: * @see MRdsControlObserver::RdsDataTA sl@0: */ sl@0: IMPORT_C virtual TInt NotifyRdsDataChange( TRdsData aRdsData ) = 0; sl@0: sl@0: /** sl@0: * Cancel NotifyRdsDataChange request. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: IMPORT_C virtual void CancelNotifyRdsDataChange() = 0; sl@0: sl@0: /** sl@0: * Turn on/off automatic switching of frequency based on Alternate Frequency. sl@0: * This will cause RDS device to search for alternate frequency when the signal strength sl@0: * deteriorates. User should be ready to receive RdsSearchBeginAF and RdsSearchEndAF. sl@0: * Automatic switching is off by default. sl@0: * sl@0: * Client should first check the capabilities to see if ERdsAlternateFrequency is sl@0: * supported. Will return KErrNotSupported if this feature is not supported. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aAuto ETrue to turn automatic switching on, EFalse to turn it off. sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: * @see MRdsControlObserver::RdsSearchBeginAF sl@0: * @see MRdsControlObserver::RdsSearchEndAF sl@0: */ sl@0: IMPORT_C virtual TInt SetAutomaticSwitching( TBool aAuto ) = 0; sl@0: sl@0: /** sl@0: * Find out whether automatic switching is on or off. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aAuto ETrue indicates that automatic switching is enabled. sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetAutomaticSwitching( TBool& aAuto ) = 0; sl@0: sl@0: /** sl@0: * Cancel ongoing search for an Alternate Frequency (AF) with stronger signal. sl@0: * sl@0: * Client can issue this request to interrupt the search indicated with sl@0: * MRdsControlObserver::RdsSearchBeginAF. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: IMPORT_C virtual void CancelAFSearch() = 0; sl@0: sl@0: /** sl@0: * Turns on/off automatic switching of frequency based on Traffic Announcement. sl@0: * This will cause RDS device to search for frequencies broadcasting traffic announcement. sl@0: * This feature is based on TP/TA fields and/or EON. It is up to the client to return to sl@0: * the previous frequency when the traffic announcement is finished. sl@0: * sl@0: * NOTE: This is only supported in dual tuner configuration since the secondary tuner sl@0: * needs to perform continuous scanning for frequencies broadcasting traffic announcement, sl@0: * while the primary tuner is used for normal tuner activities. sl@0: * Client should first check the tuner capabilities. Will return KErrNotSupported if sl@0: * this feature is not supported. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aAuto ETrue indicates that automatic switching is on. sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt SetAutomaticTrafficAnnouncement( TBool aAuto ) = 0; sl@0: sl@0: /** sl@0: * Find out whether automatic traffic announcement is enabled. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aAuto ETrue indicates that automatic traffic announcement is on. sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetAutomaticTrafficAnnouncement( TBool& aAuto ) = 0; sl@0: sl@0: /** sl@0: * Asynchronous request to find a radio station with the specified Programme Type (PTY), sl@0: * starting from the currently tuned frequency and searching in the direction specified sl@0: * (i.e. up or down). User must be ready to receive callback method StationSeekByPTYComplete sl@0: * The station found is returned in the callback. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPty The type of programme to search for. sl@0: * @param aSeekUp The direction to search in. Searches upwards if set to ETrue. sl@0: * @see MRdsControlObserver::StationSeekByPTYComplete sl@0: */ sl@0: IMPORT_C virtual void StationSeekByPTY( TRdsProgrammeType aPty, TBool aSeekUp ) = 0; sl@0: sl@0: /** sl@0: * Asynchronous request to find a radio station with Traffic Announcement (TA), sl@0: * starting from the currently tuned frequency and searching in the direction specified sl@0: * (i.e. up or down). User must be ready to receive callback method StationSeekByTAComplete sl@0: * The station found is returned in the callback. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aSeekUp The direction to search in. Searches upwards if set to ETrue. sl@0: * @see MRdsControlObserver::StationSeekByTAComplete sl@0: */ sl@0: IMPORT_C virtual void StationSeekByTA( TBool aSeekUp ) = 0; sl@0: sl@0: /** sl@0: * Asynchronous request to find a radio station with Traffic Programme (TP), sl@0: * starting from the currently tuned frequency and searching in the direction specified sl@0: * (i.e. up or down). User must be ready to receive callback method StationSeekByTPComplete sl@0: * The station found is returned in the callback. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aSeekUp The direction to search in. Searches upwards if set to ETrue. sl@0: * @see MRdsControlObserver::StationSeekByTPComplete sl@0: */ sl@0: IMPORT_C virtual void StationSeekByTP( TBool aSeekUp ) = 0; sl@0: sl@0: /** sl@0: * Cancels an ongoing retune operation, as initiated by a call to StationSeekByPTY, sl@0: * StationSeekByTA, or StationSeekByTP. sl@0: * The usual callback will not occur if this has been called. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: IMPORT_C virtual void CancelRdsStationSeek() = 0; sl@0: sl@0: /** sl@0: * Asynchronous request to find all frequencies sending the given Programme Type (PTY). sl@0: * User must be ready to receive callback method GetFreqByPTYComplete. sl@0: * sl@0: * NOTE: This is only supported in dual tuner configuration since the secondary tuner sl@0: * needs to perform continuous scanning for frequencies broadcasting given Programme Type sl@0: * while the primary tuner is used for normal tuner activities. sl@0: * Client should first check the tuner capabilities. Will return KErrNotSupported in sl@0: * callback method if this feature is not supported. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPty The type of programme to search for sl@0: * @see MRdsControlObserver::GetFreqByPTYComplete sl@0: */ sl@0: IMPORT_C virtual void GetFreqByPTY( TRdsProgrammeType aPty ) = 0; sl@0: sl@0: /** sl@0: * Cancels an ongoing request to find all frequencies sending a given Programme Type (PTY). sl@0: * The usual callback will not occur if this has been called. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: IMPORT_C virtual void CancelGetFreqByPTY() = 0; sl@0: sl@0: /** sl@0: * Asynchronous request to find all frequencies sending Traffic Announcement (TA). User must sl@0: * be ready to receive callback method GetFreqByTAComplete. sl@0: * sl@0: * NOTE: This is only supported in dual tuner configuration since the secondary tuner sl@0: * needs to perform continuous scanning for frequencies broadcasting given Traffic Announcement sl@0: * while the primary tuner is used for normal tuner activities. sl@0: * Client should first check the tuner capabilities. Will return KErrNotSupported in sl@0: * callback method if this feature is not supported. sl@0: * sl@0: * @since S60 3.2 sl@0: * @see MRdsControlObserver::GetFreqByTAComplete sl@0: */ sl@0: IMPORT_C virtual void GetFreqByTA() = 0; sl@0: sl@0: /** sl@0: * Cancels an ongoing request to find all frequencies sending Traffic Announcement. sl@0: * The usual callback will not occur if this has been called. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: IMPORT_C virtual void CancelGetFreqByTA() = 0; sl@0: sl@0: /** sl@0: * Asynchronous request to find all Programme Service names (PS) sending the given Programme sl@0: * Type (PTY). User must be ready to receive callback method GetPSByPTYComplete. sl@0: * sl@0: * NOTE: This is only supported in dual tuner configuration since the secondary tuner sl@0: * needs to perform continuous scanning for frequencies broadcasting given Programme Type sl@0: * while the primary tuner is used for normal tuner activities. sl@0: * Client should first check the tuner capabilities. Will return KErrNotSupported in sl@0: * callback method if this feature is not supported. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPty The type of programme to search for sl@0: * @see MRdsControlObserver::GetPSByPTYComplete sl@0: */ sl@0: IMPORT_C virtual void GetPSByPTY( TRdsProgrammeType aPty ) = 0; sl@0: sl@0: /** sl@0: * Cancels an ongoing request to find all Programme Service names (PS) sending a given sl@0: * Programme Type (PTY). The usual callback will not occur if this has been called. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: IMPORT_C virtual void CancelGetPSByPTY() = 0; sl@0: sl@0: /** sl@0: * Asynchronous request to find all Programme Service names (PS) sending Traffic Announcement (TA). sl@0: * User must be ready to receive callback method GetPSByTAComplete. sl@0: * sl@0: * NOTE: This is only supported in dual tuner configuration since the secondary tuner sl@0: * needs to perform continuous scanning for frequencies broadcasting given Traffic Announcement sl@0: * while the primary tuner is used for normal tuner activities. sl@0: * Client should first check the tuner capabilities. Will return KErrNotSupported in sl@0: * callback method if this feature is not supported. sl@0: * sl@0: * @since S60 3.2 sl@0: * @see MRdsControlObserver::GetPSByTAComplete sl@0: */ sl@0: IMPORT_C virtual void GetPSByTA() = 0; sl@0: sl@0: /** sl@0: * Cancels an ongoing request to find all Programme Service names (PS) sending Traffic Announcement. sl@0: * The usual callback will not occur if this has been called. sl@0: * sl@0: * @since S60 3.2 sl@0: */ sl@0: IMPORT_C virtual void CancelGetPSByTA() = 0; sl@0: sl@0: /** sl@0: * Get the current Programme Identification code. sl@0: * RDS data is received over the air and may not be available immediately following sl@0: * tune operation. If a value is returned, this is the last known value, which may sl@0: * not be up to date. sl@0: * To be notified of the most recent value, client should use NotifyRdsDataChange. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPi On return contains Programme Identification code sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetProgrammeIdentification( TInt& aPi ) = 0; sl@0: sl@0: /** sl@0: * Get the current Programme Type. sl@0: * RDS data is received over the air and may not be available immediately following sl@0: * tune operation. If a value is returned, this is the last known value, which may sl@0: * not be up to date. sl@0: * To be notified of the most recent value, client should use NotifyRdsDataChange. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPty On return contains Programme Type sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetProgrammeType( TRdsProgrammeType& aPty ) = 0; sl@0: sl@0: /** sl@0: * Get the current Programme Service name. sl@0: * RDS data is received over the air and may not be available immediately following sl@0: * tune operation. If a value is returned, this is the last known value, which may sl@0: * not be up to date. sl@0: * To be notified of the most recent value, client should use NotifyRdsDataChange. sl@0: * sl@0: * The maximum possible length for Programme Service name is 8 characters. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aPs On return contains Programme Service name sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetProgrammeService( TRdsPSName& aPs ) = 0; sl@0: sl@0: /** sl@0: * Get the current Radio Text. sl@0: * RDS data is received over the air and may not be available immediately following sl@0: * tune operation. If a value is returned, this is the last known value, which may sl@0: * not be up to date. sl@0: * To be notified of the most recent value, client should use NotifyRdsDataChange. sl@0: * sl@0: * The maximum possible length for radio text is 64 characters. sl@0: * sl@0: * If RT+ is supported, RT+ tags information is returned along with the RT. Array is sl@0: * owned by the client. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aRt On return contains Radio Text sl@0: * @param aRTplusTags RTplus tags sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetRadioText( TRdsRadioText& aRt, RArray& aRTplusTags ) = 0; sl@0: sl@0: /** sl@0: * Get the current Clock Time and date. sl@0: * RDS data is received over the air and may not be available immediately following sl@0: * tune operation. If a value is returned, this is the last known value, which may sl@0: * not be up to date. sl@0: * To be notified of the most recent value, client should use NotifyRdsDataChange. sl@0: * sl@0: * The RDS standard states that this is broadcast within 0.1s of the start of a minute, sl@0: * and is accurate to one minute. The latency of the notification reaching the application sl@0: * cannot be guaranteed. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aCt On return contains current time and date sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetClockTime( TDateTime& aCt ) = 0; sl@0: sl@0: /** sl@0: * Get Traffic Announcement status at the current station. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aTaStatus On return, will be ETrue if current station has ongoing traffic announcement sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetTrafficAnnouncementStatus( TBool& aTaStatus ) = 0; sl@0: sl@0: /** sl@0: * Get Traffic Programme status at the current station. sl@0: * sl@0: * @since S60 3.2 sl@0: * @param aTpStatus On return, will be ETrue if current station supports traffic programme sl@0: * @return A standard system error code or RDS control error (TRdsControlError). sl@0: */ sl@0: IMPORT_C virtual TInt GetTrafficProgrammeStatus( TBool& aTpStatus ) = 0; sl@0: }; sl@0: sl@0: #endif // M_RADIORDSCONTROL_H sl@0: