• <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>
    • 軟件測試技術
    • 軟件測試博客
    • 軟件測試視頻
    • 開源軟件測試技術
    • 軟件測試論壇
    • 軟件測試沙龍
    • 軟件測試資料下載
    • 軟件測試雜志
    • 軟件測試人才招聘
      暫時沒有公告

    字號: | 推薦給好友 上一篇 | 下一篇

    用VB實現網絡螞蟻的拖放窗口

    發布: 2007-7-14 20:28 | 作者: 佚名    | 來源: 網絡轉載     | 查看: 22次 | 進入軟件測試論壇討論

    領測軟件測試網 作者:武漢 艾軍

    網絡螞蟻的查看菜單中,有菜單項名叫"拖放窗口",當我們需要下載文件時,只要把網頁中的超鏈接拖到這個"窗口"里就能順序的進行文件的下載,下面我們就在 VB 中嘗試制做這種"拖放窗口"。
    第一步,我們先要使"窗口"永遠顯示在第一位。
    因為我們在瀏覽網頁時,要開許多 IE 窗口,那當然不能讓這個拖放窗口被 IE 窗口覆蓋到,這個技巧可以用 API 函數 SetWindowPos 來實現。
    第二步,我們要制作無邊框的窗口。(沒有標題欄)
    因為這樣看起來比較專業,這個技巧比較容易,可以通過設置 Form 的 BorderStyle 屬性來實現。
    第三步,我們要能用鼠標拖動這個窗口。
    因為我們的第二步操作,由于這個窗口沒有了標題欄,只能通過 API 函數 ReleaseCapture、SendMessage 來實現窗口的拖動。
    第四步,我們要使這個窗口接受拖放。(就是拖超鏈接呀)
    這步最關鍵,不過也最簡單,只要設置 Form 的OLEDropMode 屬性就行了。
    好了,步驟完成,現在開始程序的完整代碼了:
    Private Declare Function ReleaseCapture Lib "user32" () As Long 注釋:釋放鼠標捕獲
    Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long 注釋:向窗口進程發送消息
    Const HTCAPTION = 2
    Const WM_NCLBUTTONDOWN = &HA1

    Const SWP_NOSIZE = &H1
    Const SWP_NOMOVE = &H2
    Const HWND_TOPMOST = -1
    Const SWP_SHOWWINDOW = &H40
    Const strWebSite = "你拖放的是網頁地址,地址是"
    Const strWebImage = "你拖放的是網頁圖象,圖象將保存到PictureBox中"
         
    Private Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long        注釋:設置窗口大小、位置、順序
       
    Private Sub Form_Load()

    注釋:窗口的屬性分別為:(請在設計窗口中定義)
    注釋:Form1.Height = 570
    注釋:Form1.Left = 150
    注釋:Form1.Top = 200
    注釋:Form1.Width = 570
    注釋:Form1.BackColor = &HFFFF00
    注釋:Form1.BorderStyle = 1
    注釋:Form1.OLEDropMode = 1 注釋:使Form1可以接受OLE拖放
    注釋:Form1.ControBox=False

        SetWindowPos Me.hwnd, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOMOVE Or SWP_NOSIZE Or SWP_SHOWWINDOW 注釋: 使用Windows API函數SetWindowPos將窗口設置為總在最前面以捕捉拖放操作
    End Sub

    Private Sub Form_OLEDragDrop(Data As DataObject, Effect As Long, Button As Integer, Shift As Integer, x As Single, y As Single) 注釋:拖放操作時發生
    On Error Resume Next
        Effect = vbDropEffectCopy
        If Data.GetFormat(vbCFText) Then        注釋:拖放的是網頁地址
            MsgBox strWebSite + Data.GetData(vbCFText)
        ElseIf Data.GetFormat(vbCFDIB) Then     注釋:拖放的是網頁圖象
            MsgBox strWebImage
        End If
    End Sub

    Private Sub Form_DblClick()
        Unload Me 注釋:雙擊窗口時,退出程序
    End Sub

    Private Sub Form_MouseDown(Button As Integer, Shift As Integer, x As Single, y As Single)
    ReleaseCapture
    SendMessage hwnd, WM_NCLBUTTONDOWN, HTCAPTION, 0& 注釋:使窗口可以通過鼠標拖動
    End Sub



    OK,至此所有的工作都已完成,大家可以自己運行程序試一試,打開網頁拖動 1 個超鏈接到這個窗口,將通過 MsgBox 顯示該超鏈接的地址,如果拖動是的一個圖像,則顯示是一個圖像。
    這只是一個簡單的例子,在此基礎上進一步修改完善就可以運用到其他的許多方面 ,這些就留給朋友自己去思考吧。程序在 VB6.0、Windows 98 下運行良好,如果大家對此還有什么問題,請到 www.d1vb.com 來一起討論。(對編輯的話:這是一個 VB 論壇,我總在上面)。

    延伸閱讀

    文章來源于領測軟件測試網 http://www.kjueaiud.com/


    關于領測軟件測試網 | 領測軟件測試網合作伙伴 | 廣告服務 | 投稿指南 | 聯系我們 | 網站地圖 | 友情鏈接
    版權所有(C) 2003-2010 TestAge(領測軟件測試網)|領測國際科技(北京)有限公司|軟件測試工程師培訓網 All Rights Reserved
    北京市海淀區中關村南大街9號北京理工科技大廈1402室 京ICP備2023014753號-2
    技術支持和業務聯系:info@testage.com.cn 電話:010-51297073

    軟件測試 | 領測國際ISTQBISTQB官網TMMiTMMi認證國際軟件測試工程師認證領測軟件測試網

    老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月

  • <ruby id="5koa6"></ruby>
    <ruby id="5koa6"><option id="5koa6"><thead id="5koa6"></thead></option></ruby>

    <progress id="5koa6"></progress>

  • <strong id="5koa6"></strong>