123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330 |
- #include "stdafx.h"
- #include "SkinTab.h"
- #ifdef _DEBUG
- #define new DEBUG_NEW
- #undef THIS_FILE
- static char THIS_FILE[] = __FILE__;
- #endif
- #define IDC_CURSOR_HAND 132
- CSkinTab::CSkinTab()
- {
- m_bIsCDC=FALSE;
- m_dwState=HTNORMAL;
- m_hIconHand=AfxGetApp()->LoadCursor(IDC_CURSOR_HAND);
- m_iCurrentSelect=1;
- m_iCurrentFouce=-1;
- }
- CSkinTab::~CSkinTab()
- {
- }
- BEGIN_MESSAGE_MAP(CSkinTab, CStatic)
-
- ON_WM_PAINT()
- ON_WM_LBUTTONDOWN()
- ON_WM_ERASEBKGND()
- ON_WM_MOUSEMOVE()
- ON_WM_TIMER()
- ON_WM_SETCURSOR()
-
- END_MESSAGE_MAP()
- void CSkinTab::PreSubclassWindow()
- {
-
- ModifyStyle(0,SS_NOTIFY);
- CStatic::PreSubclassWindow();
- }
- void CSkinTab::OnPaint()
- {
- CPaintDC dc(this);
- CRect rc;GetClientRect(&rc);
- CDC memDC;memDC.CreateCompatibleDC(&dc);
- CBitmap bmpBack;bmpBack.CreateCompatibleBitmap(&dc,rc.Width(),rc.Height());
- CBitmap *bmpOld=memDC.SelectObject(&bmpBack);
- memDC.BitBlt(0,0,rc.Width(),rc.Height(),&m_memDC,0,0,SRCCOPY);
- if(m_bmpBG.m_hObject != NULL)
- m_bmpBG.ExtendDraw(&memDC,rc,10,50);
- CRect rcItem;
- TABITEM* tabItem;
- for(int i=0;i<m_aryItem.GetSize();i++)
- {
- CDC tmpDC;tmpDC.CreateCompatibleDC(&dc);
-
- tabItem=(TABITEM*)m_aryItem.GetAt(i);
- GetTabItemRect(i,&rcItem);
- bmpOld=tmpDC.SelectObject(&m_bmpNormal);
- if(m_iCurrentFouce==i)
- {
- bmpOld=tmpDC.SelectObject(&m_bmpHover);
- }
- if(m_iCurrentSelect==i)
- {
- bmpOld=tmpDC.SelectObject(&m_bmpHdown);
- }
- memDC.BitBlt(rcItem.left+1,rcItem.top,rcItem.Width(),rcItem.Height(),&tmpDC,0,0,SRCCOPY);
- tmpDC.SelectObject(bmpOld);
- ReleaseDC(&tmpDC);
- tmpDC.DeleteDC();
- ::DrawIconEx(memDC,rcItem.left+8,rcItem.top+3,tabItem->icon,24,24,0,NULL,DI_NORMAL);
- }
- dc.BitBlt(0,0,rc.Width(),rc.Height(),&memDC,0,0,SRCCOPY);
- memDC.DeleteDC();
- }
- void CSkinTab::OnLButtonDown(UINT nFlags, CPoint point)
- {
-
-
- CRect rcItem;
- for(int i=0;i<m_aryItem.GetSize();i++)
- {
- CWnd *tabItemView;
- tabItemView=(CWnd*)((TABITEM*)m_aryItem.GetAt(i))->pVoid;
- CRect recTab(0,0,Width(),Heighth());
- if(tabItemView && recTab.PtInRect(point))
- tabItemView->ShowWindow(SW_HIDE);
- GetTabItemRect(i,&rcItem);
- if(rcItem.PtInRect(point))
- {
- m_iCurrentSelect=i;
- if((m_aryItem.GetAt(i))!=NULL)
- {
- if(tabItemView)
- tabItemView->ShowWindow(SW_NORMAL);
- }
- }
-
- }
- Invalidate();
- CStatic::OnLButtonDown(nFlags, point);
- }
- BOOL CSkinTab::OnEraseBkgnd(CDC* pDC)
- {
-
- if(!m_bIsCDC)
- {
- m_memDC.CreateCompatibleDC(pDC);
- CRect rc;GetClientRect(&rc);
- CBitmap bmpBack;bmpBack.CreateCompatibleBitmap(pDC,rc.Width(),rc.Height());
- m_memDC.SelectObject(&bmpBack);
-
- m_memDC.BitBlt(0,0,rc.Width(),rc.Height(),pDC,0,0,SRCCOPY);
-
-
- m_bIsCDC=TRUE;
- bmpBack.DeleteObject();
-
- }
- return TRUE;
-
- }
- void CSkinTab::SetIcon(int nIndex,UINT nIcon,void *pVoid)
- {
- TABITEM* tabItem=new TABITEM;
- tabItem->nIndex=nIndex;
- tabItem->icon=AfxGetApp()->LoadIcon(nIcon);
- tabItem->pVoid=pVoid;
- m_aryItem.Add(tabItem);
- }
- void CSkinTab::SetIcon(int nIndex,LPCTSTR szIcon,void *pVoid)
- {
- TABITEM* tabItem=new TABITEM;
- tabItem->nIndex=nIndex;
- tabItem->icon=(HICON)::LoadImage(AfxGetApp()->m_hInstance,szIcon,IMAGE_ICON,24,24,LR_LOADFROMFILE);
- tabItem->pVoid=pVoid;
- m_aryItem.Add(tabItem);
- }
- void CSkinTab::SetBmp(UINT nBmpNormal, UINT nBmpHover, UINT nBmpHdown)
- {
- m_bmpNormal.LoadBitmap(nBmpNormal);
- m_bmpHover.LoadBitmap(nBmpHover);
- m_bmpHdown.LoadBitmap(nBmpHdown);
- }
- void CSkinTab::SetSkin(CString strNormal, CString strHover, CString strDown)
- {
- m_bmpNormal.LoadImage(strNormal);
- m_bmpHover.LoadImage(strHover);
- m_bmpHdown.LoadImage(strDown);
- }
- void CSkinTab::SetSkin(CString strBmpTab)
- {
- CEnBitmap bmp;
- bmp.LoadImage(strBmpTab);
- if(bmp.m_hObject != NULL)
- {
- bmp.DrawImage(m_bmpNormal,1,1,3,1);
- bmp.DrawImage(m_bmpHover,2,1,3,1);
- bmp.DrawImage(m_bmpHdown,3,1,3,1);
- }
- if(bmp.m_hObject != NULL) bmp.DeleteObject();
- }
- void CSkinTab::SetSkinBG(CString strBmpBG)
- {
- m_bmpBG.LoadImage(strBmpBG);
- }
- void CSkinTab::AddTabItem(TABITEM &item)
- {
-
- }
- void CSkinTab::AddTabItem(UINT nBmpNormal, UINT nBmpHover, UINT nBmpHdown, UINT nIcon, void *pVoid)
- {
-
- }
- void CSkinTab::OnMouseMove(UINT nFlags, CPoint point)
- {
-
-
- CRect rcItem(0,0,Width(),Heighth());
- if(rcItem.PtInRect(point))
- {
- SetTimer(1,10,NULL);
- Invalidate();
- }
- CStatic::OnMouseMove(nFlags, point);
- }
- void CSkinTab::OnTimer(UINT nIDEvent)
- {
-
- CPoint pt(GetMessagePos());
- ScreenToClient(&pt);
- CRect rc;
-
- BOOL bIsOK=FALSE;
- for (int i=0;i<m_aryItem.GetSize();i++)
- {
- GetTabItemRect(i,&rc);
- if(rc.PtInRect(pt))
- {
- m_iCurrentFouce=i;
- bIsOK=TRUE;
- }
- }
-
- if (!bIsOK)
- {
- m_iCurrentFouce=-1;
- KillTimer(1);
- }
- Invalidate();
- CStatic::OnTimer(nIDEvent);
- }
- BOOL CSkinTab::OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message)
- {
-
- CPoint pt(GetMessagePos());
- ScreenToClient(&pt);
- CRect rcItem(0,0,Width(),Heighth());
- if(rcItem.PtInRect(pt))
- {
- ::SetCursor(m_hIconHand);
- return TRUE;
- }
- return CStatic::OnSetCursor(pWnd, nHitTest, message);
- }
- void CSkinTab::GetTabItemRect(int nIndex, CRect *rc)
- {
- BITMAP bm;
- m_bmpNormal.GetBitmap(&bm);
-
- rc->SetRect(0,nIndex*bm.bmHeight,bm.bmWidth,nIndex*bm.bmHeight+bm.bmHeight);
- }
|