(101) 改變LVIS_SELECTED的狀態(tài)顏色?
我想將CListCtrl項和CTreeCtrl項在LVIS_SELECTED狀態(tài)時的顏色變灰.
方法一:查找函數(shù)CustomDraw,它是IE4提供的公共控制,允許有你自己的代碼.
方法二:生成一個draw控件,然后在DrawItem中處理文本顏色.
(102) 如何只存儲文檔的某一部分?
我只想存儲文檔的某一部分,能否象使用文件一樣使用文檔?(也就是有定位函數(shù)).將每個CArchive類設(shè)置為CFile類的派生類,這樣你就能使用Seek等成員函數(shù).
(103) 保存工具條菜單有bug嗎?
使 用浮動菜單條時,SaveBarState和LoadBarState出現(xiàn)了問題.如果菜單是浮動的,重起應(yīng)用程序時它會出現(xiàn)在左上角,而它固定在屏幕其 它位置時,下一次啟動就會出現(xiàn)在該位置,這是什么原因?你試試這個PToolBar->Create(this,..., ID_MYTOOLBAR);
你的工具條需要包括id,而不是象默認的工具條那樣.
(104) Tip of the day的bug
我 創(chuàng)建了一個簡單的mdi應(yīng)用程序,使用.BSF(自定義的文檔擴展名)作為它的文檔我保存一個foo.bsf文檔后,可以在資源管理器中雙擊該文件打開 mdi應(yīng)用程序同時打開foo.bsf文檔.但當(dāng)我給mdi應(yīng)用程序加上a tip of the day組件之后,從資源管理器中雙擊foo.bsf后,就會給我一個警告:ASSERT(::IsWindow(m_hWnd)),然后mdi應(yīng)用程序就 死那了.
當(dāng)從dde啟動應(yīng)用程序(例如:雙擊相關(guān)文檔)時,"Tip of the Day"是有bug的.你可以看看函數(shù)"ShowTipAtStartup",它在"InitInstance"中調(diào)用,可以看到tip of the day作為一個模式對話框顯示,在處理其它消息時它一直進行消息循環(huán)你可心修改ShowTipAtStartup使其從dde啟動時不出現(xiàn)tip of the day.
void CTipOfApp::ShowTipAtStartup(void)
{
// CG: This function added by 'Tip of the Day' component.
CCommandLineInfo cmdInfo;
ParseCommandLine(cmdInfo);
if (
cmdInfo.m_bShowSplash &&
cmdInfo.m_nShellCommand != CCommandLineInf:FileDDE
)
{
CTipDlg dlg;
if (dlg.m_bStartup)
dlg.DoModal();
}
}
如果還有其它bug,你可以設(shè)定cmdInfo.m_nShellCommand的過濾.
(105) 如何可以讓我的程序可以顯示在其它的窗口上面?
讓用戶選擇"總是在最上面"最好是在系統(tǒng)菜單里加入一個選項.可以通過修改WM_SYSCOMMAND消息來發(fā)送用戶的選擇.菜單的命令標(biāo)識(id)會作為一個參數(shù)傳給OnSysCommand().要定義標(biāo)識(id),將如下代碼加入到CMainFrame.CPP中:
#define WM_ALWAYSONTOP WM_USER + 1
將"總在最上面"的菜單項加入到系統(tǒng)菜單中,將如下代碼加入到函數(shù)CMainFrame::OnCreate()中:
CMenu* pSysMenu = GetSystemMenu(FALSE);
pSysMenu->AppendMenu(MF_SEPARATOR);
pSysMenu->AppendMenu(MF_STRING, WM_ALWAYSONTOP,
"&Always On Top");
使用ClassWizard,加入對WM_SYSCOMMAND消息的處理,你應(yīng)該改變消息過濾器,使用系統(tǒng)可以處理這個消息.
void CMainFrame::OnSysCommand(UINT nID, LPARAM lParam)
{
switch ( nID )
{
case WM_ALWAYSONTOP:
if ( GetExStyle() & WS_EX_TOPMOST )
{
SetWindowPos(&wndNoTopMost, 0, 0, 0, 0,
SWP_NOSIZE | SWP_NOMOVE);
GetSystemMenu(FALSE)->CheckMenuItem(WM_ALWAYSONTOP,
MF_UNCHECKED);
}
else
{
SetWindowPos(&wndTopMost, 0, 0, 0, 0,
SWP_NOSIZE | SWP_NOMOVE);
GetSystemMenu(FALSE)->CheckMenuItem(WM_ALWAYSONTOP,MF_CHECKED);
}
break;
default:
CFrameWnd::OnSysCommand(nID, lParam);
}
}
(106) 如何控制窗口框架的最大最小尺寸?
要控制一個框架的的最大最小尺寸,你需要做兩件事情.在CFrameWnd的繼承類中處理消息WM_GETMINMAXINFO,結(jié)構(gòu)MINMAXINFO設(shè)置了整個窗口類的限制,因此記住要考慮工具條,卷動條等等的大小.
// 最大最小尺寸的象素點 - 示例
#define MINX 200
#define MINY 300
#define MAXX 300
#define MAXY 400
void CMyFrameWnd::OnGetMinMaxInfo(MINMAXINFO FAR* lpMMI)
{
CRect rectWindow;
GetWindowRect(&rectWindow);
CRect rectClient;
GetClientRect(&rectClient);
// get offset of toolbars, scrollbars, etc.
int nWidthOffset = rectWindow.Width() - rectClient.Width();
int nHeightOffset = rectWindow.Height() - rectClient.Height();
lpMMI->ptMinTrackSize.x = MINX + nWidthOffset;
lpMMI->ptMinTrackSize.y = MINY + nHeightOffset;
lpMMI->ptMaxTrackSize.x = MAXX + nWidthOffset;
lpMMI->ptMaxTrackSize.y = MAXY + nHeightOffset;
}
第二步,在CFrameWnd的繼承類的PreCreateWindow函數(shù)中去掉WS_MAXIMIZEBOX消息,否則在最大化時你將得不到預(yù)料的結(jié)果.
BOOL CMyFrameWnd::PreCreateWindow(CREATESTRUCT& cs)
{
cs.style &= ~WS_MAXIMIZEBOX;
return CFrameWnd::PreCreateWindow(cs);
}
(107) 如何改變窗口框架的顏色?
MDI框架的客戶區(qū)被另一個窗口的框架所覆蓋.為了改變客戶區(qū)的背景色,你需要重畫這個客戶窗口.為了做到這點,你要處理消息WM_ERASEBKND產(chǎn)生一個新類,從CWnd繼承,姑且稱之為CMDIClient.給它加上一個成員變量,
#include "MDIClient.h"
class CMainFrame : public CMDIFrameWnd
{
...
protected:
CMDIClient m_wndMDIClient;
}
在CMainFrame中重載CMDIFrameWnd::OnCreateClient
BOOL CMainFrame::OnCreateClient(LPCREATESTRUCT lpcs, CCreateContext* pContext)
{
if ( CMDIFrameWnd::OnCreateClient(lpcs, pContext) )
{
m_wndMDIClient.SubclassWindow(m_hWndMDIClient);
return TRUE;
}
else
return FALSE;
}
然后就可以加入對消息WM_ERASEBKGND的處理了.
(108) 如何將應(yīng)用程序窗口置于屏幕正中?
要將你的應(yīng)用程序窗口放置在屏幕正中央,只須在MainFrame的OnCreate函數(shù)中加入:
CenterWindow( GetDesktopWindow() );