한글과 특수문자를 구분할 수 있는 루틴 문제에요
글쓴이: shei77 / 작성시간: 금, 2008/12/05 - 1:22오후
궁금한 게 있습니다.
"가나다라마바12332432?!@#%$#"
이러한 데이터가 있잖아요
이걸 한글과 특수 문자나 숫자로 구분할 수 있는 방법이 있을까요?
Draw()하는 부분에서 모두 유니코드로 한글, 숫자, 특수문자까지 2byte로 되어져
버려서 이렇게 공백이 생깁니다.
가나다라마1234 (9자)
??2342!%$(공백) (9자)
??2342!%$(공백) (9자)
이렇게 만들고 싶네요
(글자수는 다르지만 길이는 똑같게)
가나다라마1234
??2342!%$??2
342!%$
Forums:
ksc5601 이라면...
ksc5601 이라면...
char buf[] = "가나다123@";
char *p = buf;
while( p )
{
if ( *p & 0x80 )
{
put2byte( *p )
p++;
}
else
{
put1byte( *p );
}
p++;
}
이렇게 하면 되지 않을까요...
ksc5601문자셋에서는 0x80 bit 가 체크되어 있으면 2바이트 문자입니다.
-------------------------------------------------------------------------
다시읽어보니.... UNICODE네요..
코드값이 0x0000 ~ 0x007F 까지 반각문자로 보면 되지 않을까요..
감사합니다.
감사합니다. ^^
-----------------------------
기술은 기술, 그것이 전부는 아니다.
----------------------------------------------------------
It's feasible to make an inspiration on your own.
C99 의 iswdigit() 등을
C99 의 iswdigit() 등을 역이용하면 되겠는데요.
한글이나 영문이나 똑같이 한글자로 취급하시는거보니 이미 wide caracter 사용하시는 거 같은데.
OTL
좀 다르지만 되었네요.
좀 다르지만 되었네요.
MCHAR pTempChar[TOTALSIZE] = {0};
do
for(i=0 ;i {
pTempChar[i] = 총 문자열 배열[i];
현재 폰트 한자의 width 구하기;
}
while(현폰트 한자의 width
drawText(pointer, w, h, pTempChar);
대충 이런식으로 해서 해결이 되었네요.
한 글자의 폰트 사이즈로 수정했습니다.
-----------------------------
기술은 기술, 그것이 전부는 아니다.
----------------------------------------------------------
It's feasible to make an inspiration on your own.
댓글 달기