本文以實例形式講解了VC++中HTControl控件類的CHTButton按鈕控件類用法,相信對大家更好的理解VC++有一定的幫助。具體內(nèi)容如下:
一般了解VC++的朋友都知道,VC++ 按鈕控件CHTButton隸屬HTControl控件組,直接由WIN32 API實現(xiàn),你可以在SDK,MFC,wxWidget等環(huán)境下使用它。支持生成各種類型的按鈕,比如:普通按鈕,PNG透明按鈕,復選框按鈕,單選按鈕等。使用時請注意,窗體必須動態(tài)創(chuàng)建,代碼段如下:
1
2
3
|
m_HTBtnClose.Create(758, 0, 39, 20, m_hWnd, iChildId++); m_HTBtnClose.SetAllBitmap(m_hBmpBtnCloseNormal, m_hBmpBtnCloseDown,m_hBmpBtnCloseHover); m_HTBtnClose.SetParentBgMemDC(m_hdcMemBuf); |
CHTButton.h控件核心代碼及注釋說明如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
|
/***************************************************************** | Copyright (c) 2012, ******************************************************************/ #if !defined(__CHTBUTTON_H__) #define __CHTBUTTON_H__ #include "CHTTip.h" class CMyButton; class AFX_CLASS_EXPORT CHTButton { public : CHTButton(); ~CHTButton(); /**************************************************************************** | 函數(shù)功能:創(chuàng)建按鈕 | | 輸入?yún)?shù): | | x: 窗體位置x坐標(相對于父窗體) | | y: 窗體位置y坐標(相對于父窗體) | | iWidth: 窗體寬 | | iHeight: 窗體高 | | hParent: 父窗口句柄 | | hBtnId: 窗體ID | | szLabel: 窗體標題 | | dwStyle: 按鈕行為標識 | | BS_CHECKBOX :復選框按鈕 | | BS_RADIOBUTTON :單選按鈕 | | BS_NOTIFY:發(fā)送得到(BN_SETFOCUS)失去(BN_KILLFOCUS)焦點的通知 | | BS_NOTIFY << 2: 發(fā)送按下通知(BN_KILLFOCUS + 2) | | 輸出參數(shù):無 | | 返回值: 成功:窗口句柄 失敗: NULL | | 說明: | ****************************************************************************/ HWND Create( int x, int y, int iWidth, int iHeight, HWND hParent, int iBtnId, TCHAR * szLabel = NULL, DWORD dwStyle = NULL); /**************************************************************************** | 函數(shù)功能:改變窗口位置大小 | | 輸入?yún)?shù): | | iWidth: 窗體寬 -1表示寬不變 | | iHeight: 窗體高 -1表示高不變 | | x: 窗體位置x坐標 | | y: 窗體位置y坐標 | | bRepaint: 改變后是否重繪窗口 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明:如果改變了窗口大小,在MoveWindow之前需要重新設置各種位圖 | ****************************************************************************/ void MoveWindow( int x, int y, int iWidth = -1, int iHeight = -1, BOOL bRepaint = TRUE); /**************************************************************************** | 函數(shù)功能:設置提示窗口類指針 | | 輸入?yún)?shù): | | pclTip: 提示窗口類指針 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetToolTip(CHTTip* pclTip); /**************************************************************************** | 函數(shù)功能:設置提示窗口的文本 | | 輸入?yún)?shù): | | szTipText: 提示文本 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetTipText( TCHAR * szTipText); /**************************************************************************** | 函數(shù)功能:獲取窗口的句柄 | | 輸入?yún)?shù):無 | | 輸出參數(shù):無 | | 返回值: 窗體句柄 | | 說 明: | ****************************************************************************/ HWND GetHandle(); /**************************************************************************** | 函數(shù)功能:獲取父窗口的句柄 | | 輸入?yún)?shù):無 | | 輸出參數(shù):無 | | 返回值: 父窗體句柄 | | 說 明: | ****************************************************************************/ HWND GetParent(); /**************************************************************************** | 函數(shù)功能:設置字體 | | 輸入?yún)?shù): | | hFont: 字體 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetFont( HFONT hFont); /**************************************************************************** | 函數(shù)功能:設置文字的顏色 | | 輸入?yún)?shù): | | CRText: 顏色值 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetBtnTextColor( COLORREF CRText); /**************************************************************************** | 函數(shù)功能:設置字體(鼠標停留窗體上時) | | 輸入?yún)?shù): | | hFont: 字體 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明:如未設置則采用SetFont設置的字體 | ****************************************************************************/ void SetHoverFont( HFONT hFont); /**************************************************************************** | 函數(shù)功能:設置文字的顏色(鼠標停留窗體上時) | | 輸入?yún)?shù): | | CRText: 顏色值 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明:如未設置則采用SetBtnTextColor設置的顏色 | ****************************************************************************/ void SetHoverBtnTextColor( COLORREF CRText); /**************************************************************************** | 函數(shù)功能:使窗口無效并繪制窗口 | | 輸入?yún)?shù):無 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void Disable(); /**************************************************************************** | 函數(shù)功能:使窗口有效并按常態(tài)繪制窗口 | | 輸入?yún)?shù):無 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void Enable(); /**************************************************************************** | 函數(shù)功能:設置按鈕顯示的文本 | | 輸入?yún)?shù): | | szLabel: 按鈕的文本 | | point: 文字起始坐標,默認居中 | | bTextMove:按下時文字是否移動(向右下角移動一像素) | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetLabel( TCHAR * szLabel, POINT* point = NULL, BOOL bTextMove = TRUE); /**************************************************************************** | 函數(shù)功能:獲取按鈕上的文本 | | 輸入?yún)?shù): | | szLabel: 按鈕的文本 | | 輸出參數(shù):無 | | 返回值: 文本指針 | | 說 明: | ****************************************************************************/ TCHAR * GetLabel(); /**************************************************************************** | 函數(shù)功能:獲取按鈕狀態(tài) | | 輸入?yún)?shù):無 | | 輸出參數(shù):無 | | 返回值: 按鈕狀態(tài) 0:常態(tài) 1:按下 2:長按 3:無效 | | 說 明: | ****************************************************************************/ int GetState(); /**************************************************************************** | 函數(shù)功能:設置長按生效時間 | | 輸入?yún)?shù): | | wLongPressTime : 長按生效時間(長按通知碼BN_KILLFOCUS + 3) | | 0表示不打開長按功能 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetLongPressTime( WORD wLongPressTime); /**************************************************************************** | 函數(shù)功能:設置復選和單選按鈕的狀態(tài) | | 輸入?yún)?shù): | | bCheck: FALSE(BST_UNCHECKED)或者TRUE(BST_CHECKED) | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetCheck( BOOL bCheck); /**************************************************************************** | 函數(shù)功能:獲取復選和單選按鈕的狀態(tài) | | 輸入?yún)?shù):無 | | 輸出參數(shù):無 | | 返回值: FALSE(BST_UNCHECKED)或者TRUE(BST_CHECKED) | | 說 明: | ****************************************************************************/ BOOL GetCheck(); /**************************************************************************** | 函數(shù)功能:設置按鈕常態(tài)的位圖 | | 輸入?yún)?shù): | | hBitmap: 位圖 | | iNormalLeftLen: 位圖左側不可拉伸部分的長度 | | iNormalRightLen: 位圖右側不可拉伸部分的長度 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetNormalBitmap( HBITMAP hBitmap, int iNormalLeftLen = 0, int iNormalRightLen = 0); /**************************************************************************** | 函數(shù)功能:設置按鈕按下的位圖 | | 輸入?yún)?shù): | | hBitmap: 位圖 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetLBtnDownBitmap( HBITMAP hBitmap); /**************************************************************************** | 函數(shù)功能:設置鼠標在按鈕之上時按鈕的位圖 | | 輸入?yún)?shù): | | hBitmap: 位圖 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetHoverBitmap( HBITMAP hBitmap); /**************************************************************************** | 函數(shù)功能:設置按鈕無效時的位圖 | | 輸入?yún)?shù): | | hBitmap: 位圖 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetDisableBitmap( HBITMAP hBitmap); void SetAllBitmap( HBITMAP hBitmapNormal, HBITMAP hBitmapLBtnDown, HBITMAP hBitmapHover, int iNormalLeftLen = 0, int iNormalRightLen = 0); /**************************************************************************** | 函數(shù)功能:設置按鈕上的圖標的位圖 | | 輸入?yún)?shù): | | hBitmap: 位圖 | | pIconRect:圖標占據(jù)的矩形 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetIcon( HBITMAP hBitmap, RECT* pIconRect); /**************************************************************************** | 函數(shù)功能:設置窗體的不透明度 | | 輸入?yún)?shù): | | iTransparency: 不透明度的百分比 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void SetTransparency( int iTransparency); /**************************************************************************** | 函數(shù)功能:設置父窗體背景內(nèi)存畫布 | | 輸入?yún)?shù): | | hParentBgMemDC: 父窗體背景內(nèi)存畫布 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明:當父窗體背景在變化并且此窗體本身也有透明度時(包括窗體使用的位圖 | | 具有透明度或者窗體沒有背景位圖),需要調(diào)用此接口 | ****************************************************************************/ void SetParentBgMemDC( HDC hParentBgMemDC, int x = 0, int y = 0); /**************************************************************************** | 函數(shù)功能:設置父窗體使用的背景位圖 | | 輸入?yún)?shù): | | hParentBgBitmap: 父窗體使用的背景位圖 | | x, y 位圖繪畫起始點坐標 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明:當父窗體背景使用靜態(tài)位圖并且此窗體本身也有透明度時(包括窗體使用 | | 的位圖具有透明度或者窗體沒有背景位圖),需要調(diào)用此接口 | ****************************************************************************/ void SetParentBgBitmap( HBITMAP hParentBgBitmap, int x = 0, int y = 0); /**************************************************************************** | 函數(shù)功能:設置父窗體背景顏色 | | 輸入?yún)?shù): | | CRParentBg: 父窗體背景顏色 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明:當父窗體背景使用固定顏色并且此窗體本身也有透明度時(包括窗體使用 | | 的位圖具有透明度或者窗體沒有背景位圖),需要調(diào)用此接口 | ****************************************************************************/ void SetParentBgColor( COLORREF CRParentBg = RGB(236, 233, 216)); /**************************************************************************** | 函數(shù)功能:把窗口繪制到目標設備內(nèi)容 | | 輸入?yún)?shù): | | hdcDest: 目標設備內(nèi)容 | | x, y: 繪畫起始坐標 | | 輸出參數(shù):無 | | 返回值: 無 | | 說 明: | ****************************************************************************/ void DrawWindow( HDC hdcDest, int x = 0, int y = 0); CMyButton* GetCMyButton(); private : CMyButton* m_pclBtn; }; #endif //!__CHTBUTTON_H__ |
此類支持窗體以任意透明度顯示,操作很簡單,使用下面接口即可實現(xiàn):
1
|
void SetTransparency( int iTransparency); |
CHTButton類同時也實現(xiàn)了PNG透明按鈕,感興趣的讀者可以自己測試一下。