UI mirroring overview
The main difference between left-to-right (LTR) and right-to-left (RTL) language scripts is the direction in which content is displayed:
- LTR languages display content from left to right
- RTL languages display content from right to left
RTL content also affects the direction in which some icons and images are displayed, particularly those depicting a sequence of events.
In general, the passage of time is depicted as left to right for LTR languages, and right to left for RTL languages.
Element | LTR | RTL |
Text | Sentences are read from left to right. | Sentences are read from right to left. |
Timeline | An illustrated sequence of events progresses left to right. | An illustrated sequence of events progresses right to left. |
Imagery | An arrow pointing left to right indicates forward motion: → | An arrow pointing right to left indicates forward motion: ← |
The passage of time is depicted from left to right for LTR languages, and from right to left for RTL languages.
When a UI is changed from LTR to RTL (or vice-versa), it’s often called mirroring. An RTL layout is the mirror image of an LTR layout, and it affects layout, text, and graphics.
When a UI changes from one direction to another, these items are not mirrored:
- Numbers
- Untranslated text (even if it’s part of a phrase)
Text should always be in the correct direction for the language it’s in. For example, any LTR words, such as a URL, will continue to be shown in an LTR format, even if the rest of the UI is in RTL.
data:image/s3,"s3://crabby-images/f9d20/f9d20d4748858f1f0d505011763c97ffc29531bc" alt="Material Design: Text and numbers in correct direction"
Do.
Text and numbers should always be in the correct direction for the language.
data:image/s3,"s3://crabby-images/81b1f/81b1fd5b013508094c4ae662237416f4edfd53e8" alt="Material Design: LTR text should not be reversed"
Don’t.
LTR text shouldn’t be displayed in reverse order.
When a UI is mirrored, these changes occur:
- Text fields icons are displayed on the opposite side of a field
- Navigation buttons are displayed in reverse order
- Icons that communicate direction, like arrows, are mirrored
- Text (if it is translated to an RTL language) is aligned to the right
These items are not mirrored:
- Icons that do not communicate direction, such as a camera
- Numbers, such as the clock and phone numbers
- Charts and graphs
data:image/s3,"s3://crabby-images/7d908/7d9088ad958d3315bb023825639b338da534b316" alt="Material Design English UI in LTR"
An English UI in LTR
data:image/s3,"s3://crabby-images/9ba04/9ba04c0e33f5d70c59ced4aded7b96642875888a" alt="Arabic UI in RTL, numbers in LTR, Material Design"
An Arabic UI in RTL, with numbers presented in LTR
data:image/s3,"s3://crabby-images/141a1/141a1d11617f09502b9a7a0c05b18ef15df987f5" alt="Text editing menu in Material Design (LTR)"
Text editing menu in LTR
data:image/s3,"s3://crabby-images/678e6/678e607c5be97a3a19255b97d540fbbf62170f8b" alt="RTL text editing menu - Material Design"
Text editing menu in RTL
1. Icons related to bidirectionality are mirrored to reflect the start and end of a line of text
data:image/s3,"s3://crabby-images/2b4fc/2b4fc7a0caad96ba50c535fd7050b117db41ca8e" alt="LTR screen in Material Design"
LTR screen
On an LTR screen, the tab for “Item One” is aligned to the left, and users swipe to the left to see more tabs.
Touch target height: 48dp
Screen edge margin before first tab: 72dp
Tab labels bottom padding: 20dp
Tab labels right and left padding: 12dp
data:image/s3,"s3://crabby-images/fa133/fa133f2e42833718177333cf9770e1e0ce83851d" alt="RTL screen in Material Design"
RTL screen
On an RTL screen, the tab for “Item One” is aligned to the right, and users swipe to the right to see more tabs.
Touch target height: 48dp
Screen edge margin before first tab: 72dp
Tab labels bottom padding: 20dp
Tab labels right and left padding: 12dp
data:image/s3,"s3://crabby-images/f0d88/f0d8846c9ab3e1b2e8ad340ddc0474a5ceb72b60" alt="LTR screen in Material Design"
LTR screen
data:image/s3,"s3://crabby-images/6c3ec/6c3ec4d78b2f43e3d86d6ca581eab96f60e25fd0" alt="RTL screen in Material Design"
RTL screen
Title, icons, and UI elements are displayed flowing from right to left
1. Back button points to the right
2. Text is right-aligned
3. Primary and secondary buttons are mirrored to match reading direction
4. Checkbox appears to the right of text
5. Icons that do not communicate direction are not changed
6. Placement of units may vary across languages
7. Progress bars fill in the same direction as content is read
data:image/s3,"s3://crabby-images/2d692/2d692391e3f5298dde96fe12bfd60cec94b1bb99" alt="LTR screen in Material Design"
LTR
Navigation, overflow menu, and icons displayed left-to-right
Icon padding from screen edge: 16dp
Title distance from screen edge: 72dp
Padding below title: 20dp
Navigation bar height: 56dp
Overflow menu padding: 16dp
data:image/s3,"s3://crabby-images/5f169/5f169a9cffbb3ed34256ae906297ceb55100d3ba" alt="RTL screen in Material Design"
RTL
Navigation, overflow menu, and icons switch sides in the RTL layout
Icon padding from screen edge: 16dp
Title distance from screen edge: 72dp
Padding below title: 20dp
Navigation bar height: 56dp
Overflow menu padding: 16dp
data:image/s3,"s3://crabby-images/b3afc/b3afce773d3fce49bb2eafa71c7d6566838fb42f" alt="LTR screen in Material Design"
LTR
Padding and margin around icons and text for LTR
List item height: 72dp
Icon margin from left screen edge: 16dp
List item distance from left screen edge: 72dp
data:image/s3,"s3://crabby-images/e0a0a/e0a0a2a86be9a78e15cda8071cd3485b1cbac6a0" alt="RTL screen in Material Design"
RTL
When mirroring the layout, padding and margin around icons and text also switch placement to match RTL layouts.
List item height: 72dp
Icon margin from right screen edge: 16dp
List item distance from right screen edge: 72dp