123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330 |
- // BmpTab.cpp : implementation file
- #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::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)
- //{{AFX_MSG_MAP(CSkinTab)
- ON_WM_PAINT()
- ON_WM_LBUTTONDOWN()
- ON_WM_ERASEBKGND()
- ON_WM_MOUSEMOVE()
- ON_WM_TIMER()
- ON_WM_SETCURSOR()
- //}}AFX_MSG_MAP
- END_MESSAGE_MAP()
- /////////////////////////////////////////////////////////////////////////////
- // CSkinTab message handlers
- void CSkinTab::PreSubclassWindow()
- {
- // TODO: Add your specialized code here and/or call the base class
- 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);
- // if(tabItem->pVoid)
- // ((CWnd*)(tabItem->pVoid))->ShowWindow(SW_HIDE);
- 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);
- // if(tabItem->pVoid)
- // ((CWnd*)(tabItem->pVoid))->ShowWindow(SW_NORMAL);
- }
- 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();
- // CStatic::OnPaint();
- }
- void CSkinTab::OnLButtonDown(UINT nFlags, CPoint point)
- {
- // TODO: Add your message handler code here and/or call default
- // AfxMessageBox("dd");
- //m_dwState=HTHDOWN;
- 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)
- {
- // TODO: Add your message handler code here and/or call default
- 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_memDC.SelectObject(bmpOld);
- // bmpOld->DeleteObject();
- m_bIsCDC=TRUE;
- bmpBack.DeleteObject();
-
- }
- return TRUE;
- //return CStatic::OnEraseBkgnd(pDC);
- }
- 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)
- {
- //m_aryItem.Add(&item);
- }
- void CSkinTab::AddTabItem(UINT nBmpNormal, UINT nBmpHover, UINT nBmpHdown, UINT nIcon, void *pVoid)
- {
- //if(m_aryItem.GetSize()==0)
- // CBitmap bmpNormal,bmpHover,bmpHdown;
- // HICON icon;
- // // bmpNormal.LoadBitmap(nBmpNormal);
- // // bmpHover.LoadBitmap(nBmpHover);
- // // bmpHdown.LoadBitmap(nBmpHdown);
- // icon=AfxGetApp()->LoadIcon(nIcon);
- //
- // TABITEM* tabitm=new TABITEM;
- // // tabitm.rcItem=rc;
- // tabitm->bmpNormal.LoadBitmap(nBmpNormal);
- // tabitm->bmpHover.LoadBitmap(nBmpHover);
- // tabitm->bmpHdown.LoadBitmap(nBmpHdown);
- // tabitm->icon=icon;
- // tabitm->pVoid=NULL;
- //
- // m_aryItem.Add((void*)tabitm);
- }
- void CSkinTab::OnMouseMove(UINT nFlags, CPoint point)
- {
- // TODO: Add your message handler code here and/or call default
- //AfxMessageBox("dd");
- // m_dwState=HTHOVER;
- // CRect rc;
- // BOOL IsTrue=FALSE;
- // for(int i=0;i<m_aryItem.GetSize();i++)
- // {
- // GetTabItemRect(i,&rc);
- // if(rc.PtInRect(point))
- // {
- // m_iCurrentFouce=i;
- // IsTrue=TRUE;
- // }
- // }
- // if(!IsTrue)
- // m_iCurrentFouce=-1;
- CRect rcItem(0,0,Width(),Heighth());
- if(rcItem.PtInRect(point))
- {
- SetTimer(1,10,NULL);
- Invalidate();
- }
- CStatic::OnMouseMove(nFlags, point);
- }
- void CSkinTab::OnTimer(UINT nIDEvent)
- {
- // TODO: Add your message handler code here and/or call default
- 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();
- // if(rc.PtInRect(pt))
- // {
- // m_dwState=HTHOVER;
- // }
- // else
- // {
- // m_dwState=HTNORMAL;
- //
- //
- // }
- //
- CStatic::OnTimer(nIDEvent);
- }
- BOOL CSkinTab::OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message)
- {
- // TODO: Add your message handler code here and/or call default
- 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)
- {
- // if(m_bmpNormal.GetSafeHandle())
- // {
- BITMAP bm;
- m_bmpNormal.GetBitmap(&bm);
-
- rc->SetRect(0,nIndex*bm.bmHeight,bm.bmWidth,nIndex*bm.bmHeight+bm.bmHeight);
- // }
- // else
- // {
- // rc->SetRect(0,0,0,0);
- // }
- }
|