Author: dquintana Date: Wed Feb 12 19:46:24 2014 New Revision: 62138
URL: http://svn.reactos.org/svn/reactos?rev=62138&view=rev Log: [RSHELL] * Port the implementation of CMenuDeskBar to rshell (still disabled by default). * Begin implementing missing features: - Notify the band of the icon size change from SetIconSize.
Modified: branches/shell-experiments/base/shell/rshell/CMakeLists.txt branches/shell-experiments/base/shell/rshell/CMenuDeskBar.cpp branches/shell-experiments/dll/win32/shell32/folders/desktop.cpp
Modified: branches/shell-experiments/base/shell/rshell/CMakeLists.txt URL: http://svn.reactos.org/svn/reactos/branches/shell-experiments/base/shell/rsh... ============================================================================== --- branches/shell-experiments/base/shell/rshell/CMakeLists.txt [iso-8859-1] (original) +++ branches/shell-experiments/base/shell/rshell/CMakeLists.txt [iso-8859-1] Wed Feb 12 19:46:24 2014 @@ -28,6 +28,7 @@ add_importlibs(rshell shlwapi shell32 + gdi32 ole32 user32 msvcrt
Modified: branches/shell-experiments/base/shell/rshell/CMenuDeskBar.cpp URL: http://svn.reactos.org/svn/reactos/branches/shell-experiments/base/shell/rsh... ============================================================================== --- branches/shell-experiments/base/shell/rshell/CMenuDeskBar.cpp [iso-8859-1] (original) +++ branches/shell-experiments/base/shell/rshell/CMenuDeskBar.cpp [iso-8859-1] Wed Feb 12 19:46:24 2014 @@ -19,12 +19,21 @@ */ #include "precomp.h" #include "wraplog.h" +#include <atlwin.h>
WINE_DEFAULT_DEBUG_CHANNEL(CMenuDeskBar);
#define WRAP_LOG 1
+typedef CWinTraits< + WS_POPUP | WS_DLGFRAME | WS_CLIPCHILDREN | WS_CLIPSIBLINGS, + WS_EX_LEFT | WS_EX_LTRREADING | WS_EX_RIGHTSCROLLBAR | WS_EX_PALETTEWINDOW +> CMenuWinTraits; + class CMenuDeskBar : +#if !WRAP_LOG + public CWindowImpl<CMenuDeskBar, CWindow, CMenuWinTraits>, +#endif public CComCoClass<CMenuDeskBar>, public CComObjectRootEx<CComMultiThreadModelNoCS>, public IOleCommandTarget, @@ -54,6 +63,20 @@ IBanneredBar * m_IBanneredBar; IInitializeObject * m_IInitializeObject; #else + + CComPtr<IUnknown> m_Site; + CComPtr<IUnknown> m_Client; + HWND m_ClientWindow; + bool m_Vertical; + bool m_Visible; + int m_NeededSize; // width or height + + DWORD m_IconSize; + HBITMAP m_Banner; + + // used by resize tracking loop + bool m_Tracking; + POINT m_LastLocation; #endif
public: @@ -99,9 +122,37 @@ virtual HRESULT STDMETHODCALLTYPE GetClient(IUnknown **ppunkClient); virtual HRESULT STDMETHODCALLTYPE OnPosRectChangeDB(LPRECT prc);
+ // message handlers + LRESULT OnSize(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnNotify(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnLButtonDown(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnLButtonUp(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnMouseMove(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnCancelMode(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnCaptureChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnWindowPosChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnActivate(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled); + LRESULT OnPaint(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled);
DECLARE_NOT_AGGREGATABLE(CMenuDeskBar) DECLARE_PROTECT_FINAL_CONSTRUCT() + +#if !WRAP_LOG + DECLARE_WND_CLASS_EX(_T("BaseBar"), 0, COLOR_3DFACE) +#endif + + BEGIN_MSG_MAP(CMenuDeskBar) + MESSAGE_HANDLER(WM_SIZE, OnSize) + MESSAGE_HANDLER(WM_NOTIFY, OnNotify) + MESSAGE_HANDLER(WM_LBUTTONDOWN, OnLButtonDown) + MESSAGE_HANDLER(WM_LBUTTONUP, OnLButtonUp) + MESSAGE_HANDLER(WM_MOUSEMOVE, OnMouseMove) + MESSAGE_HANDLER(WM_CANCELMODE, OnCancelMode) + MESSAGE_HANDLER(WM_CAPTURECHANGED, OnCaptureChanged) + MESSAGE_HANDLER(WM_WINDOWPOSCHANGED, OnWindowPosChanged) + MESSAGE_HANDLER(WM_ACTIVATE, OnActivate) +/* MESSAGE_HANDLER(WM_PAINT, OnPaint) */ + END_MSG_MAP()
BEGIN_COM_MAP(CMenuDeskBar) COM_INTERFACE_ENTRY_IID(IID_IMenuPopup, IMenuPopup) @@ -135,6 +186,7 @@ return hr; }
+#if WRAP_LOG CMenuDeskBar::CMenuDeskBar() { HRESULT hr; @@ -392,3 +444,484 @@ WrapLogExit("CMenuDeskBar::OnPosRectChangeDB() = %08x\n", hr); return hr; } +#else + +CMenuDeskBar::CMenuDeskBar() : + m_ClientWindow(NULL), + m_Vertical(true), + m_Visible(false), + m_NeededSize(200), + m_Tracking(false) +{ +} + +CMenuDeskBar::~CMenuDeskBar() +{ +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::GetWindow(HWND *lphwnd) +{ + if (lphwnd == NULL) + return E_POINTER; + *lphwnd = m_hWnd; + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::ContextSensitiveHelp(BOOL fEnterMode) +{ + return E_NOTIMPL; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::OnFocusChangeIS(IUnknown *punkObj, BOOL fSetFocus) +{ + // forward to owner + return E_NOTIMPL; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::QueryStatus(const GUID *pguidCmdGroup, ULONG cCmds, + OLECMD prgCmds[], OLECMDTEXT *pCmdText) +{ + return E_NOTIMPL; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::Exec(const GUID *pguidCmdGroup, DWORD nCmdID, + DWORD nCmdexecopt, VARIANT *pvaIn, VARIANT *pvaOut) +{ + if (IsEqualIID(*pguidCmdGroup, CGID_Explorer)) + { + } + else if (IsEqualIID(*pguidCmdGroup, IID_IDeskBarClient)) + { + switch (nCmdID) + { + case 0: + // hide current band + break; + case 2: + break; + case 3: + break; + } + } + return E_NOTIMPL; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::QueryService(REFGUID guidService, REFIID riid, void **ppvObject) +{ + CComPtr<IServiceProvider> serviceProvider; + HRESULT hResult; + + if (m_Site == NULL) + return E_FAIL; + hResult = m_Site->QueryInterface(IID_IServiceProvider, reinterpret_cast<void **>(&serviceProvider)); + if (FAILED(hResult)) + return hResult; + // called for SID_STopLevelBrowser, IID_IBrowserService to find top level browser + // called for SID_IWebBrowserApp, IID_IConnectionPointContainer + // connection point called for DIID_DWebBrowserEvents2 to establish connection + return serviceProvider->QueryService(guidService, riid, ppvObject); +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::UIActivateIO(BOOL fActivate, LPMSG lpMsg) +{ + // forward to contained bar + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::HasFocusIO() +{ + // forward to contained bar + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::TranslateAcceleratorIO(LPMSG lpMsg) +{ + // forward to contained bar + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::SetClient(IUnknown *punkClient) +{ + CComPtr<IDeskBarClient> pDeskBandClient; + HRESULT hResult; + + if (m_hWnd == NULL) + { + HWND ownerWindow = NULL; + if (m_Site) + { + IOleWindow * oleWindow; + + hResult = m_Site->QueryInterface(IID_IOleWindow, reinterpret_cast<void **>(&oleWindow)); + if (SUCCEEDED(hResult)) + hResult = oleWindow->GetWindow(&ownerWindow); + + if (!::IsWindow(ownerWindow)) + return E_FAIL; + } + + Create(ownerWindow); + } + + if (punkClient == NULL) + m_Client.Release(); + else + { + hResult = punkClient->QueryInterface(IID_IUnknown, reinterpret_cast<void **>(&m_Client)); + if (FAILED(hResult)) + return hResult; + + hResult = m_Client->QueryInterface(IID_IDeskBarClient, (VOID**) &pDeskBandClient); + if (FAILED(hResult)) + return hResult; + + hResult = pDeskBandClient->SetDeskBarSite(static_cast<IDeskBar*>(this)); + if (FAILED(hResult)) + return hResult; + + } + + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::GetClient(IUnknown **ppunkClient) +{ + if (ppunkClient == NULL) + return E_POINTER; + *ppunkClient = m_Client; + if (m_Client.p != NULL) + m_Client.p->AddRef(); + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::OnPosRectChangeDB(LPRECT prc) +{ + if (prc == NULL) + return E_POINTER; + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::SetSite(IUnknown *pUnkSite) +{ + return S_OK; + CComPtr<IServiceProvider> serviceProvider; + CComPtr<IProfferService> profferService; + HRESULT hResult; + CComPtr<IOleWindow> oleWindow; + HWND ownerWindow; + + + m_Site.Release(); + if (pUnkSite == NULL) + { + return S_OK; + } + + if (m_hWnd == NULL) + { + // get window handle of parent + hResult = pUnkSite->QueryInterface(IID_ITrayPriv, reinterpret_cast<void **>(&m_Site)); + if (FAILED(hResult)) + return hResult; + + hResult = pUnkSite->QueryInterface(IID_IOleWindow, reinterpret_cast<void **>(&oleWindow)); + if (SUCCEEDED(hResult)) + hResult = oleWindow->GetWindow(&ownerWindow); + + if (!::IsWindow(ownerWindow)) + return E_FAIL; + + Create(ownerWindow); + } + else + { + //Set Owner ? + } + + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::GetSite(REFIID riid, void **ppvSite) +{ + if (ppvSite == NULL) + return E_POINTER; + *ppvSite = m_Site; + if (m_Site.p != NULL) + m_Site.p->AddRef(); + return S_OK; +} + +LRESULT CMenuDeskBar::OnSize(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + HRESULT hr; + + if (m_Client) + { + CComPtr<IOleWindow> pOw; + hr = m_Client->QueryInterface(IID_PPV_ARG(IOleWindow, &pOw)); + if (FAILED(hr)) + { + ERR("IUnknown_QueryInterface pBs failed: %x\n", hr); + return 0; + } + + HWND clientWnd; + pOw->GetWindow(&clientWnd); + + RECT rc; + + GetClientRect(&rc); + + if (m_Banner != NULL) + { + SIZE sz; + ::GetBitmapDimensionEx(m_Banner, &sz); + rc.left += sz.cx; + } + + ::SetWindowPos(clientWnd, NULL, rc.left, rc.top, rc.right - rc.left, rc.bottom - rc.top, 0); + } + + return 0; +} + +LRESULT CMenuDeskBar::OnNotify(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + CComPtr<IWinEventHandler> winEventHandler; + LRESULT result; + HRESULT hResult; + + result = 0; + if (m_Client.p != NULL) + { + hResult = m_Client->QueryInterface(IID_IWinEventHandler, reinterpret_cast<void **>(&winEventHandler)); + if (SUCCEEDED(hResult) && winEventHandler.p != NULL) + hResult = winEventHandler->OnWinEvent(NULL, uMsg, wParam, lParam, &result); + } + return result; +} + +LRESULT CMenuDeskBar::OnLButtonDown(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + SetCapture(); + m_Tracking = true; + m_LastLocation.x = LOWORD(lParam); + m_LastLocation.y = HIWORD(lParam); + return 0; +} + +LRESULT CMenuDeskBar::OnLButtonUp(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + ReleaseCapture(); + m_Tracking = false; + return 0; +} + +LRESULT CMenuDeskBar::OnMouseMove(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + POINT newLocation; + //int delta; + + if (m_Tracking) + { + newLocation.x = (short) LOWORD(lParam); + newLocation.y = (short) HIWORD(lParam); + m_LastLocation = newLocation; + } + return 0; +} + +LRESULT CMenuDeskBar::OnCancelMode(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + m_Tracking = false; + return 0; +} + +LRESULT CMenuDeskBar::OnCaptureChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + m_Tracking = false; + return 0; +} + +LRESULT CMenuDeskBar::OnWindowPosChanged(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + return 0; +} + +LRESULT CMenuDeskBar::OnActivate(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + if (LOWORD(wParam) == WA_INACTIVE) + { + //DestroyWindow(); + //ShowWindow(SW_HIDE); + } + return 0; +} + +LRESULT CMenuDeskBar::OnPaint(UINT uMsg, WPARAM wParam, LPARAM lParam, BOOL &bHandled) +{ + TRACE("OnPaint\n"); + + if (m_Banner && !m_IconSize) + { + BITMAP bm; + PAINTSTRUCT ps; + HDC hdc = BeginPaint(&ps); + + HDC hdcMem = ::CreateCompatibleDC(hdc); + HGDIOBJ hbmOld = ::SelectObject(hdcMem, m_Banner); + + ::GetObject(m_Banner, sizeof(bm), &bm); + + TRACE("Painting banner: %d by %d\n", bm.bmWidth, bm.bmHeight); + + if (!::BitBlt(hdc, 0, 0, bm.bmWidth, bm.bmHeight, hdcMem, 0, 0, SRCCOPY)) + WARN("BitBlt failed\n"); + + ::SelectObject(hdcMem, hbmOld); + ::DeleteDC(hdcMem); + + EndPaint(&ps); + } + + return 0; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::Popup(POINTL *ppt, RECTL *prcExclude, MP_POPUPFLAGS dwFlags) +{ + //ENTER >> CMenuDeskBar<03901CC0>::Popup(POINTL *ppt=00B3F428, RECTL *prcExclude=00B3F418, MP_POPUPFLAGS dwFlags=80000000) + // ENTER >> CMenuBand<00D2CCF8>::QueryService + + // ENTER >> CMenuBand<00D2CCF8>::ShowDW(BOOL fShow=1) + // ENTER >> CMenuDeskBar<03901CC0>::GetSite(REFIID riid={4622AD10-FF23-11D0-8D34-00A0C90F2719}, PVOID *ppvSite=03901D4C) + // -- *ppvSite=00BDEA90 + // EXIT <<< CMenuDeskBar::GetSite() = 00000000 + // ENTER >> CMenuBand<00D2CCF8>::SetMenu(HMENU hmenu=593F0A07, HWND hwnd=00000000, DWORD dwFlags=20000000) + // EXIT <<< CMenuBand::SetMenu() = 00000000 + // EXIT <<< CMenuBand::ShowDW() = 00000000 + // ENTER >> CMenuBand<00D2CCF8>::GetBandInfo(DWORD dwBandID=0, DWORD dwViewMode=0, DESKBANDINFO *pdbi=00B3F0F0) + // EXIT <<< CMenuBand::GetBandInfo() = 00000000 + // ENTER >> CMenuBand<00D2CCF8>::QueryService(REFGUID guidService={ED9CC020-08B9-11D1-9823-00C04FD91972}, REFIID riid={B722BCCB-4E68-101B-A2BC-00AA00404770}, void **ppvObject=00B3F304) + // -- SID is SID_SMenuBandChild. Using QueryInterface of self instead of wrapped object. + // -- *ppvObject=00D2CD08 + // EXIT <<< CMenuBand::QueryService() = 00000000 + // ENTER >> CMenuBand<00D2CCF8>::Exec(const GUID *pguidCmdGroup=76BAE1FC, DWORD nCmdID=19, DWORD nCmdexecopt=0, VARIANT *pvaIn=00000000, VARIANT *pvaOut=00000000) + // -- *pguidCmdGroup={5B4DAE26-B807-11D0-9815-00C04FD91972} + // EXIT <<< CMenuBand::Exec() = 00000001 + // ENTER >> CMenuBand<00D2CCF8>::OnPosRectChangeDB(RECT *prc=00B3E630) + // -- *prc={L: 0, T: 0, R: 218, B: 305} + // EXIT <<< CMenuBand::OnPosRectChangeDB() = 00000000 + // ENTER >> CMenuBand<00D2CCF8>::UIActivateIO(BOOL fActivate=1, LPMSG lpMsg=00000000) + // EXIT <<< CMenuBand::UIActivateIO() = 00000001 + //EXIT <<< CMenuDeskBar::Popup() = 00000000 + HRESULT hr; + IServiceProvider * sp; + IOleCommandTarget * oct; + IInputObject * io; + + hr = m_Client->QueryInterface(IID_PPV_ARG(IServiceProvider, &sp)); + if (FAILED(hr)) + return hr; + + hr = m_Client->QueryInterface(IID_PPV_ARG(IInputObject, &io)); + if (FAILED(hr)) + return hr; + + hr = sp->QueryService(SID_SMenuBandChild, IID_PPV_ARG(IOleCommandTarget, &oct)); + if (FAILED(hr)) + { + sp->Release(); + return hr; + } + + // Unknown meaning + const int CMD = 19; + const int CMD_EXEC_OPT = 0; + + hr = oct->Exec(&CLSID_MenuBand, CMD, CMD_EXEC_OPT, NULL, NULL); + + oct->Release(); + sp->Release(); + return hr; + + // FIXME: everything! + const int hackWidth = 200; + const int hackHeight = 400; + RECT r = { ppt->x, ppt->y - hackHeight, ppt->x + hackWidth, ppt->y }; + if (this->m_hWnd == NULL) + { + this->Create(NULL, &r); + } + this->SetWindowPos(NULL, r.left, r.top, r.right - r.left, r.bottom - r.top, SWP_SHOWWINDOW); + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::SetIconSize(THIS_ DWORD iIcon) +{ + HRESULT hr; + IServiceProvider * sp; + IOleCommandTarget * oct; + + m_IconSize = iIcon; + + hr = m_Client->QueryInterface(IID_PPV_ARG(IServiceProvider, &sp)); + if (FAILED(hr)) + return hr; + + hr = sp->QueryService(SID_SMenuBandChild, IID_PPV_ARG(IOleCommandTarget, &oct)); + if (FAILED(hr)) + { + sp->Release(); + return hr; + } + + // Unknown meaning + const int CMD = 16; + const int CMD_EXEC_OPT = 2; + + hr = oct->Exec(&CLSID_MenuBand, CMD, CMD_EXEC_OPT, NULL, NULL); + + oct->Release(); + sp->Release(); + return hr; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::GetIconSize(THIS_ DWORD* piIcon) +{ + if (piIcon) + *piIcon = m_IconSize; + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::SetBitmap(THIS_ HBITMAP hBitmap) +{ + m_Banner = hBitmap; + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::GetBitmap(THIS_ HBITMAP* phBitmap) +{ + if (phBitmap) + *phBitmap = m_Banner; + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::OnSelect( + DWORD dwSelectType) +{ + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::SetSubMenu( + IMenuPopup *pmp, + BOOL fSet) +{ + return S_OK; +} + +HRESULT STDMETHODCALLTYPE CMenuDeskBar::Initialize(THIS) +{ + return S_OK; +} + +#endif
Modified: branches/shell-experiments/dll/win32/shell32/folders/desktop.cpp URL: http://svn.reactos.org/svn/reactos/branches/shell-experiments/dll/win32/shel... ============================================================================== --- branches/shell-experiments/dll/win32/shell32/folders/desktop.cpp [iso-8859-1] (original) +++ branches/shell-experiments/dll/win32/shell32/folders/desktop.cpp [iso-8859-1] Wed Feb 12 19:46:24 2014 @@ -1451,7 +1451,7 @@ else { InitFormatEtc (formatetc, CF_HDROP, TYMED_HGLOBAL); - if SUCCEEDED(pDataObject->QueryGetData(&formatetc)); + if (SUCCEEDED(pDataObject->QueryGetData(&formatetc))) { passthroughtofs = TRUE; }