[PATCH 4/8] mfplay: Forward GetNativeVideoSize() to the session.
Nikolay Sivov
nsivov at codeweavers.com
Wed Apr 21 04:29:45 CDT 2021
Signed-off-by: Nikolay Sivov <nsivov at codeweavers.com>
---
dlls/mfplay/Makefile.in | 2 +-
dlls/mfplay/player.c | 15 +++++++++++++--
dlls/mfplay/tests/mfplay.c | 4 ++++
3 files changed, 18 insertions(+), 3 deletions(-)
diff --git a/dlls/mfplay/Makefile.in b/dlls/mfplay/Makefile.in
index 8cd572bf638..303226f57f6 100644
--- a/dlls/mfplay/Makefile.in
+++ b/dlls/mfplay/Makefile.in
@@ -1,6 +1,6 @@
MODULE = mfplay.dll
IMPORTLIB = mfplay
-IMPORTS = mfplat mf ole32 user32 uuid mfuuid
+IMPORTS = mfplat mf ole32 user32 uuid mfuuid strmiids
EXTRADLLFLAGS = -mno-cygwin -Wb,--prefer-native
diff --git a/dlls/mfplay/player.c b/dlls/mfplay/player.c
index 831e9fa9781..80c88721c78 100644
--- a/dlls/mfplay/player.c
+++ b/dlls/mfplay/player.c
@@ -1251,9 +1251,20 @@ static HRESULT WINAPI media_player_GetNativeVideoSize(IMFPMediaPlayer *iface,
static HRESULT WINAPI media_player_GetIdealVideoSize(IMFPMediaPlayer *iface,
SIZE *min_size, SIZE *max_size)
{
- FIXME("%p, %p, %p.\n", iface, min_size, max_size);
+ struct media_player *player = impl_from_IMFPMediaPlayer(iface);
+ IMFVideoDisplayControl *display_control;
+ HRESULT hr;
- return E_NOTIMPL;
+ TRACE("%p, %p, %p.\n", iface, min_size, max_size);
+
+ if (SUCCEEDED(hr = MFGetService((IUnknown *)player->session, &MR_VIDEO_RENDER_SERVICE,
+ &IID_IMFVideoDisplayControl, (void **)&display_control)))
+ {
+ hr = IMFVideoDisplayControl_GetIdealVideoSize(display_control, min_size, max_size);
+ IMFVideoDisplayControl_Release(display_control);
+ }
+
+ return hr;
}
static HRESULT WINAPI media_player_SetVideoSourceRect(IMFPMediaPlayer *iface,
diff --git a/dlls/mfplay/tests/mfplay.c b/dlls/mfplay/tests/mfplay.c
index 64a48cceaca..f11973ef939 100644
--- a/dlls/mfplay/tests/mfplay.c
+++ b/dlls/mfplay/tests/mfplay.c
@@ -122,6 +122,7 @@ static void test_create_player(void)
static void test_shutdown(void)
{
+ SIZE min_size, max_size;
IMFPMediaPlayer *player;
float slowest, fastest;
HRESULT hr;
@@ -156,6 +157,9 @@ static void test_shutdown(void)
ok(hr == S_OK, "Unexpected hr %#x.\n", hr);
ok(state == MFP_MEDIAPLAYER_STATE_SHUTDOWN, "Unexpected state %d.\n", state);
+ hr = IMFPMediaPlayer_GetIdealVideoSize(player, &min_size, &max_size);
+ ok(hr == MF_E_SHUTDOWN, "Unexpected hr %#x.\n", hr);
+
hr = IMFPMediaPlayer_CreateMediaItemFromURL(player, L"url", TRUE, 0, &item);
ok(hr == MF_E_SHUTDOWN, "Unexpected hr %#x.\n", hr);
--
2.30.2
More information about the wine-devel
mailing list