--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/khronosfws/openmax_al/src/mmf_adaptation/xaplaybackrateitfadaptationmmf.c Tue Aug 31 15:43:02 2010 +0300
@@ -0,0 +1,236 @@
+/*
+* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+#include "xamediaplayeradaptctxmmf.h"
+#include "xaplaybackrateitfadaptationmmf.h"
+#include "xaplayitfadaptationmmf.h"
+#include "cmmfbackendengine.h"
+
+/*XA_RATEPROP_STAGGEREDVIDEO,XA_RATEPROP_SMOOTHVIDEO,XA_RATEPROP_SILENTAUDIO,
+ XA_RATEPROP_STAGGEREDAUDIO,XA_RATEPROP_NOPITCHCORAUDIO,XA_RATEPROP_PITCHCORAUDIO*/
+#define SUPPORTEDPROPS (XA_RATEPROP_STAGGEREDVIDEO | XA_RATEPROP_SILENTAUDIO)
+/* NOTE: currently rewind rates do not seem to work */
+#define MINRATE (-1000)
+#define MAXRATE 4000
+/*
+ * XAresult XAPlaybackRateItfAdapt_SetRate(XAAdaptationGstCtx *bCtx, XApermille rate)
+ * @param XAAdaptationGstCtx *bCtx - Adaptation context, this will be casted to correct type regarding to contextID value
+ * @param XApermille rate - new playback rate in permilles of original speed
+ * @return XAresult ret - Success value
+ */
+XAresult XAPlaybackRateItfAdaptMMF_SetRate(XAAdaptationMMFCtx *bCtx, XApermille rate)
+{
+ XAresult ret = XA_RESULT_SUCCESS;
+ XAMediaPlayerAdaptationMMFCtx* mCtx = (XAMediaPlayerAdaptationMMFCtx*) bCtx;
+ DEBUG_API_A1("->XAPlaybackRateItfAdaptMMF_SetRate %d permilles", rate);
+
+ if( !bCtx || bCtx->baseObj.ctxId != XAMediaPlayerAdaptation )
+ {
+ DEBUG_ERR("Invalid context!");
+ return XA_RESULT_PARAMETER_INVALID;
+ }
+ if( rate<MINRATE || rate>MAXRATE )
+ {
+ DEBUG_ERR("Invalid rate!");
+ return XA_RESULT_PARAMETER_INVALID;
+ }
+
+ ret = mmf_playbackrateitf_set_playbackrate(mCtx->mmfContext, rate/10);
+ if(ret == XA_RESULT_SUCCESS)
+ {
+ mCtx->playrate = rate/10;
+ if(mCtx->playrate == 0 || mCtx->playrate == 100)
+ {
+ mCtx->rateprops = XA_RATEPROP_SMOOTHVIDEO | XA_RATEPROP_NOPITCHCORAUDIO;
+ }
+ else
+ {
+ mCtx->rateprops = SUPPORTEDPROPS;
+ }
+ }
+
+ DEBUG_API("<-XAPlaybackRateItfAdaptMMF_SetRate");
+ return ret;
+}
+
+/*
+ * XAresult XAPlaybackRateItfAdaptMMF_SetPropertyConstraints(XAAdaptationMMFCtx *bCtx,
+ * XAuint32 constraints)
+ */
+XAresult XAPlaybackRateItfAdaptMMF_SetPropertyConstraints(XAAdaptationMMFCtx *bCtx,
+ XAuint32 constraints)
+{
+ XAresult ret = XA_RESULT_SUCCESS;
+ XAuint32 capabilities;
+ XAMediaPlayerAdaptationMMFCtx* mCtx = NULL;
+ DEBUG_API("->XAPlaybackRateItfAdaptMMF_SetPropertyConstraints");
+
+ if( !bCtx || bCtx->baseObj.ctxId != XAMediaPlayerAdaptation )
+ {
+ DEBUG_ERR("Invalid context!");
+ return XA_RESULT_PARAMETER_INVALID;
+ }
+ mCtx = (XAMediaPlayerAdaptationMMFCtx*) bCtx;
+
+ ret = XAPlaybackRateItfAdaptMMF_GetCapabilitiesOfRate(bCtx,mCtx->playrate,&capabilities);
+
+ if( (constraints & capabilities ) == 0 )
+ {
+ DEBUG_ERR("constraints cannot be satisfied!!");
+ ret = XA_RESULT_FEATURE_UNSUPPORTED;
+ }
+ else
+ {
+ mCtx->rateprops = capabilities & constraints;
+ }
+ DEBUG_API("<-XAPlaybackRateItfAdaptMMF_SetPropertyConstraints");
+ return ret;
+}
+
+/*
+ * XAresult XAPlaybackRateItfAdaptMMF_GetProperties(XAAdaptationMMFCtx *bCtx,
+ * XAuint32 *pProperties)
+ */
+XAresult XAPlaybackRateItfAdaptMMF_GetProperties(XAAdaptationMMFCtx *bCtx,
+ XAuint32 *pProperties)
+{
+ XAresult ret = XA_RESULT_SUCCESS;
+ XAMediaPlayerAdaptationMMFCtx* mCtx = NULL;
+ DEBUG_API("->XAPlaybackRateItfAdaptMMF_GetProperties");
+
+ if( !bCtx || bCtx->baseObj.ctxId != XAMediaPlayerAdaptation )
+ {
+ DEBUG_ERR("Invalid context!");
+ return XA_RESULT_PARAMETER_INVALID;
+ }
+ mCtx = (XAMediaPlayerAdaptationMMFCtx*) bCtx;
+ *pProperties = mCtx->rateprops;
+
+ DEBUG_API("<-XAPlaybackRateItfAdaptMMF_GetProperties");
+ return ret;
+}
+
+
+XAresult XAPlaybackRateItfAdaptMMF_GetCapabilitiesOfRate(XAAdaptationMMFCtx *bCtx,
+ XApermille rate,
+ XAuint32 *pCapabilities)
+{
+ XAresult ret = XA_RESULT_SUCCESS;
+
+ DEBUG_API("->XAPlaybackRateItfAdaptMMF_GetCapabilitiesOfRate");
+ if( !bCtx || bCtx->baseObj.ctxId != XAMediaPlayerAdaptation || !pCapabilities)
+ {
+ DEBUG_ERR("Invalid context!");
+ return XA_RESULT_PARAMETER_INVALID;
+ }
+
+ if( rate < MINRATE || rate > MAXRATE )
+ {
+ DEBUG_ERR("Invalid rate!");
+ *pCapabilities = 0;
+ ret = XA_RESULT_PARAMETER_INVALID;
+ }
+ else
+ {
+ if(rate == 0 || rate == 1000)
+ {
+ *pCapabilities = XA_RATEPROP_SMOOTHVIDEO | XA_RATEPROP_NOPITCHCORAUDIO;
+ }
+ else
+ {
+ *pCapabilities = XA_RATEPROP_STAGGEREDVIDEO | XA_RATEPROP_SILENTAUDIO;
+ }
+ }
+
+ DEBUG_API("<-XAPlaybackRateItfAdaptMMF_GetCapabilitiesOfRate");
+ return ret;
+}
+
+
+XAresult XAPlaybackRateItfAdaptMMF_GetRateRange(XAAdaptationMMFCtx *bCtx,
+ XAuint8 index,
+ XApermille *pMinRate,
+ XApermille *pMaxRate,
+ XApermille *pStepSize,
+ XAuint32 *pCapabilities)
+{
+ XAresult ret = XA_RESULT_SUCCESS;
+ XAMediaPlayerAdaptationMMFCtx* mCtx;
+ XAboolean forward = XA_BOOLEAN_FALSE;
+ XAboolean backward = XA_BOOLEAN_FALSE;
+ XAuint8 allowedindex = 0;
+
+ DEBUG_API("->XAPlaybackRateItfAdaptMMF_GetRateRange");
+
+ if( !bCtx || bCtx->baseObj.ctxId != XAMediaPlayerAdaptation )
+ {
+ DEBUG_ERR("Invalid context!");
+ return XA_RESULT_PARAMETER_INVALID;
+ }
+ mCtx = (XAMediaPlayerAdaptationMMFCtx*) bCtx;
+ ret = mmf_playbackrateitf_get_playbackratecaps(mCtx->mmfContext, &forward, &backward);
+ if(ret == XA_RESULT_SUCCESS)
+ {
+ if(forward == XA_BOOLEAN_TRUE)
+ {
+ allowedindex++;
+ }
+ if(backward == XA_BOOLEAN_TRUE)
+ {
+ allowedindex++;
+ }
+
+ if( index > allowedindex )
+ {
+ ret = XA_RESULT_PARAMETER_INVALID;
+ }
+ else
+ {
+ switch(index)
+ {
+ case 0:
+ {
+ *pMinRate = 0;
+ *pMaxRate = 1000;
+ *pStepSize = 0; /* continuous range */
+ *pCapabilities = XA_RATEPROP_SMOOTHVIDEO | XA_RATEPROP_NOPITCHCORAUDIO;
+ break;
+ }
+ case 1:
+ {
+ *pMinRate = 2000;
+ *pMaxRate = 4000;
+ *pStepSize = 0; /* continuous range */
+ *pCapabilities = SUPPORTEDPROPS;
+ break;
+ }
+ case 2:
+ {
+ *pMinRate = MINRATE;
+ *pMaxRate = MINRATE;
+ *pStepSize = 0; /* continuous range */
+ *pCapabilities = SUPPORTEDPROPS;
+ break;
+ }
+ }
+ }
+ }
+
+ DEBUG_API("<-XAPlaybackRateItfAdaptMMF_GetRateRange");
+ return ret;
+}
+