在用VC開(kāi)發(fā)應(yīng)用程序時(shí),經(jīng)常會(huì)要做一些可以改變大小的對(duì)話框,而這個(gè)時(shí)候就要求對(duì)話框上的控件會(huì)隨著對(duì)話框大小的改變而改變自己的位置和大小。如果控件比較少,那可以在對(duì)話框的OnSize()事件里面添加代碼,通過(guò)計(jì)算來(lái)調(diào)整各個(gè)控件的位置和大??;但是,如果對(duì)話框上的控件比較多的話,那這將是一件非常痛苦的事情!要是程序中又有很多可以改變大小的對(duì)話框,那一個(gè)一個(gè)的OnSize()寫下來(lái),那會(huì)使程序員崩潰的!
為了解決這個(gè)問(wèn)題,我寫了一個(gè)自動(dòng)改變控件位置和大小的對(duì)話框類ClxDialog。從這個(gè)類繼承的對(duì)話框類,只要在OnInitDialog()里對(duì)控件做一些簡(jiǎn)單的設(shè)置,對(duì)話框上的控件就會(huì)隨著對(duì)話框大小的改變而改變自己的位置和大小。
為了保存控件信息,我定義了一個(gè)結(jié)構(gòu):
typedef struct _dlgControlTag
{
int iId; // 控件ID
int iFlag; // 標(biāo)志,表示怎樣改變控件的位置或者大小
int iPercent; // 改變值占對(duì)話框改變值的百分比
} DLGCTLINFO, *PDLGCTLINFO;
這里要對(duì)結(jié)構(gòu)中的iFlag和iPercent進(jìn)行一些解釋。其中iFlag是下面的枚舉值:
enum
{
MOVEX = 0, // 控件在X方向(左右)移動(dòng)
MOVEY, // 控件在Y方向(上下)移動(dòng)
MOVEXY, // 控件在X方向和Y方向同時(shí)移動(dòng)
ELASTICX, // 控件在X方向(寬度)改變大小
ELASTICY, // 控件在Y方向改(高度)改變大小
ELASTICXY // 控件在X方向和Y方向同時(shí)改變大小
};
iPercent表示改變值占對(duì)話框改變值的百分比。例如,一個(gè)控件的iPercent值為100,iFlag值為MOVEX,那么當(dāng)對(duì)話框的寬度改變100個(gè)單位的時(shí)候,這個(gè)控件就在X方向移動(dòng)100個(gè)單位;又如,一個(gè)控件的iPercent值為100,iFlag值為ELASTICXY,那么當(dāng)對(duì)話框的寬度和高度分別改變100個(gè)單位的時(shí)候,控件的高度和寬度也相應(yīng)的改變100個(gè)單位。
下面是設(shè)置控件信息的函數(shù):
BOOL SetControlProperty(PDLGCTLINFO lp, int nElements);
使用起來(lái)非常簡(jiǎn)單,在對(duì)話框的OnInitDialog()函數(shù)里面添加類似下面的代碼就行了:
// 控件信息數(shù)組
static DLGCTLINFO dcMenuGroup[] =
{
{IDOK, MOVEX, 100},
{IDCANCEL, MOVEX, 100},
{IDC_BUTTON1, MOVEX, 50},
{IDC_BUTTON1, MOVEY, 100},
{IDC_EDIT1, ELASTICX, 100},
{IDC_EDIT2, ELASTICX, 50},
{IDC_EDIT3, ELASTICX, 50},
{IDC_EDIT3, MOVEX, 50},
{IDC_EDIT4, ELASTICY, 100},
{IDC_EDIT5, ELASTICX, 100},
{IDC_EDIT5, ELASTICY, 50},
{IDC_EDIT6, ELASTICX, 100},
{IDC_EDIT6, ELASTICY, 50},
{IDC_EDIT6, MOVEY, 50},
};
// 設(shè)置控件信息
SetControlProperty(dcMenuGroup, sizeof(dcMenuGroup)/sizeof(DLGCTLINFO));
下面就是使用上面這段代碼的對(duì)話框改變大小前后的效果圖:
對(duì)兩張截圖的比較我們可以很容易的理解上面那段代碼。
我還提供了一個(gè)函數(shù):
void ShowSizeIcon(BOOL bShow = TRUE);
來(lái)設(shè)置是否顯示對(duì)話框右下角表示可以改變大小的圖標(biāo)。這個(gè)圖標(biāo)是從系統(tǒng)中讀取的,我上面的截圖是Windows2000下的,在WindowsXP中就會(huì)自動(dòng)變成XP風(fēng)格的。
好了,閑話不多說(shuō)了,下面貼出該對(duì)話框類ClxDialog的源代碼,里面有詳細(xì)的注釋:
lxDialog.h文件:
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// 自動(dòng)改變控件位置和大小的對(duì)話框類
// 文件名:lxDialog.h
// 作者:StarLee(coolstarlee@sohu.com)
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
class ClxDialog : public CDialog
{
public:
ClxDialog(UINT nID, CWnd* pParent = NULL);
typedef struct _dlgControlTag
{
int iId;
int iFlag;
int iPercent;
} DLGCTLINFO, *PDLGCTLINFO;
enum
{
MOVEX = 0,
MOVEY,
MOVEXY,
ELASTICX,
ELASTICY,
ELASTICXY
};
// 設(shè)置控件信息
BOOL SetControlProperty(PDLGCTLINFO lp, int nElements);
// 是否在對(duì)話框右下角顯示表示可改變大小的圖標(biāo)
void ShowSizeIcon(BOOL bShow = TRUE);
protected:
virtual BOOL OnInitDialog();
afx_msg void OnSize(UINT nType, int cx, int cy);
afx_msg void OnSizing(UINT nSide, LPRECT lpRect);
DECLARE_MESSAGE_MAP()
private:
int m_iClientWidth; // 對(duì)話框client區(qū)域的寬度
int m_iClientHeight; // 對(duì)話框client區(qū)域的高度
int m_iMinWidth; // 對(duì)話框的最小寬度
int m_iMinHeight; // 對(duì)話框的最小高度
PDLGCTLINFO m_pControlArray; // 控件信息數(shù)組指針
int m_iControlNumber; // 設(shè)置控件信息的控件個(gè)數(shù)
BOOL m_bShowSizeIcon; // 是否顯示表示可改變大小的圖標(biāo)
CStatic m_wndSizeIcon; // 放圖標(biāo)的靜態(tài)控件
// 保存圖標(biāo)的bitmap
CBitmap m_bmpSizeIcon;
BITMAP m_bitmap;
};
lxDialog.cpp文件:
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// 自動(dòng)改變控件位置和大小的對(duì)話框類
// 文件名:lxDialog.cpp
// 作者:StarLee(coolstarlee@sohu.com)
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include "lxDialog.h"
// 表示可改變大小的圖標(biāo)ID
#ifndef OBM_SIZE
#define OBM_SIZE 32766
#endif
ClxDialog::ClxDialog(UINT nID, CWnd* pParent /*=NULL*/)
: CDialog(nID, pParent)
, m_iClientWidth(0)
, m_iClientHeight(0)
, m_iMinWidth(0)
, m_iMinHeight(0)
, m_pControlArray(NULL)
, m_iControlNumber(0)
, m_bShowSizeIcon(TRUE)
{}
BEGIN_MESSAGE_MAP(ClxDialog, CDialog)
ON_WM_SIZE()
ON_WM_SIZING()
END_MESSAGE_MAP()
BOOL ClxDialog::OnInitDialog()
{
CDialog::OnInitDialog();
// 設(shè)置對(duì)話框?yàn)榭勺兇笮〉?br> ModifyStyle(0, WS_SIZEBOX);
// 以對(duì)話框的初始大小作為對(duì)話框的寬度和高度的最小值
CRect rectDlg;
GetWindowRect(rectDlg);
m_iMinWidth = rectDlg.Width();
m_iMinHeight = rectDlg.Height();
// 得到對(duì)話框client區(qū)域的大小
CRect rectClient;
GetClientRect(rectClient);
m_iClientWidth = rectClient.Width();
m_iClientHeight = rectClient.Height();
// Load圖標(biāo)
m_bmpSizeIcon.LoadOEMBitmap(OBM_SIZE);
m_bmpSizeIcon.GetBitmap(&m_bitmap);
// 創(chuàng)建顯示圖標(biāo)的靜態(tài)控件并放在對(duì)話框右下角
m_wndSizeIcon.Create(NULL, WS_CHILD | WS_VISIBLE | SS_BITMAP, CRect(0, 0, m_bitmap.bmWidth, m_bitmap.bmHeight), this, 0);
m_wndSizeIcon.SetBitmap(m_bmpSizeIcon);
m_wndSizeIcon.MoveWindow(m_iClientWidth - m_bitmap.bmWidth, m_iClientHeight - m_bitmap.bmHeight, m_bitmap.bmWidth, m_bitmap.bmHeight);
// 顯示圖標(biāo)
m_wndSizeIcon.ShowWindow(m_bShowSizeIcon);
return TRUE;
}
void ClxDialog::OnSize(UINT nType, int cx, int cy)
{
CDialog::OnSize(nType, cx, cy);
// 對(duì)話框?qū)挾群透叨鹊脑隽?nbsp;
int iIncrementX = cx - m_iClientWidth;
int iIncrementY = cy - m_iClientHeight;
// 最小化時(shí)增量為0
if (nType == SIZE_MINIMIZED)
{
iIncrementX = iIncrementY = 0;
}
for (int i = 0; i < m_iControlNumber; i++)
{
CWnd *pWndCtrl = NULL;
int iId = m_pControlArray[i].iId;
int iFlag = m_pControlArray[i].iFlag;
int iPercent = m_pControlArray[i].iPercent;
// 無(wú)效值
if ((iPercent < 0) || (iPercent > 100))
continue;
// 得到控件指針
pWndCtrl = GetDlgItem(iId);
if ((NULL != pWndCtrl) && IsWindow(pWndCtrl->GetSafeHwnd()))
{
CRect rectCtrl;
pWndCtrl->GetWindowRect(rectCtrl);
ScreenToClient(rectCtrl);
int iLeft = rectCtrl.left;
int iTop = rectCtrl.top;
int iWidth = rectCtrl.Width();
int iHeight = rectCtrl.Height();
switch (iFlag)
{
case MOVEX: // X方向移動(dòng)
iLeft += (iIncrementX * iPercent / 100);
break;
case MOVEY: // Y方向移動(dòng)
iTop += (iIncrementY * iPercent / 100);
break;
case MOVEXY: // X方向和Y方向同時(shí)移動(dòng)
iLeft += (iIncrementX * iPercent / 100);
iTop += (iIncrementY * iPercent / 100);
break;
case ELASTICX: // X方向改變大小
iWidth += (iIncrementX * iPercent / 100);
break;
case ELASTICY: // Y方向改變大小
iHeight += (iIncrementY * iPercent / 100);
break;
case ELASTICXY: // X方向和Y方向同時(shí)改變大小
iWidth += (iIncrementX * iPercent / 100);
iHeight += (iIncrementY * iPercent / 100);
break;
default:
;
}
// 把控件移動(dòng)到新位置
pWndCtrl->MoveWindow(iLeft, iTop, iWidth, iHeight);
}
}
// 把圖標(biāo)移動(dòng)到對(duì)話框右下角
if (IsWindow(m_wndSizeIcon.GetSafeHwnd()))
m_wndSizeIcon.MoveWindow(cx - m_bitmap.bmWidth, cy - m_bitmap.bmHeight, m_bitmap.bmWidth, m_bitmap.bmHeight);
// 記錄對(duì)話框client區(qū)域的大小
if (nType != SIZE_MINIMIZED)
{
m_iClientWidth = cx;
m_iClientHeight = cy;
}
}
void ClxDialog::OnSizing(UINT nSide, LPRECT lpRect)
{
CDialog::OnSizing(nSide, lpRect);
// 對(duì)話框不能小于初始大小
int iWidth = lpRect->right - lpRect->left;
int iHeight = lpRect->bottom - lpRect->top;
if (iWidth <= m_iMinWidth)
lpRect->right = lpRect->left + m_iMinWidth;
if(iHeight <= m_iMinHeight)
lpRect->bottom = lpRect->top + m_iMinHeight;
}
BOOL ClxDialog::SetControlProperty(PDLGCTLINFO lp, int nElements)
{
// 設(shè)置控件數(shù)組信息
if (NULL == lp)
return FALSE;
if (nElements <= 0)
return FALSE;
m_pControlArray = lp;
m_iControlNumber = nElements;
return TRUE;
}
void ClxDialog::ShowSizeIcon(BOOL bShow /*=NULL*/)
{
m_bShowSizeIcon = bShow;
}
一、簡(jiǎn)單對(duì)話框全屏顯示方法
在OnInitDialog()中任意加入:
1、ModifyStyle(WS_CAPTION,0,0); //如果不想去掉標(biāo)題欄,去掉該句。
SendMessage(WM_SYSCOMMAND,SC_MAXIMIZE,0); //不顯示任務(wù)欄
ShowWindow(SW_MAXIMIZE);//顯示任務(wù)欄
2、ShowWindow(SW_SHOWMAXIMIZED);
二、復(fù)雜一點(diǎn)的對(duì)話框全屏顯示方法,隨屏幕的分辯率而調(diào)節(jié)
void CMainFrame::OnFullScreen()
{
GetWindowPlacement(&m_OldWndPlacement);
CRect WindowRect;
GetWindowRect(&WindowRect);
CRect ClientRect;
RepositionBars(0, 0xffff, AFX_IDW_PANE_FIRST, reposQuery, &ClientRect);
ClientToScreen(&ClientRect);
//獲取屏幕的分辨率
int nFullWidth=GetSystemMetrics(SM_CXSCREEN);
int nFullHeight=GetSystemMetrics(SM_CYSCREEN);
//將除控制條外的客戶區(qū)全屏顯示到從(0,0)到(nFullWidth, nFullHeight)區(qū)域,
//將(0,0)和(nFullWidth, nFullHeight)兩個(gè)點(diǎn)外擴(kuò)充原窗口和除控制條之外的
//客戶區(qū)位置間的差值, 就得到全屏顯示的窗口位置
m_FullScreenRect.left=WindowRect.left-ClientRect.left;
m_FullScreenRect.top=WindowRect.top-ClientRect.top;
m_FullScreenRect.right=WindowRect.right-ClientRect.right+nFullWidth;
m_FullScreenRect.bottom=WindowRect.bottom-ClientRect.bottom+nFullHeight;
m_bFullScreen=TRUE; //設(shè)置全屏顯示標(biāo)志為TRUE
//進(jìn)入全屏顯示狀態(tài)
WINDOWPLACEMENT wndpl;
wndpl.length=sizeof(WINDOWPLACEMENT);
wndpl.flags=0;
wndpl.showCmd=SW_SHOWNORMAL;
wndpl.rcNormalPosition=m_FullScreenRect;
SetWindowPlacement(&wndpl);
}
三、對(duì)話框全屏及按鈕控件移到相應(yīng)位置
void CXXXDlg::OnLButtonDown(UINT nFlags, CPoint point)
{
int cx=::GetSystemMetrics(SM_CXSCREEN);
int cy=::GetSystemMetrics(SM_CYSCREEN);
CRect rtClient,rtBtn;
CWnd *pWnd=GetDlgItem(IDC_BUTTON);
GetClientRect(&rtClient); //獲得對(duì)話框客戶區(qū)屏幕坐標(biāo)
ClientToScreen(&rtClient); //映射為屏幕坐標(biāo)
pWnd->GetWindowRect(&rtBtn); //獲得button屏幕坐標(biāo)
int lx=rtBtn.Width(); //button長(zhǎng)度
int ly=rtBtn.Height(); //button高度
int dx=rtClient.right-rtBtn.right; //離右邊框的距離
int dy=rtClient.bottom-rtBtn.bottom; //離底邊框的距離
MoveWindow(CRect(0,0,cx,cy)); //移動(dòng)窗口
pWnd->MoveWindow(CRect(cx-dx-lx,cy-ly-dy,cx-dx,cy-dy)); //移動(dòng)button
CDialog::OnLButtonDown(nFlags, point);
}
四、設(shè)計(jì)狀態(tài)下指定對(duì)話框以全屏顯示
1、手工把它拽成比如1024×768, 然后Alt+V U
2、在*.rc文件中修改,但是單位不一樣。
五、用MoveWindow或SetWindowPos全屏對(duì)話框
首先計(jì)算出客戶區(qū)的大小GetClientRect();
再計(jì)算出整個(gè)窗口的大小GetWindowRect();
然后再得到當(dāng)前屏幕的大小GetSystemMetrics();
最后根據(jù)這三個(gè)數(shù)據(jù)進(jìn)行換算,當(dāng)客戶區(qū)為屏幕大小時(shí)窗口的位置的大??;
計(jì)算完成后調(diào)用MoveWindow就可以了。
文章出處:http://www.diybl.com/course/3_program/c++/cppsl/2008315/104723.html
//不知轉(zhuǎn)的誰(shuí)的!呵呵!不好意思!
本文例子是一個(gè)典型的C++/MFC對(duì)話框程序,設(shè)置了 EX_WM_TOOLWINDOW 擴(kuò)展式樣,因此在標(biāo)題欄左上角看不到系統(tǒng)菜單圖標(biāo),但通過(guò) Ctrl+Space 或者在標(biāo)題欄單擊鼠標(biāo)右鍵可以調(diào)出系統(tǒng)菜單。例子程序?qū)ο到y(tǒng)菜單進(jìn)行了定制,在原有菜單基礎(chǔ)上添加了兩個(gè)菜單命令:一個(gè)是顯示“關(guān)于”對(duì)話框;另一個(gè)是“退出”。之所以要加一個(gè)“退出”菜單命令,是因?yàn)槔映绦蚋膶懥藢?duì)話框原來(lái)默認(rèn)的“關(guān)閉”菜單命令行為(Alt-F4),用來(lái)隱藏對(duì)話框。因此必須加一個(gè)程序的“退出”出口。此外,例子程序利用一個(gè)第三方的系統(tǒng)托盤處理類,利用系統(tǒng)托盤圖標(biāo)可以顯示/隱藏對(duì)話框。 下面我們就來(lái)看看用 C++/MFC 實(shí)現(xiàn)的細(xì)節(jié)。
添加菜單
首先在資源定義文件 resource.h 中定義菜單項(xiàng)標(biāo)示,也可以在標(biāo)準(zhǔn)頭文件中定義。菜單項(xiàng)標(biāo)示必須具有唯一性。其次,Windows 對(duì)系統(tǒng)菜單的處理與常規(guī)菜單的處理方法是不同的,不管是缺省的菜單還是定制的菜單,它們都沒(méi)有象常規(guī)菜單命令那樣的消息處理例程。假設(shè)我們要添加兩個(gè)定制的系統(tǒng)單:
#define IDM_ABOUT 16
#define IDM_EXIT 17
IDM_的意思是該定義為菜單項(xiàng)ID。添加菜單命令是在對(duì)話框的初始化例程以及窗口創(chuàng)建函數(shù)(OnInitDialog(), OnCreate())中進(jìn)行的。如: BOOL CBabelOnDlg::OnInitDialog()
{
CDialog::OnInitDialog();
// 在系統(tǒng)菜單中添加 "關(guān)于..." 和 "退出" 菜單項(xiàng)
// 解決 Windows 95 中的 bug
ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
// 命令 IDs 必須在預(yù)定義的系統(tǒng)菜單之后
ASSERT(IDM_ABOUTBOX < 0xF000);
// 解決 Windows 95 中的 bug
ASSERT((IDM_EXIT & 0xFFF0) == IDM_EXIT);
// 命令 IDs 必須在預(yù)定義的系統(tǒng)菜單之后
ASSERT(IDM_EXIT < 0xF000);
CMenu* pSysMenu = GetSystemMenu(FALSE);
if (pSysMenu != NULL)
{
pSysMenu->AppendMenu(MF_STRING,IDM_EXIT,"退出(&x)");
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, IDM_ABOUTBOX, "關(guān)于(&A)...");
......
}
......
//other initialization
}
這里在添加每個(gè)菜單前都有兩個(gè) ASSERT 語(yǔ)句,第一個(gè) ASSERT 的目的是修復(fù) Windows 95 中存在的 Bug,第二個(gè) ASSERT 保證定制的命令 IDs 是在預(yù)定義的系統(tǒng)菜單之后,以免發(fā)生沖突。查一下 MSDN 庫(kù)的 MFC 文檔關(guān)于系統(tǒng)菜單的描述,你會(huì)發(fā)現(xiàn)下面的內(nèi)容: “......所有預(yù)定義的控制菜單項(xiàng)(也就是系統(tǒng)菜單)的ID號(hào)必須大于 0xF000。如果某個(gè)應(yīng)用程序要添加系統(tǒng)菜單,
其系統(tǒng)菜單的 ID 號(hào)必須小于F000。”
接下來(lái),用 GetSystemMenu 函數(shù)獲取系統(tǒng)菜單指針。調(diào)用時(shí)使用參數(shù) FALSE 獲取指針。如果用 TRUE 作為參數(shù),那么該函數(shù)會(huì)將菜單重置回缺省狀態(tài)。
如果得到的指針有效,接著調(diào)用菜單添加命令在系統(tǒng)菜單后面添加菜單項(xiàng),傳遞菜單IDs以及菜單顯示時(shí)所用的字符串。
處理定制的菜單命令
為了讓這些系統(tǒng)菜單命令工作起來(lái),我們不能依賴常規(guī)的菜單消息處理機(jī)制----即便菜單項(xiàng)相同。通常系統(tǒng)菜單通過(guò) WM_SYSCOMMAND 消息處理: void CBabelOnDlg::OnSysCommand(UINT nID, LPARAM lParam)
{
//trap our own system menu messages
if ((nID & 0xFFF0) == IDM_ABOUTBOX)
{
CAboutDlg dlgAbout;
dlgAbout.DoModal();
} else if ((nID & 0xFFF0)==SC_CLOSE){
OnClose();
} else if ((nID & 0xFFF0)==IDM_EXIT) {
::PostQuitMessage(0);
}
else {
CDialog::OnSysCommand(nID, lParam);
}
}
通過(guò)比較傳入的菜單ID進(jìn)行相應(yīng)的處理。注意代碼中又有兩個(gè)“nID & 0xFFF0”,這主要也是解決 Windows 95 的 bug。如果選擇“退出”,那么會(huì)向應(yīng)用程序發(fā)送退出消息:::PostQuitMessage(0)。
注意第二個(gè)條件檢查:SC_CLOSE 是個(gè)預(yù)定義的菜單常量。一般它是由 Windows 處理的,因?yàn)樵诶映绦蛑形覀儗?duì)它進(jìn)行了定制,所以必須要自己處理它。本來(lái) SC_CLOSE 是退出程序,但例子程序我們把它的行為改寫成隱藏對(duì)話框,也就是將應(yīng)用變成一個(gè)托盤小圖標(biāo),處理例程見(jiàn) OnClose() 函數(shù)。如果傳入的菜單ID不等于任何定制的菜單項(xiàng),那么就讓 Windows 對(duì)它進(jìn)行默認(rèn)處理: CDialog::OnSysCommand(nID, lParam);
下面是幾個(gè)最常用的系統(tǒng)菜單命令:
菜單 說(shuō)明
SC_CLOSE 關(guān)閉 CWnd 對(duì)象
SC_MAXIMIZE 或者 SC_ZOOM 最大化 CWnd 對(duì)象
SC_MINIMIZE 或者 SC_ICON 最小化 CWnd 對(duì)象
SC_MOVE 移動(dòng) CWnd 對(duì)象
SC_RESTORE 恢復(fù)窗口的正常位置和大小
SC_SIZE 改變 CWnd 對(duì)象大小
其它的幾個(gè)系統(tǒng)菜單命令一般都是在特殊情況下才使用,有關(guān)細(xì)節(jié)請(qǐng)參考有關(guān) WM_SYSCOMMAND 的文檔。
修改現(xiàn)有的菜單命令
我們已經(jīng)看到,系統(tǒng)菜單本身默認(rèn)的處理行為是可以改變的,除此之外,系統(tǒng)菜單項(xiàng)的描述文本也是可以改變的,甚至還可以刪除它們。為了修改才單命令的描述文本,我們可以用 pSysMenu 指針調(diào)用 ModifyMenu() 函數(shù)。例如,如果想要把“關(guān)閉”菜單項(xiàng)改成“隱藏”,可以象下面這么做:
pSysMenu->ModifyMenu(SC_CLOSE, MF_BYCOMMAND,IDM_HIDE, "隱藏(&H)");
MF_BYCOMMAND 參數(shù)告訴該函數(shù)將 SC_CLOSE 解釋為命令 ID。IDM_HIDE 是新的菜單 ID。最后一個(gè)參數(shù)是菜單項(xiàng)的說(shuō)明文本。還有一種調(diào)用 ModifyMenu() 的方法是使用 菜單項(xiàng)索引作為參數(shù):
pSysMenu->ModifyMenu(0,MF_BYPOSITION,IDM_HIDE,"隱藏(&H)");
第一個(gè)參數(shù) 0 表示菜單項(xiàng)的索引,指第一個(gè)菜單。
刪除菜單命令
例子程序擬將去掉系統(tǒng)菜單中的窗口“關(guān)閉”命令,暫且不說(shuō)這樣做是否合適,但是我能做到這一點(diǎn):
pSysMenu->RemoveMenu(SC_CLOSE,MF_BYCOMMMAND);
pSysMenu->RemoveMenu(0,MF_BYPOSITION);
第一行代碼刪除了與 SC_CLOSE 關(guān)聯(lián)的菜單命令。而第二行代碼表示刪除系統(tǒng)菜單命令中的第一項(xiàng)。
用這種方式修改系統(tǒng)菜單盡管限定了應(yīng)用程序的某些行為,但對(duì)于小型應(yīng)用和實(shí)用程序來(lái)說(shuō)有時(shí)是很有用的,尤其是當(dāng)你想要從任務(wù)欄存取菜單命令時(shí)----也就是程序在后臺(tái)運(yùn)行或者以最小化方式運(yùn)行,右鍵單擊任務(wù)欄圖標(biāo)將彈出系統(tǒng)菜單。
如果對(duì)話框或視類的大小調(diào)后,控件的大小和位置沒(méi)有變化,界面看起來(lái)會(huì)很不爽
控件是從CWnd派生的,但不能使用SetWindowPos()或OnSize()或OnSizing()來(lái)改變其大小,應(yīng)在父窗口的WM_SIZE消息中使用MoveWindow()來(lái)進(jìn)行調(diào)整。
VC++之根據(jù)對(duì)話框大小調(diào)整控件大小
1、在對(duì)話框類中加入成員變量CRect m_rect;用于保存對(duì)話框大小變化前的大小;
2、在對(duì)話框的OnInitDialog()函數(shù)中獲取對(duì)話框創(chuàng)建時(shí)的大?。篏etClientRect(&m_rect);
3、在WM_SIZE的響應(yīng)函數(shù)OnSize()中加入以下代碼:
if(nType!=SIZE_MINIMIZED )
{
CWnd *pWnd;
}
聯(lián)系客服