Auto-translate app text using Local Cache first, then Gemini API, with fallback to Free Google API
Select the latest successful workflow run and download the APK from the Artifacts section.
- LSPosed or another Xposed Framework variant must be installed and enabled.
- Install the downloaded APK from the link above.
- Open the LSPosed Manager app, navigate to Modules, and enable XPTranslateText.
- Select the apps you want to translate from the module settings in LSPosed.
- Kill your app and restart it.
After restart, the selected apps should display translated text automatically.
-
android.widget.TextView & Custom Components:
- Automatically translates text set via the
setText()
method. - Translation is prioritized using:
- Local Translation Cache: Speeds up translation by caching previously translated texts locally.
- Gemini API (gemini-2.0-flash-lite): Uses Google's Gemini API for translations first, with a fallback to the Free Google API when needed.
- Free Google API
- Automatically translates text set via the
-
android.webkit.WebView:
- Performs real-time translation of entire webpage content.
- Exclusively uses the Free Google API due to the dynamic nature of web content.
- Tested and confirmed working on:
- Android 13 with LSPosed
- Android 15 with LSPosed
Before | After |
---|---|
![]() |
![]() |
XPTranslateText/
├── app/
│ ├── key.jks # Generated by GitHub Actions
│ └── build.gradle
├── gradlew
├── gradlew.bat
├── keystore.properties # Local-only, not committed
└── settings.gradle