英昌盛
(吉林師范大學計算機學院,吉林四平 136000)
?
基于MFC的半透明窗口設計與實現
英昌盛
(吉林師范大學計算機學院,吉林四平 136000)
在對工業檢測結果進行實時顯示過程中,用戶常常需要對檢測的某些數據點進行觀察和分析,并根據分析的結果進行相應處理。在不影響顯示檢測結果的同時,檢測軟件還需要實時提供被選定的檢測點信息,這些信息不應該占用屏幕上固定區域,而應該隨被選定點的變化而浮動顯示。本文基于MFC設計了跟隨鼠標位置浮動顯示選定檢測點信息的半透明提示窗口,使軟件更人性化的同時提高了用戶處理檢測結果的效率。
實時;選定;浮動;半透明
隨著信息化的推進,光電檢測發揮著愈來愈重要的作用。光電檢測系統由前端檢測和后端顯示處理兩部分構成。檢測部分主要負責待檢測內容,經由光學系統、光電轉換系統,將光信號轉換成電信號;然后在系統內部經放大、模/數轉換之后形成數字化信號,從而構成一維或二維的數字信號;顯示處理部分則負責處理經電纜傳遞過來的數字信號,并以圖形或圖像的形式將檢測結果呈現給用戶。為了方便用戶處理,并給用戶更好的體驗,需要將檢測結果以簡潔明要的形式表現出來,同時將用戶關心的信息及時提供給用戶。一維數字信號通常以曲線形式呈現,而二維信號則通常以灰度圖像形式呈現。用戶關心的通常是某一檢測點的數據值或灰度值,可以使用半透明浮動窗口的形式動態向用戶呈現所選擇的數據點的信息。
1.1 顯示結果分析
檢測軟件的顯示界面通常如圖1所示。其由框架區域、顯示檢測結果對應的曲線區域和浮動顯示的動態數據區域等幾個部分構成。

圖1 檢測軟件的通常界面
框架區域是整個軟件的顯示容器;檢測結果對應的曲線區域由坐標系統和數據曲線兩部分構成,若檢測結果為二維信號則應顯示圖像的灰度信息;浮動顯示數據區提供用戶選定的檢測點相關信息,通常跟隨鼠標浮動實時顯示,同時為不遮住其下方的曲線及其它內容,需以半透明的方式呈現。
根據檢測軟件常用界面及要求,可以設計帶浮動信息提示窗口的檢測軟件布局[1],如圖2所示。其由主對話框、顯示曲線的靜態文本區域和顯示浮動區域的子對話框構成。

圖2 檢測軟件的界面構成

圖3 半透明提示窗口的布局
1.2 實現原理
對于框架,可以使用MFC中的對話框來實現;對于檢測結果顯示區域,則需要將MFC中的靜態文本采用子類化技術來完成;對于浮動區域,則仍需要使用對話框來實現。
檢測結果的可視化分為兩部分:擴展CStatic類形成一個能夠自我重繪的子類,在該子類中完成坐標系及相應檢測數據的繪制工作;MFC中的CStatic控件與該擴展子類進行關聯以實現子類化,從而完成檢測結果的顯示及繪制。
對于浮動窗口則需要解決兩個問題:一是半透明;一是實時浮動顯示相應內容。對于半透明,可以使用Windows提供的SetLayeredWindowAttributes函數,借助層次化來實現。對于數據的動態顯示及窗口浮動,則需要建立主對話框與浮動對話框之間的數據關聯及消息響應來實現[2]。
創建基于對話框的MFC應用程序,在對話框中刪除原有控件,然后添加一個靜態文本控件,同時添加一個新的對話框,并將其設置為無邊框風格。
2.1 檢測數據顯示實現
將已經編寫好的自定義數據顯示類CDataShow類添加到項目中,并在相應的文件中添加對其頭文件的引用。CDataShow類主要完成與主對話框類進行數據交換、繪制坐標系統以及曲線的實時繪制等工作,同時還需要與半透明提示窗口時行消息傳遞。
2.2 半透明窗口實現原理
在MFC中,可以借助user32.dll提供的SetLayeredWindowAttributes函數來實現層次化,通過層次化來創建半透明窗口。用于實現半透明窗口的對話框不能使用邊框,而且應該添加一個靜態文本控件用于顯示數據點信息,其布局如圖3所示。
2.3 半透明窗口實現
以子對話框為基礎,創建一個新的對話框類CMyTextDlg,同時需要對該類添加重寫虛函數OnInitDialog。在對話框初始化函數中,使用SetWindowLong函數設置子對話框窗口風格[3]為WS_EX_LAYERED(0x00080000);設置好該風格之后,就可以調用SetLayeredWindowAttributes函數來透明化窗口。透明化窗口之后,還需要將其設置為頂層窗體,同時取消其在任務欄中的圖標顯示。
BOOL CMyTextDlg::OnInitDialog()
{
……
SetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE,GetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE)|WS_EX_LAYERED);
……
ModifyStyleEx(WS_EX_APPWINDOW,WS_EX_TOOLWINDOW,SWP_FRAMECHANGED);
::SetWindowPos(m_hWnd,HWND_TOPMOST,0,0,0,0,SWP_NOSIZE|SWP_NOMOVE);
……
}
為在提示窗口中動態顯示提示信息,需要為CMyTextDlg類添加自定義公共函數SetText。
voidCMyTextDlg::SetText(CStringStr)
{
SetDlgItemText(IDC_INFO,Str);
}
在主對話框中使用子對話框作為提示窗口時,需要在其頭文件中添加對子對話框類的引用,同時定義與之對應的對象指針和標志量。
CMyTextDlg *m_pDlgAlpha;
BOOL m_bIsCap;
因用戶感興趣的數據均處于檢測結果的繪制區域,當鼠標不在該區域內時不應顯示提示窗口。所以需要捕獲主對話框的鼠標按下及移動事件,并添加相應的消息響應函數。
voidCmyTestDlg::OnLButtonDown(UINT nFlags,CPoint point)
{
m_bIsCap=TRUE;
if(!m_pDlgAlpha)
{
m_pDlgAlpha=new CMyTextDlg;
m_pDlgAlpha->Create(CMyTextDlg::IDD,CWnd::FromHandle(::GetDesktopWindow()));
}
CDialog::OnLButtonDown(nFlags, point);
}
voidCmyTestDlg::OnLButtonUp(UINT nFlags, CPoint point)
{
if(m_pDlgAlpha)
{
m_pDlgAlpha->ShowWindow(SW_HIDE);
deletem_pDlgAlpha;m_pDlgAlpha=NULL;
}
m_bIsCap=FALSE;
CDialog::OnLButtonUp(nFlags, point);
}
voidCmyTestDlg::OnMouseMove(UINT nFlags, CPoint point)
{
……
CStringstr=_T("");
str.Format(_T("坐標:(%d,%d)"),pnt.x,pnt.y);
ShowTips(color,str);
……
}
為主對話框添加公共函數void ShowTips(CStringStr),通過子對話框指針設置其中的提示文本,并根據文本的高度及寬度動態調整了對話框的大小。
voidCmyTestDlg::ShowTips(CStringStr )
{
……
HWND DeskHwnd = ::GetDesktopWindow(); //取得桌面句柄
HDC DeskDC= ::GetWindowDC(DeskHwnd);
CDC *pDC=CDC::FromHandle(DeskDC);
CSizesSize=pDC->GetTextExtent(Str);//獲得文字的寬和高
m_pDlgAlpha->MoveWindow(pnt.x+10,pnt.y,sSize.cx,sSize.cy);
m_pDlgAlpha->SetText(Str);
m_pDlgAlpha->ShowWindow(SW_SHOW);
ReleaseDC(pDC);
::ReleaseDC(m_hWnd,DeskDC);
}
經實際測試,檢測軟件在顯示檢測結果曲線的同時,能夠實時浮動顯示用戶選定的檢測數據點信息,改善并提高了用戶的使用體驗。
[1]聶斐,殷興輝.基于MFC的實時數據動態顯示界面設計[J].電子設計工程,2013(10):136-138.
[2]楊剛.基于MFC用戶界面設計主、子對話框數據的傳遞[J].機電產品開發與創新,2005(6):98-99.
[3]孫鑫,余安萍.Visual C++深入詳解[M].北京:電子工業出版社,2006.
Designing and Implementation of Semitransparent Window Based on MFC
YING Chang-sheng
(Jilin Normal University, Siping Jilin 136000, China)
In the duration of displaying the detected industrial result, users often need to analyze some detected points and do some corresponding process according to the analysis. Detecting software should also provide information of selected detecting points, as well as showing the detecting result. The information should be displayed in a floating region and should not occupy display region. Our software displays the information of selected points in a semitransparent floating window based on MFC, which providing a kindly user interface.
real time; selected; floating; semitransparent

2016-03-29
英昌盛(1979- ),男,講師,從事算法與圖像處理研究。
TP312
A
2095-7602(2016)08-0038-04