用C++開發WM應用系列文章索引
引言:
這年過得,特別鬱悶,感覺回到了經濟大蕭條時期~~~~好冷清,不過也好有閒情逸緻來寫部落格~嘻嘻。今天呢,就通過一個旋轉螢幕處理的小例子,來和大家一起複習一下MFC的使用等基本操作。
本文:
回顧以前幾篇文章,我們基本上瞭解了MFC應用程式嚮導的用處,今天,我們也不例外,還是開啟vs,建立一個c++下的智慧型裝置項目,選用MFC智慧型裝置應用程式模板,我們的項目起名就叫做“ScreenMng”吧,之後是我選用WM5 For PPC的SDK,然後“基於對話方塊”,最後確認一下,整個項目的架構就搭好了!
然後,開啟資源檢視視窗,對我們的對話方塊進行如下設計:
也是非常的簡單吧,每個按鈕對應了一個角度,待稍侯為他們添加旋轉代碼時,好辨認。
我們為按鈕添加事件處理常式吧,如:
這是處理九十度旋轉的按鈕嚮導介面,相信大家並不陌生了!我們為四個按鈕分別添加他們的"BN_CLICKED"事件。在接下來的內容中,我們要瞭解兩個重要的知識:
1、DEVMODE結構體,這是啥玩意兒呢?他比較重要,從名稱大致可以猜出,他和裝置的某種模式有關,而在這裡,此模式也可以理解成為顯示模式,當然,這種解釋還不是完全的正確,具體介紹請參看MSDN的連結http://msdn.microsoft.com/en-us/library/dd183565(VS.85).aspx 這裡已經詳細的告訴了我們,這個結構體中每個屬性的作用及用法,這樣一來,我們也就解決了大部分主要困難,既然我們可以定義一個結構體來描述裝置的顯示模式,那麼,下一步,當然是告訴裝置去根據定義的結構體來切換顯示模式了吧~
2、ChangeDisplaySettingsEx函數,這又是我們學到的一個“新”玩意兒,其實,如果你曾經看到過MSDN的這篇文章,相信你就大概明白了!中文內容,我就不多說了,這個函數的使用很簡單,配合上面那個結構體,傳入定義好的DEVMODE結構體以及其他幾個“可Null”參數,我們就可以讓裝置切換到我們想要的顯示模式了!此函數的MSDN說明地址如下:http://msdn.microsoft.com/en-us/library/aa923082.aspx,其實很簡單的~~~~
OK,在準備好了這兩個知識點後,剩下來的事情就很簡單了,首先,為每個按鈕函數定義一個特定的結構體,指明單擊按鈕後,需要裝置切換成何種顯示模式。其次,使用函數改變當前的顯示模式。
主要的函數代碼如下,我們以90度按鈕為例:
旋轉90度代碼
void CScreenMngDlg::OnBnClickedButton90()
{
// TODO: 在此添加控制項通知處理常式代碼
DEVMODE devmode = {0};
devmode.dmSize = sizeof(DEVMODE);
devmode.dmDisplayOrientation = DMDO_90; //旋轉90度
devmode.dmFields = DM_DISPLAYORIENTATION;
ChangeDisplaySettingsEx(NULL, &devmode, NULL, 0, NULL);
PrepScreen();
}
可以看到,還有一個PrepScreen()方法,這個方法其實也就是一個UI更新方法,主要是在一個Static控制項上,顯示當前的顯示模式,代碼如下,特簡單:
PrepScreen代碼
// 準備螢幕公用函數
void CScreenMngDlg::PrepScreen(void)
{
CString b;
//取得當前模式
DEVMODE devmode = {0};
devmode.dmSize = sizeof(DEVMODE);
devmode.dmFields = DM_DISPLAYORIENTATION;
ChangeDisplaySettingsEx(NULL, &devmode, 0, CDS_TEST, NULL);
switch(devmode.dmDisplayOrientation)
{
case DMDO_0:
b=_T("0度/預設模式");
break;
case DMDO_90:
b=_T("90度/水平模式");
break;
case DMDO_180:
b=_T("180度/垂直模式");
break;
case DMDO_270:
b=_T("270度/倒立模式");
break;
}
State.SetWindowText(b);
}
需要說明的是,那個State變數,是添加在Static1控制項上的一個控制項變數,你別說不知道如何添加啊~~~汗~~~,在這個函數中,我們也學會了如何取當前顯示模式了,對吧!
至此,整個例子接近尾聲,在我點擊270按鈕後,模擬器橫屏,證明程式無誤,可是,當我關閉程式是,裝置還是停留在270顯示模式,暈~這個尾巴留大了!於是,我想到OnClose函數,順其自然地,我為對話方塊添加了OnClose訊息處理常式,方法是:在資源檢視中,單擊對話方塊任意一個空白地區,在右側出現的屬性視窗,選擇訊息表徵圖,在找到"WM_OnClose",選擇添加OnClose函數,如:
然後,回到代碼實現檔案,把下面這段代碼添加進去,我想各位和我想的差不多吧:
OnClose代碼
void CScreenMngDlg::OnClose()
{
// TODO: 在此添加訊息處理常式代碼和/或調用預設值
DEVMODE devmode = {0};
devmode.dmSize = sizeof(DEVMODE);
devmode.dmDisplayOrientation = DMDO_0; //回到預設狀態
devmode.dmFields = DM_DISPLAYORIENTATION;
ChangeDisplaySettingsEx(NULL, &devmode, NULL, 0, NULL);
PrepScreen();
CDialog::OnClose();
}
但是,現實是殘酷的,我測試了一下,這段代碼在我關閉表單時沒有任何作用,裝置還是橫著,於是,我上網尋找資料,發現一個有趣的東東:OnClose和OnDestroy,至此,我也收穫了不少,看完之後,我又對對話方塊表單添加了OnDestroy訊息處理函數,把相同的代碼從OnClose中拷貝到了OnDestroy中,這才順利讓裝置在關閉程式後恢複正常顯示:
OnDestroy代碼
void CScreenMngDlg::OnDestroy()
{
CDialog::OnDestroy();
// TODO: 在此處添加訊息處理常式代碼
DEVMODE devmode = {0};
devmode.dmSize = sizeof(DEVMODE);
devmode.dmDisplayOrientation = DMDO_0; //回到預設狀態
devmode.dmFields = DM_DISPLAYORIENTATION;
ChangeDisplaySettingsEx(NULL, &devmode, NULL, 0, NULL);
PrepScreen();
}
總結:
1、在今天的這篇文章中,我們又複習了一遍建立MFC程式的步驟,添加控制項,為控制項添加處理常式,添加變數!
2、我們還學習了DEVMODE結構體以及ChangeDisplaySettingsEx函數的簡單使用。
3、我們學會了為表單添加訊息處理常式,諸如:OnClose和OnDestroy
4、最後,我們還瞭解了一下OnClose和OnDestroy的一些區別和聯絡。
附上本次例子的項目代碼:點此查看