Click here to Skip to main content
13,792,728 members
Click here to Skip to main content
Add your own
alternative version


49 bookmarked
Posted 5 Aug 2006
Licenced CPOL


, 11 Aug 2006
Rate this:
Please Sign up or sign in to vote.
This is a simple class that makes transparent dialog boxes rise more smoothly.

Sample Image - CGlassDialog.jpg


Before introducing this class, I want you to know my English is not very good. And, this is my first article. I've always got a lot of help from this site, so I really wanted to write an article and give back to the community.

Anyway, this is a simple class that makes transparent dialog boxes rise more smoothly. The reason why I made this is.. I've been making a program that has transparent windows. I thought if the windows could rise in more smoothly, it would be better visually. And I made up my mind to make this class.

How to make this??

It's so simple, I use an OnTimer() for the smooth rising.

First, you must declare this in your .h file:

#define WS_EX_LAYERED   0x00080000
#define LWA_COLORKEY    0x00000001
#define LWA_ALPHA       0x00000002
#define ULW_COLORKEY    0x00000001
#define ULW_ALPHA       0x00000002
#define ULW_OPAQUE      0x00000004


and then, you can use this code:

SLWA pSetLayeredWindowAttributes = NULL;  
HINSTANCE hmodUSER32 = LoadLibrary("USER32.DLL"); 
pSetLayeredWindowAttributes =(SLWA)GetProcAddress(hmodUSER32, 
SetWindowLong(m_hWnd, GWL_EXSTYLE, 
           GetWindowLong(m_hWnd, GWL_EXSTYLE) | WS_EX_LAYERED);
pSetLayeredWindowAttributes(m_hWnd, 0, (255 * m_nGlass) / 100, LWA_ALPHA);

In this code, m_nGlass is the rating of transparency so you can set this from 0 to 100. (If you set m_nGlass to 0, the dialog box will be perfectly transparent. If you set m_nGlass to 100, the dialog box will not be transparent at all.)

I've used this point. OnTimer() is the event function of WM_TIMER, so it makes executes the function in regular intervals.

in OnTimer(), you change the value of m_nGlass:

(m_nGlass >= 70) ? ReleaseTimer() : m_nGlass += m_nStepUnit; 

How to use this??

If you want to use this class, first, add GlassiDialog.h and GlassDialog.cpp into your project and #include GlassDialog.h where needed. Then, inherit the CGlassDialog class in your dialog class. (I.e., you should change the base class in your dialog from CDialog to CGlassDialog. Just go to your .cpp, .h files and use the "Replace" feature of your code editor to replace all CDialog with CGlassDialog.)

Now, that's all! Your dialog class is ready to go. When you create your dialog object, you will be able to see a smooth rising dialog box.

Thank you for reading my article!! :)


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


About the Author

Youngman Park
Software Developer
Korea (Republic of) Korea (Republic of)
No Biography provided

You may also be interested in...

Comments and Discussions

QuestionYour Project Pin
coronys7-Aug-06 21:32
membercoronys7-Aug-06 21:32 
AnswerRe: Your Project Pin
Youngman Park8-Aug-06 4:04
memberYoungman Park8-Aug-06 4:04 
GeneralRe: Your Project Pin
coronys8-Aug-06 4:41
membercoronys8-Aug-06 4:41 
AnswerRe: Your Project [modified] Pin
Youngman Park8-Aug-06 4:55
memberYoungman Park8-Aug-06 4:55 
GeneralRe: Your Project Pin
coronys8-Aug-06 6:48
membercoronys8-Aug-06 6:48 
GeneralRe: Your Project Pin
Youngman Park8-Aug-06 18:39
memberYoungman Park8-Aug-06 18:39 
Generalgood job Pin
MrGoodly6-Aug-06 9:22
memberMrGoodly6-Aug-06 9:22 
GeneralRe: good job Pin
Youngman Park7-Aug-06 4:37
memberYoungman Park7-Aug-06 4:37 

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

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

Permalink | Advertise | Privacy | Cookies | Terms of Use | Mobile
Web02 | 2.8.181207.3 | Last Updated 12 Aug 2006
Article Copyright 2006 by Youngman Park
Everything else Copyright © CodeProject, 1999-2018
Layout: fixed | fluid