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

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

?? asyncreader.pas

?? 一套及時通訊的原碼
?? PAS
?? 第 1 頁 / 共 2 頁
字號:
unit AsyncReader;

   (*********************************************************************
    * The contents of this file are used with permission, subject to    *
    * the Mozilla Public License Version 1.1 (the "License"); you may   *
    * not use this file except in compliance with the License. You may  *
    * obtain a copy of the License at                                   *
    * http://www.mozilla.org/MPL/MPL-1.1.html                           *
    *                                                                   *
    * Software distributed under the License is distributed on an       *
    * "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or    *
    * implied. See the License for the specific language governing      *
    * rights and limitations under the License.                         *
    *                                                                   *
    * (C) 2004 Martin Offenwanger: coder@dsplayer.de                    *
    *********************************************************************)
{
@author(Martin Offenwanger: coder@dsplayer.de)
@created(Apr 22, 2004)
@lastmod(Sep 09, 2004)
}

interface

uses
  ActiveX, Classes, DirectShow9, BaseClass, Windows, Queue, Config, Forms,
  ShoutCastStream, SysUtils, Dialogs, ExtCtrls;

type
  TAsyncIO = class(TInterfacedObject, IAsyncReader)
  private
    FStream: IStream;
    FStop,
      FWaiting,
      FFlushing,
      FFwdStream: boolean;
    FReaderLock,
      FListsLock: TBCCritSec;
    FWorkList,
      FDoneList: TQueue;
    FWorkEvent,
      FDoneEvent,
      FAllDoneEv: TBCAMEvent;
    FOutCount: Longint;
    FStrmSize: Int64;
    FThread: TThread;
    FURLMode: boolean;
    FMediaControl: IMediaControl;
    { the pause and run commands called with FMediaControl in Syncread
      must called via a timer, otherwise ondestroy in unit filter won't called }
    FTimerPlay: TTimer;
    FTimerPause: TTimer;
    procedure OnTimerPlay(Sender: TObject);
    procedure OnTimerPause(Sender: TObject);
    procedure PutDoneItem(AItem: PAsyncRequest);
    function GetDoneItem: PAsyncRequest;
    function PutWorkItem(AItem: PAsyncRequest): HRESULT;
    function GetWorkItem: PAsyncRequest;
    function SetPosition(const APos: Int64): HResult;
    procedure InitStreamLen;
    function SetStreamPos(const APos: Int64): HResult;
    function GetStreamPos: Int64;
    function CreateRequest(llPos: LONGLONG; lLength: Integer;
      bAligned: BOOL; pBuffer: Pointer; pContext: Pointer;
      dwUser: DWORD): PAsyncRequest;
    procedure CompleteRequest(Req: PAsyncRequest);
    function InitAllocator(out Alloc: IMemAllocator): HRESULT; virtual;
    function DoRequest(llPos: LONGLONG; lLength: Longint;
      bAligned: BOOL; pBuffer: Pointer; pContext: Pointer;
      dwUser: DWORD): HResult;
    function DoWaitForNext(dwTimeout: DWORD; var ppContext: Pointer;
      var pdwUser: DWORD; var pcbActual: Longint): HRESULT;
  protected
    // IAsyncReader methods
    function RequestAllocator(pPreferred: IMemAllocator;
      pProps: PAllocatorProperties;
      out ppActual: IMemAllocator): HResult; stdcall;
    function Request(pSample: IMediaSample; dwUser: DWORD): HResult; stdcall;
    function WaitForNext(dwTimeout: DWORD; out ppSample: IMediaSample;
      out pdwUser: DWORD): HResult; stdcall;
    function SyncReadAligned(pSample: IMediaSample): HResult; stdcall;
    function SyncRead(llPosition: int64; lLength: Longint;
      pBuffer: Pbyte): HResult; stdcall;
    function Length(out pTotal, pAvailable: int64): HResult; stdcall;
  public
    constructor Create(AStream: IStream; FwdOnly: boolean = false;
      const StreamSize: Int64 = 0; URLMode: boolean = false);
    // calling the destructor causes crashes
    destructor Destroy; override;
    // we use this function to detroy memeber objects
    procedure FreeAllObjects;
    // the graph object for full control during buffering URL stream
    procedure SetActiveGraph(var FilterGraph: IFilterGraph);
    procedure Addref;
    procedure Release;
    procedure Process;
    // IAsyncReader methods
    function BeginFlush: HRESULT; stdcall;
    function EndFlush: HRESULT; stdcall;
    // FURLMode methods
    procedure Connect(Adress: string; Port: string;
      Location: string; MetaData: boolean);
  end;

implementation

uses WorkerThread, filter;

procedure TAsyncIO.setActiveGraph(var FilterGraph: IFilterGraph);
begin
  // In URlmode we need to control the Graph during buffering
  if (FURLMode) and (FMediaControl = nil) then
  begin
    FilterGraph.QueryInterface(IID_IMediaControl, FMediaControl);
    FTimerPlay := TTimer.Create(nil);
    FTimerPlay.Enabled := false;
    FTimerPlay.Interval := 1;
    // makes shure that run is always called after pause
    FTimerPlay.OnTimer := OnTimerPlay;
    FTimerPause := TTimer.Create(nil);
    FTimerPause.Enabled := false;
    FTimerPause.Interval := 1;
    FTimerPause.OnTimer := OnTimerPause;
  end;
end;

procedure TAsyncIO.Connect(Adress: string; Port: string; Location: string;
  MetaData: boolean);
begin
  GFExit := false;
  g_threadedShoutCastStream := TThreadedShoutcastStream.Create(Adress, Port,
    Location, MetaData);
end;

procedure TAsyncIO.Release;
begin
  _Release;
end;

procedure TAsyncIO.Addref;
begin
  _AddRef;
end;

constructor TAsyncIO.Create(AStream: IStream; FwdOnly: boolean = false;
  const StreamSize: Int64 = 0; URLMode: boolean = false);
begin
  inherited Create;
  FTimerPlay := nil;
  if g_threadedShoutCastStream <> nil then
  begin
    g_threadedShoutCastStream.Destroy;
    g_threadedShoutCastStream := nil;
  end;
  FURLMode := URLMode;
  FStream := AStream;
  FListsLock := TBCCritSec.Create;
  FReaderLock := TBCCritSec.Create;
  FWorkList := TQueue.Create;
  FDoneList := TQueue.Create;
  FWorkEvent := TBCAMEvent.Create(true);
  FDoneEvent := TBCAMEvent.Create(true);
  FAllDoneEv := TBCAMEvent.Create(true);
  FFwdStream := FwdOnly;
  FStrmSize := StreamSize;
  FWorkEvent.Reset;
  FThread := TWorkThread.Create(Self);
  FThread.Resume;
end;

procedure TAsyncIO.FreeAllObjects;
var
  Req: PAsyncRequest;
begin
  FStop := true;
  FThread.Terminate;
  FWorkEvent.SetEv;
  FThread.WaitFor;
  FThread.Free;
  Req := GetDoneItem;
  while Req <> nil do
  begin
    Dispose(Req);
    Req := GetDoneItem;
  end;
  // FStream._Release;
  FReaderLock.Free;
  FListsLock.Free;
  FWorkList.Free;
  FDoneList.Free;
  FWorkEvent.Free;
  FDoneEvent.Free;
  FAllDoneEv.Free;
  FTimerPlay.Free;
  FTimerPause.Free;
end;

destructor TAsyncIO.Destroy;
var
  Req: PAsyncRequest;
begin
  GFExit := true;
  FStop := true;
  FThread.Terminate;
  FWorkEvent.SetEv;
  FThread.WaitFor;
  FThread.Free;
  Req := GetDoneItem;
  while Req <> nil do
  begin
    Dispose(Req);
    Req := GetDoneItem;
  end;
  FStream := nil;
  FReaderLock.Free;
  FListsLock.Free;
  FWorkList.Free;
  FDoneList.Free;
  FWorkEvent.Free;
  FDoneEvent.Free;
  FAllDoneEv.Free;
  inherited destroy;
end;

function TAsyncIO.BeginFlush: HRESULT;
var
  Req: PAsyncRequest;
begin
  GFExit := true;
  { need to nil here IMediaControl,
    if not, the destructor in TFilter will not executed }
  FMediaControl := nil;
  FListsLock.Lock;
  Result := S_OK;
  // we nil here and in the filter destructor
  if g_threadedShoutCastStream <> nil then
  begin
    g_threadedShoutCastStream.Destroy;
    g_threadedShoutCastStream := nil;
  end;
  if GFStringQueue <> nil then
  begin
    GFStringQueue.destroy;
    GFStringQueue := nil;
  end;
  try
    FFlushing := true;
    Req := GetWorkItem;
    while Req <> nil do
    begin
      PutDoneItem(Req);
      Req := GetWorkItem;
    end;
    if FOutCount > 0 then
    begin
      Assert(not FWaiting);
      FAllDoneEv.Reset;
      FWaiting := true;
    end
    else
    begin
      FDoneEvent.SetEv;
      FWorkEvent.SetEv;
    end;
  finally
    FListsLock.UnLock;
  end;
  //Assert(FWaiting);
  while FWaiting do
  begin
    FAllDoneEv.Wait();
    FListsLock.Lock;
    try
      if FOutCount = 0 then
      begin
        FWaiting := false;
        FDoneEvent.SetEv;
      end;
    finally
      FListsLock.UnLock;
    end;
  end;
end;

function TAsyncIO.EndFlush: HRESULT;
begin
  GFExit := true;
  FListsLock.Lock;
  FFlushing := false;
  Assert(not FWaiting);

  if FDoneList.Count > 0 then
    FDoneEvent.SetEv
  else
    FDoneEvent.Reset;

  Result := S_OK;
  FListsLock.UnLock;
end;

procedure TAsyncIO.Process;
var
  Req: PAsyncRequest;
begin
  while true do
  begin
    FWorkEvent.Wait;
    FListsLock.Lock;
    Req := GetWorkItem;
    if Req <> nil then
      Inc(FOutCount);
    FListsLock.UnLock;

    if Req <> nil then
    begin
      CompleteRequest(Req);
      FListsLock.Lock;
      PutDoneItem(Req);
      Dec(FOutCount);
      if (FOutCount = 0) and FWaiting then
        FAllDoneEv.SetEv;
      FListsLock.UnLock;
    end;
    if FStop then
      break;
  end;
end;

function TAsyncIO.DoRequest(
  llPos: LONGLONG; lLength: Integer; bAligned: BOOL; pBuffer,
  pContext: Pointer; dwUser: DWORD): HResult;
var
  Req: PAsyncRequest;
begin
  Req := CreateRequest(llPos, lLength, bAligned, pBuffer, pContext, dwUser);
  Result := PutWorkItem(Req);
  if not Succeeded(Result) then
    Dispose(Req);
end;

function TAsyncIO.DoWaitForNext(dwTimeout: DWORD; var ppContext: Pointer;
  var pdwUser: DWORD; var pcbActual: Integer): HRESULT;
var
  Req: PAsyncRequest;
begin
  Result := S_OK;
  ppContext := nil;
  pdwUser := 0;
  pcbActual := 0;
  while true do
  begin
    if (not FDoneEvent.Wait(dwTimeout)) then
    begin
      Result := VFW_E_TIMEOUT;
      Break;
    end;
    Req := GetDoneItem;
    if Req <> nil then
    begin
      ppContext := Req.FContext;
      pdwUser := Req.FUser;
      pcbActual := Req.FLength;
      Result := Req.Fhr;
      Dispose(Req);
      Break;
    end
    else
    begin
      FListsLock.Lock;
      try
        if FFlushing {and not FWaiting} then
        begin
          Result := VFW_E_WRONG_STATE;
          Break;
        end;
      finally
        FListsLock.UnLock;
      end;
    end;
  end;
end;

procedure TAsyncIO.OnTimerPlay(Sender: TObject);
begin
  if FMediaControl <> nil then
    FMediaControl.Run;
  FTimerPlay.Enabled := false;
end;

procedure TAsyncIO.OnTimerPause(Sender: TObject);
begin
  if FMediaControl <> nil then
    FMediaControl.Pause;
  FTimerPause.Enabled := false;
end;

function TAsyncIO.SyncRead(llPosition: int64; lLength: Longint;
  pBuffer: Pbyte): HResult;
var
  Req: PAsyncRequest;
  DataWritten: boolean;
  i: integer;
  StringStream: TStringStream;
  Buffer: string;
  Tempbuffer: string;
  Avdata: int64;
  Application: TApplication;
  Buffering: boolean;
  Count: integer;
begin
  // we do not accept a Nil buffer
  if pBuffer = nil then
  begin
    result := E_FAIL;
    exit;
  end;
  Result := S_OK;
  // the URL buffer control for Dirctshow is added here
  // buffering during the playback
  if FURLMode then
  begin
    // the min. buffersize must be equal to the requested length
    if GFBufferSize < lLength then
      GFBufferSize := lLength;
    // Mpeg1 splitter requests same samples during connection process and
    // after starting the graph.
    StringStream := nil;
    GFStreamPos := llPosition;
    DataWritten := false;
    Buffer := '';
    Tempbuffer := '';
    Avdata := 0;
    Buffering := false;
    Count := 0;
    Application := TApplication.Create(nil);
    if not GFConnected then
    begin
      if assigned(GFFilterCallBack) then
        GFFilterCallBack.AsyncExFilterState(false, false, true, false, 0);

      // since XP ServicePack2 rc2 the mpeg splitter requests a end sample
      // of the stream during pin connection process,
      // we skip this sample because we can't send it
      if (llPosition > (GCFInt64max - lLength - 2)) then
      begin
        result := E_FAIL;
        exit;
      end;
      i := 0;
      if GFStringQueue = nil then
      begin
        result := E_FAIL;
        exit;
      end;
      while not Datawritten do
      begin
        if GFStringQueue <> nil then
          Count := GFStringQueue.getcount;
        if ((GFExit) or (GFStringQueue = nil) or (Count <= i)) then

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜亚洲福利老司机| 亚洲欧洲成人精品av97| 在线91免费看| 精品免费日韩av| 国产精品嫩草99a| 亚洲精品中文在线影院| 玉米视频成人免费看| 日韩精品国产精品| 国产精品一区二区三区乱码| 99精品久久免费看蜜臀剧情介绍| 91碰在线视频| 亚洲精品一区二区三区香蕉| 亚洲欧美日韩在线不卡| 日韩精品一级二级| 91浏览器打开| 欧美tk—视频vk| 亚洲一级二级在线| 丁香天五香天堂综合| 欧美日韩五月天| 国产精品女主播av| 九色综合狠狠综合久久| 欧美在线色视频| 国产精品福利影院| 国产在线一区二区综合免费视频| 欧美无乱码久久久免费午夜一区| 精品国产91九色蝌蚪| 图片区小说区区亚洲影院| 成人免费高清在线观看| 久久精品人人做人人综合| 日韩综合小视频| 欧美午夜免费电影| 一区二区三区色| 99国产精品久久久久久久久久| 国产网红主播福利一区二区| 精彩视频一区二区三区| 精品乱人伦一区二区三区| 日本中文字幕一区| 精品精品欲导航| 国产在线精品一区二区不卡了| 精品国产123| 国产大陆亚洲精品国产| 国产精品国模大尺度视频| 成人激情免费视频| 亚洲欧美国产毛片在线| 欧美艳星brazzers| 欧美a一区二区| 国产欧美精品一区二区三区四区 | 欧美性欧美巨大黑白大战| 亚洲男人的天堂一区二区| 欧美三级日韩三级国产三级| 图片区小说区国产精品视频| 久久久久久电影| 日本韩国欧美一区二区三区| 亚洲激情校园春色| 日韩欧美国产不卡| 成人免费黄色在线| 午夜成人免费视频| 久久综合色之久久综合| 色婷婷av一区二区三区软件| 三级一区在线视频先锋| 国产欧美1区2区3区| 欧美系列亚洲系列| 国产91丝袜在线18| 亚洲va韩国va欧美va精品| 国产精品初高中害羞小美女文| 精品视频一区二区不卡| av中文一区二区三区| 久久国产精品第一页| 亚洲bdsm女犯bdsm网站| 国产精品国产精品国产专区不蜜| 欧美欧美欧美欧美首页| 成人app在线| 天堂va蜜桃一区二区三区漫画版 | 国产成人综合亚洲91猫咪| 亚洲国产成人精品视频| 亚洲人成小说网站色在线 | 99久久99久久精品免费看蜜桃| 久久精品国内一区二区三区| 日韩精品电影在线观看| 亚洲成人免费在线观看| 五月婷婷久久综合| 亚洲第一激情av| 性感美女极品91精品| 天天综合日日夜夜精品| 亚洲电影一级黄| 蜜臀av国产精品久久久久| 日韩精品成人一区二区在线| 午夜精品影院在线观看| 蜜桃在线一区二区三区| 在线观看不卡视频| www.亚洲人| 欧美视频在线观看一区二区| 欧美久久婷婷综合色| 日韩亚洲欧美在线| 久久精品亚洲精品国产欧美kt∨| 国产视频一区在线播放| 一区二区三区欧美在线观看| 亚洲国产精品一区二区久久恐怖片| 亚洲电影一区二区三区| 麻豆成人综合网| 91丨九色丨蝌蚪丨老版| 日韩一级视频免费观看在线| 国产欧美一区二区在线| 一区二区三区四区五区视频在线观看 | 欧美大片一区二区| 中文字幕欧美一区| 久久er99热精品一区二区| 成人激情免费视频| 69av一区二区三区| 亚洲婷婷在线视频| 另类小说色综合网站| 成人短视频下载| 日韩免费观看2025年上映的电影| 欧美极品美女视频| 精品一区二区三区久久久| 色欧美片视频在线观看| 国产欧美日韩精品a在线观看| 午夜视黄欧洲亚洲| 一本大道av一区二区在线播放| 精品国产一区二区三区av性色| 亚洲电影一区二区| 欧美午夜一区二区三区| 自拍偷拍亚洲欧美日韩| 成人理论电影网| 久久精品男人的天堂| 国产一区二区剧情av在线| 欧美精品一区二区蜜臀亚洲| 六月丁香婷婷色狠狠久久| 这里只有精品视频在线观看| 午夜伦理一区二区| 欧美一区二区国产| 韩日欧美一区二区三区| 26uuu亚洲| 国产.欧美.日韩| 亚洲精品日产精品乱码不卡| 91啦中文在线观看| 日韩av不卡在线观看| 久久久久久久网| 成人午夜碰碰视频| 一级女性全黄久久生活片免费| 91久久久免费一区二区| 日本欧美久久久久免费播放网| 欧美一级高清大全免费观看| 国产一区二区三区高清播放| 国产日韩欧美高清| 欧美狂野另类xxxxoooo| 国产麻豆成人传媒免费观看| 中文字幕一区二区三区在线观看| 91在线观看一区二区| 五月激情丁香一区二区三区| 精品久久国产字幕高潮| 91在线你懂得| 国产精品白丝jk白祙喷水网站| 亚洲乱码中文字幕| 中文字幕第一区二区| 欧美一区午夜视频在线观看| 懂色av一区二区夜夜嗨| 久久国产视频网| 天堂久久久久va久久久久| 中文字幕中文字幕一区| 久久亚洲免费视频| 日韩免费电影一区| 91精品国产综合久久国产大片| 在线亚洲一区二区| 91亚洲国产成人精品一区二三| 成人午夜电影小说| 国产99久久久久久免费看农村| 精品一区二区在线看| 久久超碰97中文字幕| 美日韩黄色大片| 国产老妇另类xxxxx| 国产91精品在线观看| 成人福利视频网站| 欧洲日韩一区二区三区| 在线看一区二区| 在线播放91灌醉迷j高跟美女| 在线成人av影院| 久久久亚洲欧洲日产国码αv| 国产婷婷色一区二区三区在线| 国产欧美一区二区精品婷婷| 亚洲人成亚洲人成在线观看图片| 一卡二卡欧美日韩| 日本成人在线网站| www.日韩大片| 欧美日韩精品一区二区在线播放| 欧美一级欧美三级| 国产精品毛片久久久久久| 亚洲一级电影视频| 粉嫩一区二区三区性色av| 91国产免费观看| 精品国产精品一区二区夜夜嗨| 亚洲私人黄色宅男| 精品一区二区三区免费视频| 成人免费视频视频| 欧美日韩成人综合在线一区二区| 欧美高清在线视频| 日韩高清在线电影| 欧美午夜电影网| 中文字幕在线观看一区| 韩国视频一区二区|