0
点赞
收藏
分享

微信扫一扫

android 部分韩国手机采用KSC5601编码保存联系人,MTK平台手机无法显示联系人姓名


按照spec的明确规定,SIM卡上姓名采用的编码方式应该是gsm8 ucs80 81 82这些。
而韩国部分手机(如较早的功能机器以及galaxy S等)采用的却是KSC5601编码,在spec支持之外。
 
现在MTK的design则是遵守spec的:
1.在modem层判断到编码方式不在spec之列后,不去上报数据给APP(这就导致了姓名栏位显示为空)
2.spec范围内的编码数据则在解码转化为utf16,用于显示
 
因此本问题是对比机没有按照spec来做导致的,下面的解决方案是一种的work around的方法:
将不在spec之内的编码方式均按照KSC5601来解码
 
 

1.modem\l4\phb\src\phb_utils.c



else if (raw_data[offset] > CODING_UCS2_82) //添加此if语句

{

kal_uint8 ch1;

kal_uint8 ch2;

decoded_str->charset = CHARSET_UCS2;

if (raw_data_len % 2 == 0)

{

raw_data_len--;

}

for (count = 2; offset < raw_data_len;)

{

/* Exceeds capacity, truncate */

if ((count-1) >= decoded_str->length)

{

break;

}

ch1 = raw_data[offset++];

ch2 = raw_data[offset++];

if (ch1 == 0xFF && ch2 == 0xFF)

{

break;

}

decoded_str->data[count++] = ch1;

decoded_str->data[count++] = ch2;

}

decoded_str->data[0] = 0xFE;

decoded_str->data[1] = 0XFE;

}

else

{

return 0;

}

2. IccProvider.java (frameworks\base\core\telephony\...)


A,引入如下包:  import java.io.UnsupportedEncodingException;
B, 
loadRecord函数,在如下语句:

contact[0] = index;

contact[1] = alphaTag;

contact[2] = number;


之后添加以下语句:

if(alphaTag.length() >= 2  &&  alphaTag.charAt(0) == '\uFEFE'){

String strKSC = "";

try{

byte[] inData = alphaTag.substring(1).getBytes("utf-16be");

strKSC = new String(inData ,"KSC5601");

} catch (UnsupportedEncodingException ex) {

Log.e(TAG,"implausible UnsupportedEncodingException", ex);

}

contact[1] = strKSC;

Log.i(TAG,"decode using KSC5601");



}

举报

相关推荐

0 条评论