免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
對(duì)話框大小調(diào)整
一個(gè)可以自動(dòng)改變控件位置和大小的對(duì)話框類。從這個(gè)類繼承的對(duì)話框類,只要在OnInitDialog()里寫幾行簡(jiǎn)單的代碼,對(duì)話框上的控件就會(huì)隨著對(duì)話框大小的改變而改變自己的位置和大小。

        在用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;
}

 

posted @ 2008-10-15 22:25 jcss 閱讀(189) | 評(píng)論 (0)編輯

一、簡(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

posted @ 2008-10-15 22:02 jcss 閱讀(109) | 評(píng)論 (0)編輯
窗口右上角的三個(gè)圖標(biāo)(是否顯示)可通過(guò) 屬性 中的 Maximize, Minimize, System Menu 更改
posted @ 2008-10-15 21:28 jcss 閱讀(63) | 評(píng)論 (0)編輯

   //不知轉(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)菜單。

posted @ 2008-10-15 21:22 jcss 閱讀(34) | 評(píng)論 (0)編輯
位圖按鈕的實(shí)現(xiàn)方法:  
  首先,我們創(chuàng)建一個(gè)基于對(duì)話框的應(yīng)用程序CmyDialog   ;  
  Ι.MFC的CBitmapButton類,這也是最簡(jiǎn)單的功能最強(qiáng)的位圖按鈕。我們可以采取如下的步驟:  
  1. 為按鈕指定唯一的按鈕標(biāo)題(此例子為OK按鈕,這里設(shè)置按鈕標(biāo)題為OK)并選中Ownerdraw屬性,然后在項(xiàng)目中加一些位圖資源,并用名字標(biāo)示這些資源而不要用數(shù)字ID,其ID分別為”OKU”、”OKD”、”OKF”、”OKX”(一定要加雙引號(hào)),分別對(duì)應(yīng)于按鈕的“松開(kāi)(Up)”、“按下(Down)”、“獲得輸入焦點(diǎn)(focused)”和“禁止(Disable)”狀態(tài)。  
  2. 我們還要在對(duì)話框類中加入CBitmapButton   m_aBmpBtn;數(shù)據(jù)成員。  
  3. 在初始化中為這個(gè)成員調(diào)用:    
                              …  
  m_aBmpBtn.   AutoLoad(IDOK,this);  
  …  
  點(diǎn)擊編譯按鈕,成功后運(yùn)行程序,哈哈,看看效果,我們的位圖按鈕已經(jīng)建立了。  
  /*如果以上方法不行請(qǐng)檢查你的BITMAP   資源,APPSTUDIO中,"OKU"和   "OKD"   等的資源名稱都是需要用引號(hào)引起來(lái)的,   AutoLoad不成功,很可能就是由此產(chǎn)生的。     */  
  改變CANCLE按鈕的標(biāo)題,可以設(shè)置其標(biāo)題為ICON或者BITMAP   :(這里我們演示了bitmap的用法,Icon按鈕讀者可以按照下面的代碼處理)  
  Ⅱ.使用圖標(biāo)制作按鈕  
  1. 打開(kāi)ICON按鈕的屬性頁(yè),在Style中選中Icon   。  
  2. 在對(duì)話框類的頭文件中定義成員變量(使用ClassWizard加入這個(gè)成員變量)  
  CButton   m_   IconBtn;//對(duì)應(yīng)于圖標(biāo)按鈕  
  3. 創(chuàng)建相應(yīng)的圖標(biāo)或者位圖資源:  
  圖標(biāo)資源:IDI_ICONBUTTON  
  4.在初始化中加入如下代碼:    
  …  
  //對(duì)應(yīng)于圖標(biāo)按鈕  
  HICON   hIcon=AfxGetApp()->LoadIcon(IDI_   ICONBUTTON);  
  m_IconBtn.SetIcon(hIcon);  
  …  
  重新編譯運(yùn)行我們的程序,奇妙的圖像按鈕呈現(xiàn)在我們的眼前了。  
  Ⅲ.使用位圖制作按鈕  
  1. 打開(kāi)BITMAP按鈕的屬性頁(yè),在Style中選中Bitmap。  
  2. 對(duì)話框類的頭文件中定義成員變量(使用ClassWizard加入這個(gè)成員變量)  
                              CButton   m_IconBtn;  
  3.創(chuàng)建位圖資源:  
  位圖資源:IDB_BITMAPBUTTON  
  4.在初始化中加入如下代碼:    
  //對(duì)應(yīng)于位圖按鈕  
  …  
  HBITMAP   hBmp=::LoadBitmap(AfxGetInstanceHandle(),  
  MAKEINTRESOURCE(IDB_   BITMAPBUTTON));  
  m_BmpBtn.SetBitmap(hBmp);  
posted @ 2008-10-15 14:48 jcss 閱讀(66) | 評(píng)論 (0)編輯

如果對(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;

 pWnd = GetDlgItem(IDC_LIST);     //獲取控件句柄
 if(pWnd)//判斷是否為空,因?yàn)閷?duì)話框創(chuàng)建時(shí)會(huì)調(diào)用此函數(shù),而當(dāng)時(shí)控件還未創(chuàng)建
 {
  CRect rect;   
//獲取控件變化前大小
  pWnd->GetWindowRect(&rect);
  ScreenToClient(
&rect);//將控件大小轉(zhuǎn)換為在對(duì)話框中的區(qū)域坐標(biāo)
  
// cx/m_rect.Width()為對(duì)話框在橫向的變化比例
  rect.left=rect.left*cx/m_rect.Width();/////調(diào)整控件大小
  rect.right=rect.right*cx/m_rect.Width();
  rect.top
=rect.top*cy/m_rect.Height();
  rect.bottom
=rect.bottom*cy/m_rect.Height();
  pWnd
->MoveWindow(rect);//設(shè)置控件大小
 }

 GetClientRect(
&m_rect);//將變化后的對(duì)話框大小設(shè)為舊大小

}

本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
CStatic控件的基本使用
對(duì)話框控件背景、字體顏色設(shè)置?(轉(zhuǎn))
MFC
wx python 基本控件
MFC控件隨窗口大小變化,多次縮放不改變位置
控件大小隨窗口變化的方法(MFC)
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服