Develop an Android App to support English and Arab

2019-06-15 09:32发布

I am developing an Android app to support both En/Ar. But I faced a problem that if the user changes from En to Ar the alignment of the user interface must turns from "left to right" to "right to left".

Example: (TextView)(EditText) this is in En

But in Ar it should be: (EditText)(TextView).

Is there a way to do this without creating two different layouts or two different versions?

4条回答
欢心
2楼-- · 2019-06-15 09:36

I've tried to take some of the horror out of this by creating a set of custom LabeledView components (for Form components such as CheckBox, EditText and Spinners). These views (such as LabledEditText) inflates a region-specific layout and implements the bare minimum of calls in order to act as a facade (EditText in this case).

res/layout/component_labeled_view.xml - [TextView][EditText]
res/layout-ar/component_labeled_view.xml - [EditText][TextView]

The View class itself contains:

public LabeledEditText(Context context, AttributeSet attrs) {
    super(context, attrs);  
    LayoutInflater inflator = LayoutInflater.from(context);

    mContainer      = inflator.inflate(R.layout.component_labeled_edittext, null);      
    mValueView      = (EditText) mContainer.findViewById(R.id.editText);
    mLabelTextView  = (TextView) mContainer.findViewById(R.id.textView);

    align(attrs);
}

public Editable getText() { 
    return ((EditText)mValueView).getText();
}

public void setText(String text) {  
    ((EditText)mValueView).setText(text);
}   

public void addTextChangedListener(TextWatcher watcher) {   
    ((EditText)mValueView).addTextChangedListener(watcher);
}

This should at least cut down any duplication as you should now be able to reference the LabeledEditText view rather than an TextView and EditText combo.

In my implementation which I haven't fully shown I've gone a step further and created an abstract LabeledView class which uses some custom attributes allowing me to customise both label and value in specific situations (see the align(attrs); line of code). Depending on how big your app is you might want to try something similar?

查看更多
啃猪蹄的小仙女
3楼-- · 2019-06-15 09:46

Why can't this be done with two layouts (you never said why this is not desireable)? As described by the Android Developers documentation

A large part of localizing an application is providing alternative text for different languages. In some cases you will also provide alternative graphics, sounds, layouts, and other locale-specific resources.

An application can specify many res// directories, each with different qualifiers. To create an alternative resource for a different locale, you use a qualifier that specifies a language or a language-region combination.

Ref: http://developer.android.com/guide/topics/resources/localization.html

So in your case create res/layout-ar then copy your existing layout into this folder and then simply swap them round. Simple, follows best practices and is easy to do. This also makes any further localisation changes easier going forward without having to write more code.

If you were to write code you are going to need to find the default language of the device and then swap the Views based on this. You can get the language by:

Locale.getDefault().getDisplayLanguage();

See this question for more detail: Get the current language in device

On a final personal note: I think the former is a much better separation of concerns, as the code provides logic and the XML layouts actually control the layout (with Android selecting the right resources automagically for you without having to write any more code).

查看更多
Lonely孤独者°
4楼-- · 2019-06-15 09:50

Why not just make the TextView above the EditText?

查看更多
Explosion°爆炸
5楼-- · 2019-06-15 09:55

Android 4.2 introduced native support for right to left layout.

  • In AndroidManifest set the android:supportsRtl="true"
  • In layout properties use the start/end properties instead of left/right.

Here is the video with detailed explanation: https://youtu.be/plW1qSGDSzs

查看更多
登录 后发表回答