『原創』用C++開發WM應用系列(4)——處理旋轉螢幕

來源:互聯網
上載者:User

用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的一些區別和聯絡。

附上本次例子的項目代碼:點此查看

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.