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

... 106  107  108  [109]  110  111  112  113  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11230정성태6/28/201718912제니퍼 .NET: 26. 제니퍼 닷넷 적용 사례 (6) - 잦은 Recycle 문제
11229정성태6/27/201720291오류 유형: 402. Windows Server Backup 관리 콘솔이 없어진 경우
11228정성태6/26/201717460개발 환경 구성: 320. Visual Basic .NET 프로젝트에서 내장 Manifest 자원을 EXE 파일로부터 제거하는 방법파일 다운로드1
11227정성태6/19/201725875개발 환경 구성: 319. windbg에서 python 스크립트 실행하는 방법 - pykd [6]
11226정성태6/19/201717014오류 유형: 401. Microsoft Edge를 실행했는데 입력 반응이 없는 경우
11225정성태6/19/201716245오류 유형: 400. Outlook - The required file ExSec32.dll cannot be found in your path. Install Microsoft Outlook again.
11224정성태6/13/201718744.NET Framework: 661. Json.NET의 DeserializeObject 수행 시 속성 이름을 동적으로 바꾸는 방법파일 다운로드1
11223정성태6/12/201717681개발 환경 구성: 318. WCF Service Application과 WCFTestClient.exe
11222정성태6/10/201721825오류 유형: 399. WCF - A property with the name 'UriTemplateMatchResults' already exists.파일 다운로드1
11221정성태6/10/201718869오류 유형: 398. Fakes - Assembly 'Jennifer5.Fakes' with identity '[...].Fakes, [...]' uses '[...]' which has a higher version than referenced assembly '[...]' with identity '[...]'
11220정성태6/10/201723691.NET Framework: 660. Shallow Copy와 Deep Copy [1]파일 다운로드2
11219정성태6/7/201718825.NET Framework: 659. 닷넷 - TypeForwardedFrom / TypeForwardedTo 특성의 사용법
11218정성태6/1/201721752개발 환경 구성: 317. Hyper-V 내의 VM에서 다시 Hyper-V를 설치: Nested Virtualization
11217정성태6/1/201717906오류 유형: 397. initerrlog: Could not open error log file 'C:\...\MSSQL12.MSSQLSERVER\MSSQL\Log\ERRORLOG'
11216정성태6/1/201719600오류 유형: 396. Activation context generation failed
11215정성태6/1/201721238오류 유형: 395. 관리 콘솔을 실행하면 "This app has been blocked for your protection" 오류 발생 [1]
11214정성태6/1/201718627오류 유형: 394. MSDTC 서비스 시작 시 -1073737712(0xC0001010) 오류와 함께 종료되는 문제 [1]
11213정성태5/26/201724005오류 유형: 393. TFS - The underlying connection was closed: Could not establish trust relationship for the SSL/TLS secure channel.
11212정성태5/26/201723270오류 유형: 392. Windows Server 2016에 KB4019472 업데이트가 실패하는 경우
11211정성태5/26/201722121오류 유형: 391. BeginInvoke에 전달한 람다 함수에 CS1660 에러가 발생하는 경우
11210정성태5/25/201722450기타: 65. ActiveX 없는 전자 메일에 사용된 "개인정보 보호를 위해 암호화된 보안메일"의 암호화 방법
11209정성태5/25/201770064Windows: 143. Windows 10의 Recovery 파티션을 삭제 및 새로 생성하는 방법 [16]
11208정성태5/25/201728830오류 유형: 390. diskpart의 set id 명령어에서 "The specified type is not in the correct format." 오류 발생
11207정성태5/24/201729674Windows: 142. Windows 10의 복구 콘솔로 부팅하는 방법
11206정성태5/24/201722886오류 유형: 389. DISM.exe - The specified image in the specified wim is already mounted for read/write access.
11205정성태5/24/201722621.NET Framework: 658. C#의 tail call 구현은? [1]
... 106  107  108  [109]  110  111  112  113  114  115  116  117  118  119  120  ...