Click here to Skip to main content
13,899,749 members
Click here to Skip to main content
Add your own
alternative version


113 bookmarked
Posted 25 May 2005

Multilingual support for applications

, 6 Jun 2005
Rate this:
Please Sign up or sign in to vote.
An easy solution to add multilingual support to your application in 10 minutes.

Why another article about multilingual applications?

Well, about a year ago, I needed my application to support multiple languages. I thought it would be very easy to find out how to do this. There are a lot of articles that explain how to do this, but none of them fit my needs.

What can I find here?


What I really needed were simple .h and .cpp files which are able to load a language DLL and extract the strings I need. None of the articles I found provided this. At this point, I decided to write my own classes which could do the task I wanted them to do. I am a little active on some forums, and I see this question keeps coming back of how to implement multiple languages to an application. What I see is that it is really hard to understand how it works, the first time. So I decided to write a little article and add my language files to CodeProject.

How to use?

I tried to implement the files so that they are really easy to use. Let's explain how the class works.

Use string tables

Some people are still hard-coding the strings of their application in their code. This isn't the best solution on earth. So use string tables, because this is needed if you want to add multiple language support to your application.

Add files to project

First of all, you have to add the files Language.cpp and Language.h to your project. Now you are almost ready adding multilingual support to your application. The class I developed is a so-called singleton class. This means that you don't have to create the class every time. You only have to load and release the language at startup, and you can use the class everywhere.

How to load a language

Now, you are ready to load your first language. Normally, you load language at the startup of your application. Here is some example code that will try to load the system's default language:

BOOL CMyApp::InitInstance()
    .. some default code here

    // Init language object 
    CLanguage * pLanguage = CLanguage::Instance(); 

    // If you want, you can init the location of the dll's and the default language
    pLanguage->Init("lng", "dutch");

    // Load system default language 
    if (!pLanguage->LoadLanguage(GetSystemDefaultLangID())) 
        // Show error
        AfxMessageBox("Unable to load system language, "
                                  "default language is used");

    // Load dialog
    CMyDialog dlg;
    // Release language

    .. rest of code

It was pretty easy to load a language, wasn't it? Keep in mind that the Init function is not really needed. If you don't call this function, the defaults "lng" and "english" are used. But this is not all, you also have to load the strings.

How to load strings

You have loaded a language, but you also want to load strings. For example, you have a dialog with a nice static control. This is how you load the language:

BOOL CMyDialog::OnInitDialog()
    // Call original function

    // Init language object
    CLanguage * pLanguage = CLanguage::Instance();

    // Set text for static control

    .. rest of code

The language object will see if the user has loaded a valid DLL. If so, the string will be loaded from the DLL, if not, the default string table will be used. Still easy isn't it? That is all you have to do in your application.

How to create the language DLLs

There are a few easy steps to take:

  1. Create project.

    First, you have to create a project for your DLL. Start Visual Studio, and choose File -> New.... Then select Win32 Dynamic-Link Library. Give your project a new name and click OK. You now have seen a wizard, select a DLL that exports some symbols. The default files for the DLL are now created.

  2. Copy string table from original project.

    Now the default files are created, close the current (language DLL) project. Open your real application in the IDE now and open the string table. Use CTRL + A to select all items and then copy them. Close project again.

  3. Add string table to language project.

    Open your language project again. Select File -> New... and select resource script. Give the resource script a name and click OK. Now you can add resources to your project. Right click on the resource file and select Insert..., then select String table. Now copy the string table of your application to the language DLL (just use CTRL + V). As you will see, all values are now in the language DLL. You can start translating all the sentences now. If you are ready, you can compile the project. The DLL is now ready to use!


There are a lot of languages automatically supported by the language class. Of course, you can edit these settings yourself in Language.cpp (see InitLanguages function). A list of languages supported and the name of the DLL which is expected is given below:

Language DLLIDCodeLanguage description
Dutch (Standard)
Belgian (Flemish)
French (standard)
German (standard)
Italian (standard)
Norwegian (bokmal)
Norwegian (nynorsk)
portugues_br.dll0x0416PTBPortuguese (Brazilian)
Spanish (standard/traditional)
Spanish (modern)


  • June 3rd, 2005
    • Updated source code, constants can be changed at run-time;
    • Updated source code, you don't have to link to libraries anymore;
    • Removed MFC version, Win32 version will work in MFC applications;
  • June 1st, 2005
    • Added example application;
    • Added MFC and non-MFC versions;
    • Fixed bug when including multiple files;
  • May 26th, 2005
    • First release.


This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here


About the Author

Geert van Horrik
Software Developer CatenaLogic
Netherlands Netherlands
I am Geert van Horrik, and I have studied Computer Science in the Netherlands.

I love to write software using .NET (especially the combination of WPF and C#). I am also the lead developer of Catel, an open-source application development framework for WPF, Silverlight, WP7 and WinRT with the focus on MVVM.

I have my own company since January 1st 2007, called CatenaLogic. This company develops commercial and non-commercial software.

To download (or buy) applications I have written, visit my website:

You may also be interested in...


Comments and Discussions

GeneralIt's good! I have used this Class in my application to support simple Chinese, which language code is 0x0804. -- Thanks. Pin
Daniel.Li1-Nov-09 15:54
memberDaniel.Li1-Nov-09 15:54 
QuestionWill Japanese string supported? Pin
Vamsee_Krishna4-May-08 20:10
memberVamsee_Krishna4-May-08 20:10 
QuestionWill your application support chinese or japanese literals ? Pin
ganesa moorthy3-Apr-08 19:49
memberganesa moorthy3-Apr-08 19:49 

Your approach is nice.
Let me ask one question this point of time! Would your application support other literals apart from english alphabets.

If so, How ?

I tried copying chinese strings into string table but it is copied as some ???.??? like sometime it is stored as boxes ( ascii character )

Kindly tell me if i am wrong!

Thanks a lot!
Rose | [Rose]

Thanks a lot

AnswerRe: Will your application support chinese or japanese literals ? Pin
Geert van Horrik3-Apr-08 19:53
memberGeert van Horrik3-Apr-08 19:53 
GeneralOverkill solution Pin
KarstenK1-Oct-07 1:36
mveKarstenK1-Oct-07 1:36 
QuestionWhy re-enventing the wheel again and again? Pin
localizer4-May-06 4:35
memberlocalizer4-May-06 4:35 
GeneralCopy string table fails !!! Pin
jack2000de27-Feb-06 6:09
memberjack2000de27-Feb-06 6:09 
GeneralRe: Copy string table fails !!! Pin
Geert van Horrik27-Feb-06 6:53
memberGeert van Horrik27-Feb-06 6:53 
GeneralRe: Copy string table fails !!! Pin
jack2000de27-Feb-06 21:31
memberjack2000de27-Feb-06 21:31 
GeneralRe: Copy string table fails !!! Pin
Geert van Horrik28-Feb-06 0:08
memberGeert van Horrik28-Feb-06 0:08 
GeneralHelp Pin
sreejith ss nair18-Sep-05 21:31
membersreejith ss nair18-Sep-05 21:31 
GeneralRe: Help Pin
Geert van Horrik18-Sep-05 23:09
memberGeert van Horrik18-Sep-05 23:09 
GeneralRe: Help Pin
sreejith ss nair20-Sep-05 19:35
membersreejith ss nair20-Sep-05 19:35 
GeneralRe: Help Pin
sreejith ss nair20-Sep-05 19:35
membersreejith ss nair20-Sep-05 19:35 
GeneralMultilingual support for application Pin
geoyar25-Jun-05 12:29
membergeoyar25-Jun-05 12:29 
GeneralRe: Multilingual support for application Pin
StarlightNo127-Jun-05 8:36
memberStarlightNo127-Jun-05 8:36 
GeneralEasier way: few code changes and languge resource-only DLL. Pin
Herbert Yu20-Jul-05 10:22
memberHerbert Yu20-Jul-05 10:22 
GeneralGood work ! Pin
Ventruing21-Jun-05 7:09
memberVentruing21-Jun-05 7:09 
GeneralA what about menu ?! Pin
Fredy Pumpicka16-Jun-05 22:52
memberFredy Pumpicka16-Jun-05 22:52 
GeneralRe: A what about menu ?! Pin
disabledman19-Jul-05 20:27
memberdisabledman19-Jul-05 20:27 
GeneralAnother another approach Pin
EzioXia6-Jun-05 0:46
memberEzioXia6-Jun-05 0:46 
GeneralRe: Another another approach Pin
Geert van Horrik6-Jun-05 1:06
memberGeert van Horrik6-Jun-05 1:06 
GeneralRe: Another another approach Pin
Dimitris Vasiliadis13-Jun-05 23:25
memberDimitris Vasiliadis13-Jun-05 23:25 
GeneralRe: Another another approach Pin
Geert van Horrik13-Jun-05 20:33
memberGeert van Horrik13-Jun-05 20:33 
GeneralHere is "Another approach" Pin
Herbert Yu20-Jul-05 10:30
memberHerbert Yu20-Jul-05 10:30 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Cookies | Terms of Use | Mobile
Web01 | 2.8.190306.1 | Last Updated 7 Jun 2005
Article Copyright 2005 by Geert van Horrik
Everything else Copyright © CodeProject, 1999-2019
Layout: fixed | fluid