Microsoft MVP성태의 닷넷 이야기
Windows: 97. cmd.exe 창에서 사용할 폰트를 추가하는 방법 [링크 복사], [링크+제목 복사],
조회: 31117
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 
(연관된 글이 2개 있습니다.)

cmd.exe 창에서 사용할 폰트를 추가하는 방법

cmd.exe 창에서 사용할 수 있는 폰트는 아래의 글에서 설명했던 제어판의 시스템 로케일 값에 따라 다릅니다.

개발자 PC 환경 - 유니코드(Unicode)를 위한 설정
; https://www.sysnet.pe.kr/2/0/762

윈도우 8.1에서는 "제어판" / "국가 또는 지역(Region)"으로 선택할 수 있는데, "관리자 옵션(Administrative)" 탭의 "유니코드를 지원하지 않는 프로그램용 언어(Language for non-Unicode programs)"를 "한국어(Korean)"로 설정하는 것과 영어(English)로 설정하는 것에 따라 다음과 같이 기본 폰트 제공이 다릅니다.

font_in_console_1.png

시스템 로케일이 영문인 경우:
- Lucida Console
- Consolas 
- Raster Fonts

시스템 로케일이 한글인 경우:
- Raster Fonts
- 굴림체

위의 그림에서 왼쪽은 시스템 로케일 언어가 영문인 경우의 cmd.exe 속성창을 본 것입니다. 보시는 바와 같이 한글이 없습니다. 하지만 시스템 로케일 언어가 한글인 경우의 오른쪽 그림은 "굴림체" 폰트가 등록되어 있습니다. 이는 윈도우 자체를 영문 윈도우로 설치했느냐, 한글 윈도우로 설치했느냐와 무관합니다. 즉, 영문 윈도우를 설치했어도 시스템 로케일 값을 한글로 바꾸면 콘솔(cmd.exe) 창에서 한글 입력 및 출력이 가능합니다.

콘솔(cmd.exe) 창에서 사용할 수 있는 폰트는 레지스트리에 등록되어 있기 때문에 다음과 같이 확인할 수 있습니다.

font_in_console_2.png

경로: HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Console\TrueTypeFont

기본값 목록

0: Lucida Console
00: Consolas
932: *MS ゴシック
936: *新宋?
949: *굴림체
950: *細明體

확실한 내부 동작은 알 수 없지만 영문과 한글의 경우 폰트가 다르게 보이는 것은 코드 페이지와 연관이 있는 것 같습니다. 가령, chcp 명령어로 해당 콘솔 창의 코드 페이지를 확인할 수 있는데요.

시스템 로케일 == 영문인 경우)

c:\temp>chcp
Active code page: 437

시스템 로케일 == 한글인 경우) 

c:\temp>chcp
Active code page: 949

시스템 로케일이 한글인 경우 기본 코드 페이지가 949이고, 이는 레지스트리에 등록된 "949: *굴림체" 항목과 무관하지는 않을 것 같습니다. (더 이상의 자세한 설명은 관련된 자료를 찾지 못해서 할 수가 없군요. ^^)

그렇다면 혹시 시스템 로케일이 영문인 경우 코드 페이지만 변경해서 한글 폰트를 사용할 수 있도록 만들 수 있지 않을까요? 직접 해보면 알 수 있지만 아쉽게도 cmd.exe 창의 특별한 설계 탓인지 949 코드 페이지 변경은 실패합니다. 그 외에 유니코드 코드 페이지인 Little Endian 용 1200과 Big Endian 용 1201로의 전환도 실패합니다.

시스템 로케일 == 영문인 경우)

C:\temp>chcp 949
Invalid code page

C:\temp>chcp 1200
Invalid code page

C:\temp>chcp 1201
Invalid code page

유니 코드 용으로 허용되는 것은 UTF-8 코드 페이지인 65001입니다.

C:\temp>chcp 65001
Active code page: 65001

재미있는 것은 이렇게 바꾸고 dir 같은 명령어를 치면 다음과 같은 식으로 오류가 발생합니다.

C:\temp>dir
 Volume in drive C has no label.
 Volume Serial Number is 8A2C-9CD0

 Directory of C:\temp

The system cannot write to the specified device.

저 오류 메시지를 본 기억이 나는군요. ^^

cmd.exe - The system cannot write to the specified device.
; https://www.sysnet.pe.kr/2/0/1277

위의 글에서 설명했던 대로 "dir > con"과 같은 식으로 출력을 redirect시키면 실행 결과가 보입니다. ^^




글의 주제로 돌아와서, cmd.exe 창에서 사용할 폰트를 추가하는 것이 가능합니다. 하지만 이것이 녹록치 않은데, 마이크로소프트의 엄격한 기준을 통과해야 하기 때문입니다.

Necessary criteria for fonts to be available in a command window
; http://support.microsoft.com/kb/247815/en-us

- The font must be a fixed-pitch font.
- The font cannot be an italic font.
- The font cannot have a negative A or C space.
- If it is a TrueType font, it must be FF_MODERN.
- If it is not a TrueType font, it must be OEM_CHARSET.

저야 폰트 전문가가 아니기 때문에 위의 내용을 자세하게 이해하지는 못하겠지만 (또한 저 기준으로 만족하는 폰트인지 어떻게 확인할 수 있는지도 모르지만) 어쨌든 '고정 폭' 폰트여야 한다는 것이 기본 전제입니다. 이를 "monospaced font"라고도 말하는 것 같은데, 다음의 폰트 관련 사이트에서 이 기준을 만족하는 폰트를 찾아볼 수 있습니다.

FONTSPACE
; http://www.fontspace.com/
; http://www.fontspace.com/search/?q=monospace

FONT ex
; http://www.fontex.org/
; http://www.fontex.org/monospaced-fonts.html

FONTS2U
; http://www.fonts2u.com
; http://www.fonts2u.com/category.html?id=17

위의 사이트에 등록된 모든 monospaced font들을 테스트 해본 것은 아니지만 "Necessary criteria for fonts to be available in a command window"의 엄격한 규칙 때문에 "monospaced font"라고 해서 모두 cmd.exe 창에서 등록되는 것은 아닐 것 같습니다. 어쨌든 요행을 바라고 ^^ 한번 등록해 보는 식으로 사용하는 수밖에 없습니다.

예를 들어, 제가 해보니까 다음의 폰트들이 등록 가능했습니다. (물론, 더 있겠지만!)

White Rabbit font
; http://www.dafont.com/white-rabbit.font

DejaVuSansMono.ttf
; http://dejavu-fonts.org/wiki/Main_Page

Free UCS Outline Fonts (FreeMono)
; http://savannah.gnu.org/projects/freefont/

등록 방법은 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Console\TrueTypeFont 경로에 다음과 같이 간단하게 "0"을 이어붙이는 방식으로 등록하고 재부팅을 해야 합니다. 그럼 cmd.exe 속성 창에서 다음과 같이 등록된 폰트들을 선택할 수 있습니다.

font_in_console_3.png

그런데, 폰트 이름은 어디서 구하는 걸까요? 역시 레지스트리의 "HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Fonts" 경로에 가면 시스템에 등록된 폰트 목록이 나오고 그중에서 "Name" 영역에 해당하는 것 중 괄호를 제외한 영역을 이름으로 사용하면 됩니다.

font_in_console_4.png




참고로, 폰트 폴더에 대해 다음의 명령을 실행하면 특수 폴더의 뷰가 아닌 일반 파일 뷰로 볼 수 있습니다.

attrib -r -s c:\Windows\Fonts

또한 폰트 파일을 구해서 설치하는 중에 실수로 윈도우 탐색기에서 제공하는 암호화된 상태의 TTF 파일을 더블 클릭한 후 "Install" 버튼을 눌러 설치했는데 해당 폰트들은 탐색기의 "C:\Windows\Fonts"에 보이지 않았고, 부팅 속도가 눈에 띄게 저하되었습니다. 이런 경우 attrib 명령을 통해 일반 파일 뷰로 바꾸면 파일이 암호화된 상태임을 알리는 색상으로 파일명이 표시되는데, 해당 암호화 기능을 풀어주면 됩니다.




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

[연관 글]






[최초 등록일: ]
[최종 수정일: 7/10/2021]

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

비밀번호

댓글 작성자
 



2018-06-25 01시02분
이 글은 근래의 Windows 10에서 유효하지 않습니다. 자세한 사항은 다음의 글을 참고하세요.

영문 설정의 Windows 10 명령행 창(cmd.exe)의 한글 지원
; http://www.sysnet.pe.kr/2/0/11559

정성태

... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12712정성태7/15/20218207개발 환경 구성: 579. Azure - 리눅스 호스팅의 Site Extension 제작 방법
12711정성태7/15/20218543개발 환경 구성: 578. Azure - Java Web App Service를 위한 Site Extension 제작 방법
12710정성태7/15/202110340개발 환경 구성: 577. MQTT - emqx.io 서비스 소개
12709정성태7/14/20216932Linux: 42. 실행 중인 docker 컨테이너에 대한 구동 시점의 docker run 명령어를 확인하는 방법
12708정성태7/14/202110330Linux: 41. 리눅스 환경에서 디스크 용량 부족 시 원인 분석 방법
12707정성태7/14/202177599오류 유형: 734. MySQL - Authentication method 'caching_sha2_password' not supported by any of the available plugins.
12706정성태7/14/20218758.NET Framework: 1076. C# - AsyncLocal 기능을 CallContext만으로 구현하는 방법 [2]파일 다운로드1
12705정성태7/13/20218940VS.NET IDE: 168. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 - 두 번째 이야기
12704정성태7/12/20218084개발 환경 구성: 576. Azure VM의 서비스를 Azure Web App Service에서만 접근하도록 NSG 설정을 제한하는 방법
12703정성태7/11/202113730개발 환경 구성: 575. Azure VM에 (ICMP) ping을 허용하는 방법
12702정성태7/11/20218864오류 유형: 733. TaskScheduler에 등록된 wacs.exe의 Let's Encrypt 인증서 업데이트 문제
12701정성태7/9/20218504.NET Framework: 1075. C# - ThreadPool의 스레드는 반환 시 ThreadStatic과 AsyncLocal 값이 초기화 될까요?파일 다운로드1
12700정성태7/8/20218896.NET Framework: 1074. RuntimeType의 메모리 누수? [1]
12699정성태7/8/20217701VS.NET IDE: 167. Visual Studio 디버깅 중 GC Heap 상태를 보여주는 "Show Diagnostic Tools" 메뉴 사용법
12698정성태7/7/202111658오류 유형: 732. Windows 11 업데이트 시 3% 또는 0%에서 다운로드가 멈춘 경우
12697정성태7/7/20217550개발 환경 구성: 574. Windows 11 (Insider Preview) 설치하는 방법
12696정성태7/6/20218152VC++: 146. 운영체제의 스레드 문맥 교환(Context Switch)을 유사하게 구현하는 방법파일 다운로드2
12695정성태7/3/20218196VC++: 145. C 언어의 setjmp/longjmp 기능을 Thread Context를 이용해 유사하게 구현하는 방법파일 다운로드1
12694정성태7/2/202110150Java: 24. Azure - Spring Boot 앱을 Java SE(Embedded Web Server)로 호스팅 시 로그 파일 남기는 방법 [1]
12693정성태6/30/20217891오류 유형: 731. Azure Web App Site Extension - Failed to install web app extension [...]. {1}
12692정성태6/30/20217779디버깅 기술: 180. Azure - Web App의 비정상 종료 시 남겨지는 로그 확인
12691정성태6/30/20218602개발 환경 구성: 573. 테스트 용도이지만 테스트에 적합하지 않은 Azure D1 공유(shared) 요금제
12690정성태6/28/20219434Java: 23. Azure - 자바(Java)로 만드는 Web App Service - Tomcat 호스팅
12689정성태6/25/20219996오류 유형: 730. Windows Forms 디자이너 - The class Form1 can be designed, but is not the first class in the file. [1]
12688정성태6/24/20219694.NET Framework: 1073. C# - JSON 역/직렬화 시 리플렉션 손실을 없애는 JsonSrcGen [2]파일 다운로드1
12687정성태6/22/20217628오류 유형: 729. Invalid data: Invalid artifact, java se app service only supports .jar artifact
... 31  32  33  34  35  36  [37]  38  39  40  41  42  43  44  45  ...