当我将语言切换为阿拉伯语时,通话记录页面不显示数据

when I switch language to Arabic, the call log page does not display data

在我的android项目中,当我切换语言为阿拉伯语时,通话记录页面不显示数据,但是当我切换为其他语言(如英语)时可以正常显示,如何解决, 请看以下资料

1.A callLog适配器部分代码如下:

 //显示归属地
        if (callLog.getBelong_area() != null && !callLog.getBelong_area().equals("")) {
            LogE.e("item","有归属地:"+callLog.getBelong_area());
            holder.belong_area.setVisibility(View.VISIBLE);
            holder.belong_area.setText(callLog.getBelong_area());
        } else {
            LogE.e("item","没有有归属地");
            holder.belong_area.setText("");
            holder.belong_area.setVisibility(View.GONE);
        }

2.It输入固定值后仍然不显示数据,例如:

holder.belong_area.setText("北京"); 

3.Print日志日志如下:

08-23 10:07:13.241 17494-17494/com.allinone.callerid E/item: 有归属地:北京 08-23 10:07:13.607 17494-17494/com.allinone.callerid E/item: 有归属地:Shijiazhuang, Hebei 08-23 10:07:13.674 17494-17494/com.allinone.callerid E/item: 有归属地:北京 08-23 10:07:13.714 17494-17494/com.allinone.callerid E/item: 有归属地:湖北省,武汉市

4.Runtime截图:

阿拉伯语(错误),

enter image description here

english language(right)

enter image description here

你的系统应该有合适的字符集。

您可以检查以下代码来检测语言的字符集。

public class CharsetDetectTest {

    public static void main(String[] args) {
        detectCharset("北京");
    }

    public static void detectCharset(String originalStr) {

        String[] charSet 
          = { "utf-8", "big5", "EUC-CN", "iso-8859-1", "gb2312" };

        for (int i = 0; i < charSet.length; i++) {
            for (int j = 0; j < charSet.length; j++) {
                try {
                    LogE.e("charaters",
                        "[" + charSet[i] + "==>" + charSet[j] + "] = "
                        + new String(originalStr.getBytes(charSet[i]), charSet[j]));
                } catch (UnsupportedEncodingException e) {
                    e.printStackTrace();
                }
            }
        }

    }
}

调试输出将是

[utf-8==>utf-8] = 北京
[utf-8==>big5] = ��鈭�
[utf-8==>EUC-CN] = ��浜�
[utf-8==>iso-8859-1] = å京
[utf-8==>gb2312] = ��浜�
[big5==>utf-8] = �_��
[big5==>big5] = 北京
[big5==>EUC-CN] = �_ㄊ
[big5==>iso-8859-1] = ¥_¨Ê
[big5==>gb2312] = �_ㄊ
[EUC-CN==>utf-8] = ����
[EUC-CN==>big5] = 控儔
[EUC-CN==>EUC-CN] = 北京
[EUC-CN==>iso-8859-1] = ±±¾©
[EUC-CN==>gb2312] = 北京
[iso-8859-1==>utf-8] = ??
[iso-8859-1==>big5] = ??
[iso-8859-1==>EUC-CN] = ??
[iso-8859-1==>iso-8859-1] = ??
[iso-8859-1==>gb2312] = ??
[gb2312==>utf-8] = ����
[gb2312==>big5] = 控儔
[gb2312==>EUC-CN] = 北京
[gb2312==>iso-8859-1] = ±±¾©
[gb2312==>gb2312] = 北京

然后,使用正确的字符集之一。

holder.belong_area.setText(new String("北京".getBytes("utf-8"), "utf-8")); 

holder.belong_area.setText(new String("北京".getBytes("utf-8")); 

您可以查看中文字符site

此致,