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

萬星星@豌豆莢 歡迎加入我們
一個吃軟飯的男人!!!!!我只想寫程序####
微博: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>
            欧美1区2区视频| 欧美中在线观看| 欧美成人亚洲成人日韩成人| 精品电影在线观看| 亚洲国产成人在线播放| 麻豆成人综合网| 你懂的国产精品永久在线| 亚洲国内自拍| 一区二区欧美日韩| 国产视频观看一区| 欧美电影免费观看大全| 欧美激情综合五月色丁香小说| 久久久精品日韩| 精品福利电影| 亚洲裸体俱乐部裸体舞表演av| 国产精品久久久对白| 久久久免费av| 欧美日韩亚洲另类| 久久午夜电影| 欧美日韩精品一区二区三区四区| 午夜视频久久久| 蜜乳av另类精品一区二区| 亚洲午夜女主播在线直播| 欧美一区二区三区啪啪| 亚洲免费激情| 久久久噜久噜久久综合| 在线午夜精品| 噜噜爱69成人精品| 欧美亚洲视频一区二区| 欧美成人有码| 久久久久久有精品国产| 欧美日韩午夜| 欧美激情1区2区3区| 国产精品自拍视频| 亚洲美女网站| 亚洲乱亚洲高清| 久久久精彩视频| 久久成年人视频| 欧美涩涩视频| 亚洲精品在线视频| 在线欧美日韩| 久久国内精品视频| 久久国产精品第一页| 欧美天堂亚洲电影院在线观看| 欧美韩日一区| 在线国产精品播放| 欧美亚洲视频| 久久av资源网站| 国产精品毛片在线看| 99riav久久精品riav| 亚洲精品视频在线| 猛男gaygay欧美视频| 美日韩精品视频免费看| 国产主播一区二区三区四区| 中文欧美字幕免费| 亚洲一区二区在线免费观看| 欧美精品1区2区| 亚洲日本中文字幕| 一区二区欧美日韩| 欧美日韩岛国| 一区二区三区免费观看| 亚洲午夜黄色| 国产精品美女黄网| 午夜精品一区二区三区四区| 欧美一二三视频| 国产在线视频欧美| 久久久五月天| 亚洲黄色视屏| 亚洲一区三区在线观看| 国产精品国产一区二区| 亚洲免费综合| 麻豆精品一区二区综合av| 在线成人国产| 欧美激情免费观看| 亚洲欧美精品伊人久久| 欧美激情一区二区三区在线| 亚洲国产成人精品久久久国产成人一区 | 激情五月***国产精品| 久久精品麻豆| 亚洲国产成人精品视频| 亚洲丝袜av一区| 国产欧美在线观看| 久久亚洲不卡| 亚洲精品在线电影| 久久精品国产欧美激情| 在线电影国产精品| 欧美日韩国产精品专区| 亚洲在线1234| 欧美国产欧美综合| 亚洲专区一区二区三区| 国模叶桐国产精品一区| 欧美福利在线| 午夜视频一区在线观看| 欧美成人在线网站| 亚洲女人天堂av| 亚洲国产欧美一区二区三区久久 | 国产精品免费看| 久久一综合视频| 这里只有精品丝袜| 欧美激情国产日韩| 欧美一区二区三区免费看| 亚洲国产精品久久久久婷婷老年| 欧美视频中文字幕在线| 久久人人爽人人爽爽久久| 99精品视频一区| 欧美激情按摩在线| 久久高清福利视频| 亚洲午夜精品久久久久久app| 国内精品久久久| 国产精品日韩在线观看| 欧美国产亚洲精品久久久8v| 午夜欧美精品久久久久久久| 亚洲精品乱码| 亚洲成色www8888| 久久久久99精品国产片| 亚洲一区二区三区影院| 最新成人在线| 伊人久久av导航| 国产亚洲制服色| 国产精品乱人伦一区二区| 欧美日韩国产成人在线免费 | 日韩午夜电影av| 亚洲第一综合天堂另类专| 久久一区二区视频| 欧美专区在线观看一区| 亚洲免费在线视频| 亚洲视频你懂的| 中日韩男男gay无套| 99爱精品视频| 亚洲日本激情| 亚洲人成高清| 亚洲精品一区二区三区蜜桃久| 亚洲成人资源网| 在线观看久久av| 在线观看欧美黄色| 亚洲高清在线观看| 在线欧美小视频| 亚洲日本在线观看| 亚洲综合日韩在线| 亚洲影视中文字幕| 亚洲欧美综合| 欧美亚洲日本网站| 久久激情网站| 久久综合给合久久狠狠狠97色69| 久久久一区二区| 免费av成人在线| 亚洲欧洲免费视频| 亚洲精品一区二区三| 亚洲精品人人| 中文一区字幕| 亚洲综合视频1区| 欧美一区2区三区4区公司二百 | 亚洲成人资源| 亚洲日本无吗高清不卡| 宅男精品视频| 亚洲欧美一区二区三区久久 | 亚洲午夜一区| 久久成人人人人精品欧| 久久综合精品一区| 亚洲国产精品成人综合色在线婷婷| 亚洲国产精品一区二区久| 日韩视频在线你懂得| 亚洲欧美日韩中文视频| 久久亚洲春色中文字幕久久久| 欧美成人激情视频免费观看| 欧美日韩视频免费播放| 国产色产综合色产在线视频| 亚洲福利国产| 亚洲欧美精品在线| 噜噜噜躁狠狠躁狠狠精品视频| 最新日韩在线视频| 亚洲免费视频观看| 美女黄色成人网| 国产精品视频xxxx| 亚洲电影在线| 欧美一区二区福利在线| 欧美激情一区二区三区成人| 亚洲先锋成人| 欧美成人精品激情在线观看| 国产精品乱码一区二区三区| 亚洲国语精品自产拍在线观看| 亚洲欧美日韩综合一区| 欧美国产日产韩国视频| 亚洲欧美国产三级| 欧美日本高清视频| 激情综合久久| 欧美一区二区成人| 亚洲精选一区| 男男成人高潮片免费网站| 国产精品综合av一区二区国产馆| 亚洲精品日产精品乱码不卡| 久久精品国产第一区二区三区最新章节 | 亚洲国产一成人久久精品| 欧美一区二区免费观在线| 亚洲人午夜精品免费| 久久青草久久| 国产亚洲欧美日韩精品| 亚洲自拍偷拍麻豆| 99国产精品| 欧美日韩精品|