I wanted to start something that is related to 3D perspective with Sketch today but somehow I got interested in App Internationalization while watching a little WWDC video. So I decided to build a simple multi-lingo app to test some ideas.
I was excited about the possibilities of the app functions and got really excited. But I am also fully aware of my skills and knowledge level.
Thoughts
- The App will not be complicated but enough to demonstrate the fundamentals of internationalization
- Greetings in different languages should be fun
- Maybe some audio greeting as well
- There are many others things that I can do, but this is literally my first mini App with Swift. I should just focus on the core value of my project today which is to learn iOS internationalization basics
Objective
- Learn internationalization of Interface strings, programmatically generated strings, image assets, audio files
- Learn how to handle translation files
- Learn Sketch export to speed up development
- Preview and debug in translated languages
- How to process right-to-left language
Steps
- A simple design in Sketch
- Setup Github
- Layout Storyboard, put together the basic App in English
- Add localized strings
- Process the translation file. Personally I found Brightec.com quite useful and handy. But with this project, it’s not necessary. All strings can be easily added via Xcode.
- Add localized images. Use the “Localized String” approach to localize images. (The asset image does not support localization so well).
- Programmatically switch language and region. First I thought it was too much trouble. Normally users can do it from the system setting. Later I found a solution in Stackoverflow.com which is to get files from the respective language folders.
- Add localized audio files
- Refine Autolayout to support multiple devices
- Other use of NSLocalizedString & best practice — > check next time
data:image/s3,"s3://crabby-images/a1d63/a1d6357a885ac5363ea06b9d0aa20b72593baff5" alt="sketch design (quite different from the final result )"
data:image/s3,"s3://crabby-images/f0779/f0779d2ee93fbaee64b4623a77806ce9e1f2b8ed" alt="how nice sketch support folder export"
data:image/s3,"s3://crabby-images/a09cd/a09cd0bf503ad3d906364acc064d8c4050078c82" alt="Xcode manages image assets very nicely"
data:image/s3,"s3://crabby-images/7dd7d/7dd7ddc7bb89ae6c3645c430b71cc3e1136293c4" alt="first version in english"
data:image/s3,"s3://crabby-images/32340/3234086ea7057c24636a9e41bd45791bd03b3036" alt="my headache in landscape view"
data:image/s3,"s3://crabby-images/2a674/2a674203f45723e64df3edc39de97d6c1d5b1ade" alt="autolayout and constrains"
data:image/s3,"s3://crabby-images/2256f/2256fc8a3723cd5aa907440b8ad909b721ae2fdb" alt="App in my mother tongue"
data:image/s3,"s3://crabby-images/61bbe/61bbe0361c3c8d6a46cc3d4d505bc13d1a6dc6f8" alt="second version with multi-lingo support"
Lesson Learned
- Autolayout is such a headache and I spent a lot of time adjusting different devices, landscape and portrait. I had to give up landscape option at the end. I can shift locations, but simply too much to manage the compact height. Next time if the project is easy, perhaps I can quietly sit down and adjust one by one.
- Sketch made the export process like an easy breeze.
- Somehow Xcode can not located the m4a file that I recorded with Quicktime player. Mp3 files are ok. Later I learned that m4a files don’t get automatically copied to Build Resources. Need to add manually.
- In Xcode 6, you can actually export and import XLIFF (https://en.wikipedia.org/wiki/XLIFF) files
Nice-to-have functions for the future version:
- Add right-to-left support // good to have with more complicated layout.
- Show progress when playing the audio
- Add an audio database with different audio samples.
- Users can listen to a group of audio samples in one language
- Allow users randomly submit language audios
Bug needs fix:
- Showing nil when adding additional ViewControllers.
Further Reading
- Internationalization and localization of Apps in Xcode 6 and Swift http://rshankar.com/internationalization-and-localization-of-apps-in-xcode-6-and-swift/
- How to record audio files in Mac: http://www.mactip.net/how-to-record-sound-on-a-mac/