rpeffect.h
上传用户:zhongxx05
上传日期:2007-06-06
资源大小:33641k
文件大小:4k
源码类别:

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. #ifndef _IMF_EFFECT_H
  36. #define _IMF_EFFECT_H
  37. typedef _INTERFACE IIMFEffect IIMFEffect;
  38.  /****************************************************************************
  39.  *
  40.  *  Interface:          IIMFEffect
  41.  *
  42.  *  Purpose:            IMF Effect Interface
  43.  *
  44.  *  IID_IIMFEffect:     {54A71422-AE44-11d1-A8BC-444553540001}
  45.  *
  46.  ****************************************************************************/
  47. DEFINE_GUID(IID_IIMFEffect, 0x54a71422, 0xae44, 0x11d1, 0xa8, 0xbc, 0x44,
  48.             0x45, 0x53, 0x54, 0x0, 0x1);
  49. #define CLSID_IIMFEffect IID_IIMFEffect
  50. #undef  INTERFACE
  51. #define INTERFACE IIMFEffect
  52. DECLARE_INTERFACE_(IIMFEffect, IUnknown)
  53. {
  54.     /*
  55.      * IUnknown methods
  56.      */
  57.     STDMETHOD(QueryInterface)   (THIS_ REFIID riid, void **ppvObj) PURE;
  58.     STDMETHOD_(ULONG32,AddRef)  (THIS) PURE;
  59.     STDMETHOD_(ULONG32,Release) (THIS) PURE;
  60.     /*
  61.      * IIMFEffect methods
  62.      */
  63.     /*
  64.      * This method returns information about the IMF Effect Plugin:
  65.      * namely, the package name (single string) and the names of all
  66.      * the effects this package contains (multiple strings).
  67.      */
  68.     STDMETHOD(GetEffectInfo) (THIS_ REF(const char  *) pszPackageName,
  69.                                     REF(const char **) ppszEffectName) PURE;
  70.     /*
  71.      * This method inputs the parameters of the effect and then
  72.      * outputs a session handle which uniquely identifies this session.
  73.      */
  74.     STDMETHOD(InitEffect)   (THIS_ const char * /*IN*/  pszEffectName,
  75.                                    BYTE *       /*IN*/  pImageIn1,
  76.                                    BYTE *       /*IN*/  pImageIn2,
  77.                                    BYTE *       /*IN*/  pImageOut,
  78.                                    UINT32       /*IN*/  ulWidth,
  79.                                    UINT32       /*IN*/  ulHeight,
  80.                                    UINT32       /*IN*/  ulImageIn1PadWidth,
  81.                                    UINT32       /*IN*/  ulImageIn2PadWidth,
  82.                                    UINT32       /*IN*/  ulImageOutPadWidth,
  83.                                    const char * /*IN*/  pszData,
  84.                                    IHXBuffer * /*IN*/  pFileBuffer,
  85.                                    REF(INT32)   /*OUT*/ rlSessionHandle) PURE;
  86.     /*
  87.      * This method does the effect. lPercentComplete is in the range [0, 100].
  88.      */
  89.     STDMETHOD(DoEffect)      (THIS_ INT32  lSessionHandle,
  90.                                     UINT32 ulPercentComplete) PURE;
  91.     /*
  92.      * This method instructs the effect package to release whatever 
  93.      * resources it allocated in InitEffect().
  94.      */
  95.     STDMETHOD(TermEffect)    (THIS_ INT32 lSessionHandle) PURE;
  96. };
  97. #endif