六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

VB中不規則圖形熱點的完成

[摘要]所謂圖形熱點就是指定圖形或圖像上的某部分區域,當鼠標在這部分區域上單擊或雙擊時,就像命令按鈕一樣會引發相應事件。筆者在VB 5中用Windows提供的三個API函數輕松實現了任何形狀的圖形熱點,在此...
所謂圖形熱點就是指定圖形或圖像上的某部分區域,當鼠標在這部分區域上單擊或雙擊時,就像命令按鈕一樣會引發相應事件。筆者在VB 5中用Windows提供的三個API函數輕松實現了任何形狀的圖形熱點,在此具體介紹這一技術的實現步驟。
  首先在VB5中新建一"標準EXE工程",設置窗體Form1的ScaleMode屬性為3。在窗體代碼的聲明部分定義如下三個API函數:
  Private Type POINTAPI
    x As Long
    y As Long
  End Type
  Private Declare Function CreatePolygonRgn Lib "gdi32" (lpPoint As POINTAPI, ByVal nCount As Long, ByVal nPolyFillMode As Long) As Long
  Private Declare Function DeleteObject Lib "gdi32"(ByVal hObject As Long) As Long
  Private Declare Function PtInRegion Lib "gdi32" (ByVal hRgn As Long,ByVal x As Long, ByVal y As Long) As Long
  函數說明:CreatePolygonRgn( )函數是用來創建一個圖形熱點對象,lpPoint參數為形成圖形熱點區的第一個邊界點坐標,nCount參數指出了邊界點的個數(如nCount<3時,將無法形成一個封閉區域),nPolyFillMode參數指定填充模式,該函數返回圖形熱點對象(Long型);DeleteObject( )函數用來刪除一個由hObject參數指定的對象;PtInRegion( )函數用來判斷某坐標(由參數x、y指出)是否在hRgn圖形熱 點對象指出的熱點區內,若是返回1,否則返回0。
  其次在申明部分再添入下列自定義變量:
  Const MAXCOUNT = 30 '熱點區邊界點的最多個數
  Dim RgnPt(MAXCOUNT) As POINTAPI '熱點數組
  Dim RgnObject, RgnCount, flag As Long
  然后在Form1窗體的上方創建一個PictureBox控件,設置名稱為P1 ,ScaleMode屬性為3,Picture屬性指定一幅BMP圖像。在P1的MouseMove事件和MouseDown事件中添入下列代碼:
  Private Sub P1_MouseDown(button As Integer, shift As Integer, x As Single, y As Single)
   If button = 1 Then '必須按下鼠標左鍵才有效
    RgnPt(RgnCount).x = x
    RgnPt(RgnCount).y = y
    RgnCount = RgnCount + 1
   End If
  End Sub
  Private Sub P1_MouseMove(button As Integer, shift As Integer, x As Single, y As Single)
   If PtInRegion(RgnObject, x, y) = 1 Then
    Label1.ForeColor = QBColor(12)
    Label1.Caption = " 進入圖形熱點區!鼠標形狀變為沙漏狀!"
    P1.MousePointer = 11 '設置鼠標形狀為沙漏狀
   ElseIf flag = 1 Then
    Label1.ForeColor = 0
    Label1.Caption = " 沒有進入圖形熱點區!"
    P1.MousePointer = 0
   End If
  End Sub
  接著在P1的下方并排創建兩個CommandButton控件,Caption屬性分別設為"創建熱點"和"使用熱點", 名稱分別設為CrtRgn(對應"創建熱點")和DspRgn。在這兩個命令按鈕的下方創建一個Label控件作為操作 提示區,取默認名Label1,Caption屬性設為空,BackColor設為白色, BorderStyle屬性設為1,字體為黑體加粗小四號。雙擊CrtRgn和DspRgn,在它們的Click事件中分別添入以下代碼:
  Private Sub CrtRgn_Click()
   Dim tmp As Long
   RgnCount = 0
   tmp = DeleteObject(RgnObject)
   Label1.Caption = " 在圖像上單擊鼠標左鍵來創建圖形熱點的范圍!"+ _
    "至少應在不同位置單擊三次以上,否則形不成封閉區域!"
   flag = 0
  End Sub
  Private Sub DspRgn_Click()
   RgnObject = CreatePolygonRgn(RgnPt(0), RgnCount, 1)
   flag = 1
  End Sub
  最后在窗體代碼的任意位置添入Form_Load()事件:
  Private Sub Form_Load()
   ScaleMode = 3
   P1.ScaleMode = 3
  End Sub
  按F5運行后,首先單擊"創建熱點"按鈕,在圖像區域內的不同位置 單擊鼠標左鍵,最好單擊三次以上,否則形不成熱點區。然后單擊"使用熱點"按鈕,在圖像框內移動鼠標,你會發現當鼠標進入熱點區后, 形狀變為沙漏狀。本文中的程序僅為演示程序,在實際應用中,可以事先創建好熱點區數組,然后在熱點區的MouseDown( )事件中添入相應的代碼,即可使用圖形熱點代替命令按鈕。
  本程序在VB5/Win 95、Win 98下通過。


主站蜘蛛池模板: 四虎影院视频在线观看 | 欧美爽爽爽爽爽爽视频 | 亚洲视频在线免费 | 亚洲第一黄色网址 | 日本中文在线观看 | 最近最新中文字幕在线第一页 | 亚洲伊人久久大香线焦 | 日韩二级| 最近更新在线中文字幕一页 | 中文字幕在线观看亚洲日韩 | 亚洲免费高清视频 | 性配久久久 | 亚洲爱爱网站 | 色综合久久久久久 | 特黄大片aaaaa毛片 | 亚洲a在线播放 | 婷婷综合在线 | 亚洲五月婷婷 | 色综合伊人色综合网站中国 | 天天摸夜夜添狠狠添2018 | 午夜欧美精品久久久久久久 | 日本亚洲天堂 | 天天看天天射天天碰 | 中文字幕成人免费高清在线 | 手机看片国产免费永久 | 欧美怡红院免费全视频 | 亚洲a视频在线 | 亚洲毛片免费视频 | 伊人久久伊人 | 中文字幕免费高清视频 | 人人天天夜夜 | 亚洲国产日韩在线观看 | 欧洲美女高清一级毛片 | 午夜高清视频在线观看 | 天天天射 | 日韩在线视频线视频免费网站 | 亚洲欧美国产人成在线app | 沈樵在线观看福利 | 天天操天天干天天射 | 青草视频在线观看完整版 | 午夜国产在线观看 |