⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 acm_defs.bas

📁 vb中如何进行网络编程的示例,包括:UDP聊天,TCP聊天,UDP,TCP flood攻击等 非常棒
💻 BAS
字号:
Attribute VB_Name = "ACM_Defs"
Option Explicit
'== ACM API Constants ================================================
Public Const ACMERR_BASE = 512
Public Const ACMERR_NOTPOSSIBLE = (ACMERR_BASE + 0)
Public Const ACMERR_BUSY = (ACMERR_BASE + 1)
Public Const ACMERR_UNPREPARED = (ACMERR_BASE + 2)
Public Const ACMERR_CANCELED = (ACMERR_BASE + 3)

' AcmStreamSizeFormat Constants
Public Const ACM_STREAMSIZEF_SOURCE = &H0
Public Const ACM_STREAMSIZEF_DESTINATION = &H1
Public Const ACM_STREAMSIZEF_QUERYMASK = &HF

' acmStreamConvert Formats
Public Const ACM_STREAMCONVERTF_BLOCKALIGN = &H4
Public Const ACM_STREAMCONVERTF_START = &H10
Public Const ACM_STREAMCONVERTF_END = &H20

' Done Bits For ACMSTREAMHEADER.fdwStatus
Public Const ACMSTREAMHEADER_STATUSF_DONE = &H10000
Public Const ACMSTREAMHEADER_STATUSF_PREPARED = &H20000
Public Const ACMSTREAMHEADER_STATUSF_INQUEUE = &H100000

' Done Bits For acmStreamOpen Formats
Public Const ACM_STREAMOPENF_QUERY = &H1
Public Const ACM_STREAMOPENF_ASYNC = &H2
Public Const ACM_STREAMOPENF_NONREALTIME = &H4

'== ACM API Declarations ================================================
'Declare Function acmStreamOpen Lib "MSACM32" (ByVal hAS As Integer, ByVal hADrv As Integer, wfxSrc As WAVEFORMATEX, wfxDst As WAVEFORMATEX, wFltr As Any, ByVal dwCallback As Long, ByVal dwInstance As Long, ByVal fdwOpen As Long) As Integer
'Declare Function acmStreamOpen Lib "MSACM32" (ByVal hAS As Long, ByVal hADrv As Long, wfxSrc As WAVEFORMATEX, wfxDst As WAVEFORMATEX, wFltr As Long, ByVal dwCallback As Long, ByVal dwInstance As Long, ByVal fdwOpen As Long) As Long
Declare Function acmStreamOpen Lib "MSACM32" (ByVal hAS As Long, ByVal hADrv As Long, wfxSrc As WAVEFORMATEX, wfxDst As WAVEFORMATEX, ByVal wFltr As Long, ByVal dwCallback As Long, ByVal dwInstance As Long, ByVal fdwOpen As Long) As Long

Declare Function acmStreamPrepareHeader Lib "MSACM32" (ByVal hAS As Integer, hASHdr As ACMSTREAMHEADER, ByVal dwPrepare As Long) As Integer
Declare Function acmStreamUnprepareHeader Lib "MSACM32" (ByVal hAS As Integer, hASHdr As ACMSTREAMHEADER, ByVal dwUnPrepare As Long) As Integer
Declare Function acmStreamConvert Lib "MSACM32" (ByVal hAS As Integer, hASHdr As ACMSTREAMHEADER, ByVal dwConvert As Long) As Integer
Declare Function acmStreamClose Lib "MSACM32" (ByVal hAS As Integer, ByVal dwClose As Long) As Integer
Declare Function acmStreamReset Lib "MSACM32" (ByVal hAS As Integer, ByVal dwReset As Long) As Integer
Declare Function acmStreamSize Lib "MSACM32" (ByVal hAS As Integer, ByVal cbInput As Long, ByVal dwOutBytes As Long, ByVal dwSize As Long) As Integer


'== ACM User Defined Datatypes ================================================
Type WAVEFILTER
    cbStruct      As Long
    dwFilterTag   As Long
    fdwFilter     As Long
    dwReserved(5) As Long
End Type

Type ACMSTREAMHEADER            ' [ACM STREAM HEADER TYPE]
    cbStruct As Long            ' Size of header in bytes
    dwStatus As Long            ' Conversion status buffer
    dwUser As Long              ' 32 bits of user data specified by application
    pbSrc As Long               ' Source data buffer pointer
    cbSrcLength As Long         ' Source data buffer size in bytes
    cbSrcLengthUsed As Long     ' Source data buffer size used in bytes
    dwSrcUser As Long           ' 32 bits of user data specified by application
    cbDst As Long               ' Dest data buffer pointer
    cbDstLength As Long         ' Dest data buffer size in bytes
    cbDstLengthUsed As Long     ' Dest data buffer size used in bytes
    dwDstUser As Long           ' 32 bits of user data specified by application
    dwReservedDriver(10) As Long ' Reserved and should not be used
End Type
'==============================================================================

'------------------------------------------------------------------
Public Function acmCompress(srcWavefmt As WAVEFORMATEX, dstWavefmt As WAVEFORMATEX) As Boolean
'------------------------------------------------------------------
    Dim rc As Long
    Dim hAS As Long
    Dim hASHdr As ACMSTREAMHEADER
'   Dim wFltr As WAVEFILTER
    Dim dwConvert As Long, dwClose As Long, dwReset As Long
    Dim cbInput As Long, dwOutBytes As Long, dwSize As Long
'------------------------------------------------------------------
    ' Open/Configure an acm Stream Handle For Compression
'   rc = acmStreamOpen(hAS, 0, srcWavefmt, dstWavefmt, wFltr, 0, 0, dwOpen)
    rc = acmStreamOpen(hAS, 0, srcWavefmt, dstWavefmt, 0, 0, 0, ACM_STREAMOPENF_ASYNC)
    Debug.Print "acmStreamOpen rc= ", rc
    
    ' Prepare acm Stream Header
    rc = acmStreamPrepareHeader(hAS, hASHdr, 0)
    Debug.Print "acmStreamPrepareHeader rc= ", rc
    
        cbInput = 255 ' must be non zero
    
        ' Calculate acm Stream Size of Output Buffer
        rc = acmStreamSize(hAS, cbInput, dwOutBytes, ACM_STREAMSIZEF_SOURCE)
        Debug.Print "acmStreamSize(input) rc= ", rc
        
        ' Calculate acm Stream Size of Output Buffer
        rc = acmStreamSize(hAS, cbInput, dwOutBytes, ACM_STREAMSIZEF_DESTINATION)
        Debug.Print "acmStreamSize(output) rc= ", rc
    
    ' Convert/Compress acm Stream Wave Buffer
    rc = acmStreamConvert(hAS, hASHdr, dwConvert)
    Debug.Print "acmStreamConvert rc= ", rc
    
    ' Wait Until Conversion Complete...
    Do                                                          ' Loop Until Conversion Is Done
        DoEvents                                                ' Post Events...
    Loop Until hASHdr.dwStatus And ACMSTREAMHEADER_STATUSF_DONE ' Check For The DONE Flag.

    ' UnPrepare acm Stream Header
    rc = acmStreamUnprepareHeader(hAS, hASHdr, 0)
    Debug.Print "acmStreamUnprepareHeader rc= ", rc
    
    ' Close acm Stream Handle
    rc = acmStreamClose(hAS, dwClose)
    Debug.Print "acmStreamClose rc= ", rc
'------------------------------------------------------------------
End Function
'------------------------------------------------------------------

'--------------------------------------------------------------
Public Sub InitAcmHDR(asHdr As ACMSTREAMHEADER, srcHdr As WAVEHDR)
' Initialize's An Input Wave Header's DataBuffer And Size Members...
'--------------------------------------------------------------
    Dim rc As Long                                      ' Function Return Code...
'--------------------------------------------------------------
    asHdr.cbStruct = Len(asHdr)                         ' Size of header in bytes
    asHdr.pbSrc = srcHdr.lpData                         ' Copy pointer To uncompressed data
    asHdr.cbSrcLength = srcHdr.lpData                   ' Copy size of uncompress data
    
    asHdr.cbDstLength = asHdr.cbSrcLength               ' Allocate Enough Memory For Compression
    asHdr.dwDstUser = GlobalAlloc(GMEM_MOVEABLE Or GMEM_SHARE Or GMEM_ZEROINIT, _
                                  asHdr.cbDstLength)    ' Allocate Global Memory
    asHdr.cbDst = GlobalLock(asHdr.dwDstUser)           ' Lock Memory handle
'--------------------------------------------------------------
End Sub
'--------------------------------------------------------------

'--------------------------------------------------------------
Public Sub WaitForACMCallBack(CallBackBit As Long, cbFlag As Long)
' Waits For Asynchronous Function Callback Bit To Be Set.
'--------------------------------------------------------------
    Do                                  ' Loop Until CallBack Bit Is Set!
        DoEvents                        ' Post Events...
    Loop Until (((CallBackBit And cbFlag) = cbFlag) Or _
                 (CallBackBit = 0))     ' Check For (CallBack Bit Or Null)...
'--------------------------------------------------------------
End Sub
'--------------------------------------------------------------



⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -