Click here to Skip to main content
Click here to Skip to main content

XCharMap - A dialog to display a character map

, 3 Jun 2003 CPOL
Rate this:
Please Sign up or sign in to vote.
XCharMap demonstrates the use of CXCharMap, a class that displays a character map similar to the Windows Character Map utility.
<!-- Add the rest of your HTML here -->


In some apps, the user may want to select how to display certain characters. For example, in text editors, it is common to have option to display whitespace (space and tab). When I had this requirement recently, I tried to use Microsoft's Character Map to allow user to select the display characters. Unfortunately, unless you are willing to use clipboard, there is no way to seamlessly integrate Character Map into your app. So here is XCharMap, my implementation of Character Map as a convenient dialog that you can customize to meet your needs.

The XCharMap Dialog

        XCharMap screenshot

The XCharMap dialog displays 256 characters in selected font. In dialog caption, the character code under the cursor is displayed in hex, octal, and decimal. Below character grid are optional UI elements, which you can remove from the display by calling XCharMap APIs. When user left-clicks (or right-clicks) a character, it is displayed in left-click/right-click box. The last character that was left-clicked may be copied to Characters to copy edit box by clicking on Select. Clicking on Copy will then transfer contents of edit box to clipboard.

To remove Characters to copy UI elements, you can call

  • CXCharMap::EnableCharsToCopy(FALSE).

To remove left-click/right-click UI elements, you can call

  • CXCharMap::EnableClicks(FALSE).

When both sets of UI elements are removed, the XCharMap dialog will be shrunk to fit character grid. To remove character code display in dialog caption, you can call

  • CXCharMap::EnableCharacterCode(FALSE).

Here is code from XCharMapTestDlg.cpp that shows how to call CXCharMap and disable all optional UI elements:

void CXCharMapTestDlg::OnTest()
    CXCharMap dlg;


    if (dlg.DoModal() == IDOK)
        // process return here
        TRACE(_T("m_nLeftClickRow=%d\n"), dlg.m_nLeftClickRow);
        TRACE(_T("m_nLeftClickCol=%d\n"), dlg.m_nLeftClickCol);
        TRACE(_T("m_nRightClickRow=%d\n"), dlg.m_nRightClickRow);
        TRACE(_T("m_nRightClickCol=%d\n"), dlg.m_nRightClickCol);

How To Use

To integrate IsOpenType() into your app, you first need to add following files to your project:

  • Clipboard.cpp
  • Clipboard.h
  • GetFontFile.cpp
  • GetFontFile.h
  • IsOpenType.cpp
  • IsOpenType.h
  • XCharGrid.cpp
  • XCharGrid.h
  • XCharMap.cpp
  • XCharMap.h
  • XFontPreviewCombo.cpp
  • XFontPreviewCombo.h

Next, include the header file XCharMap.h in appropriate project files. Now you are ready to start using CXCharMap.


Currently the XCharMap implementation does not support Unicode.

Acknowledgments and references

Revision History

Version 1.0 - 2003 June 4

  • Initial public release.


This software is released into the public domain. You are free to use it in any way you like. If you modify it or extend it, please to consider posting new code here for everyone to share. This software is provided "as is" with no expressed or implied warranty. I accept no liability for any damage or loss of business that this software may cause.


This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


About the Author

Hans Dietrich
Software Developer (Senior) Hans Dietrich Software
United States United States
I attended St. Michael's College of the University of Toronto, with the intention of becoming a priest. A friend in the University's Computer Science Department got me interested in programming, and I have been hooked ever since.
Recently, I have moved to Los Angeles where I am doing consulting and development work.
For consulting and custom software development, please see

Comments and Discussions

GeneralUnicode version PinmemberE Olivier18-Aug-04 0:46 
GeneralDetecting OpenType Fonts Pinmembergjr29-Apr-04 22:38 
GeneralRe: Detecting OpenType Fonts PinmemberHans Dietrich30-Apr-04 1:34 
GeneralRe: Detecting OpenType Fonts Pinmembergjr30-Apr-04 19:27 
GeneralRe: Detecting OpenType Fonts Pinmembergjr1-May-04 22:09 
I think the problem is just that the code is not checking for the CFF version of OTF font files. (For those interested in font arcana the OpenType format details are available at MS site 'Organization of an OpenType Font' at
If we are pretty sure that the file is SOME form of font file I think you can test for OpenType under Windows (not MAC) with code along the lines of:
// Quick & dirty combination
   // pFileBuf points to start of file data
   const LONG lVersion = *(LONG *)pFileBuf;   // the DWORD version
   _CASSERT(!(sizeof(TT_OFFSET_TABLE) % 4)); // Compile time ASSERT - Must be 4 byte alignment
   const LONG lDSIGTag = *(LONG *)(pFileBuf + sizeof(TT_OFFSET_TABLE));   // the DWORD Tag
   const bool bFoundTTF =
         (0x00000100 == lVersion && // Big Endian 0x00010000 = v1.0 - OpenType font contains TrueType outlines
         0x47495344 == lDSIGTag);   // Big Endian 0x44534947 = 'DSIG - Tag
   bool bFoundOTF;
   if (bFoundTTF)
         { // Is TrueType OTF
         bFoundOTF = true;
         } // Is TrueType OTF
         { // NOT TrueType OTF - try CFF
         const bool bFoundCFF = (0x4F54544F == lVersion); // Big Endian 0x4F54544F = 'OTTO' - OpenType font contains CFF data
         bFoundOTF = bFoundCFF;
         } // NOT TrueType OTF - try CFF
I can't think of any Windows OpenType file that will not be correctly identified by this test and I have used a more elaborate version of it in another context without finding a non conforming font file.

Generalunicode... PinmemberManikandan28-Mar-04 21:31 
AnswerRe: unicode... PinmentorHans Dietrich2-Apr-11 5:16 
GeneralDoes not display chars of Windings font PinmemberPnirff13-Jun-03 1:02 
GeneralRe: Does not display chars of Windings font PinmemberHans Dietrich13-Jun-03 2:57 
GeneralRe: Does not display chars of Windings font PinmemberPnirff13-Jun-03 4:47 
GeneralUseless PinmemberJohn R. Shaw5-Jun-03 16:23 
GeneralRe: Useless PinmemberStephan Poirier9-Jun-03 21:11 
GeneralRe: Useless PinmemberJohn R. Shaw10-Jun-03 3:16 
GeneralRe: Useless PinmemberStephan Poirier10-Jun-03 14:37 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web03 | 2.8.150224.1 | Last Updated 4 Jun 2003
Article Copyright 2003 by Hans Dietrich
Everything else Copyright © CodeProject, 1999-2015
Layout: fixed | fluid