資源描述:
《csharp擴展trackbar控件顯示不同風格》由會員上傳分享,免費在線閱讀,更多相關內容在行業(yè)資料-天天文庫。
1、C#擴展TrackBar控件顯示不同風格1.控件效果2.開發(fā)思路TrackBar控件沒有像其他控件那樣,直接提供給用戶重繪的函數,要實現個性化的TrackBar控件直接繼承TrackBar控件,利用TrackBar的一些Windows消息,獲取TrackBar控件的信息,然后自己完全重繪,這種方法的好處是保留TrackBar控件的標準操作和屬性,但是需要比較清楚的了解TrackBar控件的Windows消息。3.源碼介紹實現TrackBar控件顯示不同風格需要的一些API消息。TrackBar控件
2、相關的一些消息都是以TBM(TackBarMessage)開頭的,在TrackBar控件的美化中,主要用到了以下三個消息:l????????TBM_GETCHANNELRECT獲取軌道的位置和大小。l????????TBM_GETTHUMBRECT獲取滑塊的位置和大小。l????????TBM_GETNUMTICS獲取刻度的總個數。要獲取這些信息,只需要向TrackBar控件發(fā)送相應的消息即可,例如需要獲取取軌道的位置和大小:SendMessage(hWnd,TBM.TBM_GETCHANNELR
3、ECT,0,reftrackRect)。? 接下來就是重繪TrackBar控件了。重繪TrackBar控件,需要重寫WndProc函數,在WM_PAINT消息實現重繪就行了://////接收消息//////protectedoverridevoidWndProc(refMessagem){switch(m.Msg){caseWM.WM_PAINT:if(!_bPainting){_bPainting=true;P
4、AINTSTRUCTps=newPAINTSTRUCT();NativeMethods.BeginPaint(m.HWnd,refps);DrawTrackBar(m.HWnd);NativeMethods.ValidateRect(m.HWnd,refps.rcPaint);NativeMethods.EndPaint(m.HWnd,refps);_bPainting=false;m.Result=Result.TRUE;}else{base.WndProc(refm);}break;defau
5、lt:base.WndProc(refm);break;}}DrawTrackBar函數的功能就是獲取TrackBar控件的一些信息,然后分別調用四個函數來繪制TrackBar控件:?OnRenderBackground函數,繪制TrackBar控件的背景。?OnRenderTick函數,繪制TrackBar控件的刻度。?OnRenderTrack函數,繪制TrackBar控件的軌道。?OnRenderThumb函數,繪制TrackBar控件的滑塊。這四個函數都是可以重寫的,如果想實現不同樣式的T
6、rackBar控件,重寫這四個函數,可以相應的繪制。DrawTrackBar函數的具體代碼:privatevoidDrawTrackBar(IntPtrhWnd){ControlStatestate=ControlState.Normal;boolhorizontal=base.Orientation==Orientation.Horizontal;ImageDctempDc=newImageDc(base.Width,base.Height);TrackRECTtrackRect=newTrac
7、kRECT();TrackRECTthumbRect=newTrackRECT();Graphicsg=Graphics.FromHdc(tempDc.Hdc);NativeMethods.SendMessage(hWnd,TBM.TBM_GETCHANNELRECT,0,reftrackRect);NativeMethods.SendMessage(hWnd,TBM.TBM_GETTHUMBRECT,0,refthumbRect);RectangletrackRectangle=horizont
8、al?trackRect.Rect:Rectangle.FromLTRB(trackRect.Top,trackRect.Left,trackRect.Bottom,trackRect.Right);if(ThumbHovering(thumbRect)){if(Helper.LeftKeyPressed()){state=ControlState.Pressed;}else{state=ControlState.Hover;}}//繪制TrackBar控件的背景using(Pai