안녕하세요.
editText에 입력한 문자를 구분해서 각기 다른 작업을 하려고 합니다.
안드로이드에서 string은 유니코드 형식으로 인식된다고해서 해당 문자를
유니코드 범위로 구분 한 후, if문으로 나누어 작업하려고 하는데요..
구글링 참조해서 유니코드 범위 중에서 한글 범위는 아래와 같이 지정했습니다.
((c >= '\uAC00' && c <= '\uD7AF')
|| (c >= '\u1100' && c <= '\u11FF')
|| (c >= '\u3130' && c <= '\u318F'))
문제는..일본어 인데요,
가타카나 히라가나도 한글처럼 범위가 지정되어있어서 저런 식으로 구현을 했는데..
[3040~309F
30A0~30FF
31F0~31FF]
한글은 변환할 때 ksc5601을 사용했고, 일본어는 변형할 때 shift jis를 사용했습니다.
히라가나/가타카나/한자를 사용할 때 shift jis를 사용 여부에따라 다음과 같은 현상이 발생합니다.
1.shift jis를 사용하지 않을 시
-일본식 한자 깨짐. [공통으로 사용하는 한자는 안깨지는 것 같습니다.]
-히라가나 가타카나는 정상출력됩니다.
2.shift jis를 사용했을 시
-일본식한자 및 모든 한자 정상 출력됩니다.
-히라가나 가타카나 깨집니다.
이런 경우, 한자를 사용할 때만 shift jis를 사용해야 하는건지 궁금합니다..ㅠㅠ..