A bevelline with horizontal and vertical text

The class described here replaces my former issue cdxCBevelLine.
This class provides the following options:

rotated_bevel.gif (5061 Byte)

Features:
  • A bevel line even if user has strange fonts
    (have you ever created a sunken static with a height of 1 for a bevelline and tested your program on a machine that has 200% larger fonts ?).
  • Text rotates appropiately (usable with any font).
  • Reacts properly on WM_ENABLEWINDOW.
  • Might be used as an example for my cdxCRot90DC (which you may find in the misc section of codeguru's).

How to use (in a dialog):

  1. Add cdxCRotBevelLine.h, cdxCRotBevelLine.cpp, cdxCRot90DC.h and cdxCRot90DC.cpp to your project.
  2. Add a static control to your dialog resource.
    Enter some appropiate text to it.
    If your static's width is greater than its height the bevelline will appear horizontal, vertical otherwise.
    If the bevelline is drawn vertically, the text is rotated by 900 degrees by default (left hand examples of upper image).
    To modify this, put a "~" in front of your control text (right hand bevels in the upper image).
  3. Change its ID to something like IDC_BEVEL_1, open classwizard and assign a member variable, type control (CStatic) to it ("m_wndBevel1" for example).
  4. Open your dialog class' header file.
    Add #include "cdxCRotBevelLine.h".
    Find the line "CStatic m_wndBevel1;" and replace the "CStatic" by "cdxCRotBevelLine".
  5. Compile and run.

Notes:

  • This class may even be useful to you if you only need horizontal bevels.
    Some people mentioned that it's enough to create a sunken static with a height of 1 (use Alt while sizing the control) and to put another text control over it.
    In fact, this will look really strange if the user choosed big fonts for his display - the dialog resource will automatically adapt the the newly found font and your height of 1 may become 3 or stuff - and suddenly friend user doesn't have a bevelline but a sunken static.

Files:

Download demo project - 52 KB

Download source - 30 KB



Comments

  • Note about Win95,98,CE and PlgBlt

    Posted by Legacy on 01/08/2000 12:00am

    Originally posted by: Brian V Shifrin

    I like your code, but ....

    To everyone who trying to run it on Windows 95,98 or CE
    text rotation will not work.

    Trouble with PlgBlt. This API only supported on NT and 2000.

    Platforms SDK lists PlgBlt as
    Windows 95/98: Unsupported.
    Windows CE: Unsupported.

    You should only see horizontal labels where BitBlt is used instead of PlgBlt.

    Reply
  • rotate doesn't work

    Posted by Legacy on 04/06/1999 12:00am

    Originally posted by: Mike Wild

    I tried the sample and the rotated text isn't shown on WIN 95 with VC 6.0


    Mike

    Reply
Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • Live Event Date: May 11, 2015 @ 1:00 p.m. ET / 10:00 a.m. PT One of the languages that have always been supported with the Intel® RealSense™ SDK (Software Developer Kit) is JavaScript, specifically so that web-enabled apps could be created. Come hear from Intel Expert Bob Duffy as he reviews his own little "space shooting" game where the orientation of your face controls the aiming reticle to help teach developers how to write apps and games in JavaScript that can use facial and gesture …

  • You may not realize the complexity you could be creating when developing mobile apps – many companies don't initially. You could be doubling your IT costs for development and delivery; not to mention, risking sales, productivity and brand satisfaction. Read this IBM-commissioned Forrester Study to understand the key cost drivers of mobile app delivery -- for both customer-facing and enterprise applications. Find out how you could lower costs and increase success with the right strategy and investment.

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date