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

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

?? asyncreader.pas

?? 為Delphi2005做了改動 DSPack 2.3.3 (Sep 2004). DSPack is a set of Components and class to write Multimedia
?? 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一区二区三区免费野_久草精品视频
99热国产精品| 中文字幕日本不卡| 国产精品―色哟哟| 日韩精品乱码免费| 一本色道综合亚洲| 久久免费午夜影院| 天天爽夜夜爽夜夜爽精品视频| 国产酒店精品激情| 91精品国产高清一区二区三区 | 自拍偷拍亚洲欧美日韩| 婷婷成人激情在线网| 色综合网色综合| 亚洲精品一区二区三区影院| 亚洲国产精品嫩草影院| av综合在线播放| 久久一夜天堂av一区二区三区| 亚洲电影一级片| 色呦呦日韩精品| 国产精品美女久久久久久2018 | 91精品国产麻豆国产自产在线 | 91精品国产综合久久久久久久久久| 国产拍揄自揄精品视频麻豆| 日韩国产精品久久久| 久久超碰97人人做人人爱| 日韩欧美一级二级三级久久久| 经典三级一区二区| 一区二区三区在线观看动漫| 亚洲综合免费观看高清在线观看 | 亚洲国产aⅴ天堂久久| 婷婷久久综合九色综合伊人色| 日韩av网站免费在线| 国产伦精一区二区三区| a美女胸又www黄视频久久| 欧洲色大大久久| 日韩欧美国产一二三区| 国产精品久久久久7777按摩| 一区二区三区在线免费观看| 麻豆精品国产传媒mv男同| 成人a区在线观看| 在线成人免费观看| 国产精品夫妻自拍| 男女男精品视频| 色婷婷精品久久二区二区蜜臂av| 欧美一区二区在线免费观看| 国产精品少妇自拍| 麻豆视频观看网址久久| av一区二区三区四区| 6080yy午夜一二三区久久| 国产日韩欧美电影| 奇米影视在线99精品| 成人18精品视频| www国产精品av| 亚洲一区在线视频| 成人性色生活片免费看爆迷你毛片| 欧美成人一级视频| 亚洲综合在线免费观看| 国产精品乡下勾搭老头1| 91精品欧美一区二区三区综合在 | 亚洲色图另类专区| 国产一区视频网站| 日韩欧美一级特黄在线播放| 亚洲成av人片一区二区梦乃| 99精品欧美一区| 国产欧美综合在线观看第十页| 美女在线视频一区| 91精品久久久久久蜜臀| 偷拍自拍另类欧美| 欧美最猛性xxxxx直播| 亚洲特级片在线| 99麻豆久久久国产精品免费| 国产亚洲欧美一区在线观看| 美女精品一区二区| 欧美一区二区在线免费观看| 天使萌一区二区三区免费观看| 在线观看一区日韩| 亚洲国产一区二区三区| 欧洲精品一区二区三区在线观看| 日韩一区有码在线| 91亚洲国产成人精品一区二区三| 国产精品丝袜91| 成人开心网精品视频| 亚洲欧洲三级电影| 色香蕉久久蜜桃| 亚洲一区二区四区蜜桃| 欧美四级电影在线观看| 五月激情综合婷婷| 5月丁香婷婷综合| 九九国产精品视频| 亚洲h动漫在线| 在线亚洲+欧美+日本专区| 一个色在线综合| 欧美日本在线一区| 奇米亚洲午夜久久精品| 欧美精品一区二区三区蜜臀| 国产盗摄一区二区三区| 国产精品美日韩| 色婷婷国产精品久久包臀| 亚洲大片一区二区三区| 欧美一卡2卡3卡4卡| 国产一区二区按摩在线观看| 中文字幕一区二区在线观看| 色悠悠亚洲一区二区| 日韩国产欧美三级| 久久天天做天天爱综合色| thepron国产精品| 亚洲福利国产精品| 日韩视频一区在线观看| 国产福利91精品一区| 亚洲午夜久久久久久久久电影网| 欧美一区二区黄色| 成人av资源网站| 日韩制服丝袜先锋影音| 久久精品人人做人人爽人人| 日本高清不卡aⅴ免费网站| 日本美女一区二区| 日韩美女精品在线| 日韩一区和二区| 99久久精品99国产精品| 日本网站在线观看一区二区三区| 国产欧美精品一区二区三区四区 | 青青草97国产精品免费观看无弹窗版| 精品日韩在线观看| 91福利资源站| 国产v日产∨综合v精品视频| 亚洲1区2区3区视频| 国产精品久久久久久久久果冻传媒 | 国产在线乱码一区二区三区| 亚洲色图在线看| 精品毛片乱码1区2区3区| 在线精品国精品国产尤物884a| 国产一区二区三区在线观看免费视频 | 韩国三级电影一区二区| 夜色激情一区二区| 国产精品二三区| 国产欧美日韩在线看| 日韩一区二区三| 在线观看视频欧美| 不卡视频在线观看| 国产伦理精品不卡| 蜜臀av亚洲一区中文字幕| 亚洲专区一二三| 亚洲色图在线播放| 亚洲欧洲一区二区三区| 国产性天天综合网| 久久一区二区三区国产精品| 在线播放国产精品二区一二区四区| 成人av动漫网站| 成人午夜激情影院| 成人精品免费看| 国产不卡高清在线观看视频| 精品一区二区三区免费毛片爱 | 亚洲精品国久久99热| 久久久久国色av免费看影院| 日韩欧美一区电影| 日韩欧美在线不卡| 欧美成人一级视频| 欧美精品一区二区三区在线 | 成人一二三区视频| 成人h动漫精品一区二区| 成人午夜激情在线| 色综合久久综合网欧美综合网| 99久久99久久精品免费看蜜桃| 国产精品白丝av| 99麻豆久久久国产精品免费优播| a级高清视频欧美日韩| 一本大道av伊人久久综合| 日本道在线观看一区二区| 在线观看亚洲一区| 欧美日韩中文字幕一区| 555www色欧美视频| 精品国产成人在线影院| 欧美经典三级视频一区二区三区| 中日韩av电影| 亚洲综合成人网| 热久久国产精品| 国产风韵犹存在线视精品| 成人黄色a**站在线观看| 91一区二区三区在线观看| 欧美在线|欧美| 欧美v亚洲v综合ⅴ国产v| 国产色产综合色产在线视频| 亚洲色图视频免费播放| 亚洲国产色一区| 国产福利一区二区三区在线视频| av亚洲产国偷v产偷v自拍| 欧美日韩亚洲综合在线| 久久天天做天天爱综合色| 亚洲女人的天堂| 欧美aaaaaa午夜精品| 成人avav在线| 91精品国产综合久久香蕉麻豆| www日韩大片| 一区二区三区四区视频精品免费 | 精品在线免费视频| 99国产欧美另类久久久精品| 欧美精品日韩精品| 中文字幕在线一区| 琪琪久久久久日韩精品| 91社区在线播放| 久久精品在线观看|