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

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

?? modparsers.bas

?? 防Listview控件源碼
?? 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一区二区三区免费野_久草精品视频
91精品婷婷国产综合久久| 日韩一级免费一区| 成人看片黄a免费看在线| 国精品**一区二区三区在线蜜桃| 亚洲成a人v欧美综合天堂| 一区二区三区在线视频免费| 亚洲免费观看高清在线观看| 尤物在线观看一区| 亚洲在线观看免费视频| 丝袜a∨在线一区二区三区不卡| 亚洲国产日产av| 毛片av一区二区| 国产成人免费视频精品含羞草妖精| 高清成人免费视频| 一本一道波多野结衣一区二区| av亚洲精华国产精华精| 91啪亚洲精品| 91精品国产91久久久久久一区二区| 日韩欧美高清dvd碟片| 久久亚洲综合av| 日韩久久一区二区| 亚洲国产精品一区二区www在线| 免播放器亚洲一区| 福利一区福利二区| 欧美性色黄大片| 精品福利在线导航| 国产精品久久久久一区 | 日韩一区二区免费视频| 日韩欧美美女一区二区三区| 中文字幕不卡三区| 五月天激情综合网| 国产盗摄一区二区三区| 欧美日韩一区在线| 久久九九影视网| 五月婷婷综合在线| 99久久婷婷国产综合精品| 3d成人动漫网站| 国产精品国产三级国产普通话蜜臀 | 国产精品电影一区二区三区| 亚洲一区中文在线| 国产91综合网| 日韩一区二区三区精品视频| 国产精品久久久久国产精品日日| 日韩和的一区二区| 日本乱人伦aⅴ精品| www久久精品| 五月激情综合婷婷| 色系网站成人免费| 欧美激情资源网| 蜜桃久久久久久久| 欧美日韩国产首页在线观看| 国产亚洲精品7777| 麻豆久久一区二区| 欧美日韩成人高清| 亚洲老司机在线| eeuss鲁片一区二区三区在线看| 亚洲精品一区二区三区蜜桃下载 | 99精品偷自拍| 国产亚洲午夜高清国产拍精品| 日韩精品一二三区| 欧美三级欧美一级| 亚洲午夜精品网| 欧美性猛片aaaaaaa做受| 国产精品毛片无遮挡高清| 一区二区三区 在线观看视频| 91丨九色丨黑人外教| 亚洲成a人片综合在线| 久久久99精品久久| 欧亚洲嫩模精品一区三区| 视频一区二区中文字幕| 国产女人18水真多18精品一级做| 色激情天天射综合网| 国产资源精品在线观看| 亚洲一区二区欧美| 欧美极品少妇xxxxⅹ高跟鞋 | 久久精品夜色噜噜亚洲a∨| 欧美伊人久久久久久久久影院 | 午夜影院在线观看欧美| 中文字幕第一区| 91精品国产综合久久福利| 本田岬高潮一区二区三区| 日韩中文字幕一区二区三区| 国产精品麻豆一区二区| 欧美xfplay| 欧美伦理视频网站| 91国产免费看| 99在线视频精品| 国产福利精品导航| 美日韩一区二区| 午夜精品视频在线观看| 亚洲欧洲精品成人久久奇米网| 2欧美一区二区三区在线观看视频| 在线视频欧美精品| 一本久道中文字幕精品亚洲嫩| 福利一区二区在线| 久久69国产一区二区蜜臀| 亚洲成人自拍偷拍| 一区二区久久久久久| 中文字幕在线一区免费| 国产日韩欧美一区二区三区综合| 欧美一区二区国产| 777欧美精品| 欧美日韩亚洲综合| 欧美午夜不卡在线观看免费| 91浏览器在线视频| 91麻豆成人久久精品二区三区| 波多野结衣亚洲一区| 国产xxx精品视频大全| 久久国产精品99久久久久久老狼| 天堂一区二区在线免费观看| 亚洲成人先锋电影| 日韩精品久久久久久| 亚洲观看高清完整版在线观看 | 九九精品视频在线看| 日本午夜精品一区二区三区电影| 亚洲v日本v欧美v久久精品| 亚洲第一福利视频在线| 五月天激情综合| 六月丁香综合在线视频| 狠狠色丁香婷婷综合| 国产一区二区伦理| 成人国产精品免费观看视频| 不卡视频一二三四| 色综合天天综合狠狠| 欧美性受xxxx| 91麻豆精品国产| 久久一区二区三区四区| 精品粉嫩超白一线天av| 久久久久久久久久久电影| 国产日韩一级二级三级| 亚洲欧美日韩国产综合| 丝袜诱惑制服诱惑色一区在线观看 | 亚洲影院在线观看| 日韩不卡一二三区| 国产精品白丝jk黑袜喷水| 成人免费毛片高清视频| 在线观看亚洲a| 日韩欧美一二三| 国产婷婷色一区二区三区| 亚洲免费在线视频一区 二区| 亚洲不卡一区二区三区| 国产真实精品久久二三区| 暴力调教一区二区三区| 91精品久久久久久久久99蜜臂| 26uuu色噜噜精品一区| 国产精品成人免费在线| 天天综合天天做天天综合| 国产一区三区三区| 91福利国产成人精品照片| 日韩欧美一区二区视频| 欧美国产日韩一二三区| 午夜成人免费电影| 国产mv日韩mv欧美| 欧美一区二区啪啪| 国产精品传媒在线| 日本aⅴ免费视频一区二区三区| 国产成人精品免费看| 欧美日韩1234| 国产精品污网站| 开心九九激情九九欧美日韩精美视频电影 | 久草中文综合在线| av中文字幕在线不卡| 91精品在线观看入口| 中文字幕一区免费在线观看 | 日韩精品专区在线影院观看| 成人免费在线播放视频| 九色综合国产一区二区三区| 91成人看片片| 国产精品日韩成人| 激情深爱一区二区| 欧美日韩aaaaa| 亚洲综合小说图片| 成人黄色大片在线观看| 久久亚洲一区二区三区明星换脸| 午夜精品久久久久影视| 色呦呦国产精品| 国产精品网站一区| 国产乱人伦偷精品视频不卡| 欧美日本在线播放| 亚洲精品一二三四区| 成人高清免费观看| 久久久国产精品不卡| 久久99久国产精品黄毛片色诱| 欧美日韩亚州综合| 一个色综合网站| 色妞www精品视频| 亚洲欧洲另类国产综合| 成人精品一区二区三区中文字幕| 26uuu精品一区二区| 狠狠色综合播放一区二区| 日韩欧美成人一区二区| 美女国产一区二区三区| 91精品国产综合久久福利软件| 天天色综合天天| 欧美一区二区在线播放| 青青草国产精品亚洲专区无| 欧美一区在线视频| 麻豆成人久久精品二区三区小说| 欧美精品一二三区| 日韩高清在线不卡|