亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? modparsers.bas

?? 很棒的網頁音樂播放器,可以嵌入網頁。界面很漂亮
?? BAS
?? 第 1 頁 / 共 2 頁
字號:
Attribute VB_Name = "modParsers"
'****************************************************************************
'人人為我,我為人人
'枕善居漢化收藏整理
'發布日期:2007/05/08
'描    述:另類自定義listview控件源碼(支持真彩色圖標)
'網    站:http://www.Mndsoft.com/  (VB6源碼博客)
'網    站:http://www.VbDnet.com/   (VB.NET源碼博客,主要基于.NET2005)
'e-mail  :Mndsoft@163.com
'e-mail  :Mndsoft@126.com
'OICQ    :88382850
'          如果您有新的好的代碼別忘記給枕善居哦!
'****************************************************************************
'
'感謝您使用本站源碼,如果方便的話請給于本站一點支持,謝謝。
'
'本站物品:
'700MB容量的VB.NET源碼光盤(38元包快遞)
'支持支付寶交易:http://auction1.taobao.com/auction/0/item_detail-0db1-a8aba972995270433643e99d2e4ac592.jhtml
'也可以銀行匯款:http://www.mndsoft.com/sale/yh.png
'
'USB電腦遙控器 源碼光盤
'支持支付寶交易:http://auction1.taobao.com/auction/0/item_detail-0db1-dd4a9c3f6a5785231091b01d54af01fd.jhtml
'也可以銀行匯款:http://www.mndsoft.com/sale/yh.png
'
'如果您給于本站一點支持,本站將更好的利用自身優勢為您尋找您需要的代碼!
Option Explicit

' No APIs are declared public. This is to prevent possibly, differently
' declared APIs or different versions, of the same API, from conflciting
' with any APIs you declared in your project. Same rule for UDTs.

Private Type SafeArrayBound
    cElements As Long
    lLbound As Long
End Type
Private Type SafeArray        ' used as DMA overlay on a DIB
    cDims As Integer
    fFeatures As Integer
    cbElements As Long
    cLocks As Long
    pvData As Long
    rgSABound(0 To 1) As SafeArrayBound
End Type
Private Type PictDesc
    Size As Long
    Type As Long
    hHandle As Long
    hPal As Long
End Type
Private Type RECT
    Left As Long
    Top As Long
    Right As Long
    Bottom As Long
End Type

Private Declare Function VarPtrArray Lib "msvbvm60.dll" Alias "VarPtr" (ByRef Ptr() As Any) As Long
Private Declare Sub CopyMemory Lib "kernel32.dll" Alias "RtlMoveMemory" (ByRef Destination As Any, ByRef Source As Any, ByVal Length As Long)

' used to create a stdPicture from a byte array
Private Declare Function CreateStreamOnHGlobal Lib "ole32" (ByVal hGlobal As Long, ByVal fDeleteOnRelease As Long, ppstm As Any) As Long
Private Declare Function GlobalAlloc Lib "kernel32" (ByVal uFlags As Long, ByVal dwBytes As Long) As Long
Private Declare Function GlobalLock Lib "kernel32" (ByVal hMem As Long) As Long
Private Declare Function GlobalUnlock Lib "kernel32" (ByVal hMem As Long) As Long
Private Declare Function GlobalSize Lib "kernel32" (ByVal hMem As Long) As Long
Private Declare Function OleLoadPicture Lib "olepro32" (pStream As Any, ByVal lSize As Long, ByVal fRunmode As Long, riid As Any, ppvObj As Any) As Long
Private Declare Function OleCreatePictureIndirect Lib "olepro32.dll" (lpPictDesc As PictDesc, riid As Any, ByVal fPictureOwnsHandle As Long, iPic As IPicture) As Long

' used to see if DLL exported function exists
Private Declare Function LoadLibrary Lib "kernel32" Alias "LoadLibraryA" (ByVal lpLibFileName As String) As Long
Private Declare Function FreeLibrary Lib "kernel32" (ByVal hLibModule As Long) As Long
Private Declare Function GetProcAddress Lib "kernel32" (ByVal hModule As Long, ByVal lpProcName As String) As Long

' GDI32 APIs
Private Declare Function CombineRgn Lib "gdi32.dll" (ByVal hDestRgn As Long, ByVal hSrcRgn1 As Long, ByVal hSrcRgn2 As Long, ByVal nCombineMode As Long) As Long
Private Declare Function DeleteObject Lib "gdi32" (ByVal hObject As Long) As Long
Private Declare Function ExtCreateRegion Lib "gdi32" (lpXform As Any, ByVal nCount As Long, lpRgnData As Any) As Long
Private Declare Function GetRegionData Lib "gdi32.dll" (ByVal hRgn As Long, ByVal dwCount As Long, ByRef lpRgnData As Any) As Long
Private Declare Function GetRgnBox Lib "gdi32.dll" (ByVal hRgn As Long, ByRef lpRect As RECT) As Long
Private Declare Function CreateRectRgn Lib "gdi32.dll" (ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long
' User32 APIs
Private Declare Function SetRect Lib "user32" (lpRect As RECT, ByVal X1 As Long, ByVal Y1 As Long, ByVal X2 As Long, ByVal Y2 As Long) As Long



Public Function iparseCreateShapedRegion(cHost As c32bppDIB) As Long

    '*******************************************************
    ' FUNCTION RETURNS A HANDLE TO A REGION IF SUCCESSFUL.
    ' If unsuccessful, function retuns zero.
    ' The fastest region from bitmap routines around, custom
    ' designed by LaVolpe. This version modified to create
    ' regions from alpha masks.
    '*******************************************************
    
    ' Useful should a region want to be created around the alpha image.
    ' Tip. Check c32bppDIB.Alpha property before calling this routine.
    '   -- If Alpha=False: When applying to a Window handle,
    '       then SetWindowRgn hWnd,0&,True uses no extra system resources
    '       vs setting the window region to a rectangular region
    
    ' declare bunch of variables...
    Dim rgnRects() As RECT ' array of rectangles comprising region
    Dim rectCount As Long ' number of rectangles & used to increment above array
    Dim rStart As Long ' pixel that begins a new regional rectangle
    
    Dim X As Long, Y As Long ' loop counters
    Dim lScanWidth As Long ' used to size the DIB bit array
    
    Dim bDib() As Byte  ' the DIB bit array
    Dim tSA As SafeArray ' array overlay
    Dim rtnRegion As Long ' region handle returned by this function
    Dim Width As Long, Height As Long
    
    On Error GoTo CleanUp
      
    ' Simple sanity checks
    Width = cHost.Width
    If Width < 1& Then Exit Function
    Height = cHost.Height
    
    If cHost.Alpha = False Then
        iparseCreateShapedRegion = CreateRectRgn(0&, 0&, Width, Height)
        Exit Function
    End If
    
    lScanWidth = Width * 4& ' how many bytes per bitmap line?
    With tSA                ' prepare array overlay
        .cbElements = 1     ' byte elements
        .cDims = 2          ' two dim array
        .pvData = cHost.BitsPointer  ' data location
        .rgSABound(0).cElements = Height
        .rgSABound(1).cElements = lScanWidth
    End With
    ' overlay now
    CopyMemory ByVal VarPtrArray(bDib()), VarPtr(tSA), 4&
    
     ' start with an arbritray number of rectangles
    ReDim rgnRects(0 To Width * 3&)
    ' reset flag
    rStart = -1&
    
    ' begin pixel by pixel comparisons
    For Y = Height - 1 To 0& Step -1&
        ' the alpha byte is every 4th byte
        For X = 3& To lScanWidth - 1& Step 4&
        
            ' test to see if next pixel is 100% transparent
            If bDib(X, Y) = 0 Then
                If rStart > -1& Then ' we're currently tracking a rectangle,
                                    ' so let's close it
                    ' see if array needs to be resized
                   If rectCount + 1& = UBound(rgnRects) Then _
                       ReDim Preserve rgnRects(0 To UBound(rgnRects) + Width * 3&)
                    
                    ' add the rectangle to our array
                    SetRect rgnRects(rectCount + 2&), rStart, Height - Y - 1&, X \ 4, Height - Y
                    rStart = -1& ' reset flag
                    rectCount = rectCount + 1&     ' keep track of nr in use
                End If
            
            Else
                ' not a target color
                If rStart = -1& Then rStart = X \ 4 ' set start point
            
            End If
        Next X
        If rStart > -1& Then
            ' got to end of bitmap without hitting another transparent pixel
            ' but we're tracking so we'll close rectangle now
           
                ' see if array needs to be resized
           If rectCount + 1& = UBound(rgnRects) Then _
               ReDim Preserve rgnRects(0 To UBound(rgnRects) + Width * 3&)
                ' add the rectangle to our array
            SetRect rgnRects(rectCount + 2), rStart, Height - Y - 1, X \ 4, Height - Y
            rStart = -1& ' reset flag
            rectCount = rectCount + 1&     ' keep track of nr in use
        End If
    Next Y

    ' remove the array overlay
    CopyMemory ByVal VarPtrArray(bDib()), 0&, 4&
        
    On Error Resume Next
    ' check for failure & engage backup plan if needed
    If Not rectCount = 0 Then
        ' there were rectangles identified, try to create the region in one step
        rtnRegion = CreatePartialRegion(rgnRects(), 2&, rectCount + 1&, 0&, Width)
        
        ' ok, now to test whether or not we are good to go...
        ' if less than 2000 rectangles, region should have been created & if it didn't
        ' it wasn't due O/S restrictions -- failure
        If rtnRegion = 0& Then
            If rectCount > 2000& Then
                ' Win98 has limitation of approximately 4000 regional rectangles
                ' In cases of failure, we will create the region in steps of
                ' 2000 vs trying to create the region in one step
                rtnRegion = CreateWin98Region(rgnRects, rectCount + 1&, 0&, Width)
            End If
        End If
    End If

CleanUp:
    Erase rgnRects()
    
    If Err Then ' failure; probably low on resources
        If Not rtnRegion = 0& Then DeleteObject rtnRegion
        Err.Clear
    Else
        iparseCreateShapedRegion = rtnRegion
    End If


End Function

Private Function CreatePartialRegion(rgnRects() As RECT, lIndex As Long, uIndex As Long, leftOffset As Long, cx As Long) As Long
    ' Helper function for CreateShapedRegion & CreateWin98Region
    ' Called to create a region in its entirety or stepped (see CreateWin98Region)

    On Error Resume Next
    ' Note: Ideally contiguous rectangles of equal height & width should be combined
    ' into one larger rectangle. However, thru trial & error I found that Windows
    ' does this for us and taking the extra time to do it ourselves
    ' is too cumbersome & slows down the results.
    
    ' the first 32 bytes of a region is the header describing the region.
    ' Well, 32 bytes equates to 2 rectangles (16 bytes each), so I'll
    ' cheat a little & use rectangles to store the header
    With rgnRects(lIndex - 2) ' bytes 0-15
        .Left = 32&                     ' length of region header in bytes
        .Top = 1&                       ' required cannot be anything else
        .Right = uIndex - lIndex + 1&   ' number of rectangles for the region
        .Bottom = .Right * 16&          ' byte size used by the rectangles; can be zero
    End With
    With rgnRects(lIndex - 1&) ' bytes 16-31 bounding rectangle identification
        .Left = leftOffset                  ' left
        .Top = rgnRects(lIndex).Top         ' top
        .Right = leftOffset + cx            ' right
        .Bottom = rgnRects(uIndex).Bottom   ' bottom
    End With
    ' call function to create region from our byte (RECT) array
    CreatePartialRegion = ExtCreateRegion(ByVal 0&, (rgnRects(lIndex - 2&).Right + 2&) * 16&, rgnRects(lIndex - 2&))
    If Err Then Err.Clear

End Function

Private Function CreateWin98Region(rgnRects() As RECT, rectCount As Long, leftOffset As Long, cx As Long) As Long
    ' Fall-back routine when a very large region fails to be created.
    ' Win98 has problems with regional rectangles over 4000
    ' So, we'll try again in case this is the prob with other systems too.
    ' We'll step it at 2000 at a time which is stil very quick

    Dim X As Long, Y As Long ' loop counters
    Dim win98Rgn As Long     ' partial region
    Dim rtnRegion As Long    ' combined region & return value of this function
    Const RGN_OR As Long = 2&
    Const scanSize As Long = 2000&

    ' we start with 2 'cause first 2 RECTs are the header
    For X = 2& To rectCount Step scanSize
    
        If X + scanSize > rectCount Then
            Y = rectCount
        Else
            Y = X + scanSize
        End If
        
        ' attempt to create partial region, scanSize rects at a time
        win98Rgn = CreatePartialRegion(rgnRects(), X, Y, leftOffset, cx)
        
        If win98Rgn = 0& Then    ' failure
            ' cleaup combined region if needed
            If Not rtnRegion = 0& Then DeleteObject rtnRegion
            Exit For ' abort; system won't allow us to create the region
        Else
            If rtnRegion = 0& Then ' first time thru
                rtnRegion = win98Rgn
            Else ' already started
                ' use combineRgn, but only every scanSize times
                CombineRgn rtnRegion, rtnRegion, win98Rgn, RGN_OR
                DeleteObject win98Rgn
            End If
        End If
    Next
    ' done; return result
    CreateWin98Region = rtnRegion
    
End Function

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲色图色小说| 亚洲国产精品成人久久综合一区| heyzo一本久久综合| 久国产精品韩国三级视频| 日韩中文字幕区一区有砖一区| 亚洲精品菠萝久久久久久久| 亚洲激情欧美激情| 五月激情综合网| 日日夜夜免费精品| 久久精品国产成人一区二区三区 | 久久精品二区亚洲w码| 五月天国产精品| 国内外成人在线| 国产sm精品调教视频网站| 国产91精品免费| 91麻豆文化传媒在线观看| 欧美午夜电影一区| 在线不卡中文字幕| 精品国产91久久久久久久妲己| 欧美精品一区二区精品网| 国产情人综合久久777777| 中文字幕在线不卡视频| 亚洲午夜在线视频| 久久er99热精品一区二区| 国产精品一区二区果冻传媒| jlzzjlzz欧美大全| 91麻豆精品91久久久久久清纯| 欧美不卡一二三| 综合精品久久久| 欧美aa在线视频| 91麻豆swag| 日韩欧美色电影| 一区二区三区四区av| 男男成人高潮片免费网站| 成人黄动漫网站免费app| 精品1区2区3区| 久久精品在线观看| 亚洲一区二区视频在线| 国产乱码字幕精品高清av| 日本丶国产丶欧美色综合| 欧美一区二区久久| 国产精品国产三级国产三级人妇 | 国产美女一区二区| 色狠狠色噜噜噜综合网| 欧美不卡一区二区三区| 亚洲国产人成综合网站| 国产精品小仙女| 欧美成人伊人久久综合网| 亚洲免费在线观看视频| 国产大陆a不卡| 日韩三级免费观看| 亚洲国产精品欧美一二99| 成a人片亚洲日本久久| 久久伊99综合婷婷久久伊| 丝袜a∨在线一区二区三区不卡| 99久久伊人网影院| 国产亚洲欧美一区在线观看| 琪琪一区二区三区| 欧美日韩亚洲高清一区二区| 中文字幕一区二区三区不卡| 国产成人免费网站| 久久久无码精品亚洲日韩按摩| 亚洲v中文字幕| 欧美性色黄大片手机版| 综合亚洲深深色噜噜狠狠网站| 国产高清不卡一区二区| 91麻豆精品国产| 日韩高清在线观看| 欧美日韩国产123区| 亚洲一区成人在线| 欧洲一区在线观看| 亚洲一线二线三线久久久| 色综合久久久久综合体桃花网| 国产精品私人自拍| 色一情一乱一乱一91av| 国产欧美精品在线观看| 国产成人自拍高清视频在线免费播放| 欧美大度的电影原声| 免费成人在线观看视频| 日韩网站在线看片你懂的| 亚洲mv大片欧洲mv大片精品| 欧美亚洲另类激情小说| 天涯成人国产亚洲精品一区av| 欧美日本乱大交xxxxx| 丝袜亚洲精品中文字幕一区| 欧美高清视频在线高清观看mv色露露十八| 亚洲一区二区三区美女| 欧美精品日韩综合在线| 美女网站色91| 国产欧美va欧美不卡在线| av在线一区二区三区| 亚洲欧美日韩一区二区| 欧美色中文字幕| 麻豆精品国产传媒mv男同| 久久这里只精品最新地址| 成人动漫视频在线| 亚洲一区二区高清| 久久综合久久综合亚洲| 成人综合婷婷国产精品久久| 最近中文字幕一区二区三区| 欧美亚洲高清一区| 经典三级一区二区| 中文字幕在线不卡一区| 7777女厕盗摄久久久| 国产风韵犹存在线视精品| 一区二区三区中文免费| 欧美一级电影网站| 成人免费三级在线| 午夜精品一区在线观看| 国产亲近乱来精品视频| 欧美又粗又大又爽| 国产久卡久卡久卡久卡视频精品| 亚洲免费观看高清在线观看| 精品va天堂亚洲国产| 欧洲色大大久久| 国产在线视频精品一区| 亚洲午夜在线观看视频在线| 久久久精品一品道一区| 91麻豆精品国产自产在线| 91麻豆福利精品推荐| 精品一区二区三区在线视频| 一区二区三区四区高清精品免费观看 | 国产欧美精品一区aⅴ影院| 色综合久久综合网欧美综合网| 经典三级在线一区| 日韩成人伦理电影在线观看| 亚洲人成人一区二区在线观看| 精品国产制服丝袜高跟| 欧美男男青年gay1069videost| 成人污视频在线观看| 激情图片小说一区| 日本aⅴ亚洲精品中文乱码| 亚洲视频一二三| 国产精品三级av在线播放| 精品国产一区二区精华| 欧美精品高清视频| 欧美日韩在线观看一区二区| 99综合影院在线| 国产999精品久久| 国产露脸91国语对白| 韩国欧美国产1区| 琪琪一区二区三区| 免费不卡在线视频| 日韩极品在线观看| 婷婷久久综合九色综合绿巨人| 亚洲裸体在线观看| 亚洲欧美在线aaa| 国产精品家庭影院| 亚洲精品视频自拍| 亚洲欧美日韩综合aⅴ视频| 国产精品乱码一区二三区小蝌蚪| 国产日韩成人精品| 中文av一区二区| 国产精品久久久久久久裸模 | 欧美人与z0zoxxxx视频| 欧美理论在线播放| 宅男噜噜噜66一区二区66| 欧美精品自拍偷拍动漫精品| 欧美日韩精品一区视频| 91麻豆精品国产自产在线| 日韩欧美中文字幕精品| 精品免费国产二区三区| 久久久久久免费| 国产精品色在线| 亚洲精品一二三| 五月天一区二区| 精品一二三四区| 丁香婷婷综合色啪| 在线视频欧美区| 4438x成人网最大色成网站| 精品日韩在线观看| 中文字幕 久热精品 视频在线| 国产精品萝li| 天堂成人免费av电影一区| 国产在线精品免费| 99综合电影在线视频| 欧美精品色综合| 久久久久久日产精品| 一区二区高清在线| 精品制服美女久久| 91女人视频在线观看| 欧美性大战久久| 久久综合资源网| 亚洲欧美成人一区二区三区| 午夜精品一区二区三区免费视频| 蜜桃视频在线观看一区二区| 波多野结衣欧美| 欧美一激情一区二区三区| 国产丝袜欧美中文另类| 亚洲一区在线免费观看| 国产一区二区三区四| 欧美综合天天夜夜久久| 久久久国产综合精品女国产盗摄| 亚洲另类中文字| 久久se精品一区精品二区| 在线观看一区二区精品视频| 久久欧美一区二区| 日日夜夜精品视频天天综合网| 99久久精品国产精品久久| 精品久久国产字幕高潮|