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

Symbian

开发平台:

Visual C++

  1. /* ***** BEGIN LICENSE BLOCK *****
  2.  * Source last modified: $Id: sm1time.h,v 1.2.12.1 2004/07/09 01:57:34 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 _SM1TIME_H_
  50. #define _SM1TIME_H_
  51. class CSmil1TimelineElement;
  52. class CSmil1TimelineElementManager
  53. {
  54. public:
  55.     CSmil1TimelineElementManager ();
  56.     ~CSmil1TimelineElementManager ();
  57.     void addTimelineElement (CSmil1TimelineElement* pElement);
  58.     void addNotification (const char* pID,
  59. CSmil1TimelineElement* pElement);
  60.     void notify (const char* pID);
  61.     void resetTimeline ();
  62.     CSmil1TimelineElement*
  63. getTimelineElement (const char* pID);
  64. private:
  65.     CHXMapStringToOb* m_pElementMap;
  66.     CHXMapStringToOb* m_pNotifierMap;
  67. };
  68. class CSmil1TimelineElement
  69. {
  70. public:
  71.     CSmil1TimelineElement (CSmil1Element *pSourceElement,
  72. CSmil1Parser* pParser);
  73.     virtual ~CSmil1TimelineElement ();
  74.     virtual void setDelay (UINT32 ulDelay);
  75.     virtual void setDuration (UINT32 ulDuration,
  76. BOOL bSetFromParent = FALSE);
  77.     virtual void setMaxDuration (UINT32 ulMaxDuration);
  78.     virtual void adjustDependentDuration(CSmil1TimelineElement* pDependent);
  79.     virtual void addDuration (UINT32 ulDuration, 
  80. UINT32 ulDelay,
  81. const char* pID)
  82. {
  83. }
  84.     BOOL initialDelaySet ()
  85. { return m_bDelaySet; }
  86.     BOOL delayEvent ()
  87. { return m_bDelayEvent; }
  88.     BOOL durationSet ()
  89. { return m_bDurationSet; }
  90.     BOOL durationEvent ()
  91. { return m_bDurationEvent; }
  92.     void reset ();
  93.     virtual void elementResolved (CSmil1TimelineElement* pElement);
  94.     void setParent (CSmil1TimelineElement* pParent)
  95.     {
  96.         m_pParent = pParent;
  97.     }
  98.     void setDependent (CSmil1TimelineElement* pDependent)
  99.     {
  100.         m_pDependent = pDependent;
  101.     }
  102.     void addChild (CSmil1TimelineElement* pChild);
  103.     UINT32 getDuration ();
  104.     UINT32 getDelay ();
  105.     virtual void dump ();
  106.     char* m_pID;
  107. protected:
  108.     CSmil1Element* m_pSourceElement;
  109.     CSmil1Parser* m_pParser;
  110.     CHXSimpleList* m_pChildren;
  111.     CSmil1TimelineElement* m_pParent;
  112.     CSmil1TimelineElement* m_pDependent;
  113.     BOOL m_bDelaySet;
  114.     BOOL m_bDelayEvent;
  115.     BOOL m_bDurationEvent;
  116.     BOOL m_bDurationSet;
  117.     BOOL m_bMaxDurationSet;
  118.     BOOL m_bDontResetDuration;
  119.     //The following is for cases where a non-event delay and
  120.     // an event delay exist and m_bDelaySet is not sufficient
  121.     // to keep track of all 3 possible delaySet states.  The
  122.     // non-event delay is always set before the event is resolved
  123.     // so that's why there are 3 and not 4 states:
  124.     BOOL m_bNonEventDelaySet;
  125.     friend class CSmil1TimelinePar;
  126.     friend class CSmil1TimelineSeq;
  127.     friend class CSmil1TimelineAnchor;
  128. };
  129. class CSmil1TimelinePar: public CSmil1TimelineElement
  130. {
  131. public:
  132.     CSmil1TimelinePar (CSmil1Element* pSourceElement, 
  133. CSmil1Parser* pRenderer);
  134.     virtual ~CSmil1TimelinePar ();
  135.     virtual void setDelay (UINT32 ulDelay);
  136.     virtual void setDuration (UINT32 ulDuration,
  137. BOOL bSetFromParent = FALSE);
  138.     virtual void setMaxDuration (UINT32 ulMaxDuration);
  139.     virtual void adjustDependentDuration(CSmil1TimelineElement* pDependent);
  140.     virtual void addDuration (UINT32 ulDuration, 
  141. UINT32 ulDelay,
  142. const char* pID);
  143.     virtual void elementResolved (CSmil1TimelineElement* pElement);
  144.     void durationResolved (UINT32 ulDuration,
  145. BOOL bUpdateChildren);
  146. private:
  147.     int m_nDurationAdded;
  148.     UINT32 m_ulFirstDuration;
  149.     UINT32 m_ulLastDuration;
  150. };
  151. class CSmil1TimelineSeq: public CSmil1TimelineElement
  152. {
  153. public:
  154.     CSmil1TimelineSeq (CSmil1Element* pSourceElement, 
  155. CSmil1Parser* pRenderer);
  156.     virtual void setDelay (UINT32 ulDelay);
  157.     virtual void setDuration (UINT32 ulDuration,
  158. BOOL bSetFromParent = FALSE);
  159.     virtual void setMaxDuration (UINT32 ulMaxDuration);
  160.     virtual void adjustDependentDuration(CSmil1TimelineElement* pDependent);
  161.     BOOL  setElementDuration (UINT32& ulDurationLeft, CSmil1TimelineElement* pElement);
  162.     virtual void addDuration (UINT32 ulDuration, 
  163. UINT32 ulDelay,
  164. const char* pID);
  165. private:
  166.     int m_nDurationAdded;
  167. };
  168. class CSmil1TimelineAnchor: public CSmil1TimelineElement
  169. {
  170. public:
  171.     CSmil1TimelineAnchor (CSmil1Element* pSourceElement, 
  172. CSmil1Parser* pRenderer);
  173.     virtual ~CSmil1TimelineAnchor ();
  174.     virtual void elementResolved (CSmil1TimelineElement* pElement);
  175.     void durationResolved (UINT32 ulDuration);
  176. private:
  177.     int m_nDurationAdded;
  178. };
  179. #endif /* _SM1TIME_H_ */