pxeffect.cpp
上传用户:zhongxx05
上传日期:2007-06-06
资源大小:33641k
文件大小:11k
源码类别:

Symbian

开发平台:

C/C++

  1. /* ***** BEGIN LICENSE BLOCK ***** 
  2.  * Version: RCSL 1.0/RPSL 1.0 
  3.  *  
  4.  * Portions Copyright (c) 1995-2002 RealNetworks, Inc. All Rights Reserved. 
  5.  *      
  6.  * The contents of this file, and the files included with this file, are 
  7.  * subject to the current version of the RealNetworks Public Source License 
  8.  * Version 1.0 (the "RPSL") available at 
  9.  * http://www.helixcommunity.org/content/rpsl unless you have licensed 
  10.  * the file under the RealNetworks Community Source License Version 1.0 
  11.  * (the "RCSL") available at http://www.helixcommunity.org/content/rcsl, 
  12.  * in which case the RCSL will apply. You may also obtain the license terms 
  13.  * directly from RealNetworks.  You may not use this file except in 
  14.  * compliance with the RPSL or, if you have a valid RCSL with RealNetworks 
  15.  * applicable to this file, the RCSL.  Please see the applicable RPSL or 
  16.  * RCSL for the rights, obligations and limitations governing use of the 
  17.  * contents of the file.  
  18.  *  
  19.  * This file is part of the Helix DNA Technology. RealNetworks is the 
  20.  * developer of the Original Code and owns the copyrights in the portions 
  21.  * it created. 
  22.  *  
  23.  * This file, and the files included with this file, is distributed and made 
  24.  * available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
  25.  * EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
  26.  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS 
  27.  * FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
  28.  * 
  29.  * Technology Compatibility Kit Test Suite(s) Location: 
  30.  *    http://www.helixcommunity.org/content/tck 
  31.  * 
  32.  * Contributor(s): 
  33.  *  
  34.  * ***** END LICENSE BLOCK ***** */ 
  35. // include
  36. #include "hxtypes.h"
  37. #include "hxwintyp.h"
  38. #include "hxcom.h"
  39. #include "hxresult.h"
  40. #include "ihxpckts.h"
  41. // hxcont
  42. #include "hxstring.h"
  43. // hxmisc
  44. #include "unkimp.h"
  45. #include "baseobj.h"
  46. // pxcomlib
  47. #include "gstring.h"
  48. #include "pxutil.h"
  49. #include "pxrect.h"
  50. #include "pxcolor.h"
  51. #include "pxeffect.h"
  52. // hxdebug
  53. #include "hxassert.h"
  54. #include "hxheap.h"
  55. #ifdef _DEBUG
  56. #undef HX_THIS_FILE
  57. static char HX_THIS_FILE[] = __FILE__;
  58. #endif
  59. BEGIN_INTERFACE_LIST(PXEffect)
  60. END_INTERFACE_LIST
  61. UINT32 PXEffect::PackedSize(UINT32 ulMajVer, UINT32 ulMinVer)
  62. {
  63.     UINT32 ulOpaqueSize = 0;
  64.     if (ulMajVer <= 1 && ulMinVer <= 4)
  65.     {
  66.         // Get the size of the opaque data
  67.         UINT32 ulFixedSize[8] = {42, 66, 46, 66, 74, 58, 74, 67};
  68.         ulOpaqueSize          = ulFixedSize[m_ucEffectType] + m_cURL.GetLength();
  69.         if (m_ucEffectType == kEffectTypeExternal)
  70.         {
  71.             ulOpaqueSize += m_cPackage.GetLength() + m_cName.GetLength() +
  72.                             m_cData.GetLength()    + m_cFile.GetLength();
  73.         }
  74.     }
  75. #if defined(_DEBUG)
  76.     else
  77.     {
  78.         HX_ASSERT(FALSE);
  79.     }
  80. #endif
  81.     return ulOpaqueSize;
  82. }
  83. void PXEffect::Pack(BYTE * &pBuffer, UINT32 ulMajVer, UINT32 ulMinVer)
  84. {
  85.     if (ulMajVer <= 1 && ulMinVer <= 4)
  86.     {
  87.         // Pack the common parts of the packet at the beginning
  88.         Pack32(pBuffer,     2);
  89.         UINT32 ulFlags = 0;
  90.         if (m_bLastUse)
  91.         {
  92.             ulFlags |= 1;
  93.         }
  94.         if (m_bDisplayImmediately)
  95.         {
  96.             ulFlags |= 4;
  97.         }
  98.         if (m_bPostBackChannel)
  99.         {
  100.             ulFlags |= 8;
  101.         }
  102.         Pack32(pBuffer,     ulFlags);
  103.         Pack32(pBuffer,     m_ucEffectType);
  104.         Pack32(pBuffer,     m_ulStart);
  105.         Pack32(pBuffer,     m_ulMaxFps);
  106.         PackStringNoNullTerm(pBuffer, m_cURL);
  107.         // Now here's the tricky part
  108.         switch (m_ucEffectType)
  109.         {
  110.             case kEffectTypeFill:
  111.                 m_cColor.Pack(pBuffer,   ulMajVer, ulMinVer);
  112.                 m_cDstRect.Pack(pBuffer, ulMajVer, ulMinVer);
  113.                 break;
  114.             case kEffectTypeFadeIn:
  115.             case kEffectTypeCrossFade:
  116.                 Pack32(pBuffer, m_ulDuration);
  117.                 Pack32(pBuffer, m_ulTarget);
  118.                 m_cSrcRect.Pack(pBuffer, ulMajVer, ulMinVer);
  119.                 m_cDstRect.Pack(pBuffer, ulMajVer, ulMinVer);
  120.                 Pack32(pBuffer, (UINT32) m_bAspectFlag);
  121.                 break;
  122.             case kEffectTypeFadeOut:
  123.                 Pack32(pBuffer, m_ulDuration);
  124.                 m_cColor.Pack(pBuffer,   ulMajVer, ulMinVer);
  125.                 m_cDstRect.Pack(pBuffer, ulMajVer, ulMinVer);
  126.                 break;
  127.             case kEffectTypeWipe:
  128.                 Pack32(pBuffer, m_ulDuration);
  129.                 Pack32(pBuffer, m_ucWipeType);
  130.                 Pack32(pBuffer, m_ucWipeDirection);
  131.                 Pack32(pBuffer, m_ulTarget);
  132.                 m_cSrcRect.Pack(pBuffer, ulMajVer, ulMinVer);
  133.                 m_cDstRect.Pack(pBuffer, ulMajVer, ulMinVer);
  134.                 Pack32(pBuffer, (UINT32) m_bAspectFlag);
  135.                 break;
  136.             case kEffectTypeViewChange:
  137.                 Pack32(pBuffer, m_ulDuration);
  138.                 m_cSrcRect.Pack(pBuffer, ulMajVer, ulMinVer);
  139.                 m_cDstRect.Pack(pBuffer, ulMajVer, ulMinVer);
  140.                 break;
  141.             case kEffectTypeExternal:
  142.                 Pack32(pBuffer, m_ulDuration);
  143.                 Pack32(pBuffer, m_ulTarget);
  144.                 m_cSrcRect.Pack(pBuffer, ulMajVer, ulMinVer);
  145.                 m_cDstRect.Pack(pBuffer, ulMajVer, ulMinVer);
  146.                 Pack32(pBuffer, (UINT32) m_bAspectFlag);
  147.                 PackString(pBuffer, m_cPackage);
  148.                 PackString(pBuffer, m_cName);
  149.                 PackString(pBuffer, m_cData);
  150.                 PackString(pBuffer, m_cFile);
  151.                 break;
  152.             case kEffectTypeAnimate:
  153.                 Pack32(pBuffer, m_ulDuration);
  154.                 Pack32(pBuffer, m_ulTarget);
  155.                 m_cSrcRect.Pack(pBuffer, ulMajVer, ulMinVer);
  156.                 m_cDstRect.Pack(pBuffer, ulMajVer, ulMinVer);
  157.                 Pack32(pBuffer, (UINT32) m_bAspectFlag);
  158.                 break;
  159.         }
  160.     }
  161. #if defined(_DEBUG)
  162.     else
  163.     {
  164.         HX_ASSERT(FALSE);
  165.     }
  166. #endif
  167. }
  168. void PXEffect::UnPack(BYTE * &pBuffer, UINT32 ulMajVer, UINT32 ulMinVer)
  169. {
  170.     if (ulMajVer <= 1 && ulMinVer <= 4)
  171.     {
  172.         // Pack the common parts of the packet at the beginning
  173.         UINT32 ulTmp;
  174.         UnPack32(pBuffer,     ulTmp); // packet type
  175.         UnPack32(pBuffer,     ulTmp); // flags
  176.         m_bLastUse            = (ulTmp & 1 ? TRUE : FALSE);
  177.         m_bDisplayImmediately = (ulTmp & 4 ? TRUE : FALSE);
  178.         m_bPostBackChannel    = (ulTmp & 8 ? TRUE : FALSE);
  179.         UnPack32(pBuffer,     ulTmp); // effect type
  180.         m_ucEffectType = (BYTE) ulTmp;
  181.         UnPack32(pBuffer,     m_ulStart);
  182.         UnPack32(pBuffer,     m_ulMaxFps);
  183.         UnPackStringNoNullTerm(pBuffer, m_cURL);
  184.         // Now here's the tricky part
  185.         switch (m_ucEffectType)
  186.         {
  187.             case kEffectTypeFill:
  188.                 m_cColor.UnPack(pBuffer,   ulMajVer, ulMinVer);
  189.                 m_cDstRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  190.                 m_bHasTarget = FALSE;
  191.                 break;
  192.             case kEffectTypeFadeIn:
  193.             case kEffectTypeCrossFade:
  194.                 UnPack32(pBuffer, m_ulDuration);
  195.                 UnPack32(pBuffer, m_ulTarget);
  196.                 m_cSrcRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  197.                 m_cDstRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  198.                 UnPack32(pBuffer, ulTmp);
  199.                 m_bAspectFlag = (BOOL) ulTmp;
  200.                 m_bHasTarget  = TRUE;
  201.                 break;
  202.             case kEffectTypeFadeOut:
  203.                 UnPack32(pBuffer, m_ulDuration);
  204.                 m_cColor.UnPack(pBuffer,   ulMajVer, ulMinVer);
  205.                 m_cDstRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  206.                 m_bHasTarget  = FALSE;
  207.                 break;
  208.             case kEffectTypeWipe:
  209.                 UnPack32(pBuffer, m_ulDuration);
  210.                 UnPack32(pBuffer, ulTmp);
  211.                 m_ucWipeType = (BYTE) ulTmp;
  212.                 UnPack32(pBuffer, ulTmp);
  213.                 m_ucWipeDirection = (BYTE) ulTmp;
  214.                 UnPack32(pBuffer, m_ulTarget);
  215.                 m_cSrcRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  216.                 m_cDstRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  217.                 UnPack32(pBuffer, ulTmp);
  218.                 m_bAspectFlag = (BOOL) ulTmp;
  219.                 m_bHasTarget  = TRUE;
  220.                 break;
  221.             case kEffectTypeViewChange:
  222.                 UnPack32(pBuffer, m_ulDuration);
  223.                 m_cSrcRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  224.                 m_cDstRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  225.                 m_bHasTarget  = TRUE;
  226.                 break;
  227.             case kEffectTypeExternal:
  228.                 UnPack32(pBuffer, m_ulDuration);
  229.                 UnPack32(pBuffer, m_ulTarget);
  230.                 m_cSrcRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  231.                 m_cDstRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  232.                 UnPack32(pBuffer, ulTmp);
  233.                 m_bAspectFlag = (BOOL) ulTmp;
  234.                 UnPackStringNoNullTerm(pBuffer, m_cPackage);
  235.                 UnPackStringNoNullTerm(pBuffer, m_cName);
  236.                 UnPackStringNoNullTerm(pBuffer, m_cData);
  237.                 UnPackStringNoNullTerm(pBuffer, m_cFile);
  238.                 m_bHasTarget  = TRUE;
  239.                 break;
  240.             case kEffectTypeAnimate:
  241.                 UnPack32(pBuffer, m_ulDuration);
  242.                 UnPack32(pBuffer, m_ulTarget);
  243.                 m_cSrcRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  244.                 m_cDstRect.UnPack(pBuffer, ulMajVer, ulMinVer);
  245.                 UnPack32(pBuffer, ulTmp);
  246.                 m_bAspectFlag = (BOOL) ulTmp;
  247.                 m_bHasTarget  = TRUE;
  248.                 break;
  249.         }
  250.     }
  251. #if defined(_DEBUG)
  252.     else
  253.     {
  254.         HX_ASSERT(FALSE);
  255.     }
  256. #endif
  257. }
  258. BOOL PXEffect::IsOverlapped(PXEffect* pEffect)
  259. {
  260.     BOOL bOverlap = FALSE;
  261.     if (pEffect)
  262.     {
  263.         // Let's first make sure this is not the same effect
  264.         if (m_ulHandle != pEffect->m_ulHandle)
  265.         {
  266.             if (m_ulStart                < pEffect->m_ulStart + pEffect->m_ulDuration &&
  267.                 m_ulStart + m_ulDuration > pEffect->m_ulStart) // XXXMEH - should these be >= && <=??
  268.             {
  269.                 // These two effects ARE overlapped in time. Now, are they
  270.                 // overlapped in space?
  271.                 // or the overlap returns
  272.                 if (m_cDstRect.IsNull()          ||
  273.                     pEffect->m_cDstRect.IsNull() ||
  274.                     m_cDstRect.IsOverlapped(pEffect->m_cDstRect))
  275.                 {
  276.                     bOverlap = TRUE;
  277.                 }
  278.             }
  279.         }
  280.     }
  281.     return bOverlap;
  282. }