Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

Visual Studio - 영문 폰트가 Fullwidth Latin Character로 바뀌는 문제

얼마 전부터 비주얼 스튜디오를 사용할 때마다 자꾸만 영문 폰트가 이상해지는 현상이 발생했습니다. 뭐랄까, 일반 글씨체는 아니고, 약간 넓은 글씨체라고 해야 할까요,,, 설명이 어려우니 ^^ 아래의 그림으로 실어봤습니다.

vs_font_cs1056_1.png

첫 번째 라인은 정상 텍스트인 반면, 두 번째 라인은 영문만 폰트가 뭔가 이상합니다. 그래서 (당연하겠지만) 컴파일을 하면 "Error CS1056 Unexpected character '...'"가 발생하게 됩니다.

비주얼 스튜디오를 종료하고 다시 시작하면 폰트가 정상적으로 돌아왔기 때문에 그냥 무시하고 있다가... 자꾸 저런 현상이 발생해서 ^^; 원인을 분석해 봤습니다.

우선, 비정상 텍스트와 정상 텍스트가 포함된 텍스트 파일을 만들고,

client
client

저장한 다음 hexa 값을 봤더니 이렇게 나옵니다.

EF BB BF // Byte order mark

c        l        i        e        n        t
63       6C       69       65       6E       74

c       l       i       e       n       t
EF BD 83 EF BD 8C EF BD 89 EF BD 85 EF BD 8E EF BD 94

'c' 글자 하나가 "EF BD 83" 3바이트로 이뤄지고 있습니다. 0xefbd83을 유니코드로 검색하면,

Unicode Character 'FULLWIDTH LATIN SMALL LETTER C' (U+FF43)
; https://www.fileformat.info/info/unicode/char/ff43/index.htm

위의 글자가 UTF-8 인코딩된 것이었습니다. 이 정보를 바탕으로 다시 검색해 보니 Visual Studio Code에서도 유사한 현상이 있었다고 합니다.

How to switch between fullwidth and halfwidth in Visual Studio Code?
; https://stackoverflow.com/questions/72759250/how-to-switch-between-fullwidth-and-halfwidth-in-visual-studio-code

그런데... 답이 없군요. ^^; 그러다 작업 표시줄의 IME 창에 눈길이 갔습니다. 오호... "Character width (Full)" 설정이 돼 있는 것입니다.

vs_font_cs1056_2.png

이 값을 "Half-width"로 바꾸면 정상적으로 ASCII 폰트로 돌아옵니다.




그나저나 이상하군요, 왜 자꾸 갑자기 저 폰트로 바뀌는 걸까요? 분명히 저는 마우스로 저 메뉴를 직접 바꾼 적이 없습니다. 검색해 보면, 이에 대한 단축키로 Shift + Space가 설정돼 있다고 하는데 제 컴퓨터에서 해보면 해당 키 조합이 먹히지 않습니다. (그냥 스페이스가 입력됩니다.)

그러니까, 설령 우연이라도 저 키 조합을 눌렀다고 해도 Fullwidth/Halfwidth 설정이 토글되었을 것 같지는 않습니다. 이에 대한 단축키를 찾아보면,

Simplified Chinese MSPY 3.0 IME Hot Key Registry Settings (Windows CE 5.0)
; https://learn.microsoft.com/en-us/previous-versions/windows/embedded/ms904626(v=msdn.10)

"HKEY_CURRENT_USER\Control Panel\Input Method\Hot Keys\00000011" 레지스트리 키 경로가 그에 대한 단축키라고 합니다. 제 컴퓨터 설정을 보면,

Key Modifiers: 04 C0 00 00
Target IME: 00 00 00 00
Virtual Key: 20 00 00 00

// Registry: HKEY_CURRENT_USER\Control Panel\Input Method\Hot Keys
// https://renenyffenegger.ch/notes/Windows/registry/tree/HKEY_CURRENT_USER/Control-Panel/Input-Method/Hot-Keys/index

// Target IME: 00 00 00 00 for all languages(?) 

// Key modifiers
// 01: Left alt
// 02: control
// 04: shift (MOD_SHIFT)

04가 Shift 키에 해당하고 Virtual Key 20은 Space 키가 맞습니다. 단지, Key Modifiers에 "C0"이 있어서 그런지 어쨌든 Shift + Space 키는 Fullwidth/Halfwidth에 대한 토글키로는 동작하지 않습니다.

일단... 오늘은 여기까지만! ^^




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 2/20/2024]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 



2025-05-08 01시39분
전각(Full-width)/반각(Half-width) 기능을 토글하는 키가 Alt + "=" 키입니다. 네이버 블로그 글에 vactorman("https://blog.naver.com/vactorman") 님이 덧글을 달아주셨군요. ^^

https://blog.naver.com/techshare/223016961489

재미있는 건 해당 토글이 항상 동작하는 것은 아니고, 조건이 있는 것 같은데요, 가령 다음과 같이 하면 재현이 안 됩니다.

1. "메모장"을 실행.
2. '영문' 타이핑 테스트를 해보면 Alt + "=" 키를 눌러도 전각/반각 전환이 안 됨.

대신, "한/영" 전환을 한 번이라도 해주면 재현이 됩니다.

1. "메모장"을 실행.
2. '한/영' 변환키를 한 번 누르면 "한글" 입력 상태로 전환.
3. Alt + "=" 키를 누르면 '전각' 입력으로 전환, Space 키를 눌러 보면 이전과 다르게 넓게 타이핑이 됨.
4. (현재는 한글 입력 상태이므로) 한글 글자로는 '전각' 차이가 안 나는데, '한/영' 변환키를 한 번 더 눌러 "영문" 입력 상태로 전환 후 타이핑을 하면 확실하게 '전각' 타이핑이 되는 것을 볼 수 있음.

저렇게 일단 '한/영' 변환키가 한 번이라도 눌린 적이 있어야, 해당 응용 프로그램 인스턴스에 한해 Alt + "=" 키로 전각/반각 토글이 가능합니다. (즉, 다시 실행하면 '한/영' 변환키를 입력한 적이 없는 경우 Alt + "=" 키는 동작하지 않습니다.)
정성태

1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13779정성태10/22/20245607개발 환경 구성: 729. WSL 2 - Mariner VM 커널 이미지 업데이트 방법
13778정성태10/21/20247129C/C++: 181. C/C++ - 소스코드 파일의 인코딩, 바이너리 모듈 상태의 인코딩
13777정성태10/20/20245558Windows: 265. Win32 API의 W(유니코드) 버전은 UCS-2일까요? UTF-16 인코딩일까요?
13776정성태10/19/20246598C/C++: 180. C++ - 고수준 FILE I/O 함수에서의 Unicode stream 모드(_O_WTEXT, _O_U16TEXT, _O_U8TEXT)파일 다운로드1
13775정성태10/19/20246620개발 환경 구성: 728. 윈도우 환경의 개발자를 위한 UTF-8 환경 설정
13774정성태10/18/20246183Linux: 91. Container 환경에서 출력하는 eBPF bpf_get_current_pid_tgid의 pid가 존재하지 않는 이유
13773정성태10/18/20245974Linux: 90. pid 네임스페이스 구성으로 본 WSL 2 + docker-desktop
13772정성태10/17/20246202Linux: 89. pid 네임스페이스 구성으로 본 WSL 2 배포본의 계층 관계
13771정성태10/17/20245940Linux: 88. WSL 2 리눅스 배포본 내에서의 pid 네임스페이스 구성
13770정성태10/17/20246407Linux: 87. ps + grep 조합에서 grep 명령어를 사용한 프로세스를 출력에서 제거하는 방법
13769정성태10/15/20247519Linux: 86. Golang + bpf2go를 사용한 eBPF 기본 예제파일 다운로드1
13768정성태10/15/20246791C/C++: 179. C++ - _O_WTEXT, _O_U16TEXT, _O_U8TEXT의 Unicode stream 모드파일 다운로드2
13767정성태10/14/20245711오류 유형: 929. bpftrace 수행 시 "ERROR: Could not resolve symbol: /proc/self/exe:BEGIN_trigger"
13766정성태10/14/20245179C/C++: 178. C++ - 파일에 대한 Text 모드의 "translated" 동작파일 다운로드1
13765정성태10/12/20246444오류 유형: 928. go build 시 "package maps is not in GOROOT" 오류
13764정성태10/11/20247035Linux: 85. Ubuntu - 원하는 golang 버전 설치
13763정성태10/11/20245927Linux: 84. WSL / Ubuntu 20.04 - bpftool 설치
13762정성태10/11/20246107Linux: 83. WSL / Ubuntu 22.04 - bpftool 설치
13761정성태10/11/20245801오류 유형: 927. WSL / Ubuntu - /usr/include/linux/types.h:5:10: fatal error: 'asm/types.h' file not found
13760정성태10/11/20246944Linux: 82. Ubuntu - clang 최신(stable) 버전 설치
13759정성태10/10/20247955C/C++: 177. C++ - 자유 함수(free function) 및 주소 지정 가능한 함수(addressable function) [6]
13758정성태10/8/20246635오류 유형: 926. dotnet tools를 sudo로 실행하는 경우 command not found
13757정성태10/8/20246945닷넷: 2306. Linux - dotnet tool의 설치 디렉터리가 PATH 환경변수에 자동 등록이 되는 이유
13756정성태10/8/20247136오류 유형: 925. ssh로 docker 접근을 할 때 "... malformed HTTP status code ..." 오류 발생
13755정성태10/7/20247687닷넷: 2305. C# 13 - (9) 메서드 바인딩의 우선순위를 지정하는 OverloadResolutionPriority 특성 도입 (Overload resolution priority)파일 다운로드1
13754정성태10/4/20246781닷넷: 2304. C# 13 - (8) 부분 메서드 정의를 속성 및 인덱서에도 확대파일 다운로드1
1  2  3  4  5  6  7  [8]  9  10  11  12  13  14  15  ...