青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

萬星星@豌豆莢 歡迎加入我們
一個吃軟飯的男人!!!!!我只想寫程序####
微博:http://weibo.com/wanlianwen
posts - 172,  comments - 1253,  trackbacks - 0
好的軟件有好的開始,微軟VS IDE的起始界面做的實在不錯,色調和布局都是很舒服,這里我動手實現了一個,下面是過程。

第一步:用spy++工具觀察VS IDE開始界面構成。

通過spy++,可以看到開始頁由一個大窗口,里面是位圖背景,在上面有一些靜態窗口,按鈕等,之間夾一個小視圖(例如最近的項目里面是一個listctrl)。基本就是這樣,實現思路就是用位圖貼在靜態小窗口構成一個小的欄,中間放一個小的主視圖,比如項目列表、msdn新聞等。


第二步:收集位圖素材。我沒有那么好的藝術細胞畫這么好的小圖片,所以只得偷vs的。由于使用vc6,所以下面全部基于vc6環境來說。用資源的方式打開vs ide執行文件(\Microsoft Visual Studio 8\Common7\IDE\devenv.exe),可以看到位圖資源基本全是起始頁的。

第三步:實現思路確定。有一些問題,里面的圖片好像沒有主界面那么大的位圖,頭部好像不是太符合尺寸:

這下我的思路是先用背景色繪制窗口,然后貼圖。背景色可以用取色工具獲取,我用firework里面的工具。
還有一個問題就是小欄位圖的四角有顏色:

貼到主窗口上去會留下與環境不相稱的一點點多余的角,這里我在網上搜到一篇mask位圖的文章,基于此,把位圖四角的淡白色去掉。
還有就是中間的位圖太小:

我準備采取重復繪制來填滿一定長度,注意水平方向和垂直方向稍有不同,所以實現的時候要進行判斷。
這樣基本敲打實現方法,接著就動手實現。

第四步:開工。vc6建立一個單文檔基于formview的程序。
工序一:繪制背景
對話框的背景顏色可以通過重載OnCtlColor來實現,而不是OnEraseBackground。
HBRUSH?CVS2005StartView::OnCtlColor(CDC*?pDC,?CWnd*?pWnd,?UINT?nCtlColor)?
{
????HBRUSH?hbr?
=?CFormView::OnCtlColor(pDC,?pWnd,?nCtlColor);
????
????
//?TODO:?Change?any?attributes?of?the?DC?here
????if(nCtlColor?==?CTLCOLOR_DLG)
????
{
????????
return?m_bkBrush;
????}

????
//?TODO:?Return?a?different?brush?if?the?default?is?not?desired
????return?hbr;
}
上面只修改對話框背景,所以進行了判斷,m_bkBrush就是背景畫刷。

工序二:貼圖,在OnPaint里面繪制Visual studio的大位圖。
void?CVS2005StartView::OnPaint()?
{
????CPaintDC?dc(
this);?//?device?context?for?painting
????
????
//?TODO:?Add?your?message?handler?code?here
????CDC????????????memDC;
????HBITMAP????????hOldBmp????????
=?NULL;
????BITMAP????????bmp;
????memDC.CreateCompatibleDC(
&dc);
????hOldBmp?
=?(HBITMAP)memDC.SelectObject(&m_bmpHeader);
????m_bmpHeader.GetBitmap(
&bmp);
????BitBlt(dc,?
0,?0,?bmp.bmWidth,?bmp.bmHeight,?memDC,?0,?0,?SRCCOPY);
????memDC.SelectObject(hOldBmp);
????
//?Do?not?call?CFormView::OnPaint()?for?painting?messages
}
這樣就所有存托背景,下面開始實現每個小欄目。實現一個就ok,思路都是一樣的。

工序三:實現繪制位圖的靜態窗口。從CStatic派生CBmpStatic類來實現繪制位圖功能。考慮到上面提及的情況,函數接口如下:
????void????SetBitmap(UINT?nBmpID,?BOOL?bHorzStretch=TRUE);
????
void????SetTitle(CString?strTitle);
實現如下:
void?CBmpStatic::OnPaint()?
{
????CPaintDC?dc(
this);?//?device?context?for?painting
????
????
//?TODO:?Add?your?message?handler?code?here
????CDC????????????srcDC;
????CDC????????????mskDC;
????CBitmap????????mskBmp;
????BITMAP????????bmp;
????srcDC.CreateCompatibleDC(
&dc);
????mskDC.CreateCompatibleDC(
&dc);
????m_bmpBack.GetBitmap(
&bmp);

????mskBmp.CreateBitmap(bmp.bmWidth,?bmp.bmHeight,?
0,?1,?NULL);
????srcDC.SelectObject(
&m_bmpBack);

????srcDC.SetBkColor(RGB(
0xEB,?0xF1,?0xFE));
????mskDC.SelectObject(mskBmp);
????mskDC.BitBlt(
0,?0,?bmp.bmWidth,?bmp.bmHeight,?&srcDC,?0,?0,?SRCCOPY);

????srcDC.SetBkColor(RGB(
255,255,255));
????srcDC.SetTextColor(RGB(
0,0,0));

????LONG????lXStart????????
=?0;
????LONG????lXEnd????????
=?bmp.bmWidth;
????LONG????lYStart????????
=?0;
????LONG????lYEnd????????
=?bmp.bmHeight;
????CRect????rc;
????GetClientRect(
&rc);
????
if(m_bHorzStretch)
????
{
????????
while(lXStart?<=?rc.Width())
????????
{
????????????
if(lXEnd?>?rc.Width())
????????????
{
????????????????lXEnd?
=?rc.Width();
????????????}

????????????dc.BitBlt(lXStart,
0,?lXEnd-lXStart,?bmp.bmHeight,?&srcDC,?0,?0,?SRCINVERT);
????????????dc.SetBkColor(RGB(
255,255,255));
????????????dc.BitBlt(lXStart,?
0,?lXEnd-lXStart,?bmp.bmHeight,?&mskDC,?0,?0,?SRCAND);
????????????dc.BitBlt(lXStart,?
0,?lXEnd-lXStart,?bmp.bmHeight,?&srcDC,?0,?0,?SRCINVERT);
????????????lXStart?
+=?bmp.bmWidth;
????????????lXEnd?
+=?bmp.bmWidth;
????????}

????}

????
else
????
{
????????
while(lYStart?<=?rc.Height())
????????
{
????????????
if(lYEnd?>?rc.Height())
????????????
{
????????????????lYEnd?
=?rc.Height();
????????????}

????????????dc.BitBlt(
0,lYStart,?bmp.bmWidth,?lYEnd-lYStart,?&srcDC,?0,?0,?SRCINVERT);
????????????dc.SetBkColor(RGB(
255,255,255));
????????????dc.BitBlt(
0,lYStart,?bmp.bmWidth,?lYEnd-lYStart,?&mskDC,?0,?0,?SRCAND);
????????????dc.BitBlt(
0,lYStart,?bmp.bmWidth,?lYEnd-lYStart,?&srcDC,?0,?0,?SRCINVERT);
????????????lYStart?
+=?bmp.bmHeight;
????????????lYEnd?
+=?bmp.bmHeight;
????????}

????}

????srcDC.DeleteDC();
????mskDC.DeleteDC();

????
if(!m_strTitle.IsEmpty())
????
{
????????dc.SelectObject(m_ftTitle);
????????dc.SetTextColor(RGB(
255,?255,?255));
????????dc.SetBkMode(TRANSPARENT);
????????dc.TextOut(
0,?4,?m_strTitle);
????}

}



void?CBmpStatic::SetBitmap(UINT?nBmpID,?BOOL?bHorzStretch)
{
????
if(m_bmpBack.GetSafeHandle())
????
{
????????m_bmpBack.DeleteObject();
????}

????m_bmpBack.LoadBitmap(nBmpID);
????m_bHorzStretch?
=?bHorzStretch;
}


void?CBmpStatic::SetTitle(CString?strTitle)
{
????m_strTitle?
=?strTitle;
}
好了,有了顯示位圖的窗口,下面我們就來擺出一個欄目(最近的項目)。

工序四:擺置窗口,實現欄目。這個是細致活,先把中間的小主視圖控件擺上,然后四周放置8個static,基本如下(可能需要根據顯示結果來適當調整)。

然后為每個static控件關聯一個CBmpStatic,并設置位圖和顯示文本。
void?CVS2005StartView::OnInitialUpdate()
{
????CFormView::OnInitialUpdate();
????GetParentFrame()
->RecalcLayout();
????ResizeParentToFit();

????m_wndPrjUpLeft.SetBitmap(
6609);
????m_wndPrjUpMiddle.SetBitmap(
6610);
????m_wndPrjUpMiddle.SetTitle(_T(
"最近的項目"));
????m_wndPrjUpRight.SetBitmap(
6611);
????m_wndMiddleLeft.SetBitmap(
6612,?FALSE);
????m_wndMiddleRight.SetBitmap(
6613,?FALSE);
????m_wndBottomLeft.SetBitmap(
6614);
????m_wndBottomMiddle.SetBitmap(
6615);
????m_wndBottomRight.SetBitmap(
6616);

????m_imgProject.Create(
16,?16,?ILC_COLOR8|ILC_MASK,?2,?0);
????m_imgProject.Add(AfxGetApp()
->LoadIcon(MAKEINTRESOURCE(6826)));
????m_wndPrjList.SetImageList(
&m_imgProject,?LVSIL_SMALL);
????m_wndPrjList.InsertItem(
0,?_T("HTMLKit"),?0);
????m_wndPrjList.InsertItem(
1,?_T("Mapgis7"),?0);


????m_wndNewsUpLeft.SetBitmap(
6609);
????m_wndNewsUpMiddle.SetBitmap(
6610);
????m_wndNewsUpMiddle.SetTitle(_T(
"Visual?Studio?開發人員新聞"));
????m_wndNewsUpRight.SetBitmap(
6611);
????m_wndNewsMiddleLeft.SetBitmap(
6612,?FALSE);
????m_wndNewsMiddleRight.SetBitmap(
6613,?FALSE);
????m_wndNewsBottomLeft.SetBitmap(
6614);
????m_wndNewsBottomMiddle.SetBitmap(
6615);
????m_wndNewsBottomRight.SetBitmap(
6616);

????m_wndNewsInfo.SetFont(
&m_ftNewInfo);
????m_wndNewsInfo.AddString(_T(
"當前的新聞頻道可能無效或者你的?Internet"));
????m_wndNewsInfo.AddString(_T(
"連接不可用.若要更新新聞頻道,請在\"工具\"菜單上點擊\"選項\",然后展開"));
}

?

好了,下面來看看我們的窗口。


花費半天時間,只是圖實現,封裝性不是很好。

總結:
看過很多漂亮的界面,qq、泡泡堂登錄界面等,思路差不多,都是基于貼圖來做的,包括游戲的實現方式也差不多。界面的美觀其實主要靠藝術家,包括圖片效果以及窗口布局。

不足:
1、沒有使用雙緩存,拖動的時候背景有閃爍。
2、滾動條滑動的時候有問題,暫時沒時間處理。
3、代碼凌亂,不曉得資源句柄有沒有釋放干凈。
4、開發新聞那個listbox是自繪的,可以通過spy++看到,我沒時間做。
還有。。。

代碼下載

posted on 2006-11-16 20:39 萬連文 閱讀(3100) 評論(3)  編輯 收藏 引用 所屬分類: MFC

FeedBack:
# re: 用MFC做VS起始頁界面
2006-11-18 14:04 | fiestay
呵呵,動手能力不錯啊  回復  更多評論
  
# re: 用MFC做VS起始頁界面
2007-04-17 15:35 | ooo
繼續努力!  回復  更多評論
  
# re: 用MFC做VS起始頁界面[未登錄]
2008-09-22 16:42 | 菜鳥
你要是能把你做好的這個再重新放到.net的起始頁里,代替他老的那個,那就更好了!  回復  更多評論
  
簡歷下載
聯系我

<2011年9月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

常用鏈接

留言簿(66)

隨筆分類

隨筆檔案

相冊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美淫片网站| 久久精品视频网| 狠狠色狠狠色综合| 国产小视频国产精品| 国产午夜精品视频| 好吊色欧美一区二区三区四区 | 午夜亚洲福利| 久久精品国产精品| 久久久久久97三级| 亚洲一级影院| 久久久久久电影| 欧美sm重口味系列视频在线观看| 免费欧美在线视频| 亚洲黄色一区| 亚洲视频在线二区| 久久精品视频在线| 欧美经典一区二区| 国产美女高潮久久白浆| 在线观看成人网| 亚洲一区二区三区四区五区黄| 久久精品二区三区| 亚洲日本一区二区三区| 欧美一区不卡| 欧美日韩亚洲另类| 在线观看91精品国产入口| 在线视频精品一区| 免费成人美女女| 亚洲免费影视第一页| 欧美1级日本1级| 国产综合在线视频| 亚洲专区一区| 亚洲人永久免费| 久久精品中文字幕免费mv| 欧美日韩在线免费| 在线看欧美视频| 欧美在线看片a免费观看| 亚洲国产欧美久久| 久久精品国产亚洲一区二区| 国产精品v一区二区三区| 亚洲精品中文字幕在线观看| 久久久久久伊人| 亚洲免费在线视频一区 二区| 欧美—级高清免费播放| 亚洲国产日韩欧美综合久久| 久久免费精品视频| 欧美亚洲综合在线| 国产欧美日韩在线观看| 午夜精品久久久久久久男人的天堂| 亚洲国产欧美一区二区三区久久| 日韩午夜免费视频| 欧美一区二区三区四区在线| 欧美日韩免费看| 午夜精品久久久久久久99黑人| 亚洲一区二区成人在线观看| 影院欧美亚洲| 亚洲一区二区三区免费在线观看 | 欧美中文字幕第一页| 最新国产成人在线观看| 激情成人在线视频| 亚洲在线免费观看| 亚洲男人的天堂在线| 欧美激情视频一区二区三区在线播放 | 亚洲精品美女91| 一本久久综合亚洲鲁鲁| 国产精品乱子久久久久| 一本色道久久88精品综合| 亚洲电影免费观看高清完整版在线| 欧美一区二区精美| 国产亚洲精品美女| 免费成人高清视频| 欧美高清视频一区二区三区在线观看| 亚洲国产天堂久久综合| 亚洲欧洲精品一区二区精品久久久 | 欧美日本免费一区二区三区| 日韩视频在线观看| 日韩一级裸体免费视频| 国产精品嫩草99av在线| 欧美一区二区三区视频在线 | 极品尤物久久久av免费看| 欧美在线免费视频| 欧美大片一区| 在线中文字幕日韩| 午夜精品久久久久久久蜜桃app| 欧美午夜一区二区三区免费大片 | 国产亚洲成人一区| 香蕉成人啪国产精品视频综合网| 久久国产99| 国产老肥熟一区二区三区| 亚洲一级一区| 久久久精品动漫| 亚洲永久在线| 久久国产精品一区二区| 99精品欧美一区| 亚洲精品影视在线观看| 国产亚洲精品综合一区91| 91久久国产综合久久| 日韩一级视频免费观看在线| 国产视频一区在线观看| 欧美激情按摩在线| 国产精品久久久久久久久果冻传媒 | 国产精品影音先锋| 亚洲黄色成人网| 国户精品久久久久久久久久久不卡| 欧美黑人在线观看| 国产亚洲视频在线| 99精品视频免费全部在线| 怡红院精品视频| 亚洲综合欧美| 一区二区三区日韩在线观看 | 国产伦理一区| 日韩视频在线一区| 91久久精品美女| 久久国产精品99精品国产| 亚洲性av在线| 欧美日产在线观看| 亚洲大片av| 亚洲第一视频| 久久99在线观看| 久久av资源网| 国产精品入口66mio| 99在线精品视频| av不卡在线观看| 欧美激情导航| 亚洲黄色性网站| 亚洲美女啪啪| 欧美18av| 最新国产乱人伦偷精品免费网站 | 欧美 日韩 国产在线| 噜噜噜91成人网| 国模私拍一区二区三区| 亚洲欧美文学| 久久久久久久久久看片| 国产日韩亚洲欧美精品| 亚洲欧美在线高清| 久久国产精品第一页| 亚洲与欧洲av电影| 欧美精品网站| 免播放器亚洲| 一区三区视频| 噜噜噜噜噜久久久久久91| 久久夜色精品一区| 在线日韩视频| 欧美成人国产va精品日本一级| 欧美成人一区二区| 亚洲理论在线| 一本色道88久久加勒比精品 | 久久资源av| 在线精品视频一区二区| 老鸭窝91久久精品色噜噜导演| 免费不卡亚洲欧美| 亚洲国产高清高潮精品美女| 欧美18av| 一区二区黄色| 久久久久久一区二区| 亚洲国产第一| 欧美日韩视频在线一区二区| 一区二区三区久久| 久久五月天婷婷| 亚洲六月丁香色婷婷综合久久| 欧美伦理在线观看| 亚洲欧美日韩成人高清在线一区| 久久全国免费视频| 日韩亚洲精品视频| 国产美女精品视频| 免费久久精品视频| 亚洲视频二区| 蜜桃精品一区二区三区| 夜夜夜久久久| 激情欧美一区二区三区在线观看| 嫩模写真一区二区三区三州| 亚洲最新色图| 欧美成人自拍| 性欧美暴力猛交另类hd| 亚洲第一在线综合在线| 国产精品二区在线观看| 开元免费观看欧美电视剧网站| av成人免费| 欧美激情精品久久久久久免费印度| 亚洲免费在线看| 亚洲第一成人在线| 国产精品一区三区| 欧美精品色综合| 久久久久久综合网天天| 一区二区三区波多野结衣在线观看| 久久久91精品国产一区二区三区| 日韩亚洲精品电影| 亚洲成人在线网站| 国产亚洲欧美一区| 欧美性大战久久久久久久| 久久一区二区精品| 欧美一区二区三区在线| 日韩视频在线观看国产| 欧美激情乱人伦| 蜜月aⅴ免费一区二区三区 | 日韩亚洲国产欧美| 亚洲成人在线网| 欧美 日韩 国产一区二区在线视频 | 亚洲高清在线| 免播放器亚洲一区| 久久久久久久综合色一本|