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

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

?? 自解壓過程.bas

?? 新魔劍壓縮機。采用新的壓縮算法對文件壓縮。
?? BAS
字號:
Attribute VB_Name = "自解壓過程"
Public Declare Function SHBrowseForFolder Lib "shell32.dll" Alias "SHBrowseForFolderA" (lpBrowseInfo As BROWSEINFO) As Long
Public Declare Function SHGetPathFromIDList Lib "shell32.dll" (ByVal pidl As Long, pszPath As String) As Long
Private Declare Function VarPtrArray Lib "msvbvm60.dll" Alias "VarPtr" (ByRef Ptr() As Any) As Long
Private Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)

Public Type BROWSEINFO
        hOwner   As Long
        pidlRoot   As Long
        pszDisplayName   As String
        lpszTitle   As String
        ulFlage   As Long
        lpfn   As Long
        lparam   As Long
        iImage   As Long
End Type

Type FileParameter
  FileAttr  As Byte
  FileDeep  As Byte
  FilePos   As Long
  FileLen   As Long
End Type

Type FileInform
  FileNme() As Byte
  FileParam As FileParameter
End Type

Type RePlaceCode
  DicCode(1 To 2) As Byte
  AscCode As Byte
End Type

Public List() As FileInform
Public RePlaceLim As Byte, Pro As Single, Cancel As Boolean, FileName As String
Private Const ReadLen As Long = 65535

Sub Main()
Dim FSO As New FileSystemObject, s As String
s = App.Path & "\" & App.EXEName & ".EXE"
If FSO.FileExists(s) Then
  Open s For Binary As #1
  Call GetList(1)
  Dim Path As String
  Path = ShowDir(FrmProgress.hWnd, "目標路徑")
  If Path <> "" Then
    Cancel = False
    FrmProgress.Show
    Call ReleaseFile(Path, 0, 1)
  End If
End If
End Sub

Function ShowDir(MehWnd As Long, Optional Title As String) As String
Dim BI As BROWSEINFO
Dim TempID As Long
Dim TempStr As String
        
TempStr = String$(255, Chr$(0))
With BI
  .hOwner = MehWnd
  .pidlRoot = 0
  .lpszTitle = Title + Chr$(0)
  .ulFlage = &H1
End With
        
TempID = SHBrowseForFolder(BI)
        
If SHGetPathFromIDList(ByVal TempID, ByVal TempStr) Then ShowDir = Left$(TempStr, InStr(TempStr, Chr$(0)) - 1)
End Function

Sub GetList(FileNum As Integer)
On Error GoTo Err
Dim AllCount As Long, EachNameLen() As Byte
Dim ListPos As Long
Dim i As Long
Seek #FileNum, LOF(FileNum) - 3
Get #FileNum, , ListPos
Seek #FileNum, ListPos
Get #FileNum, , AllCount
ReDim List(0 To AllCount)
If AllCount > 0 Then
  ReDim EachNameLen(1 To AllCount)
  Get #FileNum, , EachNameLen
  For i = 1 To AllCount
    ReDim List(i).FileNme(0 To EachNameLen(i))
    Get #FileNum, , List(i).FileNme
    Get #FileNum, , List(i).FileParam
  Next
End If
Exit Sub
Err:
  ReDim List(0)
  Seek #FileNum, LOF(FileNum) + 1
  Put #FileNum, , LOF(FileNum)
End Sub

Sub ReleaseFile(Path As String, ListPos As Long, FileNum As Integer)
On Error GoTo Err
Dim t As FileInform, r As Folder, FSO As New FileSystemObject, Name As String
Dim k As Long
If ListPos > 0 Then
  t = List(ListPos)
  If t.FileParam.FileLen >= 0 Then
    Name = Path & "\" & StrConv(t.FileNme, vbUnicode)
    If t.FileParam.FileAttr And vbDirectory Then
      If FSO.FolderExists(Name) Then
        Set r = FSO.GetFolder(Name)
      Else
        Set r = FSO.CreateFolder(Name)
      End If
      r.Attributes = t.FileParam.FileAttr
      Call ReleaseFolder(r, ListPos, FileNum)
    Else
      If FSO.FileExists(Name) Then If MsgBox("文件已存在,是否覆蓋?", vbOKCancel + vbExclamation) = vbOK Then Kill Name Else Exit Sub
      k = UnExtract(FileNum, t.FileParam.FilePos, t.FileParam.FilePos + t.FileParam.FileLen, Name)
      SetAttr Name, t.FileParam.FileAttr
    End If
  End If
Else
  Call ReleaseFolder(FSO.GetFolder(Path), ListPos, FileNum)
End If
Unload FrmProgress
Exit Sub
Err:
  Unload FrmProgress
  MsgBox "Error!"
End Sub

Sub ReleaseFolder(ParFolder As Folder, ListPos As Long, FileNum As Integer)
Dim Name As String, TListPos As Long
Dim t As FileInform, r As Folder, FSO As New FileSystemObject
Dim k As Long
TListPos = ListPos
If ListPos < UBound(List) Then
  If List(ListPos + 1).FileParam.FileDeep > List(ListPos).FileParam.FileDeep Then
    Do
      ListPos = ListPos + 1
      Do While List(ListPos).FileParam.FileLen < 0
        ListPos = ListPos + 1
        If ListPos = UBound(List) Then Exit Sub
      Loop
      t = List(ListPos)
      Name = ParFolder.Path & "\" & StrConv(t.FileNme, vbUnicode)
      If t.FileParam.FileAttr And vbDirectory Then
        If FSO.FolderExists(Name) Then
          Set r = FSO.GetFolder(Name)
        Else
          Set r = FSO.CreateFolder(Name)
        End If
        r.Attributes = t.FileParam.FileAttr
        Call ReleaseFolder(r, ListPos, FileNum)
        If Cancel Then Exit Sub
      Else
        If FSO.FileExists(Name) Then If MsgBox("文件已存在,是否覆蓋?", vbOKCancel + vbExclamation) = vbOK Then Kill Name Else Exit Sub
        k = UnExtract(FileNum, t.FileParam.FilePos, t.FileParam.FilePos + t.FileParam.FileLen, Name)
        SetAttr Name, t.FileParam.FileAttr
      End If
      If ListPos = UBound(List) Then Exit Sub
    Loop Until List(ListPos + 1).FileParam.FileDeep <= List(TListPos).FileParam.FileDeep
  End If
End If
End Sub

Private Sub ClearArray(Arr() As Byte, Pos As Long)
Dim t As Long
ReDim Arr(Pos To Pos)
Call CopyMemory(t, ByVal VarPtrArray(Arr), 4)
Call CopyMemory(ByVal t + 16, 0&, 4)
End Sub

Private Sub SwapArray(a() As Byte, b() As Byte)
Dim t As Long
Call CopyMemory(t, ByVal VarPtrArray(a), 4)
Call CopyMemory(ByVal VarPtrArray(a), ByVal VarPtrArray(b), 4)
Call CopyMemory(ByVal VarPtrArray(b), t, 4)
End Sub


Private Sub UnPointCode(SouData() As Byte, DesData() As Byte)
'變量定義
Static TempData() As Byte
Dim PointCol(1 To 16383) As Integer 'int(65535/4)=16383
Dim RealLen As Long
Dim i As Long, j As Long, k As Long
Dim l As Byte, r As Long, t As Long
Dim PointPos As Long
Dim SouPos As Long, TempPos As Long
Dim TempData2() As Byte

SouPos = LBound(SouData)

If UBound(SouData) - LBound(SouData) + 1 = 0 Then
  Erase TempData
Else
  If LBound(SouData) = 1 Then
    Call ClearArray(DesData, 1)
    Call ClearArray(TempData, 1)
  End If


  l = SouData(SouPos)
  SouPos = SouPos + 1
  RealLen = SouData(SouPos) * 256& Or SouData(SouPos + 1)
  TempPos = SouPos + 2
  SouPos = TempPos + RealLen
  PointPos = SouData(SouPos) * 256& Or SouData(SouPos + 1)
  SouPos = SouPos + 2
  Call CopyMemory(PointCol(1), SouData(SouPos), PointPos * 2)
  SouPos = SouPos + 2 * PointPos

  j = UBound(TempData)
  ReDim Preserve TempData(LBound(TempData) To j + ReadLen) '初始化目標單元大小
  PointPos = 0
  For k = TempPos To TempPos + RealLen - 1
    j = j + 1
    If SouData(k) = l Then
      PointPos = PointPos + 1
      t = PointCol(PointPos) And &HFFF
      For r = 0 To (PointCol(PointPos) And &HFFFF&) \ 4096 + 3
        TempData(j + r) = TempData(j - t + r)
      Next
      j = j + r - 1
    Else
      TempData(j) = SouData(k)
    End If
  Next
    
  'ReDim Preserve TempData(LBound(TempData) To j)  '確定目標單元真實大小
'  ReDim Preserve DesData(LBound(DesData) To j)
'  Call CopyMemory(DesData(LBound(DesData)), TempData(LBound(DesData)), j - LBound(DesData) + 1)
  If j - 4095 > LBound(DesData) Then i = j - 4095 Else i = LBound(DesData)
  
  If SouPos > UBound(SouData) Then
    Call ClearArray(SouData, SouPos)
  Else
    ReDim TempData2(SouPos To UBound(SouData))
    Call CopyMemory(TempData2(SouPos), SouData(SouPos), UBound(SouData) - SouPos + 1)
    Call SwapArray(TempData2, SouData)
  End If

  k = LBound(DesData)
  If i < k Then
    Call SwapArray(TempData, DesData)
    ReDim TempData(i To j)
    Call CopyMemory(TempData(i), DesData(i), j - i + 1)
    ReDim DesData(k To j)
    Call CopyMemory(DesData(k), TempData(k), j - k + 1)
  Else
    If k > j Then
      Call ClearArray(DesData, k)
    Else
      ReDim DesData(k To j)
      Call CopyMemory(DesData(k), TempData(k), j - k + 1)
      ReDim TempData(i To j)
      Call CopyMemory(TempData(i), DesData(i), j - i + 1)
    End If
  End If
End If

End Sub


Private Sub UnRePlaceCode(SouData() As Byte, DesData() As Byte)
Static RePlaceDic(1 To 255) As RePlaceCode '替換表
Dim RealLen As Long
Dim CycleDic(1 To 255) As RePlaceCode, CycleMap(1 To 255) As Byte
Dim CycleCount As Byte
Dim AscMap(0 To 255) As Byte   'Asc映射
Dim i As Long, j As Long, k As Byte
Dim SouPos As Long
Dim TempData() As Byte
SouPos = LBound(SouData)
'開始計時
If UBound(SouData) - LBound(SouData) + 1 = 0 Then
  Erase RePlaceDic
Else
  If LBound(SouData) = 1 Then Call ClearArray(DesData, 1)
  CycleCount = SouData(SouPos)
  SouPos = SouPos + 1
  Call CopyMemory(CycleMap(1), SouData(SouPos), CycleCount)
  For i = 1 To CycleCount
    CycleDic(i) = RePlaceDic(CycleMap(i))
  Next
  SouPos = SouPos + CycleCount
  k = SouData(SouPos)
  SouPos = SouPos + 1
  Call CopyMemory(RePlaceDic(1), SouData(SouPos), 3 * k)
  SouPos = SouPos + 3 * k
  Call CopyMemory(RePlaceDic(k + 1), CycleDic(1), 3 * CycleCount)
  k = k + CycleCount
  '讀取處理單元大小
  RealLen = SouData(SouPos) * 256& Or SouData(SouPos + 1)
  SouPos = SouPos + 2
  '生成Asc映射
  'Erase AscMap
  For i = 1 To k
    AscMap(RePlaceDic(i).AscCode) = i
  Next
  j = UBound(DesData)
  ReDim Preserve DesData(LBound(DesData) To UBound(DesData) + ReadLen) '初始化目標單元大小
  For i = SouPos To SouPos + RealLen - 1
    j = j + 1
    If AscMap(SouData(i)) = 0 Then
      DesData(j) = SouData(i) '無替換
    Else
      DesData(j) = RePlaceDic(AscMap(SouData(i))).DicCode(1) '替換
      j = j + 1
      DesData(j) = RePlaceDic(AscMap(SouData(i))).DicCode(2)
    End If
  Next
  ReDim Preserve DesData(LBound(DesData) To j) '確定目標單元真實大小
    Debug.Print j - LBound(DesData) + 1
  If i <= UBound(SouData) Then
    Call SwapArray(TempData, SouData)
    ReDim SouData(i To UBound(TempData))
    Call CopyMemory(SouData(i), TempData(i), UBound(TempData) - i + 1)
  Else
    Call ClearArray(SouData, i)
  End If
End If
End Sub


Public Function UnExtract(SouFileNum As Integer, StartPos As Long, EndPos As Long, DesFile As String) As Long
On Error GoTo Err
'變量定義
Dim RealLen As Long
Dim buffer1() As Byte, buffer2() As Byte, buffer3() As Byte
Dim SouFileLen As Long   '原文件長
Dim DesFileNum As Integer  '文件號
  
Pro = 0
FileName = Mid$(DesFile, InStrRev(DesFile, "\") + 1)
SouFileLen = EndPos - StartPos
Seek #SouFileNum, StartPos
DesFileNum = FreeFile
Open DesFile For Binary As #DesFileNum

If Seek(SouFileNum) < EndPos Then
  Call ClearArray(buffer1, StartPos)
  Call ClearArray(buffer2, 1)
  Call UnRePlaceCode(buffer1, buffer2)
  Call UnPointCode(buffer1, buffer2)
  Do
    Do Until Seek(SouFileNum) = EndPos And UBound(buffer1) - LBound(buffer1) = -1 Or UBound(buffer2) - LBound(buffer2) + 1 >= 65535 * 2
      DoEvents '防卡死
      Pro = Round((Seek(SouFileNum) - StartPos) / SouFileLen, 4) '進度計算
      If Cancel Then
        Close #DesFileNum
        UnExtract = -1
        Exit Function
      End If
      Seek #SouFileNum, LBound(buffer1)
      If EndPos - Seek(SouFileNum) >= 65535 * 2 Then RealLen = 65535 * 2 Else RealLen = EndPos - Seek(SouFileNum)
      ReDim buffer1(LBound(buffer1) To LBound(buffer1) + RealLen - 1)
      Seek #SouFileNum, LBound(buffer1)
      Get #SouFileNum, , buffer1
      Call UnRePlaceCode(buffer1, buffer2)
    Loop
    Call UnPointCode(buffer2, buffer3)
    Put #DesFileNum, , buffer3
    Call ClearArray(buffer3, UBound(buffer3) + 1)
  Loop Until UBound(buffer2) - LBound(buffer2) = -1 And Seek(SouFileNum) = EndPos And UBound(buffer1) - LBound(buffer1) = -1

End If

UnExtract = LOF(DesFileNum)
Close #DesFileNum '關閉文件
Pro = 1
Exit Function
Err: '錯誤處理
  Close #DesFileNum
  UnExtract = -1
  MsgBox "Error!"
End Function


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本黄色一区二区| 亚洲男人的天堂一区二区| 成人理论电影网| 色天使久久综合网天天| 九九**精品视频免费播放| 性久久久久久久久| 亚洲成人激情自拍| 三级精品在线观看| 日韩一区精品字幕| 日韩黄色片在线观看| 午夜成人免费视频| 日韩精彩视频在线观看| 伦理电影国产精品| 久久精品国产色蜜蜜麻豆| 麻豆中文一区二区| 国产高清在线观看免费不卡| 风流少妇一区二区| 国产丶欧美丶日本不卡视频| 国产精品 日产精品 欧美精品| 国产综合久久久久久鬼色 | 成人免费高清视频| 成人美女在线观看| 91麻豆精品一区二区三区| 色香色香欲天天天影视综合网| 一本色道综合亚洲| 在线播放中文一区| 精品国产精品一区二区夜夜嗨| 欧美精品一区二区高清在线观看| 久久久亚洲综合| 亚洲欧美自拍偷拍色图| 亚洲高清免费观看高清完整版在线观看| 亚洲国产乱码最新视频| 日本亚洲视频在线| 成人h动漫精品| 欧美日韩国产精品成人| 久久久久久9999| 亚洲午夜激情网页| 国产精品一品二品| 欧美做爰猛烈大尺度电影无法无天| 3751色影院一区二区三区| 国产婷婷色一区二区三区| 亚洲一区精品在线| 国产精品亚洲人在线观看| 欧美在线色视频| 久久精品亚洲麻豆av一区二区| 亚洲欧美国产77777| 久久99久久久欧美国产| 色94色欧美sute亚洲线路二| 日韩免费高清电影| 亚洲午夜电影网| 丁香激情综合国产| 日韩欧美中文一区| 亚洲自拍偷拍av| 亚洲精品美国一| 精彩视频一区二区| 91在线观看成人| 欧美一区二区视频观看视频| 综合在线观看色| 免费高清在线视频一区·| 91老司机福利 在线| 欧美一区二区三区视频免费播放| 最近中文字幕一区二区三区| 麻豆精品精品国产自在97香蕉| 成人免费av在线| 久久蜜臀精品av| 调教+趴+乳夹+国产+精品| 国产91丝袜在线播放九色| 91精品中文字幕一区二区三区| 最新欧美精品一区二区三区| 国产综合久久久久久鬼色| 精品视频一区二区不卡| 国产精品美女久久久久久2018| 日韩二区在线观看| 91蝌蚪porny成人天涯| 欧美大片在线观看一区二区| 亚洲伦理在线精品| 成人中文字幕电影| 久久亚洲二区三区| 久久精品国产精品亚洲精品 | 91成人在线免费观看| 精品国产在天天线2019| 丝袜亚洲另类丝袜在线| 色88888久久久久久影院按摩| 久久免费电影网| 日本最新不卡在线| 欧美日韩美女一区二区| 尤物视频一区二区| 欧美高清hd18日本| 亚洲蜜桃精久久久久久久| 北条麻妃国产九九精品视频| 久久亚洲欧美国产精品乐播| 久久国产精品区| 日韩欧美亚洲另类制服综合在线| 亚洲国产成人av| 欧美天堂一区二区三区| 一区二区三区精密机械公司| 91在线视频观看| 国产精品国产自产拍高清av | 91久久精品一区二区| 亚洲欧美综合网| 91麻豆福利精品推荐| 亚洲丝袜制服诱惑| 99久久久国产精品免费蜜臀| 中文字幕一区在线观看| 欧洲一区在线电影| 日韩和欧美一区二区三区| 欧美成人激情免费网| 久久99久久久久久久久久久| 久久一夜天堂av一区二区三区 | 国产精品视频九色porn| 成人一级视频在线观看| 亚洲素人一区二区| 国产资源在线一区| 欧美va亚洲va| 国产suv精品一区二区6| 亚洲天堂2016| 欧美色倩网站大全免费| 午夜天堂影视香蕉久久| 欧美成人伊人久久综合网| 国产露脸91国语对白| 亚洲国产高清在线| 国产一区二区不卡在线| 亚洲欧美二区三区| 日韩欧美亚洲国产精品字幕久久久| 国产一区二区三区电影在线观看| 日本一区二区三区久久久久久久久不| 成人激情免费视频| 亚洲18影院在线观看| 日韩精品一区二区三区三区免费 | 欧美日韩在线综合| 麻豆精品国产91久久久久久| 久久久久久久网| 91官网在线免费观看| 蓝色福利精品导航| 久久精品亚洲乱码伦伦中文| 日韩欧美中文字幕一区| 国产成人福利片| 亚洲免费高清视频在线| 久久夜色精品一区| 欧美精品v国产精品v日韩精品| 国产剧情一区在线| 亚洲国产成人av网| 最新欧美精品一区二区三区| 精品成人免费观看| 欧美日本不卡视频| 成人综合在线网站| 免费人成精品欧美精品| 亚洲一区二区欧美| 国产精品欧美一区二区三区| 欧美大胆人体bbbb| 欧美午夜片在线观看| 粉嫩av一区二区三区在线播放| 美女一区二区三区| 一区二区三区成人| 国产精品麻豆欧美日韩ww| 日韩一区二区中文字幕| 99在线热播精品免费| 久久精品噜噜噜成人av农村| 亚洲国产综合视频在线观看| 欧美国产精品久久| 日韩精品综合一本久道在线视频| 欧美日韩精品电影| 色呦呦国产精品| www.欧美日韩| 国产高清在线观看免费不卡| 天堂一区二区在线免费观看| 中文字幕一区在线| 国产无人区一区二区三区| 欧美大白屁股肥臀xxxxxx| 欧美片网站yy| 欧美三级电影网站| 欧美日本免费一区二区三区| 91首页免费视频| www.性欧美| 一本久道久久综合中文字幕 | 7777精品伊人久久久大香线蕉超级流畅| 91视频在线观看| 色综合一个色综合亚洲| 精品视频一区三区九区| 欧洲国内综合视频| 91精品国产综合久久精品性色| 一本久久a久久精品亚洲| 91丝袜美腿高跟国产极品老师 | 欧美自拍偷拍午夜视频| 风间由美一区二区三区在线观看 | 亚洲电影你懂得| 日本美女一区二区| 麻豆国产精品一区二区三区| 美国一区二区三区在线播放| 美国十次综合导航| 成人禁用看黄a在线| 成人高清免费观看| 欧美吞精做爰啪啪高潮| 91精品国产手机| 91精品国产色综合久久久蜜香臀| 欧美一区二区三区免费大片| 精品国产乱码久久久久久图片 | 亚洲欧美日韩中文播放| 亚洲国产精品一区二区www在线 | 国产中文字幕精品|