⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hxbsrc.h

📁 著名的 helix realplayer 基于手机 symbian 系统的 播放器全套源代码
💻 H
📖 第 1 页 / 共 2 页
字号:
/* ***** BEGIN LICENSE BLOCK ***** 
 * Version: RCSL 1.0/RPSL 1.0 
 *  
 * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved. 
 *      
 * The contents of this file, and the files included with this file, are 
 * subject to the current version of the RealNetworks Public Source License 
 * Version 1.0 (the "RPSL") available at 
 * http://www.helixcommunity.org/content/rpsl unless you have licensed 
 * the file under the RealNetworks Community Source License Version 1.0 
 * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl, 
 * in which case the RCSL will apply. You may also obtain the license terms 
 * directly from RealNetworks.  You may not use this file except in 
 * compliance with the RPSL or, if you have a valid RCSL with RealNetworks 
 * applicable to this file, the RCSL.  Please see the applicable RPSL or 
 * RCSL for the rights, obligations and limitations governing use of the 
 * contents of the file.  
 *  
 * This file is part of the Helix DNA Technology. RealNetworks is the 
 * developer of the Original Code and owns the copyrights in the portions 
 * it created. 
 *  
 * This file, and the files included with this file, is distributed and made 
 * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
 * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS 
 * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
 * 
 * Technology Compatibility Kit Test Suite(s) Location: 
 *    http://www.helixcommunity.org/content/tck 
 * 
 * Contributor(s): 
 *  
 * ***** END LICENSE BLOCK ***** */ 

#ifndef _HX_BSOURCE_
#define _HX_BSOURCE_

#include "hxresult.h"
#include "hxtypes.h"
#include "hxurl.h"
#include "hxcomm.h"			// IHXRegistryID
#include "plprefk.h"
#include "hxmap.h"
#include "hxfiles.h"
#include "hxasm.h"
#include "hxmon.h"
#include "hxhyper.h"
#include "hxclreg.h"
#include "hxpends.h"
#include "chxelst.h"
#include "statsmgr.h"
#include "statinfo.h"
#include "strminfo.h"
#include "buffmgr.h"
#include "hxausvc.h"
#include "hxaudply.h"
#include "hxplugn.h"
#include "smiltype.h"
#include "recordctl.h"
#include "hxcore.h"

// need to go in hxresult.h
#define HX_INVALID_HEADER			HXR_INVALID_PARAMETER

#define NUM_MILLISECS_IN_A_SEC			((ULONG32) 1000)

#define HX_LATE_PACKET				HXR_FAILED
#define HX_DUPLICATE_PACKET			(HXR_FAILED + 1)


///////////////////////////////////////////////////////////////
// PERFECTPLAY_FUDGE_FACTOR
//
// Percentage of average download to consider for calculations. 
// 100 = 100% and assumes that the average download time is 
// correct. Larger numbers (i.e. 110) would handle the case of 
// the average being lucky as if all future blocks come in at 
// slower rate.
#define PERFECTPLAY_FUDGE_FACTOR		(110)	

///////////////////////////////////////////////////////////////
// PERFECTPLAY_FUDGE_FACTOR_BASE
//
// Base unit of measure for percentage of average download to 
// consider for calculations.
#define PERFECTPLAY_FUDGE_FACTOR_BASE	(100)	

///////////////////////////////////////////////////////////////
// PERFECTPLAY_MIN_BUFFERS
//
// Due to the behavior of pn_net's de-interleaving support
// we must make sure that we have at least 3 superblocks of
// buffers before we can start playback in perfect play mode.
// I have tried smaller amounts, in particular I thought 
// MIN_LEAD_BLOCKS would be a logical number, but this was not
// conservative enough and the playback would stop prematurely
// even though there was data available.
#define PERFECTPLAY_MIN_BUFFERS		(mInterleaveFactor * 3)

///////////////////////////////////////////////////////////////
// PERFECTPLAY_TICKS_PER_SECOND
//
// Since the different OS's return different meanings for "ticks"
// we will use this as the ratio of ticks to seconds.
#ifdef __MWERKS__
#define PERFECTPLAY_TICKS_PER_SECOND		60
#else
#define PERFECTPLAY_TICKS_PER_SECOND		100
#endif

///////////////////////////////////////////////////////////////
// PERFECTPLAY_MIN_TIME
//
// Also due to the behavior of pn_net's de-interleaving support
// we can't play for less than about 3 superblocks of audio, so
// this define will represent this in seconds.
// This is a reasonable minimun perfect play time
#define	PERFECTPLAY_MIN_TIME	10

#define MINIMUM_PLAY_TIME   10000 /* in ms.*/

/* Approx Time to be taken for network buffering */
#define NETWORK_FUDGE_FACTOR			2000

#define MIN_BUFFERTIME_BEFORE_DELAY	500

#define RENDERER_INTERFACE_SIZE	16
#define SECURE_RENDERER_INTERFACE_SIZE	5

// forward decl.
class HXPlayer;
class CHXEvent;
class CHXEventList;
class HXClientEngine;

class Plugin2Handler;

class CBufferManager;
class SourceInfo;
class HXUpgradeCollection;

struct IHXPacket;
struct IHXStreamSource;
struct IHXValues;
struct IHXStream;
struct IHXClientEngine;
struct IHXPlayer;
struct IHXPrivateStreamSource;
struct IHXDigitalRightsManager;

// if you change these two constants please change
// ProtocolName and StreamName size in RaCOnnectionInfo
// structure in hxtypes.h as well...
#define MAX_STREAM_NAME		50
#define MAX_PROTOCOL_NAME	20

#define HX_EOF_TIME		0	// use to indicate to netplay to play until EOF of stream

#define RAM_MIMETYPE		"application/ram"

// XXXTW.	There is a copy of this in rpplmrg\rpplmgr.cpp.  Update both,
// 			if either.
enum PlayMode
{
    NORMAL_PLAY = 0,
    BUFFERED_PLAY,
    PERFECT_PLAY,
    BUFFERED_PLAY_NOT_ENTIRE_CLIP,
    PERFECT_PLAY_NOT_ENTIRE_CLIP
};

enum TurboPlayMode
{
    TURBO_PLAY_UNKNOWN,
    TURBO_PLAY_ON,
    TURBO_PLAY_OFF
};

enum TurboPlayOffReason
{
    TP_OFF_BY_UNKNOWN = 0,
    TP_OFF_BY_PREFERENCE,
    TP_OFF_BY_SERVER,
    TP_OFF_BY_REBUFFER,
    TP_OFF_BY_NOTENOUGHBW,
    TP_OFF_BY_NETCONGESTION,
    TP_OFF_BY_NONRTSP,
    TP_OFF_BY_LIVE,
    TP_OFF_BY_ROB,
    TP_OFF_BY_INVALIDTLC,
    TP_OFF_BY_MULTISURESTREAMS    
};

enum EndCode
{
    END_UNKNOWN = 0,
    END_DURATION,
    END_STOP,
    END_RECONNECT,
    END_REDIRECT,
    END_ABORT
};

struct TurboPlayStats
{
    TurboPlayOffReason	tpOffReason;
    BOOL		bBufferDone;
    UINT32		ulAcceleratedBW;
    UINT32		ulBufferedTime;

    TurboPlayStats()
    {
	tpOffReason = TP_OFF_BY_UNKNOWN;
	bBufferDone = FALSE;
	ulAcceleratedBW = 0;
	ulBufferedTime = 0;
    }
};

class HXSource : public IHXStreamSource,
		  public IHXPendingStatus,
		  public IHXRegistryID,
		  public IHXInfoLogger,
		  public IHXPrivateStreamSource,
		  public IHXBackChannel,
		  public IHXASMSource,
#if defined(HELIX_FEATURE_HYPER_NAVIGATE)
		  public IHXHyperNavigate,
		  public IHXHyperNavigate2,
#endif /* defined(HELIX_FEATURE_HYPER_NAVIGATE) */
                  public IHXSourceBufferingStats2
{
protected:
    LONG32			m_lRefCount;
    ULONG32			m_ulStreamIndex;

    HXPlayer*			m_pPlayer;
    
    CBufferManager*		m_pBufferManager;

    friend class CBufferManager;

public:
    // statistic info.
    HXClientRegistry*		m_pRegistry;
#if defined(HELIX_FEATURE_STATS) && defined(HELIX_FEATURE_REGISTRY)
    StatsManager*		m_pStatsManager;
    SOURCE_STATS*		m_pStats;
#endif /* HELIX_FEATURE_STATS && HELIX_FEATURE_REGISTRY */
    IHXValues*			m_pFileHeader;
    HX_BITFIELD			m_bRebufferingRequired : 1;
    HX_BITFIELD			m_bRTSPRuleFlagWorkAround : 1;
    HX_BITFIELD			m_bReSetup : 1;
    HX_BITFIELD			m_bFastStart : 1;
    EndCode			m_srcEndCode;
    TurboPlayStats		m_turboPlayStats;
    TurboPlayMode		m_serverTurboPlay;
    HX_BITFIELD			m_bSureStreamClip : 1;
    SourceInfo*			m_pSourceInfo;
    UINT32			m_ulMaxBandwidth;
    UINT32			m_ulDelay;    
    UINT32			m_ulOriginalDuration;
    UINT32			m_ulOriginalDelay;
    UINT32			m_ulPrefetchDelay;
    UINT32			m_ulRegistryID;
    UINT32			m_ulTurboPushDown;
    CHXSimpleList               m_PacketBufferList;
    HX_BITFIELD                 m_bContinueWithHeaders : 1;

protected:
    HX_BITFIELD			m_bDefaultAltURL : 1;

public:
				HXSource(void);

    /*
     * IUnknown methods
     */

    STDMETHOD(QueryInterface)	(THIS_
				REFIID riid,
				void** ppvObj);

    STDMETHOD_(ULONG32,AddRef)	(THIS);

    STDMETHOD_(ULONG32,Release)	(THIS);

    /*
     * IHXStreamSource methods
     */

    /************************************************************************
     *	Method:
     *		IHXStreamSource::IsLive
     *	Purpose:
     *		Ask the source whether it is live
     *
     */
    STDMETHOD_ (BOOL,IsLive)	(THIS);
    
    /************************************************************************
     *	Method:
     *	    IHXStreamSource::GetPlayer
     *	Purpose:
     *	    Get the interface to the player of which the source is
     *	    a part of.
     *
     */
    STDMETHOD(GetPlayer)	(THIS_
				REF(IHXPlayer*)    pPlayer);

    /************************************************************************
     *	Method:
     *	    IHXStreamSource::GetContext
     *	Purpose:
     *	    Get the interface to the context of which the source is
     *	    a part of.
     *
     */
    STDMETHOD(GetContext)	(THIS_
				REF(IUnknown*)	pContext);

    /************************************************************************
     *	Method:
     *	    IHXStreamSource::GetURL
     *	Purpose:
     *	    Get the URL for this source. NOTE: The returned string is
     *	    assumed to be valid for the life of the IHXStreamSource from which it
     *	    was returned.
     *
     */
    STDMETHOD_(const char*,GetURL)  (THIS);

    /************************************************************************
     *	Method:
     *	    IHXStreamSource::GetStreamCount
     *	Purpose:
     *	    Returns the current number of stream instances supported by
     *	    this source instance.
     */
    STDMETHOD_(UINT16, GetStreamCount)(THIS);

    /************************************************************************
     *	Method:
     *	    IHXStreamSource::GetStream
     *	Purpose:
     *	    Returns the Nth stream instance supported by this source.
     */
    STDMETHOD(GetStream)	(THIS_
				UINT16		nIndex,
				REF(IUnknown*)	pUnknown);

    /************************************************************************
     *	Method:
     *		HXSource::ReportError
     *	Purpose:
     *		The protocol object reports of any fatal errors. 
     *
     */
    void	ReportError (HX_RESULT theErr);


    // IHXPendingStatus methods

    /************************************************************************
     *	Method:
     *	    IHXPendingStatus::GetStatus
     *	Purpose:
     *	    Called by the user to get the current pending status from an object
     */
    STDMETHOD(GetStatus)	(THIS_
				REF(UINT16) uStatusCode, 
				REF(IHXBuffer*) pStatusDesc, 
				REF(UINT16) ulPercentDone) = 0;

    /*
     *	IHXRegistryID methods
     */

    /************************************************************************
     *	Method:
     *	    IHXRegistryID::GetID
     *	Purpose:
     *	    Get registry ID(hash_key) of the objects(player, source and stream)
     *
     */
    STDMETHOD(GetID)		(THIS_
				REF(UINT32) /*OUT*/  ulRegistryID) = 0;


    // IHXPrivateStreamSource methods 
    STDMETHOD_ (BOOL,IsSaveAllowed)	(THIS);


    /*
     * IHXBackChannel method
     */
    /************************************************************************
     *	Method:
     *	    IHXBackChannel::PacketReady
     *	Purpose:
     *      A back channel packet sent from Renderer to FileFormat plugin.
     */
    STDMETHOD(PacketReady)	(THIS_
				IHXPacket* pPacket);

    /*
     * IHXASMSource methods
     */

    /************************************************************************
     *	Method:
     *	    IHXASMSource::Subscribe
     *	Purpose:
     *      Called to inform a file format that a subscription has occurred,
     *	    to rule number uRuleNumber, for stream uStreamNumber.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -