X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/241b769f9670cd372c45db51f5f71ba83f93bad5..1f0acb435592470b421b80df854fbbb08cd2853f:/include/wx/msw/webview_ie.h diff --git a/include/wx/msw/webview_ie.h b/include/wx/msw/webview_ie.h index 416b54047c..aec06fc0d1 100644 --- a/include/wx/msw/webview_ie.h +++ b/include/wx/msw/webview_ie.h @@ -3,7 +3,7 @@ // Purpose: wxMSW IE wxWebView backend // Author: Marianne Gagnon // Id: $Id$ -// Copyright: (c) 2010 Marianne Gagnon, Steven Lamerton +// Copyright: (c) 2010 Marianne Gagnon, 2011 Steven Lamerton // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -12,7 +12,7 @@ #include "wx/setup.h" -#if wxUSE_WEBVIEW_IE +#if wxUSE_WEBVIEW_IE && defined(__WXMSW__) #include "wx/control.h" #include "wx/webview.h" @@ -22,6 +22,7 @@ #include "wx/vector.h" struct IHTMLDocument2; +class wxFSFile; class WXDLLIMPEXP_WEB wxWebViewIE : public wxWebView { @@ -104,7 +105,12 @@ public: virtual void DeleteSelection(); virtual wxString GetSelectedText(); virtual wxString GetSelectedSource(); + virtual void ClearSelection(); + virtual void RunScript(const wxString& javascript); + + //Virtual Filesystem Support + virtual void RegisterHandler(wxWebHandler* handler); // ---- IE-specific methods @@ -112,19 +118,11 @@ public: bool IsOfflineMode(); void SetOfflineMode(bool offline); - /** - * Get text zoom - * @return text zoom from 0 to 4 - */ - int GetIETextZoom(); + wxWebViewZoom GetIETextZoom(); + void SetIETextZoom(wxWebViewZoom level); - /** - * @param level 0 to 4 - */ - void SetIETextZoom(int level); - - void SetIEOpticalZoom(float zoom); - float GetIEOpticalZoom(); + wxWebViewZoom GetIEOpticalZoom(); + void SetIEOpticalZoom(wxWebViewZoom level); void onActiveXEvent(wxActiveXEvent& evt); void onEraseBg(wxEraseEvent&) {} @@ -136,8 +134,9 @@ private: wxAutomationObject m_ie; IWebBrowser2* m_webBrowser; DWORD m_dwCookie; - bool m_canNavigateBack; - bool m_canNavigateForward; + + //We store the current zoom type; + wxWebViewZoomType m_zoomType; /** The "Busy" property of IWebBrowser2 does not always return busy when * we'd want it to; this variable may be set to true in cases where the @@ -158,8 +157,74 @@ private: void ExecCommand(wxString command); IHTMLDocument2* GetDocument(); + wxDECLARE_DYNAMIC_CLASS(wxWebViewIE); +}; + +class VirtualProtocol : public IInternetProtocol +{ +protected: + ULONG m_refCount; + IInternetProtocolSink* m_protocolSink; + wxString m_html; + VOID * fileP; + + wxFSFile* m_file; + wxWebHandler* m_handler; + +public: + VirtualProtocol(wxWebHandler *handler); + ~VirtualProtocol(); + + //IUnknown + ULONG STDMETHODCALLTYPE AddRef(); + HRESULT STDMETHODCALLTYPE QueryInterface(REFIID riid, void **ppvObject); + ULONG STDMETHODCALLTYPE Release(); + + //IInternetProtocolRoot + HRESULT STDMETHODCALLTYPE Abort(HRESULT WXUNUSED(hrReason), + DWORD WXUNUSED(dwOptions)) + { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE Continue(PROTOCOLDATA *WXUNUSED(pProtocolData)) + { return S_OK; } + HRESULT STDMETHODCALLTYPE Resume() { return S_OK; } + HRESULT STDMETHODCALLTYPE Start(LPCWSTR szUrl, + IInternetProtocolSink *pOIProtSink, + IInternetBindInfo *pOIBindInfo, + DWORD grfPI, + HANDLE_PTR dwReserved); + HRESULT STDMETHODCALLTYPE Suspend() { return S_OK; } + HRESULT STDMETHODCALLTYPE Terminate(DWORD WXUNUSED(dwOptions)) { return S_OK; } + + //IInternetProtocol + HRESULT STDMETHODCALLTYPE LockRequest(DWORD WXUNUSED(dwOptions)) + { return S_OK; } + HRESULT STDMETHODCALLTYPE Read(void *pv, ULONG cb, ULONG *pcbRead); + HRESULT STDMETHODCALLTYPE Seek(LARGE_INTEGER WXUNUSED(dlibMove), + DWORD WXUNUSED(dwOrigin), + ULARGE_INTEGER* WXUNUSED(plibNewPosition)) + { return E_FAIL; } + HRESULT STDMETHODCALLTYPE UnlockRequest() { return S_OK; } +}; + +class ClassFactory : public IClassFactory +{ +private: + ULONG m_refCount; +public: + ClassFactory(wxWebHandler* handler) : m_handler(handler) {} + //IUnknown + ULONG STDMETHODCALLTYPE AddRef(); + HRESULT STDMETHODCALLTYPE QueryInterface(REFIID riid, void **ppvObject); + ULONG STDMETHODCALLTYPE Release(); + + //IClassFactory + HRESULT STDMETHODCALLTYPE CreateInstance(IUnknown* pUnkOuter, + REFIID riid, void** ppvObject); + HRESULT STDMETHODCALLTYPE LockServer(BOOL fLock); +private: + wxWebHandler* m_handler; }; -#endif // wxUSE_WEBVIEW_IE +#endif // wxUSE_WEBVIEW_IE && defined(__WXMSW__) #endif // wxWebViewIE_H