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 + "=" 키는 동작하지 않습니다.)
정성태

... 46  47  48  49  50  51  52  53  54  55  56  [57]  58  59  60  ...
NoWriterDateCnt.TitleFile(s)
12546정성태3/3/202118475개발 환경 구성: 545. github workflow/actions에서 빌드시 snk 파일 다루는 방법 - Encrypted secrets
12545정성태3/2/202121228.NET Framework: 1026. 닷넷 5에 추가된 POH (Pinned Object Heap) [10]
12544정성태2/26/202121593.NET Framework: 1025. C# - Control의 Invalidate, Update, Refresh 차이점 [2]
12543정성태2/26/202119254VS.NET IDE: 158. C# - 디자인 타임(design-time)과 런타임(runtime)의 코드 실행 구분
12542정성태2/20/202120909개발 환경 구성: 544. github repo의 Release 활성화 및 Actions를 이용한 자동화 방법 [1]
12541정성태2/18/202118440개발 환경 구성: 543. 애저듣보잡 - Github Workflow/Actions 소개
12540정성태2/17/202119874.NET Framework: 1024. C# - Win32 API에 대한 P/Invoke를 대신하는 Microsoft.Windows.CsWin32 패키지
12539정성태2/16/202119671Windows: 189. WM_TIMER의 동작 방식 개요파일 다운로드1
12538정성태2/15/202120222.NET Framework: 1023. C# - GC 힙이 아닌 Native 힙에 인스턴스 생성 - 0SuperComicLib.LowLevel 라이브러리 소개 [2]
12537정성태2/11/202120274.NET Framework: 1022. UI 요소의 접근은 반드시 그 UI를 만든 스레드에서! - 두 번째 이야기 [2]
12536정성태2/9/202119362개발 환경 구성: 542. BDP(Bandwidth-delay product)와 TCP Receive Window
12535정성태2/9/202118460개발 환경 구성: 541. Wireshark로 확인하는 LSO(Large Send Offload), RSC(Receive Segment Coalescing) 옵션
12534정성태2/8/202119192개발 환경 구성: 540. Wireshark + C/C++로 확인하는 TCP 연결에서의 closesocket 동작 [1]파일 다운로드1
12533정성태2/8/202117677개발 환경 구성: 539. Wireshark + C/C++로 확인하는 TCP 연결에서의 shutdown 동작파일 다운로드1
12532정성태2/6/202119469개발 환경 구성: 538. Wireshark + C#으로 확인하는 ReceiveBufferSize(SO_RCVBUF), SendBufferSize(SO_SNDBUF) [3]
12531정성태2/5/202117976개발 환경 구성: 537. Wireshark + C#으로 확인하는 PSH flag와 Nagle 알고리듬파일 다운로드1
12530정성태2/4/202121410개발 환경 구성: 536. Wireshark + C#으로 확인하는 TCP 통신의 Receive Window
12529정성태2/4/202119910개발 환경 구성: 535. Wireshark + C#으로 확인하는 TCP 통신의 MIN RTO [1]
12528정성태2/1/202119705개발 환경 구성: 534. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 윈도우 환경
12527정성태2/1/202119698개발 환경 구성: 533. Wireshark + C#으로 확인하는 TCP 통신의 MSS(Maximum Segment Size) - 리눅스 환경파일 다운로드1
12526정성태2/1/202116425개발 환경 구성: 532. Azure Devops의 파이프라인 빌드 시 snk 파일 다루는 방법 - Secure file
12525정성태2/1/202115287개발 환경 구성: 531. Azure Devops - 파이프라인 실행 시 빌드 이벤트를 생략하는 방법
12524정성태1/31/202115817개발 환경 구성: 530. 기존 github 프로젝트를 Azure Devops의 빌드 Pipeline에 연결하는 방법 [1]
12523정성태1/31/202117693개발 환경 구성: 529. 기존 github 프로젝트를 Azure Devops의 Board에 연결하는 방법
12522정성태1/31/202119907개발 환경 구성: 528. 오라클 클라우드의 리눅스 VM - 9000 MTU Jumbo Frame 테스트
12521정성태1/31/202118203개발 환경 구성: 527. 이더넷(Ethernet) 환경의 TCP 통신에서 MSS(Maximum Segment Size) 확인 [1]
... 46  47  48  49  50  51  52  53  54  55  56  [57]  58  59  60  ...