hxclsnk.h
上传用户:dangjiwu
上传日期:2013-07-19
资源大小:42019k
文件大小:9k
源码类别:

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: hxclsnk.h,v 1.1.1.1.50.1 2004/07/09 02:06:13 hubbe Exp $
  3.  * 
  4.  * Portions Copyright (c) 1995-2004 RealNetworks, Inc. All Rights Reserved.
  5.  * 
  6.  * The contents of this file, and the files included with this file,
  7.  * are subject to the current version of the RealNetworks Public
  8.  * Source License (the "RPSL") available at
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed
  10.  * the file under the current version of the RealNetworks Community
  11.  * Source License (the "RCSL") available at
  12.  * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
  13.  * will apply. You may also obtain the license terms directly from
  14.  * RealNetworks.  You may not use this file except in compliance with
  15.  * the RPSL or, if you have a valid RCSL with RealNetworks applicable
  16.  * to this file, the RCSL.  Please see the applicable RPSL or RCSL for
  17.  * the rights, obligations and limitations governing use of the
  18.  * contents of the file.
  19.  * 
  20.  * Alternatively, the contents of this file may be used under the
  21.  * terms of the GNU General Public License Version 2 or later (the
  22.  * "GPL") in which case the provisions of the GPL are applicable
  23.  * instead of those above. If you wish to allow use of your version of
  24.  * this file only under the terms of the GPL, and not to allow others
  25.  * to use your version of this file under the terms of either the RPSL
  26.  * or RCSL, indicate your decision by deleting the provisions above
  27.  * and replace them with the notice and other provisions required by
  28.  * the GPL. If you do not delete the provisions above, a recipient may
  29.  * use your version of this file under the terms of any one of the
  30.  * RPSL, the RCSL or the GPL.
  31.  * 
  32.  * This file is part of the Helix DNA Technology. RealNetworks is the
  33.  * developer of the Original Code and owns the copyrights in the
  34.  * portions it created.
  35.  * 
  36.  * This file, and the files included with this file, is distributed
  37.  * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
  38.  * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
  39.  * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
  40.  * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
  41.  * ENJOYMENT OR NON-INFRINGEMENT.
  42.  * 
  43.  * Technology Compatibility Kit Test Suite(s) Location:
  44.  *    http://www.helixcommunity.org/content/tck
  45.  * 
  46.  * Contributor(s):
  47.  * 
  48.  * ***** END LICENSE BLOCK ***** */
  49. #ifndef _HXCLSNK_H_
  50. #define _HXCLSNK_H_
  51. /*
  52.  * Forward declarations of some interfaces defined or used here-in.
  53.  */
  54. typedef _INTERFACE   IHXClientAdviseSink       IHXClientAdviseSink;
  55. typedef _INTERFACE   IHXRequest IHXRequest;
  56. /****************************************************************************
  57.  * 
  58.  *  Interface:
  59.  * 
  60.  * IHXClientAdviseSink
  61.  * 
  62.  *  Purpose:
  63.  * 
  64.  * Interface supplied by client to core to receive notifications of
  65.  * status changes.
  66.  * 
  67.  *  IID_IHXClientAdviseSink:
  68.  * 
  69.  * {00000B00-0901-11d1-8B06-00A024406D59}
  70.  * 
  71.  */
  72. DEFINE_GUID(IID_IHXClientAdviseSink, 0x00000B00, 0x901, 0x11d1, 0x8b, 0x6, 0x0, 
  73. 0xa0, 0x24, 0x40, 0x6d, 0x59);
  74. #undef  INTERFACE
  75. #define INTERFACE   IHXClientAdviseSink
  76. DECLARE_INTERFACE_(IHXClientAdviseSink, IUnknown)
  77. {
  78.     /*
  79.      * IUnknown methods
  80.      */
  81.     STDMETHOD(QueryInterface) (THIS_
  82. REFIID riid,
  83. void** ppvObj) PURE;
  84.     STDMETHOD_(ULONG32,AddRef) (THIS) PURE;
  85.     STDMETHOD_(ULONG32,Release) (THIS) PURE;
  86.     /*
  87.      * IHXClientAdviseSink methods
  88.      */
  89.     /************************************************************************
  90.      * Method:
  91.      *     IHXClientAdviseSink::OnPosLength
  92.      * Purpose:
  93.      *     Called to advise the client that the position or length of the
  94.      *     current playback context has changed.
  95.      */
  96.     STDMETHOD(OnPosLength) (THIS_
  97. UINT32   ulPosition,
  98. UINT32   ulLength) PURE;
  99.     /************************************************************************
  100.      * Method:
  101.      *     IHXClientAdviseSink::OnPresentationOpened
  102.      * Purpose:
  103.      *     Called to advise the client a presentation has been opened.
  104.      */
  105.     STDMETHOD(OnPresentationOpened) (THIS) PURE;
  106.     /************************************************************************
  107.      * Method:
  108.      *     IHXClientAdviseSink::OnPresentationClosed
  109.      * Purpose:
  110.      *     Called to advise the client a presentation has been closed.
  111.      */
  112.     STDMETHOD(OnPresentationClosed) (THIS) PURE;
  113.     /************************************************************************
  114.      * Method:
  115.      *     IHXClientAdviseSink::OnStatisticsChanged
  116.      * Purpose:
  117.      *     Called to advise the client that the presentation statistics
  118.      *     have changed. 
  119.      */
  120.     STDMETHOD(OnStatisticsChanged) (THIS) PURE;
  121.     /************************************************************************
  122.      * Method:
  123.      *     IHXClientAdviseSink::OnPreSeek
  124.      * Purpose:
  125.      *     Called by client engine to inform the client that a seek is
  126.      *     about to occur. The render is informed the last time for the 
  127.      *     stream's time line before the seek, as well as the first new
  128.      *     time for the stream's time line after the seek will be completed.
  129.      *
  130.      */
  131.     STDMETHOD(OnPreSeek) (THIS_
  132. ULONG32     ulOldTime,
  133. ULONG32     ulNewTime) PURE;
  134.     /************************************************************************
  135.      * Method:
  136.      *     IHXClientAdviseSink::OnPostSeek
  137.      * Purpose:
  138.      *     Called by client engine to inform the client that a seek has
  139.      *     just occurred. The render is informed the last time for the 
  140.      *     stream's time line before the seek, as well as the first new
  141.      *     time for the stream's time line after the seek.
  142.      *
  143.      */
  144.     STDMETHOD(OnPostSeek) (THIS_
  145. ULONG32     ulOldTime,
  146. ULONG32     ulNewTime) PURE;
  147.     /************************************************************************
  148.      * Method:
  149.      *     IHXClientAdviseSink::OnStop
  150.      * Purpose:
  151.      *     Called by client engine to inform the client that a stop has
  152.      *     just occurred. 
  153.      *
  154.      */
  155.     STDMETHOD(OnStop) (THIS) PURE;
  156.     /************************************************************************
  157.      * Method:
  158.      *     IHXClientAdviseSink::OnPause
  159.      * Purpose:
  160.      *     Called by client engine to inform the client that a pause has
  161.      *     just occurred. The render is informed the last time for the 
  162.      *     stream's time line before the pause.
  163.      *
  164.      */
  165.     STDMETHOD(OnPause) (THIS_
  166. ULONG32     ulTime) PURE;
  167.     /************************************************************************
  168.      * Method:
  169.      *     IHXClientAdviseSink::OnBegin
  170.      * Purpose:
  171.      *     Called by client engine to inform the client that a begin or
  172.      *     resume has just occurred. The render is informed the first time 
  173.      *     for the stream's time line after the resume.
  174.      *
  175.      */
  176.     STDMETHOD(OnBegin) (THIS_
  177. ULONG32     ulTime) PURE;
  178.     /************************************************************************
  179.      * Method:
  180.      *     IHXClientAdviseSink::OnBuffering
  181.      * Purpose:
  182.      *     Called by client engine to inform the client that buffering
  183.      *     of data is occuring. The render is informed of the reason for
  184.      *     the buffering (start-up of stream, seek has occurred, network
  185.      *     congestion, etc.), as well as percentage complete of the 
  186.      *     buffering process.
  187.      *
  188.      */
  189.     STDMETHOD(OnBuffering) (THIS_
  190. ULONG32     ulFlags,
  191. UINT16     unPercentComplete) PURE;
  192.     /************************************************************************
  193.      * Method:
  194.      *     IHXClientAdviseSink::OnContacting
  195.      * Purpose:
  196.      *     Called by client engine to inform the client is contacting
  197.      *     hosts(s).
  198.      *
  199.      */
  200.     STDMETHOD(OnContacting) (THIS_
  201.  const char* pHostName) PURE;
  202. };
  203. // $Private:
  204. /****************************************************************************
  205.  * 
  206.  *  Interface:
  207.  *
  208.  * IHXClientRequestSink
  209.  *
  210.  *  Purpose:
  211.  *
  212.  * Enables top level clients to get notified of new URLs
  213.  *
  214.  *
  215.  *      IID_IHXClientRequestSink
  216.  *
  217.  * {00000B01-0901-11d1-8B06-00A024406D59}
  218.  * 
  219.  */
  220. DEFINE_GUID(IID_IHXClientRequestSink, 0x00000B01, 0x901, 0x11d1, 0x8b, 0x6, 0x0, 
  221. 0xa0, 0x24, 0x40, 0x6d, 0x59);
  222. #undef  INTERFACE
  223. #define INTERFACE   IHXClientRequestSink
  224. DECLARE_INTERFACE_(IHXClientRequestSink, IUnknown)
  225. {
  226.     /************************************************************************
  227.      * Method:
  228.      *     IHXClientRequestSink::OnNewRequest
  229.      * Purpose:
  230.      *     Inform TLC of the new request. The TLC may choose to 
  231.      *     modify RequestHeaders at this time.
  232.      */
  233.     STDMETHOD(OnNewRequest)  (THIS_ IHXRequest* pNewRequest) PURE;
  234. };
  235. // $EndPrivate.
  236. #endif /* _HXCLSNK_H_ */