VC++介面程式設計總結
阿新 • • 發佈:2018-11-03
分享一下我老師大神的人工智慧教程!零基礎,通俗易懂!http://blog.csdn.net/jiangjunshow
也歡迎大家轉載本篇文章。分享知識,造福人民,實現我們中華民族偉大復興!
一、改變檢視背景色:在CView的OnDraw函式中添寫如下一段程式程式碼:
void CFileNameView::OnDraw(CDC* pDC)
{
CFileNameDoc* pDoc = GetDocument();
ASSERT_VALID(pDoc);
CRect rectClient;
CBrush brushBkColor;
GetClientRect(rectClient);
brushBkColor.CreateSolidBrush(RGB(255,0,0)); //顏色設定
pDC->DPtoLP(rectClient);
pDC->FillRect(rectClient,&brushBkColor);
…
}
二、往基於對話方塊的程式新增選單:
[1] 先新增選單(IDR_MENU1)資源,並加上需要的選單項。
[2] 編輯對話方塊資源IDD_DLGMENUTOOLBAR_DIALOG的屬性,在屬性對話方塊中選擇IDR_MENU1即可。
[3] 假如您不希望在對話方塊屬性中直接設定選單,而通過程式碼在程式中動態生成可以採用如下方法:
在CFileNameDlg類聲名中新增成員變數CMenu m_menu,再在CFileNameDlg::OnInitDialog() 中新增如下程式碼:
//載入選單
m_menu.LoadMenu(IDR_MENU1);
//設定當前選單
SetMenu(&m_menu);
//當你不需要選單時可以用 SetMenu(NULL);來取消當前選單
三、往基於Dialog的程式新增工具欄:
[1] 先新增工具欄(IDR_TOOLBAR1)資源,並畫好各個按鈕。
[2] 在CFileNameDlg類聲名中新增成員變數 CToolBar m_wndtoolbar;
[3] 在CFileNameDlg::OnInitDialog() 中新增如下程式碼
//新增一個平面工具條
if (!m_wndtoolbar.CreateEx( this,TBSTYLE_FLAT , WS_CHILD | WS_VISIBLE | CBRS_ALIGN_TOP | CBRS_GRIPPER | CBRS_TOOLTIPS, CRect(4,4,0,0)) || !m_wndtoolbar.LoadToolBar(IDR_TOOLBAR1) )
{
TRACE0("failed to create toolbar/n");
return FALSE;
}
m_wndtoolbar.ShowWindow(SW_SHOW);
RepositionBars(AFX_IDW_CONTROLBAR_FIRST, AFX_IDW_CONTROLBAR_LAST, 0);
四、改變對話方塊背景色:
在CDlgMenuToolbarDlg::OnPaint()中修改程式碼實現Dialog 填充顏色:
CPaintDC dc(this);
CRect rect;
GetClientRect(rect);
dc.FillSolidRect(rect, RGB(60,110,170));
方法二、在InitInstance()(不是OnInitDialog())中加入:
SetDialogBkColor(RGB(255,0,0),RGB(0,255,0));
注意:要放在InitInstance函式的最前面!
五、為dialog的工具欄新增工具提示:
[1] 在CFileNameDlg類定義中手工新增訊息對映函式的定義,如下黑體部分
//{{AFX_MSG(CFileNameDlg)
virtual BOOL OnInitDialog();
afx_msg void OnPaint();
afx_msg BOOL OnToolTipText(UINT, NMHDR* pNMHDR, LRESULT* pResult);
//}}AFX_MSG
DECLARE_MESSAGE_MAP()
[2] 在CFileNameDlg.cpp新增函式的實現程式碼
//工具欄提示
BOOL CFileNameDlg::OnToolTipText(UINT, NMHDR* pNMHDR, LRESULT* pResult)
{
ASSERT(pNMHDR->code == TTN_NEEDTEXTA || pNMHDR->code == TTN_NEEDTEXTW);
// UNICODE訊息
TOOLTIPTEXTA* pTTTA = (TOOLTIPTEXTA*)pNMHDR;
TOOLTIPTEXTW* pTTTW = (TOOLTIPTEXTW*)pNMHDR;
//TCHAR szFullText[512];
CString strTipText;
UINT nID = pNMHDR->idFrom;
if (pNMHDR->code == TTN_NEEDTEXTA && (pTTTA->uFlags & TTF_IDISHWND) ||
pNMHDR->code == TTN_NEEDTEXTW && (pTTTW->uFlags & TTF_IDISHWND))
{
// idFrom為工具條的HWND
nID = ::GetDlgCtrlID((HWND)nID);
}
if (nID != 0) //不為分隔符
{
strTipText.LoadString(nID);
strTipText = strTipText.Mid(strTipText.Find(’/n’,0)+1);
#ifndef _UNICODE
if (pNMHDR->code == TTN_NEEDTEXTA)
{
lstrcpyn(pTTTA->szText, strTipText, sizeof(pTTTA->szText));
}
else
{
_mbstowcsz(pTTTW->szText, strTipText, sizeof(pTTTW->szText));
}
#else
if (pNMHDR->code == TTN_NEEDTEXTA)
{
_wcstombsz(pTTTA->szText, strTipText,sizeof(pTTTA->szText));
}
else
{
lstrcpyn(pTTTW->szText, strTipText, sizeof(pTTTW->szText));
}
#endif
*pResult = 0;
// 使工具條提示視窗在最上面
::SetWindowPos(pNMHDR->hwndFrom, HWND_TOP, 0, 0, 0, 0,SWP_NOACTIVATE|
SWP_NOSIZE|SWP_NOMOVE|SWP_NOOWNERZORDER);
return TRUE;
}
return TRUE;
}
[3] 在CFileNameDlg.cpp中新增訊息對映,請看如下程式碼中的黑體部分
BEGIN_MESSAGE_MAP(CFileNameDlg, CDialog)
//{{AFX_MSG_MAP(CFileNameDlg)
ON_WM_PAINT()
ON_NOTIFY_EX( TTN_NEEDTEXT, 0, OnToolTipText )
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
[4] 在CFileNameDlg.h中新增宣告:
BOOL CFileNameDlg::OnToolTipText(UINT, NMHDR* pNMHDR, LRESULT* pResult);
六、給沒有工具欄的視窗新增工具欄:
在資源管理器中編輯工具欄,並將其屬性改為IDR_MAINFRAME,然後在MainFrm.h中宣告:
CToolBar m_wndToolBar;
在MainFrm.cpp中新增:
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
m_wndToolBar.Create(this);
m_wndToolBar.LoadToolBar(IDR_MAINFRAME);
……;
}
停靠工具欄:在剛才新增的後面加入下面程式碼:
m_wndToolBar.SetBarStyle(m_wndToolBar.GetBarStyle()|CBRS_TOOLTIPS|CBRS_SIZE_DYNAMIC);
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
EnableDocking(CBRS_ALIGN_ANY);
DockControlBar(&m_wndToolBar);//控制是否開啟任意停靠
完善一下功能:
在選單中新增一項“工具欄”,ID設為ID_VIEW_TOOLBAR,一切OK,試試吧!
七、建立分隔視窗:
只有框架類可以建立分隔,分隔可以巢狀。
在.h檔案中宣告 CSplitterWnd m_wndSplitter;並且包含COneView.h(新建檢視類)和CWinFrame.h(新建框架類)檔案;
然後在.cpp檔案中加入:
BOOL CMainFrame::OnCreateClient(LPCREATESTRUCT lpcs, CCreateContext* pContext)
{
if(!m_wndSplitter.CreateStatic(this,1,2))
return FALSE;
if(!m_wndSplitter.CreateView(0,0,RUNTIME_CLASS(COneView),CSize(240,420),pContext))
return FALSE;
if(!m_wndSplitter.CreateView(0,1,RUNTIME_CLASS(CWinFrame),CSize(300,500),pContext))
return FALSE;
return TRUE;
}
當用戶建立好分割視窗後,有時並不希望通過拖動切分條來調節視窗的大小。這時就必須鎖定切分條。鎖定切分條的最簡單的方法莫過於不讓 CSplitterWnd來處理WM_LBUTTONDOWN,WM_MOUSEMOVE,WM_SETCURSOR訊息,而是將這些訊息交給CWnd視窗進行處理,從而遮蔽掉這些訊息。拿WM_LBUTTONDOWN處理過程來說。修改為如下:
void CXXSplitterWnd::OnLButtonDown(UINT nFlags,CPoint point)
{
CWnd::OnLButtonDown(nFlags,point);
}
其餘的處理方法類似。
八、“開啟”按鈕的設定:
用類嚮導建立該按鈕的click函式,選擇預設值OnOpen,加入以下程式碼:
void CYourDlg::OnOpen()
{
char szFileFilter[]=
"BIN File(*.bin)|*.bin|"
"All File(*.*)|*.*||";//檔案型別過濾
CFileDialog dlg(TRUE,NULL,NULL,OFN_HIDEREADONLY,szFileFilter);
/* CFileDialog dlg(FALSE);
dlg.m_ofn .lpstrFilter =_T("文字檔案(*.txt)*.txt所有檔案(*.*)*.*");
dlg.m_ofn.lpstrDefExt=_T("txt"); */
if(dlg.DoModal()==IDOK)
{
m_path = dlg.GetPathName();//將顯示路徑的Edit控制元件命名為m_path,並增加CString變數m_path
UpdateData(FALSE);
}
}
九、視窗居中:
在初始化(OnInit)函式中增加:CenterWindow();即可
十、對話方塊加狀態條:
UINT indicators[]={ID_INITMESSAGE,ID_SEPARATOR,ID_TIMEMESSAGE,ID_PROGRESS};
m_statusbar.CreateEx(this,0,WS_CHILD | WS_VISIBLE | CBRS_BOTTOM);
m_statusbar.SetIndicators(indicators,4);
m_statusbar.ShowWindow (SW_SHOW);
RepositionBars(AFX_IDW_CONTROLBAR_FIRST, AFX_IDW_CONTROLBAR_LAST, 0);
十一、設定初始視窗狀態:
BOOL CObjectNameApp::InitInstance()
{
m_pMainWnd->SetWindowText(""); //設定初始視窗標題文字
m_pMainWnd->ShowWindow(SW_SHOWMAXIMIZED);//設定初始視窗為最大化
m_pMainWnd->UpdateWindow();
}
對於MDI函式SetWindowText無效,主視窗的標題只能在資源列表中修改,子視窗標題在**doc.cpp中過載OnNewDocument(),呼叫SetTitle("LGdownload中文版");來修改。
設定初始視窗最大化的另一優化方法:
void CMainFrame::ActivateFrame(int nCmdShow)
{
// TODO: Add your specialized code here and/or call the base class
nCmdShow=SW_MAXIMIZE;
CFrameWnd::ActivateFrame(nCmdShow);
}
十二、對話方塊透明特效:
在OnInitDialog()中加入以下程式碼:
//加入WS_EX_LAYERED擴充套件屬性
SetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE,
GetWindowLong(this->GetSafeHwnd(),GWL_EXSTYLE)^0x80000);
HINSTANCE hInst = LoadLibrary("User32.DLL");
if(hInst)
{
typedef BOOL (WINAPI *MYFUNC)(HWND,COLORREF,BYTE,DWORD);
MYFUNC fun = NULL;
//取得SetLayeredWindowAttributes函式指標
fun=(MYFUNC)GetProcAddress(hInst, "SetLayeredWindowAttributes");
if(fun)fun(this->GetSafeHwnd(),0,128,2);
FreeLibrary(hInst);
}
注意:fun的引數128不能太小,否則就完全透明瞭!
十三、設定對話方塊裡的STATIC控制元件顏色屬性:
在該對話方塊增加WM_CTLCOLOR事件,加入以下程式碼:
if( nCtlColor==CTLCOLOR_STATIC )
{
pDC->SetTextColor(RGB(255,255,255));
pDC->SetBkColor(RGB(91,145,244));
pDC->SetBkMode(TRANSPARENT); //設定透明
}
設定STATIC控制元件背景透明:
if( nCtlColor==CTLCOLOR_STATIC )
{
pDC->SetBkMode(TRANSPARENT); //設定透明
return (HBRUSH)::GetStockObject(NULL_BRUSH);
}
十四、使視窗的最大化和最小化按鈕消失:
在PreCreateWindow函式中新增以下程式碼即可:
int xSize = ::GetSystemMetrics( SM_CXSCREEN );
int ySize = ::GetSystemMetrics( SM_CYSCREEN );
cs.cx = xSize * 6 / 10;
cs.cy = ySize * 6 / 10;
cs.x = ( xSize - cs.cx ) / 2;
cs.y = ( ySize - cs.cy ) / 2;
cs.style &= ~WS_THICKFRAME;
cs.style &= ~( WS_MAXIMIZEBOX | WS_MINIMIZEBOX );
cs.dwExStyle |= WS_EX_TOOLWINDOW;
十五、設定控制元件字型顏色:(例如STATIC控制元件)
在OnCtlColor函式中新增如下程式碼:(可能需要選擇STATIC的簡單屬性)
if(nCtlColor==CTLCOLOR_STATIC)
{ pDC->SetTextColor(RGB(255,0,0));
pDC->SetBkColor(RGB(128,128,128));//設定文字背景色
pDC->SetBkMode(TRANSPARENT);//設定背景透明
}
其他控制元件的巨集定義為:
.CTLCOLOR_BTN 按鈕控制元件
.CTLCOLOR_DLG 對話方塊
.CTLCOLOR_EDIT 編輯框
.CTLCOLOR_LISTBOX 列表控制元件
.CTLCOLOR_MSGBOX 訊息控制元件
.CTLCOLOR_SCROLLBAR 滾動條控制元件
.CTLCOLOR_STATIC 靜態控制元件
十六、將字元轉換為數字:
int i = atoi("12345"); 或 sscanf("12345","%d",&i);
十七、呼叫外部應用程式可使用的函式:
CreateProcess、WinExec、ShellExecute。
例:ShellExecute(pWnd->m_wnd, "open", "my.exe", NULL, NULL, SW_NORMAL)
一、父窗體控制代碼,二、命令"open",三、檔案路徑,四、引數,五、執行路徑,六、顯示方式
十八、經典安裝程式製作軟體:InstallShield for Microsoft Visual C++6.0
release 方式是在build選單中的Set Active configuration中改
在project選單裡面,選Add to Project的component and control來加入ocx控制元件
十九、控制元件的註冊:
1.註冊
regsvr32 x:/xxx/demo.ocx 不一定非得在 Windows 系統目錄
2.解除安裝
regsvr32 /u x:/xxx/demo.ocx
二十、獲取當前時間:
CTime m_time=CTime::GetCurrentTime();
char szText[100];
memset(szText,0,100);
sprintf(szText,"%d_%d_%d",m_time.GetHour(),m_time.GetMinite(),m_time.GetSecond());
// 如何得到當前時間日期
CTime time = CTime::GetCurrentTime();
CString m_strTime = time.Format("%Y-%m-%d %H:%M:%S");
// 方法二
SYSTEMTIME ti;
GetSystemTime(&ti); // 如何得到當前時間日期
ti.wMilliseconds; // 得到毫秒時間
SYSTEMTIME time;
CString str;
GetLocalTime( &time );
str.Format( "%04d:%02d:%02d",time.wYear,time.wMonth.....);
二一、修改單文件程式的標題:
OnCreat()中加入 SetWindowText("weichao");
CMainFrame::PreCreateWindow(CREATESTRUCT& cs)中加入 cs.style =WS_OVERLAPPEDWINDOW;
二二、隱藏程式在工作列的圖示:
對話方塊程式放OnInitDialog()函式:
SetWindowLong(this->m_hWnd,GWL_EXSTYLE,WS_EX_TOOLWINDOW);//隱藏任務攔按鈕
二三、讀取編輯框內容:
GetDlgItemText(IDC_EDIT_TXDATA,m_strTXData);
二四、自繪選單寬度不對,高度是對的,解決辦法:
在ClassWizard中的ClassName下,選CMianFrame,在Messages下選WM_CONTEXTMENU並生成相應的函式,如下:
void CMainFrame::OnContextMenu(CWnd* pWnd, CPoint point)
{
CMenu menu;
menu.LoadMenu(IDR_MENU1);//IDR_MENU1是你要彈出選單的ID號.
CMenu *popup=menu.GetSubMenu(0);
popup->TrackPopupMenu(TPM_LEFTALIGN,point.x,point.y,this);
}
二五、重啟計算機:
呼叫一個API函式ExitWindowsEx就可以了, 兩個引數:UFlag,標記,可以選擇EWX_REBOOT,EWX_SHUTDOWN,EWX_POWEROFF再或上EWX_FORCE第二個引數就是0了
二六、無title對話方塊的移動:
void CScreenSnapDlg::OnLButtonDown(UINT nFlags, CPoint point)
{
//實現窗體無標題移動
PostMessage(WM_NCLBUTTONDOWN,HTCAPTION,MAKELPARAM(point.x,point.y));
CDialog::OnLButtonDown(nFlags, point);
}
二七、獲取作業系統版本:
OSVERSIONINFO OsVersionInfo;//包含作業系統版本資訊的資料結構
OsVersionInfo.dwOSVersionInfoSize= sizeof(OSVERSIONINFO);
GetVersionEx(&OsVersionInfo);//獲取作業系統版本資訊
二八、設定對話方塊為最頂層:(在OnInitDialog中新增)
SetWindowPos(&wndTopMost,0,0,0,0,SWP_NOMOVE|SWP_NOSIZE);
二九、對話方塊程式不在工作列顯示:(在OnInitDialog中新增)
ModifyStyleEx(WS_EX_APPWINDOW,WS_EX_TOOLWINDOW);
三十、向對話方塊視窗新增右鍵選單:
CMenu menu,*pmenu;
menu.LoadMenu(IDR_MENU1);
pmenu=menu.GetSubMenu(0);
CPoint ptScreen(point);
ClientToScreen(&ptScreen);
pmenu->TrackPopupMenu(TPM_RIGHTBUTTON,ptScreen.x,ptScreen.y,this);
三一、檔案查詢:(例查詢連續的換行符)
FILE *fp,*fp1;
int flag=0;
int ch;
fp=fopen("c://test.txt","r");
fp1=fopen("c://wrttest.txt","w");
while(!feof(fp))
{
ch=fgetc(fp);
if(feof(fp))
break;
if(ch==’/n’&&flag==1)
continue;
else if(ch==’/n’&&flag==0)
flag=1;
else
flag=0;
fputc(ch,fp1);
}
fclose(fp1);
fclose(fp);
三二、托盤選單不點選不能消失的解決辦法:
在選單之後使用下述程式碼:
CPoint pt;
GetCursorPos(&pt);
SetForegroundWindow();
NotifyMenu.TrackPopupMenu(TPM_RIGHTBUTTON,pt.x,pt.y,this);
PostMessage(WM_NULL,0,0);
三三、對話方塊由小到大顯示的動畫效果:
在InitDialog中增加:
ShowWindow(SW_HIDE);
CRect dlgRect;
GetClientRect(&dlgRect);
CPoint centerPoint;
centerPoint.x=dlgRect.Width()/2;
centerPoint.y=dlgRect.Height()/2;//得到對話方塊的中點座標
CRgn testrgn;
this->ShowWindow(SW_HIDE);
int m=GetSystemMetrics(SM_CYSIZEFRAME);
//以下程式碼實現對話方塊的動態彈出
for (int i=10;i<dlgRect.Width()/2+m;i+=1)
{
testrgn.CreateRectRgn(centerPoint.x-i,centerPoint.y-i,centerPoint.x+i,centerPoint.y+i);
SetWindowRgn((HRGN) testrgn,TRUE);
ShowWindow(SW_SHOW);
CenterWindow();
testrgn.DeleteObject();
}
三四、按行讀出文字檔案:
下面的例子演示了一行一行取,直到取完。
CStdioFile myFile;
CString ReadFileString;
if(myFile.Open("C://Readme.txt", Cfile::modeRead) == TRUE)
{
while(myFile.ReadString(ReadFileString) != FALSE)
{
//... 處理程式碼
}
}
三五、使用IDC_HAND時提示未定義,加入以下程式碼:
#if(WINVER >= 0x0500)
#define IDC_HAND MAKEINTRESOURCE(32649)
#endif /* WINVER >= 0x0500 */
三六、使應用程式啟動時不自動建立新文件
在預設情況下,用AppWizard開發的SDI/MDI應用程式在啟動時建立一個新的文件。如果要使應用程式在啟動時不建立新文件,只需在應用類 CmyApp::InitInstance()函式的ProcessShellCommand呼叫前加上下面的語句就可以了:
cmdInfo.m_nShellCommand = CComandLineInfo::FileNothing;
三七、播放mp3:
CFileDialog file(true);
if(file.DoModal()==IDOK)
{
CString filename=file.GetFileName();
if(hwnd!=NULL)
{
MCIWndDestroy(hwnd);
}
hwnd=MCIWndCreate(this->m_hWnd,NULL,MCIWNDF_NOPLAYBAR,filename);
::ShowWindow(hwnd,SW_HIDE);
MCIWndSetVolume(hwnd,1000);
MCIWndPlay(hwnd);
}
三八、獲取螢幕RGB值:OnTimer中新增
CPoint pos;
GetCursorPos(&pos);//獲取滑鼠座標
HDC hDC = ::GetDC(NULL);
COLORREF clr = ::GetPixel(hDC, pos.x, pos.y);
CString ClrText;
ClrText.Format("R:%d G:%d B:%d",GetRvalue(clr),GetGvalue(clr),GetBvalue(clr));
三九、開啟一個網址:
開啟[url]http://www.sina.com.cn[/url]這個站點如下:
ShellExecute(NULL, "open", "http://www.sina.com.cn",NULL, NULL, SW_MAXIMIZE );
此命令將以預設瀏覽器開啟[url]http://www.sina.com.cn[/url],並將加開後的視窗最大化。
又例:
ShellExecute(NULL, "open", "IEXPLORE.exe [url]http://www.sina.com.cn[/url]",NULL, NULL, SW_MAXIMIZE );
此命令將直接用IE開啟一個sina的站點。不過將開一個新的視窗。
四十、點陣圖按鈕:
CButton *pRadio = (CButton*)GetDlgItem(IDC_RADIO);
pRadio->SetBitmap(::LoadBitmap(AfxGetInstanceHandle(), MAKEINTRESOURCE(IDB_BITMAP)));