Add wxWebKitNewWindowEvent
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_8_BRANCH@53798 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -172,12 +172,34 @@ protected:
|
|||||||
wxString m_url;
|
wxString m_url;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#if wxABI_VERSION >= 20808
|
||||||
|
class wxWebKitNewWindowEvent : public wxCommandEvent
|
||||||
|
{
|
||||||
|
DECLARE_DYNAMIC_CLASS( wxWebViewNewWindowEvent )
|
||||||
|
public:
|
||||||
|
wxString GetURL() const { return m_url; }
|
||||||
|
void SetURL(const wxString& url) { m_url = url; }
|
||||||
|
wxString GetTargetName() const { return m_targetName; }
|
||||||
|
void SetTargetName(const wxString& name) { m_targetName = name; }
|
||||||
|
|
||||||
|
wxWebKitNewWindowEvent( wxWindow* win = (wxWindow*)(NULL));
|
||||||
|
wxEvent *Clone(void) const { return new wxWebKitNewWindowEvent(*this); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
wxString m_url;
|
||||||
|
wxString m_targetName;
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
typedef void (wxEvtHandler::*wxWebKitStateChangedEventFunction)(wxWebKitStateChangedEvent&);
|
typedef void (wxEvtHandler::*wxWebKitStateChangedEventFunction)(wxWebKitStateChangedEvent&);
|
||||||
typedef void (wxEvtHandler::*wxWebKitBeforeLoadEventFunction)(wxWebKitBeforeLoadEvent&);
|
typedef void (wxEvtHandler::*wxWebKitBeforeLoadEventFunction)(wxWebKitBeforeLoadEvent&);
|
||||||
|
typedef void (wxEvtHandler::*wxWebKitNewWindowEventFunction)(wxWebKitNewWindowEvent&);
|
||||||
|
|
||||||
BEGIN_DECLARE_EVENT_TYPES()
|
BEGIN_DECLARE_EVENT_TYPES()
|
||||||
DECLARE_LOCAL_EVENT_TYPE(wxEVT_WEBKIT_BEFORE_LOAD, wxID_ANY)
|
DECLARE_LOCAL_EVENT_TYPE(wxEVT_WEBKIT_BEFORE_LOAD, wxID_ANY)
|
||||||
DECLARE_LOCAL_EVENT_TYPE(wxEVT_WEBKIT_STATE_CHANGED, wxID_ANY)
|
DECLARE_LOCAL_EVENT_TYPE(wxEVT_WEBKIT_STATE_CHANGED, wxID_ANY)
|
||||||
|
DECLARE_LOCAL_EVENT_TYPE(wxEVT_WEBKIT_NEW_WINDOW, wxID_ANY)
|
||||||
END_DECLARE_EVENT_TYPES()
|
END_DECLARE_EVENT_TYPES()
|
||||||
|
|
||||||
#define EVT_WEBKIT_STATE_CHANGED(func) \
|
#define EVT_WEBKIT_STATE_CHANGED(func) \
|
||||||
@@ -196,6 +218,13 @@ END_DECLARE_EVENT_TYPES()
|
|||||||
(wxWebKitBeforeLoadEventFunction) & func, \
|
(wxWebKitBeforeLoadEventFunction) & func, \
|
||||||
(wxObject *) NULL ),
|
(wxObject *) NULL ),
|
||||||
|
|
||||||
|
#define EVT_WEBKIT_NEW_WINDOW(func) \
|
||||||
|
DECLARE_EVENT_TABLE_ENTRY( wxEVT_WEBKIT_NEW_WINDOW, \
|
||||||
|
wxID_ANY, \
|
||||||
|
wxID_ANY, \
|
||||||
|
(wxObjectEventFunction) \
|
||||||
|
(wxWebKitNewWindowEventFunction) & func, \
|
||||||
|
(wxObject *) NULL ),
|
||||||
#endif // wxUSE_WEBKIT
|
#endif // wxUSE_WEBKIT
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -309,6 +309,20 @@ wxWebKitBeforeLoadEvent::wxWebKitBeforeLoadEvent( wxWindow* win )
|
|||||||
SetId(win->GetId());
|
SetId(win->GetId());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
IMPLEMENT_DYNAMIC_CLASS( wxWebKitNewWindowEvent, wxCommandEvent )
|
||||||
|
|
||||||
|
DEFINE_EVENT_TYPE( wxEVT_WEBKIT_NEW_WINDOW )
|
||||||
|
|
||||||
|
wxWebKitNewWindowEvent::wxWebKitNewWindowEvent( wxWindow* win )
|
||||||
|
{
|
||||||
|
SetEventType( wxEVT_WEBKIT_NEW_WINDOW);
|
||||||
|
SetEventObject( win );
|
||||||
|
SetId(win->GetId());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//---------------------------------------------------------
|
//---------------------------------------------------------
|
||||||
// helper functions for NSString<->wxString conversion
|
// helper functions for NSString<->wxString conversion
|
||||||
//---------------------------------------------------------
|
//---------------------------------------------------------
|
||||||
@@ -851,6 +865,19 @@ void wxWebKitCtrl::MacVisibilityChanged(){
|
|||||||
[listener use];
|
[listener use];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
- (void)webView:(WebView *)sender decidePolicyForNewWindowAction:(NSDictionary *)actionInformation request:(NSURLRequest *)request newFrameName:(NSString *)frameName decisionListener:(id < WebPolicyDecisionListener >)listener
|
||||||
|
{
|
||||||
|
wxWebKitNewWindowEvent thisEvent(webKitWindow);
|
||||||
|
|
||||||
|
NSString *url = [[request URL] absoluteString];
|
||||||
|
thisEvent.SetURL( wxStringWithNSString( url ) );
|
||||||
|
thisEvent.SetTargetName( wxStringWithNSString( frameName ) );
|
||||||
|
|
||||||
|
if (webKitWindow && webKitWindow->GetEventHandler())
|
||||||
|
webKitWindow->GetEventHandler()->ProcessEvent(thisEvent);
|
||||||
|
|
||||||
|
[listener use];
|
||||||
|
}
|
||||||
@end
|
@end
|
||||||
|
|
||||||
#endif //wxUSE_WEBKIT
|
#endif //wxUSE_WEBKIT
|
||||||
|
@@ -46,6 +46,7 @@
|
|||||||
*wxSizer*ComputeFittingWindowSize*;
|
*wxSizer*ComputeFittingWindowSize*;
|
||||||
*wxSizerFlags*ReserveSpaceEvenIfHidden*;
|
*wxSizerFlags*ReserveSpaceEvenIfHidden*;
|
||||||
*wxSizerItem*ShouldAccountFor*;
|
*wxSizerItem*ShouldAccountFor*;
|
||||||
|
*wxWebKitNewWindowEvent*;
|
||||||
*wxWindowBase*ClientToWindowSize*;
|
*wxWindowBase*ClientToWindowSize*;
|
||||||
*wxWindowBase*Get*Sibling*;
|
*wxWindowBase*Get*Sibling*;
|
||||||
*wxWindowBase*WindowToClientSize*;
|
*wxWindowBase*WindowToClientSize*;
|
||||||
|
Reference in New Issue
Block a user