2012-03-28 14:29:06 +02:00
|
|
|
/*
|
2020-03-12 03:10:11 +01:00
|
|
|
* Common implementation of IVideoWindow
|
2012-03-28 14:29:06 +02:00
|
|
|
*
|
|
|
|
* Copyright 2012 Aric Stewart, CodeWeavers
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
|
|
* License along with this library; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
|
|
|
|
*/
|
|
|
|
|
2020-03-12 03:10:11 +01:00
|
|
|
#include "quartz_private.h"
|
2012-03-28 14:29:06 +02:00
|
|
|
|
2021-06-02 16:07:58 +02:00
|
|
|
#define WM_QUARTZ_DESTROY (WM_USER + WM_DESTROY)
|
|
|
|
|
2020-03-12 03:10:11 +01:00
|
|
|
WINE_DEFAULT_DEBUG_CHANNEL(quartz);
|
|
|
|
|
|
|
|
static const WCHAR class_name[] = L"wine_quartz_window";
|
2012-03-28 14:29:06 +02:00
|
|
|
|
2020-04-03 06:20:46 +02:00
|
|
|
static inline struct video_window *impl_from_IVideoWindow(IVideoWindow *iface)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
return CONTAINING_RECORD(iface, struct video_window, IVideoWindow_iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
}
|
|
|
|
|
2019-10-15 23:00:18 +02:00
|
|
|
static LRESULT CALLBACK WndProcW(HWND hwnd, UINT message, WPARAM wparam, LPARAM lparam)
|
2012-03-28 14:29:06 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = (struct video_window *)GetWindowLongPtrW(hwnd, 0);
|
2012-03-28 14:29:06 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
if (!window)
|
2019-10-15 23:00:18 +02:00
|
|
|
return DefWindowProcW(hwnd, message, wparam, lparam);
|
2012-03-28 14:29:06 +02:00
|
|
|
|
2019-10-15 23:00:17 +02:00
|
|
|
switch (message)
|
2012-03-28 14:29:06 +02:00
|
|
|
{
|
2019-10-15 23:00:17 +02:00
|
|
|
case WM_KEYDOWN:
|
|
|
|
case WM_KEYUP:
|
|
|
|
case WM_LBUTTONDBLCLK:
|
|
|
|
case WM_LBUTTONDOWN:
|
|
|
|
case WM_LBUTTONUP:
|
|
|
|
case WM_MBUTTONDBLCLK:
|
|
|
|
case WM_MBUTTONDOWN:
|
|
|
|
case WM_MBUTTONUP:
|
|
|
|
case WM_MOUSEACTIVATE:
|
|
|
|
case WM_MOUSEMOVE:
|
|
|
|
case WM_NCLBUTTONDBLCLK:
|
|
|
|
case WM_NCLBUTTONDOWN:
|
|
|
|
case WM_NCLBUTTONUP:
|
|
|
|
case WM_NCMBUTTONDBLCLK:
|
|
|
|
case WM_NCMBUTTONDOWN:
|
|
|
|
case WM_NCMBUTTONUP:
|
|
|
|
case WM_NCMOUSEMOVE:
|
|
|
|
case WM_NCRBUTTONDBLCLK:
|
|
|
|
case WM_NCRBUTTONDOWN:
|
|
|
|
case WM_NCRBUTTONUP:
|
|
|
|
case WM_RBUTTONDBLCLK:
|
|
|
|
case WM_RBUTTONDOWN:
|
|
|
|
case WM_RBUTTONUP:
|
|
|
|
if (window->hwndDrain)
|
|
|
|
{
|
|
|
|
PostMessageW(window->hwndDrain, message, wparam, lparam);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case WM_SIZE:
|
2020-05-08 03:50:23 +02:00
|
|
|
if (window->default_dst)
|
|
|
|
GetClientRect(window->hwnd, &window->dst);
|
2020-05-08 03:50:22 +02:00
|
|
|
break;
|
2021-06-02 16:07:58 +02:00
|
|
|
case WM_QUARTZ_DESTROY:
|
|
|
|
DestroyWindow(hwnd);
|
|
|
|
return 0;
|
|
|
|
case WM_CLOSE:
|
2021-06-02 16:08:00 +02:00
|
|
|
{
|
|
|
|
IFilterGraph *graph = window->pFilter->graph;
|
|
|
|
IMediaEventSink *event_sink;
|
2021-06-02 16:07:58 +02:00
|
|
|
IVideoWindow_put_Visible(&window->IVideoWindow_iface, OAFALSE);
|
2021-06-02 16:08:00 +02:00
|
|
|
if (graph && SUCCEEDED(IFilterGraph_QueryInterface(graph,
|
|
|
|
&IID_IMediaEventSink,
|
|
|
|
(void **)&event_sink)))
|
|
|
|
{
|
|
|
|
IMediaEventSink_Notify(event_sink, EC_USERABORT, 0, 0);
|
|
|
|
IMediaEventSink_Release(event_sink);
|
|
|
|
}
|
2021-06-02 16:07:58 +02:00
|
|
|
return 0;
|
2012-03-28 14:29:06 +02:00
|
|
|
}
|
2021-06-02 16:08:00 +02:00
|
|
|
}
|
2012-03-28 14:29:06 +02:00
|
|
|
|
2019-10-15 23:00:17 +02:00
|
|
|
return DefWindowProcW(hwnd, message, wparam, lparam);
|
2012-03-28 14:29:06 +02:00
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT video_window_create_window(struct video_window *window)
|
2012-03-28 14:29:06 +02:00
|
|
|
{
|
2019-10-17 02:36:47 +02:00
|
|
|
WNDCLASSW winclass = {0};
|
2012-03-28 14:29:06 +02:00
|
|
|
|
|
|
|
winclass.lpfnWndProc = WndProcW;
|
2020-04-03 06:20:48 +02:00
|
|
|
winclass.cbWndExtra = sizeof(window);
|
2012-03-28 14:29:06 +02:00
|
|
|
winclass.hbrBackground = GetStockObject(BLACK_BRUSH);
|
2020-03-12 03:10:11 +01:00
|
|
|
winclass.lpszClassName = class_name;
|
2012-03-28 14:29:06 +02:00
|
|
|
if (!RegisterClassW(&winclass) && GetLastError() != ERROR_CLASS_ALREADY_EXISTS)
|
|
|
|
{
|
2022-02-04 22:41:27 +01:00
|
|
|
ERR("Failed to register class, error %lu.\n", GetLastError());
|
2012-03-28 14:29:06 +02:00
|
|
|
return E_FAIL;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
if (!(window->hwnd = CreateWindowExW(0, class_name, L"ActiveMovie Window",
|
2019-12-06 06:08:32 +01:00
|
|
|
WS_OVERLAPPEDWINDOW | WS_CLIPSIBLINGS | WS_CLIPCHILDREN,
|
2019-10-17 02:36:47 +02:00
|
|
|
CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT,
|
2020-04-03 06:20:48 +02:00
|
|
|
NULL, NULL, NULL, NULL)))
|
2012-03-28 14:29:06 +02:00
|
|
|
{
|
|
|
|
ERR("Unable to create window\n");
|
|
|
|
return E_FAIL;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
SetWindowLongPtrW(window->hwnd, 0, (LONG_PTR)window);
|
2012-03-28 14:29:06 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2019-06-12 01:54:38 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_QueryInterface(IVideoWindow *iface, REFIID iid, void **out)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2019-06-12 01:54:38 +02:00
|
|
|
return IUnknown_QueryInterface(window->pFilter->outer_unk, iid, out);
|
|
|
|
}
|
|
|
|
|
|
|
|
ULONG WINAPI BaseControlWindowImpl_AddRef(IVideoWindow *iface)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2019-06-12 01:54:38 +02:00
|
|
|
return IUnknown_AddRef(window->pFilter->outer_unk);
|
|
|
|
}
|
|
|
|
|
|
|
|
ULONG WINAPI BaseControlWindowImpl_Release(IVideoWindow *iface)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2019-06-12 01:54:38 +02:00
|
|
|
return IUnknown_Release(window->pFilter->outer_unk);
|
|
|
|
}
|
|
|
|
|
2019-06-07 01:49:22 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_GetTypeInfoCount(IVideoWindow *iface, UINT *count)
|
2012-04-20 14:26:32 +02:00
|
|
|
{
|
2019-06-07 01:49:22 +02:00
|
|
|
TRACE("iface %p, count %p.\n", iface, count);
|
|
|
|
*count = 1;
|
|
|
|
return S_OK;
|
2012-03-28 21:53:14 +02:00
|
|
|
}
|
|
|
|
|
2019-06-07 01:49:22 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_GetTypeInfo(IVideoWindow *iface, UINT index,
|
|
|
|
LCID lcid, ITypeInfo **typeinfo)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("iface %p, index %u, lcid %#lx, typeinfo %p.\n", iface, index, lcid, typeinfo);
|
2019-06-07 01:49:22 +02:00
|
|
|
return strmbase_get_typeinfo(IVideoWindow_tid, typeinfo);
|
2012-03-28 21:53:14 +02:00
|
|
|
}
|
|
|
|
|
2019-06-07 01:49:22 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_GetIDsOfNames(IVideoWindow *iface, REFIID iid,
|
|
|
|
LPOLESTR *names, UINT count, LCID lcid, DISPID *ids)
|
|
|
|
{
|
|
|
|
ITypeInfo *typeinfo;
|
|
|
|
HRESULT hr;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("iface %p, iid %s, names %p, count %u, lcid %#lx, ids %p.\n",
|
2019-06-07 01:49:22 +02:00
|
|
|
iface, debugstr_guid(iid), names, count, lcid, ids);
|
|
|
|
|
|
|
|
if (SUCCEEDED(hr = strmbase_get_typeinfo(IVideoWindow_tid, &typeinfo)))
|
|
|
|
{
|
|
|
|
hr = ITypeInfo_GetIDsOfNames(typeinfo, names, count, ids);
|
|
|
|
ITypeInfo_Release(typeinfo);
|
|
|
|
}
|
|
|
|
return hr;
|
2012-03-28 21:53:14 +02:00
|
|
|
}
|
|
|
|
|
2019-06-07 01:49:22 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_Invoke(IVideoWindow *iface, DISPID id, REFIID iid, LCID lcid,
|
|
|
|
WORD flags, DISPPARAMS *params, VARIANT *result, EXCEPINFO *excepinfo, UINT *error_arg)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2019-06-07 01:49:22 +02:00
|
|
|
ITypeInfo *typeinfo;
|
2015-10-19 10:57:50 +02:00
|
|
|
HRESULT hr;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("iface %p, id %ld, iid %s, lcid %#lx, flags %#x, params %p, result %p, excepinfo %p, error_arg %p.\n",
|
2019-06-07 01:49:22 +02:00
|
|
|
iface, id, debugstr_guid(iid), lcid, flags, params, result, excepinfo, error_arg);
|
|
|
|
|
|
|
|
if (SUCCEEDED(hr = strmbase_get_typeinfo(IVideoWindow_tid, &typeinfo)))
|
2012-04-20 14:26:32 +02:00
|
|
|
{
|
2019-06-07 01:49:22 +02:00
|
|
|
hr = ITypeInfo_Invoke(typeinfo, iface, id, flags, params, result, excepinfo, error_arg);
|
|
|
|
ITypeInfo_Release(typeinfo);
|
2012-04-20 14:26:32 +02:00
|
|
|
}
|
|
|
|
return hr;
|
2012-03-28 21:53:14 +02:00
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_Caption(IVideoWindow *iface, BSTR caption)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, caption %s.\n", window, debugstr_w(caption));
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
if (!SetWindowTextW(window->hwnd, caption))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_FAIL;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2019-10-08 01:55:42 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_Caption(IVideoWindow *iface, BSTR *caption)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2019-10-08 01:55:42 +02:00
|
|
|
WCHAR *str;
|
|
|
|
int len;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2019-10-08 01:55:42 +02:00
|
|
|
TRACE("window %p, caption %p.\n", window, caption);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2019-10-08 01:55:42 +02:00
|
|
|
*caption = NULL;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
len = GetWindowTextLengthW(window->hwnd) + 1;
|
2019-10-08 01:55:42 +02:00
|
|
|
if (!(str = heap_alloc(len * sizeof(WCHAR))))
|
|
|
|
return E_OUTOFMEMORY;
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
GetWindowTextW(window->hwnd, str, len);
|
2019-10-08 01:55:42 +02:00
|
|
|
*caption = SysAllocString(str);
|
|
|
|
heap_free(str);
|
|
|
|
return *caption ? S_OK : E_OUTOFMEMORY;
|
2012-03-28 21:53:14 +02:00
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_WindowStyle(IVideoWindow *iface, LONG style)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, style %#lx.\n", window, style);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
if (style & (WS_DISABLED|WS_HSCROLL|WS_MAXIMIZE|WS_MINIMIZE|WS_VSCROLL))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_INVALIDARG;
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
SetWindowLongW(window->hwnd, GWL_STYLE, style);
|
|
|
|
SetWindowPos(window->hwnd, 0, 0, 0, 0, 0,
|
2019-10-09 03:02:19 +02:00
|
|
|
SWP_NOSIZE | SWP_NOMOVE | SWP_NOZORDER | SWP_NOACTIVATE | SWP_FRAMECHANGED);
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2019-10-15 23:00:20 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_WindowStyle(IVideoWindow *iface, LONG *style)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2019-10-15 23:00:20 +02:00
|
|
|
TRACE("window %p, style %p.\n", window, style);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
*style = GetWindowLongW(window->hwnd, GWL_STYLE);
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_WindowStyleEx(IVideoWindow *iface, LONG style)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, style %#lx.\n", window, style);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
if (!SetWindowLongW(window->hwnd, GWL_EXSTYLE, style))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_FAIL;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_WindowStyleEx(IVideoWindow *iface, LONG *style)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, style %p.\n", window, style);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
*style = GetWindowLongW(window->hwnd, GWL_EXSTYLE);
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_AutoShow(IVideoWindow *iface, LONG AutoShow)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, AutoShow %ld.\n", This, AutoShow);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
This->AutoShow = AutoShow;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_AutoShow(IVideoWindow *iface, LONG *AutoShow)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
TRACE("(%p/%p)->(%p)\n", This, iface, AutoShow);
|
|
|
|
|
|
|
|
*AutoShow = This->AutoShow;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_WindowState(IVideoWindow *iface, LONG state)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, state %ld.\n", window, state);
|
2020-04-03 06:20:48 +02:00
|
|
|
|
|
|
|
ShowWindow(window->hwnd, state);
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2019-10-09 03:02:20 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_WindowState(IVideoWindow *iface, LONG *state)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2019-10-09 03:02:20 +02:00
|
|
|
DWORD style;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2019-10-09 03:02:20 +02:00
|
|
|
TRACE("window %p, state %p.\n", window, state);
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
style = GetWindowLongPtrW(window->hwnd, GWL_STYLE);
|
2019-10-09 03:02:20 +02:00
|
|
|
if (!(style & WS_VISIBLE))
|
|
|
|
*state = SW_HIDE;
|
|
|
|
else if (style & WS_MINIMIZE)
|
|
|
|
*state = SW_MINIMIZE;
|
|
|
|
else if (style & WS_MAXIMIZE)
|
|
|
|
*state = SW_MAXIMIZE;
|
|
|
|
else
|
|
|
|
*state = SW_SHOW;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_BackgroundPalette(IVideoWindow *iface, LONG BackgroundPalette)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
FIXME("window %p, palette %ld, stub!\n", This, BackgroundPalette);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_BackgroundPalette(IVideoWindow *iface, LONG *pBackgroundPalette)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
FIXME("(%p/%p)->(%p): stub !!!\n", This, iface, pBackgroundPalette);
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_Visible(IVideoWindow *iface, LONG visible)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, visible %ld.\n", window, visible);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
ShowWindow(window->hwnd, visible ? SW_SHOW : SW_HIDE);
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_Visible(IVideoWindow *iface, LONG *visible)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, visible %p.\n", window, visible);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-09-09 17:07:18 +02:00
|
|
|
if (!visible)
|
|
|
|
return E_POINTER;
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
*visible = IsWindowVisible(window->hwnd) ? OATRUE : OAFALSE;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_Left(IVideoWindow *iface, LONG left)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, left %ld.\n", window, left);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
if (!SetWindowPos(window->hwnd, NULL, left, rect.top, 0, 0,
|
2019-10-08 01:55:46 +02:00
|
|
|
SWP_NOACTIVATE | SWP_NOZORDER | SWP_NOSIZE))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_FAIL;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_Left(IVideoWindow *iface, LONG *left)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, left %p.\n", window, left);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
*left = rect.left;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_Width(IVideoWindow *iface, LONG width)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2020-04-06 02:49:43 +02:00
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, width %ld.\n", window, width);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-06 02:49:43 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
if (!SetWindowPos(window->hwnd, NULL, 0, 0, width, rect.bottom - rect.top,
|
2019-10-08 01:55:46 +02:00
|
|
|
SWP_NOACTIVATE | SWP_NOZORDER | SWP_NOMOVE))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_FAIL;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_Width(IVideoWindow *iface, LONG *width)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2020-04-06 02:49:43 +02:00
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, width %p.\n", window, width);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-06 02:49:43 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
*width = rect.right - rect.left;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_Top(IVideoWindow *iface, LONG top)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, top %ld.\n", window, top);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
if (!SetWindowPos(window->hwnd, NULL, rect.left, top, 0, 0,
|
2019-10-08 01:55:46 +02:00
|
|
|
SWP_NOACTIVATE | SWP_NOZORDER | SWP_NOSIZE))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_FAIL;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_Top(IVideoWindow *iface, LONG *top)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, top %p.\n", window, top);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
*top = rect.top;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_Height(IVideoWindow *iface, LONG height)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2020-04-06 02:49:43 +02:00
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, height %ld.\n", window, height);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-06 02:49:43 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
if (!SetWindowPos(window->hwnd, NULL, 0, 0, rect.right - rect.left,
|
2020-04-03 06:20:48 +02:00
|
|
|
height, SWP_NOACTIVATE | SWP_NOZORDER | SWP_NOMOVE))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_FAIL;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_Height(IVideoWindow *iface, LONG *height)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2020-04-06 02:49:43 +02:00
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, height %p.\n", window, height);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-06 02:49:43 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
*height = rect.bottom - rect.top;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2019-10-08 01:55:45 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_Owner(IVideoWindow *iface, OAHWND owner)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2020-04-03 06:20:48 +02:00
|
|
|
HWND hwnd = window->hwnd;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, owner %#Ix.\n", window, owner);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2019-10-08 01:55:45 +02:00
|
|
|
/* Make sure we are marked as WS_CHILD before reparenting ourselves, so that
|
|
|
|
* we do not steal focus. LEGO Island depends on this. */
|
|
|
|
|
|
|
|
window->hwndOwner = (HWND)owner;
|
|
|
|
if (owner)
|
|
|
|
SetWindowLongPtrW(hwnd, GWL_STYLE, GetWindowLongPtrW(hwnd, GWL_STYLE) | WS_CHILD);
|
|
|
|
else
|
|
|
|
SetWindowLongPtrW(hwnd, GWL_STYLE, GetWindowLongPtrW(hwnd, GWL_STYLE) & ~WS_CHILD);
|
|
|
|
SetParent(hwnd, (HWND)owner);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_Owner(IVideoWindow *iface, OAHWND *Owner)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
TRACE("(%p/%p)->(%p)\n", This, iface, Owner);
|
|
|
|
|
|
|
|
*(HWND*)Owner = This->hwndOwner;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_MessageDrain(IVideoWindow *iface, OAHWND Drain)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, drain %#Ix.\n", This, Drain);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
This->hwndDrain = (HWND)Drain;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_MessageDrain(IVideoWindow *iface, OAHWND *Drain)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
TRACE("(%p/%p)->(%p)\n", This, iface, Drain);
|
|
|
|
|
|
|
|
*Drain = (OAHWND)This->hwndDrain;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_BorderColor(IVideoWindow *iface, LONG *Color)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
FIXME("(%p/%p)->(%p): stub !!!\n", This, iface, Color);
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_BorderColor(IVideoWindow *iface, LONG Color)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, colour %#lx.\n", This, Color);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_get_FullScreenMode(IVideoWindow *iface, LONG *FullScreenMode)
|
|
|
|
{
|
|
|
|
TRACE("(%p)->(%p)\n", iface, FullScreenMode);
|
|
|
|
|
|
|
|
return E_NOTIMPL;
|
|
|
|
}
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_put_FullScreenMode(IVideoWindow *iface, LONG fullscreen)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2022-02-04 22:41:27 +01:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, fullscreen %ld.\n", window, fullscreen);
|
|
|
|
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_NOTIMPL;
|
|
|
|
}
|
|
|
|
|
2019-10-09 03:02:21 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_SetWindowForeground(IVideoWindow *iface, LONG focus)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2019-10-09 03:02:21 +02:00
|
|
|
UINT flags = SWP_NOMOVE | SWP_NOSIZE;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, focus %ld.\n", window, focus);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2019-10-09 03:02:21 +02:00
|
|
|
if (focus != OAFALSE && focus != OATRUE)
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_INVALIDARG;
|
|
|
|
|
2019-10-09 03:02:22 +02:00
|
|
|
if (!window->pPin->peer)
|
2012-03-28 21:53:14 +02:00
|
|
|
return VFW_E_NOT_CONNECTED;
|
|
|
|
|
2019-10-09 03:02:21 +02:00
|
|
|
if (!focus)
|
|
|
|
flags |= SWP_NOACTIVATE;
|
2020-04-03 06:20:48 +02:00
|
|
|
SetWindowPos(window->hwnd, HWND_TOP, 0, 0, 0, 0, flags);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_SetWindowPosition(IVideoWindow *iface,
|
|
|
|
LONG left, LONG top, LONG width, LONG height)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, left %ld, top %ld, width %ld, height %ld.\n", window, left, top, width, height);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
if (!SetWindowPos(window->hwnd, NULL, left, top, width, height, SWP_NOACTIVATE | SWP_NOZORDER))
|
2012-03-28 21:53:14 +02:00
|
|
|
return E_FAIL;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_GetWindowPosition(IVideoWindow *iface,
|
|
|
|
LONG *left, LONG *top, LONG *width, LONG *height)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, left %p, top %p, width %p, height %p.\n", window, left, top, width, height);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
GetWindowRect(window->hwnd, &rect);
|
|
|
|
*left = rect.left;
|
|
|
|
*top = rect.top;
|
2020-04-06 02:49:43 +02:00
|
|
|
*width = rect.right - rect.left;
|
|
|
|
*height = rect.bottom - rect.top;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2019-12-06 06:08:29 +01:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_NotifyOwnerMessage(IVideoWindow *iface,
|
|
|
|
OAHWND hwnd, LONG message, LONG_PTR wparam, LONG_PTR lparam)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, hwnd %#Ix, message %#lx, wparam %#Ix, lparam %#Ix.\n",
|
2019-12-06 06:08:29 +01:00
|
|
|
window, hwnd, message, wparam, lparam);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2019-12-06 06:08:29 +01:00
|
|
|
/* That these messages are forwarded, and no others, is stated by the
|
|
|
|
* DirectX documentation, and supported by manual testing. */
|
|
|
|
switch (message)
|
|
|
|
{
|
|
|
|
case WM_ACTIVATEAPP:
|
|
|
|
case WM_DEVMODECHANGE:
|
|
|
|
case WM_DISPLAYCHANGE:
|
|
|
|
case WM_PALETTECHANGED:
|
|
|
|
case WM_PALETTEISCHANGING:
|
|
|
|
case WM_QUERYNEWPALETTE:
|
|
|
|
case WM_SYSCOLORCHANGE:
|
2020-04-03 06:20:48 +02:00
|
|
|
SendMessageW(window->hwnd, message, wparam, lparam);
|
2019-12-06 06:08:29 +01:00
|
|
|
break;
|
|
|
|
}
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_GetMinIdealImageSize(IVideoWindow *iface, LONG *width, LONG *height)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, width %p, height %p.\n", window, width, height);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
rect = window->ops->get_default_rect(window);
|
|
|
|
*width = rect.right - rect.left;
|
|
|
|
*height = rect.bottom - rect.top;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_GetMaxIdealImageSize(IVideoWindow *iface, LONG *width, LONG *height)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2020-04-03 06:20:48 +02:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
|
|
|
RECT rect;
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
TRACE("window %p, width %p, height %p.\n", window, width, height);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2020-04-03 06:20:48 +02:00
|
|
|
rect = window->ops->get_default_rect(window);
|
|
|
|
*width = rect.right - rect.left;
|
|
|
|
*height = rect.bottom - rect.top;
|
2012-03-28 21:53:14 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_GetRestorePosition(IVideoWindow *iface, LONG *pLeft, LONG *pTop, LONG *pWidth, LONG *pHeight)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
FIXME("(%p/%p)->(%p, %p, %p, %p): stub !!!\n", This, iface, pLeft, pTop, pWidth, pHeight);
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
HRESULT WINAPI BaseControlWindowImpl_HideCursor(IVideoWindow *iface, LONG hide)
|
2012-03-28 21:53:14 +02:00
|
|
|
{
|
2022-02-04 22:41:27 +01:00
|
|
|
struct video_window *window = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
FIXME("window %p, hide %ld, stub!\n", window, hide);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
HRESULT WINAPI BaseControlWindowImpl_IsCursorHidden(IVideoWindow *iface, LONG *CursorHidden)
|
|
|
|
{
|
2020-04-03 06:20:46 +02:00
|
|
|
struct video_window *This = impl_from_IVideoWindow(iface);
|
2012-03-28 21:53:14 +02:00
|
|
|
|
|
|
|
FIXME("(%p/%p)->(%p): stub !!!\n", This, iface, CursorHidden);
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
2020-03-12 03:10:13 +01:00
|
|
|
|
2020-05-07 02:28:52 +02:00
|
|
|
static inline struct video_window *impl_from_IBasicVideo(IBasicVideo *iface)
|
|
|
|
{
|
|
|
|
return CONTAINING_RECORD(iface, struct video_window, IBasicVideo_iface);
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_QueryInterface(IBasicVideo *iface, REFIID iid, void **out)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
return IUnknown_QueryInterface(window->pFilter->outer_unk, iid, out);
|
|
|
|
}
|
|
|
|
|
|
|
|
static ULONG WINAPI basic_video_AddRef(IBasicVideo *iface)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
return IUnknown_AddRef(window->pFilter->outer_unk);
|
|
|
|
}
|
|
|
|
|
|
|
|
static ULONG WINAPI basic_video_Release(IBasicVideo *iface)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
return IUnknown_Release(window->pFilter->outer_unk);
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetTypeInfoCount(IBasicVideo *iface, UINT *count)
|
|
|
|
{
|
|
|
|
TRACE("iface %p, count %p.\n", iface, count);
|
|
|
|
*count = 1;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetTypeInfo(IBasicVideo *iface, UINT index,
|
|
|
|
LCID lcid, ITypeInfo **typeinfo)
|
|
|
|
{
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("iface %p, index %u, lcid %#lx, typeinfo %p.\n", iface, index, lcid, typeinfo);
|
2020-05-07 02:28:52 +02:00
|
|
|
return strmbase_get_typeinfo(IBasicVideo_tid, typeinfo);
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetIDsOfNames(IBasicVideo *iface, REFIID iid,
|
|
|
|
LPOLESTR *names, UINT count, LCID lcid, DISPID *ids)
|
|
|
|
{
|
|
|
|
ITypeInfo *typeinfo;
|
|
|
|
HRESULT hr;
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("iface %p, iid %s, names %p, count %u, lcid %#lx, ids %p.\n",
|
2020-05-07 02:28:52 +02:00
|
|
|
iface, debugstr_guid(iid), names, count, lcid, ids);
|
|
|
|
|
|
|
|
if (SUCCEEDED(hr = strmbase_get_typeinfo(IBasicVideo_tid, &typeinfo)))
|
|
|
|
{
|
|
|
|
hr = ITypeInfo_GetIDsOfNames(typeinfo, names, count, ids);
|
|
|
|
ITypeInfo_Release(typeinfo);
|
|
|
|
}
|
|
|
|
return hr;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_Invoke(IBasicVideo *iface, DISPID id, REFIID iid, LCID lcid,
|
|
|
|
WORD flags, DISPPARAMS *params, VARIANT *result, EXCEPINFO *excepinfo, UINT *error_arg)
|
|
|
|
{
|
|
|
|
ITypeInfo *typeinfo;
|
|
|
|
HRESULT hr;
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("iface %p, id %ld, iid %s, lcid %#lx, flags %#x, params %p, result %p, excepinfo %p, error_arg %p.\n",
|
2020-05-07 02:28:52 +02:00
|
|
|
iface, id, debugstr_guid(iid), lcid, flags, params, result, excepinfo, error_arg);
|
|
|
|
|
|
|
|
if (SUCCEEDED(hr = strmbase_get_typeinfo(IBasicVideo_tid, &typeinfo)))
|
|
|
|
{
|
|
|
|
hr = ITypeInfo_Invoke(typeinfo, iface, id, flags, params, result, excepinfo, error_arg);
|
|
|
|
ITypeInfo_Release(typeinfo);
|
|
|
|
}
|
|
|
|
return hr;
|
|
|
|
}
|
|
|
|
|
|
|
|
static const VIDEOINFOHEADER *get_video_format(struct video_window *window)
|
|
|
|
{
|
|
|
|
/* Members of VIDEOINFOHEADER up to bmiHeader are identical to those of
|
|
|
|
* VIDEOINFOHEADER2. */
|
|
|
|
return (const VIDEOINFOHEADER *)window->pPin->mt.pbFormat;
|
|
|
|
}
|
|
|
|
|
|
|
|
static const BITMAPINFOHEADER *get_bitmap_header(struct video_window *window)
|
|
|
|
{
|
|
|
|
const AM_MEDIA_TYPE *mt = &window->pPin->mt;
|
|
|
|
if (IsEqualGUID(&mt->formattype, &FORMAT_VideoInfo))
|
|
|
|
return &((VIDEOINFOHEADER *)mt->pbFormat)->bmiHeader;
|
|
|
|
else
|
|
|
|
return &((VIDEOINFOHEADER2 *)mt->pbFormat)->bmiHeader;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_AvgTimePerFrame(IBasicVideo *iface, REFTIME *reftime)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
if (!reftime)
|
|
|
|
return E_POINTER;
|
|
|
|
if (!window->pPin->peer)
|
|
|
|
return VFW_E_NOT_CONNECTED;
|
|
|
|
|
|
|
|
TRACE("window %p, reftime %p.\n", window, reftime);
|
|
|
|
|
2020-07-23 01:29:22 +02:00
|
|
|
*reftime = (double)get_video_format(window)->AvgTimePerFrame / 1e7;
|
2020-05-07 02:28:52 +02:00
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_BitRate(IBasicVideo *iface, LONG *rate)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, rate %p.\n", window, rate);
|
|
|
|
|
|
|
|
if (!rate)
|
|
|
|
return E_POINTER;
|
|
|
|
if (!window->pPin->peer)
|
|
|
|
return VFW_E_NOT_CONNECTED;
|
|
|
|
|
|
|
|
*rate = get_video_format(window)->dwBitRate;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_BitErrorRate(IBasicVideo *iface, LONG *rate)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, rate %p.\n", window, rate);
|
|
|
|
|
|
|
|
if (!rate)
|
|
|
|
return E_POINTER;
|
|
|
|
if (!window->pPin->peer)
|
|
|
|
return VFW_E_NOT_CONNECTED;
|
|
|
|
|
|
|
|
*rate = get_video_format(window)->dwBitErrorRate;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_VideoWidth(IBasicVideo *iface, LONG *width)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, width %p.\n", window, width);
|
|
|
|
|
|
|
|
if (!width)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*width = get_bitmap_header(window)->biWidth;
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_VideoHeight(IBasicVideo *iface, LONG *height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, height %p.\n", window, height);
|
|
|
|
|
|
|
|
if (!height)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*height = abs(get_bitmap_header(window)->biHeight);
|
|
|
|
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_SourceLeft(IBasicVideo *iface, LONG left)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, left %ld.\n", window, left);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (left < 0 || window->src.right + left - window->src.left > get_bitmap_header(window)->biWidth)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
|
|
|
OffsetRect(&window->src, left - window->src.left, 0);
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_SourceLeft(IBasicVideo *iface, LONG *left)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, left %p.\n", window, left);
|
|
|
|
|
|
|
|
if (!left)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*left = window->src.left;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_SourceWidth(IBasicVideo *iface, LONG width)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, width %ld.\n", window, width);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (width <= 0 || window->src.left + width > get_bitmap_header(window)->biWidth)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
|
|
|
window->src.right = window->src.left + width;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_SourceWidth(IBasicVideo *iface, LONG *width)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, width %p.\n", window, width);
|
|
|
|
|
|
|
|
if (!width)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*width = window->src.right - window->src.left;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_SourceTop(IBasicVideo *iface, LONG top)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, top %ld.\n", window, top);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (top < 0 || window->src.bottom + top - window->src.top > get_bitmap_header(window)->biHeight)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
|
|
|
OffsetRect(&window->src, 0, top - window->src.top);
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_SourceTop(IBasicVideo *iface, LONG *top)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, top %p.\n", window, top);
|
|
|
|
|
|
|
|
if (!top)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*top = window->src.top;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_SourceHeight(IBasicVideo *iface, LONG height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, height %ld.\n", window, height);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (height <= 0 || window->src.top + height > get_bitmap_header(window)->biHeight)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
|
|
|
window->src.bottom = window->src.top + height;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_SourceHeight(IBasicVideo *iface, LONG *height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, height %p\n", window, height);
|
|
|
|
|
|
|
|
if (!height)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*height = window->src.bottom - window->src.top;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_DestinationLeft(IBasicVideo *iface, LONG left)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, left %ld.\n", window, left);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
2020-05-08 03:50:23 +02:00
|
|
|
window->default_dst = FALSE;
|
2020-05-07 02:28:52 +02:00
|
|
|
OffsetRect(&window->dst, left - window->dst.left, 0);
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_DestinationLeft(IBasicVideo *iface, LONG *left)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, left %p.\n", window, left);
|
|
|
|
|
|
|
|
if (!left)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*left = window->dst.left;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_DestinationWidth(IBasicVideo *iface, LONG width)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, width %ld.\n", window, width);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (width <= 0)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
2020-05-08 03:50:23 +02:00
|
|
|
window->default_dst = FALSE;
|
2020-05-07 02:28:52 +02:00
|
|
|
window->dst.right = window->dst.left + width;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_DestinationWidth(IBasicVideo *iface, LONG *width)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, width %p.\n", window, width);
|
|
|
|
|
|
|
|
if (!width)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*width = window->dst.right - window->dst.left;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_DestinationTop(IBasicVideo *iface, LONG top)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, top %ld.\n", window, top);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
2020-05-08 03:50:23 +02:00
|
|
|
window->default_dst = FALSE;
|
2020-05-07 02:28:52 +02:00
|
|
|
OffsetRect(&window->dst, 0, top - window->dst.top);
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_DestinationTop(IBasicVideo *iface, LONG *top)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, top %p.\n", window, top);
|
|
|
|
|
|
|
|
if (!top)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*top = window->dst.top;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_put_DestinationHeight(IBasicVideo *iface, LONG height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, height %ld.\n", window, height);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (height <= 0)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
2020-05-08 03:50:23 +02:00
|
|
|
window->default_dst = FALSE;
|
2020-05-07 02:28:52 +02:00
|
|
|
window->dst.bottom = window->dst.top + height;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_get_DestinationHeight(IBasicVideo *iface, LONG *height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, height %p.\n", window, height);
|
|
|
|
|
|
|
|
if (!height)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*height = window->dst.bottom - window->dst.top;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_SetSourcePosition(IBasicVideo *iface,
|
|
|
|
LONG left, LONG top, LONG width, LONG height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
const BITMAPINFOHEADER *bitmap_header = get_bitmap_header(window);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, left %ld, top %ld, width %ld, height %ld.\n", window, left, top, width, height);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (left < 0 || left + width > bitmap_header->biWidth || width <= 0)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
if (top < 0 || top + height > bitmap_header->biHeight || height <= 0)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
|
|
|
SetRect(&window->src, left, top, left + width, top + height);
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetSourcePosition(IBasicVideo *iface,
|
|
|
|
LONG *left, LONG *top, LONG *width, LONG *height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, left %p, top %p, width %p, height %p.\n", window, left, top, width, height);
|
|
|
|
|
|
|
|
if (!left || !top || !width || !height)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*left = window->src.left;
|
|
|
|
*top = window->src.top;
|
|
|
|
*width = window->src.right - window->src.left;
|
|
|
|
*height = window->src.bottom - window->src.top;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_SetDefaultSourcePosition(IBasicVideo *iface)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
2020-05-08 03:50:21 +02:00
|
|
|
const BITMAPINFOHEADER *bitmap_header = get_bitmap_header(window);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
TRACE("window %p.\n", window);
|
|
|
|
|
2020-05-08 03:50:21 +02:00
|
|
|
SetRect(&window->src, 0, 0, bitmap_header->biWidth, bitmap_header->biHeight);
|
|
|
|
return S_OK;
|
2020-05-07 02:28:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_SetDestinationPosition(IBasicVideo *iface,
|
|
|
|
LONG left, LONG top, LONG width, LONG height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
TRACE("window %p, left %ld, top %ld, width %ld, height %ld.\n", window, left, top, width, height);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
|
|
|
if (width <= 0 || height <= 0)
|
|
|
|
return E_INVALIDARG;
|
|
|
|
|
2020-05-08 03:50:23 +02:00
|
|
|
window->default_dst = FALSE;
|
2020-05-07 02:28:52 +02:00
|
|
|
SetRect(&window->dst, left, top, left + width, top + height);
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetDestinationPosition(IBasicVideo *iface,
|
|
|
|
LONG *left, LONG *top, LONG *width, LONG *height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, left %p, top %p, width %p, height %p.\n", window, left, top, width, height);
|
|
|
|
|
|
|
|
if (!left || !top || !width || !height)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*left = window->dst.left;
|
|
|
|
*top = window->dst.top;
|
|
|
|
*width = window->dst.right - window->dst.left;
|
|
|
|
*height = window->dst.bottom - window->dst.top;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_SetDefaultDestinationPosition(IBasicVideo *iface)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p.\n", window);
|
|
|
|
|
2020-05-08 03:50:23 +02:00
|
|
|
window->default_dst = TRUE;
|
2020-05-08 03:50:21 +02:00
|
|
|
GetClientRect(window->hwnd, &window->dst);
|
|
|
|
return S_OK;
|
2020-05-07 02:28:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetVideoSize(IBasicVideo *iface, LONG *width, LONG *height)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
const BITMAPINFOHEADER *bitmap_header = get_bitmap_header(window);
|
|
|
|
|
|
|
|
TRACE("window %p, width %p, height %p.\n", window, width, height);
|
|
|
|
|
|
|
|
if (!width || !height)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*width = bitmap_header->biWidth;
|
|
|
|
*height = bitmap_header->biHeight;
|
|
|
|
return S_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetVideoPaletteEntries(IBasicVideo *iface,
|
|
|
|
LONG start, LONG count, LONG *ret_count, LONG *palette)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
2022-02-04 22:41:27 +01:00
|
|
|
FIXME("window %p, start %ld, count %ld, ret_count %p, palette %p, stub!\n",
|
2020-05-07 02:28:52 +02:00
|
|
|
window, start, count, ret_count, palette);
|
|
|
|
|
|
|
|
if (!ret_count || !palette)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
*ret_count = 0;
|
|
|
|
return VFW_E_NO_PALETTE_AVAILABLE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_GetCurrentImage(IBasicVideo *iface, LONG *size, LONG *image)
|
|
|
|
{
|
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
|
|
|
|
TRACE("window %p, size %p, image %p.\n", window, size, image);
|
|
|
|
|
|
|
|
if (!size || !image)
|
|
|
|
return E_POINTER;
|
|
|
|
|
|
|
|
return window->ops->get_current_image(window, size, image);
|
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_IsUsingDefaultSource(IBasicVideo *iface)
|
|
|
|
{
|
2020-05-08 03:50:24 +02:00
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
|
|
|
const BITMAPINFOHEADER *bitmap_header = get_bitmap_header(window);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
2020-05-08 03:50:24 +02:00
|
|
|
TRACE("window %p.\n", window);
|
|
|
|
|
|
|
|
if (!window->src.left && !window->src.top
|
|
|
|
&& window->src.right == bitmap_header->biWidth
|
|
|
|
&& window->src.bottom == bitmap_header->biHeight)
|
|
|
|
return S_OK;
|
|
|
|
return S_FALSE;
|
2020-05-07 02:28:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static HRESULT WINAPI basic_video_IsUsingDefaultDestination(IBasicVideo *iface)
|
|
|
|
{
|
2020-05-08 03:50:23 +02:00
|
|
|
struct video_window *window = impl_from_IBasicVideo(iface);
|
2020-05-07 02:28:52 +02:00
|
|
|
|
2020-05-08 03:50:23 +02:00
|
|
|
TRACE("window %p.\n", window);
|
|
|
|
|
|
|
|
return window->default_dst ? S_OK : S_FALSE;
|
2020-05-07 02:28:52 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static const IBasicVideoVtbl basic_video_vtbl =
|
|
|
|
{
|
|
|
|
basic_video_QueryInterface,
|
|
|
|
basic_video_AddRef,
|
|
|
|
basic_video_Release,
|
|
|
|
basic_video_GetTypeInfoCount,
|
|
|
|
basic_video_GetTypeInfo,
|
|
|
|
basic_video_GetIDsOfNames,
|
|
|
|
basic_video_Invoke,
|
|
|
|
basic_video_get_AvgTimePerFrame,
|
|
|
|
basic_video_get_BitRate,
|
|
|
|
basic_video_get_BitErrorRate,
|
|
|
|
basic_video_get_VideoWidth,
|
|
|
|
basic_video_get_VideoHeight,
|
|
|
|
basic_video_put_SourceLeft,
|
|
|
|
basic_video_get_SourceLeft,
|
|
|
|
basic_video_put_SourceWidth,
|
|
|
|
basic_video_get_SourceWidth,
|
|
|
|
basic_video_put_SourceTop,
|
|
|
|
basic_video_get_SourceTop,
|
|
|
|
basic_video_put_SourceHeight,
|
|
|
|
basic_video_get_SourceHeight,
|
|
|
|
basic_video_put_DestinationLeft,
|
|
|
|
basic_video_get_DestinationLeft,
|
|
|
|
basic_video_put_DestinationWidth,
|
|
|
|
basic_video_get_DestinationWidth,
|
|
|
|
basic_video_put_DestinationTop,
|
|
|
|
basic_video_get_DestinationTop,
|
|
|
|
basic_video_put_DestinationHeight,
|
|
|
|
basic_video_get_DestinationHeight,
|
|
|
|
basic_video_SetSourcePosition,
|
|
|
|
basic_video_GetSourcePosition,
|
|
|
|
basic_video_SetDefaultSourcePosition,
|
|
|
|
basic_video_SetDestinationPosition,
|
|
|
|
basic_video_GetDestinationPosition,
|
|
|
|
basic_video_SetDefaultDestinationPosition,
|
|
|
|
basic_video_GetVideoSize,
|
|
|
|
basic_video_GetVideoPaletteEntries,
|
|
|
|
basic_video_GetCurrentImage,
|
|
|
|
basic_video_IsUsingDefaultSource,
|
|
|
|
basic_video_IsUsingDefaultDestination
|
|
|
|
};
|
|
|
|
|
2020-03-12 03:10:13 +01:00
|
|
|
void video_window_unregister_class(void)
|
|
|
|
{
|
|
|
|
if (!UnregisterClassW(class_name, NULL) && GetLastError() != ERROR_CLASS_DOES_NOT_EXIST)
|
2022-02-04 22:41:27 +01:00
|
|
|
ERR("Failed to unregister class, error %lu.\n", GetLastError());
|
2020-03-12 03:10:13 +01:00
|
|
|
}
|
2020-04-03 06:20:48 +02:00
|
|
|
|
2020-04-06 02:49:42 +02:00
|
|
|
void video_window_init(struct video_window *window, const IVideoWindowVtbl *vtbl,
|
2020-04-03 06:20:48 +02:00
|
|
|
struct strmbase_filter *owner, struct strmbase_pin *pin, const struct video_window_ops *ops)
|
|
|
|
{
|
|
|
|
memset(window, 0, sizeof(*window));
|
|
|
|
window->ops = ops;
|
|
|
|
window->IVideoWindow_iface.lpVtbl = vtbl;
|
2020-05-07 02:28:52 +02:00
|
|
|
window->IBasicVideo_iface.lpVtbl = &basic_video_vtbl;
|
2020-05-08 03:50:23 +02:00
|
|
|
window->default_dst = TRUE;
|
2020-04-03 06:20:48 +02:00
|
|
|
window->AutoShow = OATRUE;
|
|
|
|
window->pFilter = owner;
|
|
|
|
window->pPin = pin;
|
|
|
|
}
|
|
|
|
|
|
|
|
void video_window_cleanup(struct video_window *window)
|
|
|
|
{
|
|
|
|
if (window->hwnd)
|
|
|
|
{
|
|
|
|
/* Media Player Classic deadlocks if WM_PARENTNOTIFY is sent, so clear
|
|
|
|
* the child style first. Just like Windows, we don't actually unparent
|
|
|
|
* the window, to prevent extra focus events from being generated since
|
|
|
|
* it would become top-level for a brief period before being destroyed. */
|
|
|
|
SetWindowLongW(window->hwnd, GWL_STYLE, GetWindowLongW(window->hwnd, GWL_STYLE) & ~WS_CHILD);
|
|
|
|
|
2021-06-02 16:07:58 +02:00
|
|
|
SendMessageW(window->hwnd, WM_QUARTZ_DESTROY, 0, 0);
|
2020-04-03 06:20:48 +02:00
|
|
|
window->hwnd = NULL;
|
|
|
|
}
|
|
|
|
}
|