"Transtation" is the combination of "Translate" and "Station", it's an easy-to-use and powerful translation software for Android/Desktop(JVM), based on Kotlin Multiplatform + Compose Multiplatform.
- Translate one item using multiple engines (Bing, Google, Baidu, Tencent) at the same time
- Use several advanced Large Language Models (LLMs), like ChatGPT, GPT-4, ChatGLM, Qwen to translate
- Or translate by chatting with LLMs
- You can even translate very long text in
Long Text Translation
page using LLMs - Support plugin development, download, update, import, export, etc. with high scalability
- Image translation is also supported, several engines are available as well
- Screen translation is supported, floating window/regional screenshot translation/full-screen screenshot translation are all supported
- Customize your theme, language, engines, etc.
- ALL YOU NEED ABOUT TRANSLATION
Due to the time limit, some of the features are not available in Desktop version yet, but they will be added in the future.
This software is a translation software which mainly serves for Chinese users right now. It is also a open-source project which can be referred to when learning Jetpack Compose or Compose Multiplatform. The project is the KMP version of Transtation, which has been maintained for 4 year in Android platform.
The following are the features of this application:
- Kotlin Multiplatform + Compose Multiplatform + MVVM + Kotlin Coroutine + Flow + SqlDelight
- Multi-module design, with separation between the common module and the project module
- Supports synchronized translation with multiple engines, and supports plugin development, download, update, import, export, etc. with high scalability
- Makes full use of the Kotlin language features, such as lazy loading, class proxy, Coroutine, Flow, sealed classes, extension methods, extension properties, and reflection, etc.
- Based on Rhino JS, it designs and implements a complete JavaScript plugin loading, running, and debugging environment, providing one-stop support for plugin development
- Adapts to Android11 file permissions, adapts to bilingual, dark mode, landscape/tablet pages, and develops, uses and publicly releases four open source libraries
The application gradually adapts to Android13, including:
- Supports setting the application language separately
- Supports Monet icon
You can get the latest version from the following ways:
- Android
- Desktop(JVM)
- Desktop version is still in Alpha test, it can be packaged and installed successfully. Join the QQ Group to download the test version.
If you want to read the code, I recommend that you start from the main Activity
If you find it helpful, welcome to star!
v2.8.0 (2024/01/15)
TranstationKMP_intro_x264.mp4
UI v4:
- Desktop version is still under development, the UI might change a lot in the future.
Screenshot | Screenshot |
---|---|
If you're a developer and want to view the code or build the application, the following might be helpful:
In the initial days of development, I tried using Fleet, Android Studio, and IDEA multiple times to develop this application. In the end, I continued using Android Studio. Its development experience is essentially consistent with IDEA, and Desktop applications can be run directly by clicking a small button. The reasons for not choosing the other two are:
- Fleet: Currently, it seems a bit rudimentary, and it's challenging to bring up various windows (cannot be kept resident), lacks AI completion.
- IDEA: The automatically generated expect/actual positions are very strange. For example, on the Android side, it displays both
androidMain
andkotlin.androidMain
. Choosing the former has no effect, and choosing the latter generates a file with a name like:Xxx.android.commonMain.kotlin.kt
, which is not very reasonable.
I recorded some of the migration process, I suggest you read it if you're interested in it. Because it is too long, I put it to another file:
As an open-source project, you can learn about it from the following aspects:
In terms of code organization, the code here doesn't strictly follow Google's best practices. If you want to pursue elegant code, you can refer to Google's official NowInAndroid project. However, in terms of actual usage, that project's pursuit of unified data flow has led to suboptimal user experience (for example, in the version I experienced, clicking on "Favorite" in any list item would trigger an upstream flow update, refreshing the entire list. This would cause the list to scroll back to the top when you click a favorite button, which clearly doesn't align with the actual user experience).
The code is written following this rule: Composable + ViewModel. Simple logic is implemented directly in Composable, while more complex logic is implemented in ViewModel. For the sake of convenience, the State inside the ViewModel has not adopted the "internal MutableState + externally exposed State" strategy. Instead, all States are mutable, and some are directly accessed through vm.xxx
.
However, there are still some basic cleanliness aspects, such as naming conventions, code indentation, and Kotlin-style programming. The main ViewModel files and Composable pages, under AS inspection, achieve full green for the most part, with the majority of yellow Lint warnings ranging from 1 to 5, mostly relating to unused TAG variables or unused functions.
- composeApp: the main translation page
- base-kmp: the basic module, defining basic Beans, and introducing third-party modules in API form for use by other parts
- code-editor: the code editor page
- login: the login and registration page
- ai: LLM related logics
- android-code-editor: editor, language-base, language-universal: code editor View from the open-source project sora-editor
buildSrc: dependency version management
-
You need to use Android Studio version Flamingo or higher, the newest stable version is highly recommended.
-
For security reasons, the open-source part does not include the
signing.properties
file containing signature information. If you need to build a release version, please add this file yourself.-
signing.properties
-
located in the root directory
// If you need to build a release package, please add this file yourself in the project root directory /** * STORE_FILE=yourAppStroe.keystore STORE_PASSWORD=yourStorePwd KEY_ALIAS=yourKeyAlias KEY_PASSWORD=yourAliasPwd */
-
-
For Chinese developers, due to the preferred repositories are Google and Maven, you may need to configure the proxy to download the dependencies. Or you can modify the
repositories
inbuild.gradle.kts
andsettings.gradle.kts
and move the Chinese mirrors to the top.
If you are unable to run it on the latest stable version of Android Studio and the correct Gradle version, and you have confirmed that it is not due to your own issues, feel free to open an issue and ask. It's possible that I missed some files when committing to Git. I will respond as soon as I see it.
- UI design (v3) referenced from 酷安@江戸川コナン (authorized)
- UI design (V4) and promotional graphics from 酷安@松川吖
- Thank you to all the friends who have sponsored the project!
- Thank you to all the contributors!
If this project is helpful to you, welcome to Star it~