diff -r 6df133bd92e1 -r 075425b8d9a4 radioapp/radiouiengine/src/radiouiengine.cpp --- a/radioapp/radiouiengine/src/radiouiengine.cpp Fri Jun 04 10:21:36 2010 +0100 +++ b/radioapp/radiouiengine/src/radiouiengine.cpp Fri Jun 11 13:38:32 2010 +0300 @@ -19,139 +19,31 @@ #include #include #include +#include #ifdef BUILD_WIN32 # include #else -# include # include -using namespace QtMobility; #endif // WIN32_BUILD // User includes #include "radiouiengine.h" #include "radiouiengine_p.h" -#include "radiologger.h" #include "radioenginewrapper.h" #include "radiostationmodel.h" #include "radiohistorymodel.h" -#include "radiocarouselmodel.h" #include "radiohistoryitem.h" #include "radiosettings.h" -#include "radiostationfiltermodel.h" #include "radioscannerengine.h" +#include "radiogenrelocalizer.h" +#include "radiologger.h" // Constants -const QString KPathFormatter = "%1:%2%3"; -const QString KApplicationDir = "\\sys\\bin\\"; -const QString KSongRecognitionApp = "Shazam_0x200265B3.exe"; -const QString KSongRecognitionAppParams = "-listen"; - const uint DEFAULT_MIN_FREQUENCY = 87500000; -const uint RADIO_CENREP_UID = 0x101FF976; -const uint RADIO_CENREP_FREQUENCY_KEY = 0x00000107; - -struct GenreStruct -{ - int mGenreCode; - const char* mInCarousel; - const char* mInStationsList; - const char* mInHomeScreen; -}; - -const GenreStruct EuropeanGenres[] = -{ - { GenreEurope::RdsNone, "", "", "" } - ,{ GenreEurope::RdsNews, "txt_rad_info_news", "txt_rad_dblist_l1_mhz_val_news", "txt_rad_info_news_hs" } - ,{ GenreEurope::RdsCurrentAffairs, "txt_rad_info_current_affairs", "txt_rad_dblist_l1_mhz_val_current_affairs", "txt_rad_info_current_affairs_hs" } - ,{ GenreEurope::RdsInformation, "txt_rad_info_information", "txt_rad_dblist_l1_mhz_val_information", "txt_rad_info_information_hs" } - ,{ GenreEurope::RdsSport, "txt_rad_info_sport", "txt_rad_dblist_l1_mhz_val_sport", "txt_rad_info_sport_hs" } - ,{ GenreEurope::RdsEducation, "txt_rad_info_education", "txt_rad_dblist_l1_mhz_val_education", "txt_rad_info_education_hs" } - ,{ GenreEurope::RdsDrama, "txt_rad_info_drama", "txt_rad_dblist_l1_mhz_val_drama", "txt_rad_info_drama_hs" } - ,{ GenreEurope::RdsCulture, "txt_rad_info_culture", "txt_rad_dblist_l1_mhz_val_culture", "txt_rad_info_culture_hs" } - ,{ GenreEurope::RdsScience, "txt_rad_info_science", "txt_rad_dblist_l1_mhz_val_science", "txt_rad_info_science_hs" } - ,{ GenreEurope::RdsVariedSpeech, "txt_rad_info_varied", "txt_rad_dblist_l1_mhz_val_varied", "txt_rad_info_varied_hs" } - ,{ GenreEurope::RdsPopMusic, "txt_rad_info_pop_music", "txt_rad_dblist_l1_mhz_val_pop_music", "txt_rad_info_pop_music_hs" } - ,{ GenreEurope::RdsRockMusic, "txt_rad_info_rock_music", "txt_rad_dblist_l1_mhz_val_rock_music", "txt_rad_info_rock_music_hs" } - ,{ GenreEurope::RdsEasyListening, "txt_rad_info_easy_listening", "txt_rad_dblist_l1_mhz_val_easy_listening", "txt_rad_info_easy_listening_hs" } - ,{ GenreEurope::RdsLightClassical, "txt_rad_info_light_classical", "txt_rad_dblist_l1_mhz_val_light_classical", "txt_rad_info_light_classical_hs" } - ,{ GenreEurope::RdsSeriousClassical, "txt_rad_info_serious_classical", "txt_rad_dblist_l1_mhz_val_serious_classical", "txt_rad_info_serious_classical_hs" } - ,{ GenreEurope::RdsOtherMusic, "txt_rad_info_other_music", "txt_rad_dblist_l1_mhz_val_other_music", "txt_rad_info_other_music_hs" } - ,{ GenreEurope::RdsWeather, "txt_rad_info_weather", "txt_rad_dblist_l1_mhz_val_weather", "txt_rad_info_weather_hs" } - ,{ GenreEurope::RdsFinance, "txt_rad_info_finance", "txt_rad_dblist_l1_mhz_val_finance", "txt_rad_info_finance_hs" } - ,{ GenreEurope::RdsChildrensProgrammes, "txt_rad_info_childrens_programmes", "txt_rad_dblist_l1_mhz_val_childrens_programmes", "txt_rad_info_childrens_programmes_hs" } - ,{ GenreEurope::RdsSocialAffairs, "txt_rad_info_social_affairs", "txt_rad_dblist_l1_mhz_val_social_affairs", "txt_rad_info_social_affairs_hs" } - ,{ GenreEurope::RdsReligion, "txt_rad_info_religion", "txt_rad_dblist_l1_mhz_val_religion", "txt_rad_info_religion_hs" } - ,{ GenreEurope::RdsPhoneIn, "txt_rad_info_phone_in", "txt_rad_dblist_l1_mhz_val_phone_in", "txt_rad_info_phone_in_hs" } - ,{ GenreEurope::RdsTravel, "txt_rad_info_travel", "txt_rad_dblist_l1_mhz_val_travel", "txt_rad_info_travel_hs" } - ,{ GenreEurope::RdsLeisure, "txt_rad_info_leisure", "txt_rad_dblist_l1_mhz_val_leisure", "txt_rad_info_leisure_hs" } - ,{ GenreEurope::RdsJazzMusic, "txt_rad_info_jazz_music", "txt_rad_dblist_l1_mhz_val_jazz_music", "txt_rad_info_jazz_music_hs" } - ,{ GenreEurope::RdsCountryMusic, "txt_rad_info_country_music", "txt_rad_dblist_l1_mhz_val_country_music", "txt_rad_info_country_music_hs" } - ,{ GenreEurope::RdsNationalMusic, "txt_rad_info_national_music", "txt_rad_dblist_l1_mhz_val_national_music", "txt_rad_info_national_music_hs" } - ,{ GenreEurope::RdsOldiesMusic, "txt_rad_info_oldies_music", "txt_rad_dblist_l1_mhz_val_oldies_music", "txt_rad_info_oldies_music_hs" } - ,{ GenreEurope::RdsFolkMusic, "txt_rad_info_folk_music", "txt_rad_dblist_l1_mhz_val_folk_music", "txt_rad_info_folk_music_hs" } - ,{ GenreEurope::RdsDocumentary, "txt_rad_info_documentary", "txt_rad_dblist_l1_mhz_val_documentary", "txt_rad_info_documentary_hs" } - ,{ GenreEurope::RdsAlarmTest, "txt_rad_info_alarm_test", "txt_rad_dblist_l1_mhz_val_alarm_test", "txt_rad_info_alarm_test_hs" } - ,{ GenreEurope::RdsAlarm, "txt_rad_info_alarm", "txt_rad_dblist_l1_mhz_val_alarm", "txt_rad_info_alarm_hs" } -}; -const int EuropeanGenresCount = sizeof( EuropeanGenres ) / sizeof ( EuropeanGenres[0] ); +const uint RADIO_CENREP_UID = 0x2002FF52; +const uint RADIO_CENREP_FREQUENCY_KEY = 0x207; -const GenreStruct AmericanGenres[] = -{ - { GenreAmerica::RbdsNone, "", "", "" } - ,{ GenreAmerica::RbdsNews, "txt_rad_info_news", "txt_rad_dblist_l1_mhz_val_news", "txt_rad_info_news_hs" } - ,{ GenreAmerica::RbdsInformation, "txt_rad_info_information", "txt_rad_dblist_l1_mhz_val_information", "txt_rad_info_information_hs" } - ,{ GenreAmerica::RbdsSports, "txt_rad_info_sport", "txt_rad_dblist_l1_mhz_val_sport", "txt_rad_info_sport_hs" } - ,{ GenreAmerica::RbdsTalk, "txt_rad_info_talk", "txt_rad_dblist_l1_mhz_val_talk", "txt_rad_info_talk_hs" } - ,{ GenreAmerica::RbdsRock, "txt_rad_info_rock_music", "txt_rad_dblist_l1_mhz_val_rock_music", "txt_rad_info_rock_music_hs" } //TODO: Check - ,{ GenreAmerica::RbdsClassicRock, "txt_rad_info_classic_rock", "txt_rad_dblist_l1_mhz_val_classic_rock", "txt_rad_info_classic_rock_hs" } - ,{ GenreAmerica::RbdsAdultHits, "txt_rad_info_adult_hits", "txt_rad_dblist_l1_mhz_val_adult_hits", "txt_rad_info_adult_hits_hs" } - ,{ GenreAmerica::RbdsSoftRock, "txt_rad_info_soft_rock", "txt_rad_dblist_l1_mhz_val_soft_rock", "txt_rad_info_soft_rock_hs" } - ,{ GenreAmerica::RbdsTop40, "txt_rad_info_top_40", "txt_rad_dblist_l1_mhz_val_top_40", "txt_rad_info_top_40_hs" } - ,{ GenreAmerica::RbdsCountry, "txt_rad_info_country_music", "txt_rad_dblist_l1_mhz_val_country_music", "txt_rad_info_country_music_hs" } //TODO: Check - ,{ GenreAmerica::RbdsOldies, "txt_rad_info_oldies_music", "txt_rad_dblist_l1_mhz_val_oldies_music", "txt_rad_info_oldies_music_hs" } //TODO: Check - ,{ GenreAmerica::RbdsSoft, "txt_rad_info_soft", "txt_rad_dblist_l1_mhz_val_soft", "txt_rad_info_soft_hs" } - ,{ GenreAmerica::RbdsNostalgia, "txt_rad_info_nostalgia", "txt_rad_dblist_l1_mhz_val_nostalgia", "txt_rad_info_nostalgia_hs" } - ,{ GenreAmerica::RbdsJazz, "txt_rad_info_jazz_music", "txt_rad_dblist_l1_mhz_val_jazz_music", "txt_rad_info_jazz_music_hs" } //TODO: Check - ,{ GenreAmerica::RbdsClassical, "txt_rad_info_classical", "txt_rad_dblist_l1_mhz_val_classical", "txt_rad_info_classical_hs" } - ,{ GenreAmerica::RbdsRhythmAndBlues, "txt_rad_info_rhythm_and_blues", "txt_rad_dblist_l1_mhz_val_rhythm_and_blues", "txt_rad_info_rhythm_and_blues_hs" } - ,{ GenreAmerica::RbdsSoftRhythmAndBlues, "txt_rad_info_soft_rhythm_and_blues", "txt_rad_dblist_l1_mhz_val_soft_rhythm_and_blues", "txt_rad_info_soft_rhythm_and_blues_hs" } - ,{ GenreAmerica::RbdsLanguage, "txt_rad_info_language", "txt_rad_dblist_l1_mhz_val_language", "txt_rad_info_language_hs" } - ,{ GenreAmerica::RbdsReligiousMusic, "txt_rad_info_religious_music", "txt_rad_dblist_l1_mhz_val_religious_music", "txt_rad_info_religious_music_hs" } - ,{ GenreAmerica::RbdsReligiousTalk, "txt_rad_info_religious_talk", "txt_rad_dblist_l1_mhz_val_religious_talk", "txt_rad_info_religious_talk_hs" } - ,{ GenreAmerica::RbdsPersonality, "txt_rad_info_personality", "txt_rad_dblist_l1_mhz_val_personality", "txt_rad_info_personality_hs" } - ,{ GenreAmerica::RbdsPublic, "txt_rad_info_public", "txt_rad_dblist_l1_mhz_val_public", "txt_rad_info_public_hs" } - ,{ GenreAmerica::RbdsCollege, "txt_rad_info_college", "txt_rad_dblist_l1_mhz_val_college", "txt_rad_info_college_hs" } - ,{ GenreAmerica::RbdsUnassigned1, "", "", "" } - ,{ GenreAmerica::RbdsUnassigned2, "", "", "" } - ,{ GenreAmerica::RbdsUnassigned3, "", "", "" } - ,{ GenreAmerica::RbdsUnassigned4, "", "", "" } - ,{ GenreAmerica::RbdsUnassigned5, "", "", "" } - ,{ GenreAmerica::RbdsWeather, "txt_rad_info_weather", "txt_rad_dblist_l1_mhz_val_weather", "txt_rad_info_weather_hs" }//TODO: Check - ,{ GenreAmerica::RbdsEmergencyTest, "txt_rad_info_alarm_test", "txt_rad_dblist_l1_mhz_val_alarm_test", "txt_rad_info_alarm_test_hs" }//TODO: Check - ,{ GenreAmerica::RbdsEmergency, "txt_rad_info_alarm", "txt_rad_dblist_l1_mhz_val_alarm", "txt_rad_info_alarm_hs" }//TODO: Check -}; -const int AmericanGenresCount = sizeof( AmericanGenres ) / sizeof ( AmericanGenres[0] ); - -/*! - * - */ -bool RadioUiEngine::isOfflineProfile() -{ - bool offline = false; - -#ifdef BUILD_WIN32 - QScopedPointer settings( new QSettings( "Nokia", "QtFmRadio" ) ); - offline = settings->value( "Offline", false ).toBool(); -#else - QSystemDeviceInfo deviceInfo; - if ( deviceInfo.currentProfile() == QSystemDeviceInfo::OfflineProfile ) { - offline = true; - } -#endif - - return offline; -} /*! * @@ -170,6 +62,9 @@ QScopedPointer settings( new XQSettingsManager() ); XQSettingsKey key( XQSettingsKey::TargetCentralRepository, RADIO_CENREP_UID, RADIO_CENREP_FREQUENCY_KEY ); frequency = settings->readItemValue( key, XQSettingsManager::TypeInt ).toUInt(); + if ( frequency == 0 ) { + frequency = DEFAULT_MIN_FREQUENCY; + } #endif return frequency; @@ -220,6 +115,60 @@ } /*! + * + */ +void RadioUiEngine::setFirstTimeStartPerformed( bool firstTimeStartPerformed ) +{ + Q_D( RadioUiEngine ); + d->mEngineWrapper->settings().setFirstTimeStartPerformed( firstTimeStartPerformed ); +} + +/*! + * + */ +void RadioUiEngine::setPowerOn() +{ + setMute( false ); + + Q_D( RadioUiEngine ); + if ( d->mPowerOffTimer ) { + d->mPowerOffTimer->stop(); + d->mPowerOffTimer->deleteLater(); + d->mPowerOffTimer = NULL; + } +} + +/*! + * + */ +void RadioUiEngine::setPowerOff( int delay ) +{ + Q_D( RadioUiEngine ); + d->mEngineWrapper->setMute( true, false ); + + if ( delay > 0 ) { + if ( !d->mPowerOffTimer ) { + d->mPowerOffTimer = new QTimer( this ); + Radio::connect( d->mPowerOffTimer, SIGNAL(timeout()), + this, SIGNAL(powerOffRequested()) ); + } + + d->mPowerOffTimer->start( delay ); + } else { + emit powerOffRequested(); + } +} + +/*! + * + */ +bool RadioUiEngine::isPoweringOff() const +{ + Q_D( const RadioUiEngine ); + return d->mPowerOffTimer && d->mPowerOffTimer->isActive(); +} + +/*! * Returns the settings handler owned by the engine */ RadioSettingsIf& RadioUiEngine::settings() @@ -247,24 +196,15 @@ } /*! - * Creates a new filter model + * */ -RadioStationFilterModel* RadioUiEngine::createNewFilterModel( QObject* parent ) -{ - return new RadioStationFilterModel( *this, parent ); -} - -/*! - * Creates a new carousel model - */ -RadioCarouselModel* RadioUiEngine::carouselModel() +RadioScannerEngine* RadioUiEngine::createScannerEngine() { Q_D( RadioUiEngine ); - if ( !d->mCarouselModel ) { - d->mCarouselModel.reset( new RadioCarouselModel( *this, *d->mStationModel ) ); + if ( !d->mScannerEngine ) { + d->mScannerEngine = new RadioScannerEngine( *d ); } - - return d->mCarouselModel.data(); + return d->mScannerEngine; } /*! @@ -273,10 +213,7 @@ RadioScannerEngine* RadioUiEngine::scannerEngine() { Q_D( RadioUiEngine ); - if ( !d->mScannerEngine ) { - d->mScannerEngine = new RadioScannerEngine( *d ); - } - return d->mScannerEngine; + return d->mScannerEngine.data(); } /*! @@ -395,24 +332,7 @@ */ QString RadioUiEngine::genreToString( int genre, GenreTarget::Target target ) { - RadioRegion::Region currentRegion = region(); - - const GenreStruct* genreArray = currentRegion == RadioRegion::America ? AmericanGenres : EuropeanGenres; - const int genreCount = currentRegion == RadioRegion::America ? AmericanGenresCount : EuropeanGenresCount; - - for( int i = 0; i < genreCount; ++i ) { - if ( genreArray[i].mGenreCode == genre ) { - if ( target == GenreTarget::Carousel ) { - return qtTrId( genreArray[i].mInCarousel ); - } else if ( target == GenreTarget::StationsList ) { - return qtTrId( genreArray[i].mInStationsList ); - } else if ( target == GenreTarget::HomeScreen ) { - return qtTrId( genreArray[i].mInHomeScreen ); - } - } - } - - return ""; + return RadioGenreLocalizer::genreToString( region(), genre, target ); } /*! @@ -420,28 +340,8 @@ */ bool RadioUiEngine::isSongRecognitionAppAvailable() { - //TODO: Check if there is a better way to check if an application is available - bool available = false; - - // Check the Z: drive - QString fullPath = QString( KPathFormatter ).arg( "Z" ).arg( KApplicationDir ).arg( KSongRecognitionApp ); - available = QFile::exists( fullPath ); - - LOG_FORMAT( "Checking file: %s. found %d", GETSTRING( fullPath ), available ); - - if ( !available ) { - // Check the C: drive - fullPath = QString( KPathFormatter ).arg( "C" ).arg( KApplicationDir ).arg( KSongRecognitionApp ); - available = QFile::exists( fullPath ); - LOG_FORMAT( "Checking file: %s. found %d", GETSTRING( fullPath ), available ); - if ( !available ) { - // Check the E: drive - fullPath = QString( KPathFormatter ).arg( "E" ).arg( KApplicationDir ).arg( KSongRecognitionApp ); - available = QFile::exists( fullPath ); - LOG_FORMAT( "Checking file: %s. found %d", GETSTRING( fullPath ), available ); - } - } - return available; + //TODO: Implement Shazam support + return false; } /*! @@ -473,48 +373,33 @@ } /*! - * Public slot - * Tunes to the given frequency + * Sets or unsets the engine to manual seek mode + */ +void RadioUiEngine::setManualSeekMode( bool manualSeek ) +{ + Q_D( RadioUiEngine ); + d->mEngineWrapper->setManualSeekMode( manualSeek ); +} + +/*! + * Checks if the engine is in manual seek mode */ -void RadioUiEngine::tuneFrequency( uint frequency, const int reason ) +bool RadioUiEngine::isInManualSeekMode() const +{ + Q_D( const RadioUiEngine ); + return d->mEngineWrapper->isInManualSeekMode(); +} + +/*! + * Tunes the radio engine to given frequency + */ +void RadioUiEngine::setFrequency( uint frequency, const int reason ) { Q_D( RadioUiEngine ); if ( frequency != d->mStationModel->currentStation().frequency() && d->mEngineWrapper->isFrequencyValid( frequency ) ) { LOG_FORMAT( "RadioUiEngine::tuneFrequency, frequency: %d", frequency ); d->cancelSeeking(); - d->mEngineWrapper->tuneFrequency( frequency, reason ); - } -} - -/*! - * Public slot - * Tunes to the given frequency after a delay - */ -void RadioUiEngine::tuneWithDelay( uint frequency, const int reason ) -{ - Q_D( RadioUiEngine ); - if ( frequency != d->mStationModel->currentStation().frequency() && d->mEngineWrapper->isFrequencyValid( frequency ) ) { - LOG_FORMAT( "RadioEngineWrapperPrivate::tuneWithDelay, frequency: %d", frequency ); - d->cancelSeeking(); - d->mEngineWrapper->tuneWithDelay( frequency, reason ); - } -} - -/*! - * Public slot - * Tunes to the given preset - */ -void RadioUiEngine::tunePreset( int presetIndex ) -{ - Q_D( RadioUiEngine ); - if ( presetIndex != d->mStationModel->currentStation().presetIndex() ) { - RadioStation station; - if ( d->mStationModel->findPresetIndex( presetIndex, station ) != RadioStation::NotFound && - d->mEngineWrapper->isFrequencyValid( station.frequency() ) ) { - LOG_FORMAT( "RadioEngineWrapperPrivate::tunePreset, presetIndexPosition: %d", presetIndex ); - - d->mEngineWrapper->tuneFrequency( station.frequency(), TuneReason::Unspecified ); - } + d->mEngineWrapper->setFrequency( frequency, reason ); } } @@ -558,7 +443,7 @@ { if ( isAntennaAttached() ) { Q_D( RadioUiEngine ); - Seeking::Direction direction = static_cast( seekDirection ); + Seek::Direction direction = static_cast( seekDirection ); emitSeekingStarted( direction ); d->mEngineWrapper->startSeeking( direction, TuneReason::Seek ); } @@ -570,14 +455,7 @@ */ void RadioUiEngine::launchSongRecognition() { - LOG_FORMAT("RadioUiEngine::launchSongRecognition() starting: %s", GETSTRING( KSongRecognitionApp ) ); - - QStringList arguments; - arguments << KSongRecognitionAppParams; - - bool started = QProcess::startDetached( KSongRecognitionApp, arguments ); - Q_UNUSED( started ); - LOG_ASSERT( started, LOG_FORMAT("RadioUiEngine::launchSongRecognition() failed to start %s", GETSTRING( KSongRecognitionApp ) ) ); + //TODO: Implement Shazam support } /*! @@ -591,7 +469,7 @@ /*! * Function used by the private implementation to emit a seekingStarted signal */ -void RadioUiEngine::emitSeekingStarted( Seeking::Direction direction ) +void RadioUiEngine::emitSeekingStarted( Seek::Direction direction ) { emit seekingStarted( direction ); }