No description
https://radiowave.sven-neurath.de
- Kotlin 100%
|
All checks were successful
PR CI / build-lint-test (push) Successful in 13m59s
compileSdk is already 36; align targetSdk ahead of the expected Google Play requirement for app updates (Aug 2026 cycle). Co-Authored-By: Claude Fable 5 <noreply@anthropic.com> |
||
|---|---|---|
| .github | ||
| .vscode | ||
| app | ||
| auto | ||
| build-logic | ||
| core | ||
| docs | ||
| feature | ||
| gradle | ||
| .gitignore | ||
| build.gradle.kts | ||
| CHANGELOG.md | ||
| CONTRIBUTING.md | ||
| gradle.properties | ||
| gradlew | ||
| gradlew.bat | ||
| keystore.properties.example | ||
| LICENSE.txt | ||
| README.de.md | ||
| README.md | ||
| ROADMAP.de.md | ||
| ROADMAP.md | ||
| settings.gradle.kts | ||
RadioWave
The modern, ad-free internet radio app for Android.
Fast | Privacy-first | No tracking | 45,000+ stations
Project website: radiowave.sven-neurath.de
Roadmap
The public roadmap is available in ROADMAP.md.
- Focus: stability and user value
- Updated continuously with releases and polish passes
- Feedback is welcome through GitHub Issues
- RadioWave is live on Google Play; beta/sideload notes now only apply to GitHub APKs and test installs
Availability
- Website: https://radiowave.sven-neurath.de
- Google Play: https://play.google.com/store/apps/details?id=de.darksoon.radiowave
- GitHub Releases: https://github.com/darksoon/RadioWave/releases/latest
- Android package /
applicationId:de.darksoon.radiowave
Highlights
- No account required, everything stays on the device
- Completely ad-free, no analytics, no behavior tracking
- 45,000+ stations via Radio Browser
- Album art lookup via the iTunes Search API
- Launcher quick actions for
Search,Favorites,Player, andSettings - Android Auto support with favorites, quick access, search, and previous/next in the car player
- Chromecast / Google Cast support with direct route selection from the player
- Sleep timer and direct share action in the fullscreen player
- Local crash-report export with share action and prefilled GitHub issue handoff
Screenshots
| Home | Search |
|---|---|
![]() |
![]() |
| Favorites | Fullscreen Player | Settings |
|---|---|---|
![]() |
![]() |
![]() |
| Android Auto 1 | Android Auto 2 |
|---|---|
![]() |
![]() |
| Android Auto 3 | Android Auto 4 |
|---|---|
![]() |
![]() |
Tech Stack
- Kotlin 2.1.0
- Jetpack Compose + Material 3
- Clean Architecture + MVVM
- Hilt
- Media3 / ExoPlayer
- Room
- Retrofit + Kotlinx Serialization
Quick Start
git clone https://github.com/darksoon/RadioWave.git
cd RadioWave
chmod +x gradlew
./gradlew :build-logic:build
./gradlew assembleDebug
Local Builds
# Full build
./gradlew build
# Lint + tests
./gradlew lint
./gradlew test
# Install debug APK
./gradlew installDebug
# GitHub-flavor debug build
./gradlew :app:assembleGithubDebug
# Play Store debug build
./gradlew :app:assemblePlayDebug
Restricted Networks / Proxy
If Gradle downloads are blocked, use a mirror or proxy:
# ~/.gradle/gradle.properties
systemProp.http.proxyHost=<proxy-host>
systemProp.http.proxyPort=<proxy-port>
systemProp.https.proxyHost=<proxy-host>
systemProp.https.proxyPort=<proxy-port>
Release Signing
Signed release builds are handled through GitHub Actions.
- For GitHub/direct download use the signed
githubAPK - For Google Play distribution use the signed
playApp Bundle (.aab)
For local signing experiments only:
cp keystore.properties.example keystore.properties
# edit keystore.properties
Installation
Google Play
Install RadioWave from Google Play:
https://play.google.com/store/apps/details?id=de.darksoon.radiowave
GitHub APK
- Open the latest release page:
https://github.com/darksoon/RadioWave/releases/latest - Download the current APK asset.
- Allow installs from unknown sources if your device asks for it.
- Open the APK and install it.
Player Improvements
- Short network interruptions are handled more gracefully with improved reconnect tuning
- The playback timer now reflects actual listening time and pauses during buffering
- Fullscreen player includes a share action and a sleep timer
- Favorites can be reordered more easily from the favorites screen
- Active Chromecast sessions can be started directly from the fullscreen player, station changes are handed over to TV, and in-app play/pause controls route to the cast device
Android Auto
- Browse is optimized for in-car usage:
Favorites,Quick Access,Top Stations,Genres - Quick Access combines favorites and recents
- Search merges local and remote results more robustly
- Previous/next in the car player now works as real station navigation
- Browse/search callbacks run asynchronously so Android Auto is not blocked by repository or network work
- The player only holds the WiFiLock while the active network is Wi-Fi; WakeLock stays active for stable playback
See also: docs/ANDROID_AUTO_DEV_MODE.md
Chromecast / Google Cast
- Cast devices can be selected directly from the fullscreen player
- Starting a cast session moves the current station to TV and stops parallel phone playback
- Changing stations while casting updates the TV stream instead of starting a separate local stream
- In-app play/pause controls work on the active cast session
- The player UI shows when playback is currently running on TV
- Alexa / Echo streaming is not part of this cast integration and would require a separate Amazon-specific solution
GitHub Actions
Manual Android Build
Available under Actions -> Manual Android Build -> Run workflow.
PR CI
- Runs automatically on pushes and pull requests to
main - Can also be started manually
- Uses Gradle build cache plus configuration cache
- Test-task gating is configuration-cache-safe, so CI no longer breaks on modules without unit tests
Release Build
- Signed releases are created through
Actions -> Release Build - The workflow:
- updates
app.versionNameandapp.versionCode - builds a signed Play APK plus a Play Store App Bundle (
.aab) - creates a tag and GitHub release
- uploads release assets, including native debug-symbol artifacts for Play Console troubleshooting
- updates
- Workflows are prepared for the GitHub Actions Node 24 migration (
actions/checkout@v5)
Privacy
- No analytics
- No ads
- No hidden telemetry
- Crash reports are stored locally only and shared explicitly by the user
License
RadioWave is licensed under the GNU General Public License v3.0 or later. See LICENSE.txt.
For source files, Kotlin code uses SPDX-License-Identifier: GPL-3.0-or-later.
Links
- Website: https://radiowave.sven-neurath.de
- Google Play: https://play.google.com/store/apps/details?id=de.darksoon.radiowave
- GitHub Releases: https://github.com/darksoon/RadioWave/releases/latest
- Ko-fi: https://ko-fi.com/darksoon
Credits
- Station data: Radio Browser API
- Album art: iTunes Search API
- Icons: Material Design Icons








