亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
婷婷夜色潮精品综合在线| 色综合激情久久| 美女在线一区二区| 日韩精品三区四区| 午夜欧美2019年伦理| 日韩国产成人精品| 免费看日韩精品| 美女视频网站久久| 国产一区二区三区日韩| 国产成人精品aa毛片| 成人午夜在线播放| 99久免费精品视频在线观看| 99国产精品久久久| 在线免费观看视频一区| 欧美性一二三区| 宅男在线国产精品| 欧美大胆人体bbbb| 国产女主播视频一区二区| 国产精品色在线观看| 亚洲乱码国产乱码精品精小说 | 在线播放一区二区三区| 欧美肥妇bbw| 亚洲精品一区二区三区精华液| 亚洲精品在线一区二区| 中文一区二区完整视频在线观看| ●精品国产综合乱码久久久久| 亚洲一区二区美女| 男男视频亚洲欧美| 国产成a人亚洲| 91麻豆swag| 91精品午夜视频| 国产午夜久久久久| 亚洲最新在线观看| 成人一区二区三区视频| 91国产丝袜在线播放| 4438成人网| 国产欧美一区二区精品忘忧草| 亚洲天堂成人网| 蜜桃av一区二区| 成人国产精品免费观看| 欧美日韩卡一卡二| 国产精品系列在线| 天堂久久久久va久久久久| 国产精品一区在线观看你懂的| 99久久精品久久久久久清纯| 欧美一区二区三区小说| 国产精品久99| 美女视频黄久久| 色视频欧美一区二区三区| 精品88久久久久88久久久| 一区二区三区在线视频免费 | 欧美在线视频全部完| 日韩精品中文字幕在线不卡尤物| 亚洲品质自拍视频| 黄页网站大全一区二区| 精品视频一区 二区 三区| 久久欧美中文字幕| 日韩主播视频在线| 99re视频精品| 国产欧美一区二区精品仙草咪| 天堂久久一区二区三区| 91网页版在线| 精品剧情在线观看| 午夜av电影一区| 91香蕉视频在线| 久久精品亚洲国产奇米99| 日韩中文字幕一区二区三区| 色综合天天综合给合国产| 久久久久久亚洲综合影院红桃| 日本伊人色综合网| 91传媒视频在线播放| 国产精品毛片高清在线完整版 | 欧美一区二区三区免费大片| 亚洲精品免费电影| 成人app下载| 国产欧美日韩在线| 久久99日本精品| 欧美一区二区三区影视| 亚洲国产日日夜夜| 色呦呦国产精品| 中文字幕一区二区三区色视频| 国产精品夜夜嗨| 久久午夜电影网| 狠狠网亚洲精品| 久久欧美一区二区| 国产中文字幕一区| 精品国产亚洲一区二区三区在线观看| 天天色 色综合| 欧美另类z0zxhd电影| 亚洲成精国产精品女| 欧美日韩在线播放三区| 亚洲一区二区免费视频| 欧美亚男人的天堂| 亚洲成a人片在线观看中文| 色天使久久综合网天天| 一区二区三区蜜桃网| 色婷婷精品大视频在线蜜桃视频| 亚洲欧洲日产国码二区| 97se亚洲国产综合自在线| 日韩一区日韩二区| 99riav一区二区三区| 日韩伦理免费电影| 色哟哟精品一区| 亚洲一二三专区| 欧美一区午夜视频在线观看| 99久久精品国产观看| 亚洲欧美中日韩| 日本道色综合久久| 日韩影院免费视频| 精品久久久久久最新网址| 国产老肥熟一区二区三区| 欧美激情在线观看视频免费| 成人久久久精品乱码一区二区三区| 国产精品欧美一级免费| av一本久道久久综合久久鬼色| 成人免费在线视频观看| 在线中文字幕不卡| 婷婷成人激情在线网| 日韩免费观看2025年上映的电影 | 欧美午夜精品免费| 亚洲高清一区二区三区| 91精品在线麻豆| 激情六月婷婷久久| 欧美国产日韩精品免费观看| 91美女精品福利| 亚洲国产成人精品视频| 欧美一级艳片视频免费观看| 国产精品正在播放| 亚洲免费观看高清完整版在线| 欧美日韩国产美| 狠狠色2019综合网| 亚洲区小说区图片区qvod| 这里只有精品免费| 国产成人精品www牛牛影视| 悠悠色在线精品| 亚洲精品一区二区三区香蕉| 97久久精品人人做人人爽| 天堂成人免费av电影一区| 久久品道一品道久久精品| 色综合久久中文字幕| 秋霞午夜鲁丝一区二区老狼| 国产欧美日韩不卡免费| 欧美日韩免费一区二区三区视频| 国产中文字幕精品| 一级精品视频在线观看宜春院| 日韩色在线观看| 99久久久国产精品免费蜜臀| 奇米色一区二区三区四区| **性色生活片久久毛片| 91精品国产欧美日韩| av在线不卡网| 国模冰冰炮一区二区| 亚洲影院免费观看| 国产欧美视频一区二区三区| 欧美午夜片在线观看| 国产成人精品影视| 日日夜夜免费精品| 亚洲婷婷综合色高清在线| 久久综合成人精品亚洲另类欧美| 色欧美88888久久久久久影院| 精品一区二区国语对白| 亚洲一区影音先锋| 欧美韩国日本不卡| 日韩欧美视频在线| 在线欧美日韩国产| 成人福利视频在线看| 看片的网站亚洲| 亚洲一区二区三区四区在线| 中文字幕成人在线观看| 日韩视频在线一区二区| 欧洲一区二区三区在线| www.亚洲在线| 久久国产乱子精品免费女| 亚洲一区av在线| 亚洲日本va在线观看| 欧美精品一区二区不卡 | 亚洲同性gay激情无套| 久久综合九色综合97婷婷女人| 欧美乱妇20p| 91九色最新地址| 99热这里都是精品| 国产激情一区二区三区| 开心九九激情九九欧美日韩精美视频电影 | 亚洲综合在线观看视频| 亚洲欧美视频在线观看视频| 精品国产一区二区三区四区四| 91网站视频在线观看| 成人黄色电影在线 | 性感美女久久精品| 亚洲免费色视频| 亚洲婷婷在线视频| 成人欧美一区二区三区在线播放| 欧美国产一区二区| 国产无一区二区| 2023国产一二三区日本精品2022| 日韩美女一区二区三区四区| 日韩视频一区二区三区在线播放| 欧美人妖巨大在线| 欧美日韩国产首页| 欧美三级中文字幕在线观看|