quartz: Implement stop position in the filtergraph.
This commit is contained in:
parent
669949251d
commit
43f9fff0a0
|
@ -203,6 +203,7 @@ typedef struct _IFilterGraphImpl {
|
||||||
GUID timeformatseek;
|
GUID timeformatseek;
|
||||||
LONGLONG start_time;
|
LONGLONG start_time;
|
||||||
LONGLONG position;
|
LONGLONG position;
|
||||||
|
LONGLONG stop_position;
|
||||||
} IFilterGraphImpl;
|
} IFilterGraphImpl;
|
||||||
|
|
||||||
static HRESULT WINAPI Filtergraph_QueryInterface(IFilterGraphImpl *This,
|
static HRESULT WINAPI Filtergraph_QueryInterface(IFilterGraphImpl *This,
|
||||||
|
@ -2038,10 +2039,23 @@ static HRESULT WINAPI MediaSeeking_GetDuration(IMediaSeeking *iface,
|
||||||
static HRESULT WINAPI MediaSeeking_GetStopPosition(IMediaSeeking *iface,
|
static HRESULT WINAPI MediaSeeking_GetStopPosition(IMediaSeeking *iface,
|
||||||
LONGLONG *pStop) {
|
LONGLONG *pStop) {
|
||||||
ICOM_THIS_MULTI(IFilterGraphImpl, IMediaSeeking_vtbl, iface);
|
ICOM_THIS_MULTI(IFilterGraphImpl, IMediaSeeking_vtbl, iface);
|
||||||
|
HRESULT hr = S_OK;
|
||||||
|
|
||||||
FIXME("(%p/%p)->(%p): stub !!!\n", This, iface, pStop);
|
TRACE("(%p/%p)->(%p)\n", This, iface, pStop);
|
||||||
|
|
||||||
return S_OK;
|
if (!pStop)
|
||||||
|
return E_POINTER;
|
||||||
|
|
||||||
|
EnterCriticalSection(&This->cs);
|
||||||
|
if (This->stop_position < 0)
|
||||||
|
/* Stop position not set, use duration instead */
|
||||||
|
hr = IMediaSeeking_GetDuration(iface, pStop);
|
||||||
|
else
|
||||||
|
*pStop = This->stop_position;
|
||||||
|
|
||||||
|
LeaveCriticalSection(&This->cs);
|
||||||
|
|
||||||
|
return hr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI MediaSeeking_GetCurrentPosition(IMediaSeeking *iface,
|
static HRESULT WINAPI MediaSeeking_GetCurrentPosition(IMediaSeeking *iface,
|
||||||
|
@ -2116,7 +2130,9 @@ static HRESULT WINAPI MediaSeeking_SetPositions(IMediaSeeking *iface,
|
||||||
else if ((dwCurrentFlags & 0x7) != AM_SEEKING_NoPositioning)
|
else if ((dwCurrentFlags & 0x7) != AM_SEEKING_NoPositioning)
|
||||||
FIXME("Adjust method %x not handled yet!\n", dwCurrentFlags & 0x7);
|
FIXME("Adjust method %x not handled yet!\n", dwCurrentFlags & 0x7);
|
||||||
|
|
||||||
if ((dwStopFlags & 0x7) != AM_SEEKING_NoPositioning)
|
if ((dwStopFlags & 0x7) == AM_SEEKING_AbsolutePositioning)
|
||||||
|
This->stop_position = *pStop;
|
||||||
|
else if ((dwStopFlags & 0x7) != AM_SEEKING_NoPositioning)
|
||||||
FIXME("Stop position not handled yet!\n");
|
FIXME("Stop position not handled yet!\n");
|
||||||
|
|
||||||
args.current = pCurrent;
|
args.current = pCurrent;
|
||||||
|
@ -5084,6 +5100,7 @@ HRESULT FilterGraph_create(IUnknown *pUnkOuter, LPVOID *ppObj)
|
||||||
fimpl->nItfCacheEntries = 0;
|
fimpl->nItfCacheEntries = 0;
|
||||||
memcpy(&fimpl->timeformatseek, &TIME_FORMAT_MEDIA_TIME, sizeof(GUID));
|
memcpy(&fimpl->timeformatseek, &TIME_FORMAT_MEDIA_TIME, sizeof(GUID));
|
||||||
fimpl->start_time = fimpl->position = 0;
|
fimpl->start_time = fimpl->position = 0;
|
||||||
|
fimpl->stop_position = -1;
|
||||||
|
|
||||||
hr = CoCreateInstance(&CLSID_FilterMapper2, NULL, CLSCTX_INPROC_SERVER, &IID_IFilterMapper2, (LPVOID*)&fimpl->pFilterMapper2);
|
hr = CoCreateInstance(&CLSID_FilterMapper2, NULL, CLSCTX_INPROC_SERVER, &IID_IFilterMapper2, (LPVOID*)&fimpl->pFilterMapper2);
|
||||||
if (FAILED(hr)) {
|
if (FAILED(hr)) {
|
||||||
|
|
Loading…
Reference in New Issue