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

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: wmbufctl.h,v 1.2.8.1 2004/07/09 02:05:58 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 WMBUFCTL_H
  50. #define WMBUFCTL_H
  51. #include "hxbufctl.h"
  52. class HXWatermarkBufferControl : public IHXWatermarkBufferControl
  53. {
  54. public:
  55.     HXWatermarkBufferControl();
  56.     
  57.     /*
  58.      * IUnknown methods
  59.      */
  60.     STDMETHOD(QueryInterface)   (THIS_
  61.                                 REFIID riid,
  62.                                 void** ppvObj);
  63.     STDMETHOD_(ULONG32,AddRef)  (THIS);
  64.     STDMETHOD_(ULONG32,Release) (THIS);
  65.     /*
  66.      * IHXBufferControl method
  67.      */
  68.     /************************************************************************
  69.      * Method:
  70.      *     IHXBufferControl::Init
  71.      * Purpose:
  72.      *      Initialize the buffer control object with a context
  73.      *      so it can find the interfaces it needs to do buffer
  74.      *      control
  75.      */
  76.     STDMETHOD(Init) (THIS_ IUnknown* pContext);
  77.     /************************************************************************
  78.      * Method:
  79.      *     IHXBufferControl::OnBuffering
  80.      * Purpose:
  81.      *      Called while buffering
  82.      */
  83.     STDMETHOD(OnBuffering) (THIS_ UINT32 ulRemainingInMs,
  84.     UINT32 ulRemainingInBytes);
  85.     /************************************************************************
  86.      * Method:
  87.      *     IHXBufferControl::OnBufferingDone
  88.      * Purpose:
  89.      *      Called when buffering is done
  90.      */
  91.     STDMETHOD(OnBufferingDone)(THIS);
  92.     /************************************************************************
  93.      * Method:
  94.      *     IHXBufferControl::OnResume
  95.      * Purpose:
  96.      *      Called when playback is resumed
  97.      */
  98.     STDMETHOD(OnResume) (THIS);
  99.     
  100.     /************************************************************************
  101.      * Method:
  102.      *     IHXBufferControl::OnPause
  103.      * Purpose:
  104.      *      Called when playback is paused
  105.      */
  106.     STDMETHOD(OnPause) (THIS);
  107.     /************************************************************************
  108.      * Method:
  109.      *     IHXBufferControl::OnSeek
  110.      * Purpose:
  111.      *      Called when a seek occurs
  112.      */
  113.     STDMETHOD(OnSeek) (THIS);
  114.     /************************************************************************
  115.      * Method:
  116.      *     IHXBufferControl::OnClipEnd
  117.      * Purpose:
  118.      *      Called when we get the last packet in the clip
  119.      */
  120.     STDMETHOD(OnClipEnd) (THIS);
  121.     /************************************************************************
  122.      * Method:
  123.      *     IHXBufferControl::Close()
  124.      * Purpose:
  125.      *      Called when the owner of this object wishes to shutdown
  126.      *      and destroy this object. This call causes the buffer control
  127.      *      object to release all it's interfaces references.
  128.      */
  129.     STDMETHOD(Close)(THIS);
  130.     /*
  131.      * IHXWatermarkBufferControl method
  132.      */
  133.     /************************************************************************
  134.      * Method:
  135.      *     IHXWatermarkBufferControl::SetSource
  136.      * Purpose:
  137.      *      Tells the object what HXSource object it is associated with.
  138.      */
  139.     STDMETHOD(SetSource)(THIS_ HXSource* pSource);
  140.     /************************************************************************
  141.      * Method:
  142.      *     IHXWatermarkBufferControl::OnBufferReport
  143.      * Purpose:
  144.      *      Initiates control operations based on buffering information.
  145.      *      
  146.      */
  147.     STDMETHOD(OnBufferReport)(THIS_ UINT32 ulBufferInMs,
  148.       UINT32 ulBuffer);
  149.     /************************************************************************
  150.      * Method:
  151.      *     IHXWatermarkBufferControl::ClearChillState
  152.      * Purpose:
  153.      *      Sets the chill state to NONE
  154.      *      
  155.      */
  156.     STDMETHOD(ClearChillState)(THIS);
  157. private:
  158.     ~HXWatermarkBufferControl();
  159.     HX_RESULT ChangeAccelerationStatus(BOOL bMayBeAccelerated,
  160.        BOOL bUseAccelerationFactor,
  161.        UINT32 ulAccelerationFactor);
  162.     HX_RESULT ResetAccelState();
  163.     ULONG32 m_lRefCount;
  164.     HXSource* m_pSource;
  165.     enum ChillState { HX_NONE, CHILL, HALF, HUNDRETH };
  166.     enum ChillState m_ChillState;
  167. };
  168. #endif /* WMBUFCTL_H */