Skip to main content

Implementing In-app and pre-locale language selection in Android

Modern Android App Architecture

One of the essential features for a globalized app is the ability to provide users with the option to choose their preferred language within the application. In this blog post, we will guide you through the process of implementing in-app language selection in an Android app.

Step 1: Create Locale String Resource

Create a string resource file for each respective locale by navigating to res > new > Android Resource File. Select Locale and create a
string.xml
file. Copy and paste the translations of your app content into these files.

Step 2: Configure Locale Preferences

In the res/xmlfolder, create a new file called locales_config.xml and specify the locales of your choice. for example look at the following code:

<?xml version="1.0" encoding="utf-8"?> <locale-config xmlns:android="http://schemas.android.com/apk/res/android"> <locale android:name="en" /> //English <locale android:name="ta" /> //Tamil <locale android:name="hi" /> //Hindi <locale android:name="ml" /> //Malayalam </locale-config>

Step 3: Add resource.properties file

Switch to project view and in the resfolder, create a new file called resources.properties and specify the default locales of your choice, this will be the fallback locale if the requested one is un-available,for example look at the following code:

unqualifiedResLocale=en

Step 4: Update Module Gradle File

The list of language tags need to added to resourseConfiguration make sure you add all the language tags, have shared the updated code below as per my sample app:

android { ... androidResources { generateLocaleConfig = true } ... defaultConfig { ... resourceConfigurations.plus(listOf("ta", "en", "hi", "your-language-tag")) } }

Step 5: Manifest Configuration

You can let the device handle the locales, for that we are going to use a service called androidx.appcompat.app.AppLocalesMetadataHolderService with the following configuration, you can just copy paste the following code

<application ...> <service android:name="androidx.appcompat.app.AppLocalesMetadataHolderService" android:enabled="false" android:exported="false"> <meta-data android:name="autoStoreLocales" android:value="true" /> </service> </application>

Step 6: Implement Locale Selection Function

fun localeSelection(context: Context, localeTag: String) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) { context.getSystemService(LocaleManager::class.java).applicationLocales = LocaleList.forLanguageTags(localeTag) } else { AppCompatDelegate.setApplicationLocales( LocaleListCompat.forLanguageTags(localeTag) ) } }

Step 7: Usage Example

val context = LocalContext.current Button(onClick = { localeSelection(context = context, localeTag = Locale("ta").toLanguageTag()) }) { Text(text = "Tamil") }

That's it! You've successfully implemented in-app language selection in your Android app. Feel free to check out the sample app on GitHub for a hands-on example.

If you encounter any issues or have questions, please leave a comment, and will do my best to assist you.

Comments

Popular posts from this blog

Basics of Room Persistence Library in Android #RP1

Room is a library built on top of SQLite that provides a more convenient and structured way to manage your app's local database. It lets you work with your data as Kotlin objects (data classes) instead of manually formulating them using SQL queries, which itself is a tedious task prone to many errors.   It also simplifies interactions with the database with many great features like validating the queries, seamless integration with Kotlin Flow, paging, LiveData, and many more. These features make Room the most preferred option for offline-first apps, as it expedites the process and helps us to avoid issues early in the development cycle. Since Google has the best article for setting up, I will be skipping the setup Dependency setup: Official Guide on Setting up Room Dependencies and plugins   Please do ensure you follow the above guide and then sync and build your project successfully, as it will help you to try out the components yourself. In t...

Search Textfield with options and clear button ideal for app TopBar- Jetpack Compose Component

In this blog post, we'll explore a simple yet effective implementation of a search bar in Jetpack Compose. The provided SearchTextField composable offers a basic text field with a placeholder, suitable for building the app top bar. Screen Shot of the Component from my Jot-app The following code can be used to your project directly and it should work as expected, the idea was to have a search bar for a top app which can also hst the buttons on either ends,do check the code below If you have any suggestions or improvements for the code, let's have a conversation below. Your feedback is valuable to me