X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6c5ae2d2a6f716e8a89b27579026b9d085f84191..61940a7061d0b5d5122b1e1e939cfa2d72596999:/wxPython/demo/wxHtmlWindow.py?ds=sidebyside diff --git a/wxPython/demo/wxHtmlWindow.py b/wxPython/demo/wxHtmlWindow.py index 942dea6134..48b0706111 100644 --- a/wxPython/demo/wxHtmlWindow.py +++ b/wxPython/demo/wxHtmlWindow.py @@ -1,9 +1,22 @@ - -import sys, os - -from wxPython.wx import * -from wxPython.html import * -import wxPython.lib.wxpTag +# 11/18/2003 - Jeff Grimmett (grimmtooth@softhome.net) +# +# o Updated for wx namespace +# +# 12/13/2003 - Jeff Grimmett (grimmtooth@softhome.net) +# +# o got the wxpTag stuff working right. +# +# 12/18/2003 - Jeff Grimmett (grimmtooth@softhome.net) +# +# o wxScrolledMessageDialog -> ScrolledMessageDialog +# + +import os +import sys + +import wx +import wx.html as html +import wx.lib.wxpTag from Main import opj @@ -11,18 +24,17 @@ from Main import opj # This shows how to catch the OnLinkClicked non-event. (It's a virtual # method in the C++ code...) -class MyHtmlWindow(wxHtmlWindow): +class MyHtmlWindow(html.HtmlWindow): def __init__(self, parent, id, log): - wxHtmlWindow.__init__(self, parent, id) + html.HtmlWindow.__init__(self, parent, id, style=wx.NO_FULL_REPAINT_ON_RESIZE) self.log = log - EVT_SCROLLWIN( self, self.OnScroll ) + self.Bind(wx.EVT_SCROLLWIN, self.OnScroll ) def OnScroll( self, event ): - print 'event.GetOrientation()',event.GetOrientation() - print 'event.GetPosition()',event.GetPosition() + #print 'event.GetOrientation()',event.GetOrientation() + #print 'event.GetPosition()',event.GetPosition() event.Skip() - def OnLinkClicked(self, linkinfo): self.log.WriteText('OnLinkClicked: %s\n' % linkinfo.GetHref()) @@ -43,66 +55,90 @@ class MyHtmlWindow(wxHtmlWindow): self.base_OnCellClicked(cell, x, y, evt) -class TestHtmlPanel(wxPanel): +# This filter doesn't really do anything but show how to use filters +class MyHtmlFilter(html.HtmlFilter): + def __init__(self, log): + html.HtmlFilter.__init__(self) + self.log = log + + # This method decides if this filter is able to read the file + def CanRead(self, fsfile): + self.log.write("CanRead: %s\n" % fsfile.GetMimeType()) + return False + + # If CanRead returns True then this method is called to actually + # read the file and return the contents. + def ReadFile(self, fsfile): + return "" + + +class TestHtmlPanel(wx.Panel): def __init__(self, parent, frame, log): - wxPanel.__init__(self, parent, -1) + wx.Panel.__init__(self, parent, -1, style=wx.NO_FULL_REPAINT_ON_RESIZE) self.log = log self.frame = frame self.cwd = os.path.split(sys.argv[0])[0] + if not self.cwd: self.cwd = os.getcwd() + if frame: + self.titleBase = frame.GetTitle() + + html.HtmlWindow_AddFilter(MyHtmlFilter(log)) self.html = MyHtmlWindow(self, -1, log) - self.html.SetRelatedFrame(frame, "wxPython: (A Demonstration) -- %s") + self.html.SetRelatedFrame(frame, self.titleBase + " -- %s") self.html.SetRelatedStatusBar(0) - self.printer = wxHtmlEasyPrinting() + self.printer = html.HtmlEasyPrinting() - self.box = wxBoxSizer(wxVERTICAL) - self.box.Add(self.html, 1, wxGROW) + self.box = wx.BoxSizer(wx.VERTICAL) + self.box.Add(self.html, 1, wx.GROW) - subbox = wxBoxSizer(wxHORIZONTAL) -## btn = wxButton(self, 1201, "Show Default") -## EVT_BUTTON(self, 1201, self.OnShowDefault) -## subbox.Add(btn, 1, wxGROW | wxALL, 2) + subbox = wx.BoxSizer(wx.HORIZONTAL) - btn = wxButton(self, 1202, "Load File") - EVT_BUTTON(self, 1202, self.OnLoadFile) - subbox.Add(btn, 1, wxGROW | wxALL, 2) + btn = wx.Button(self, -1, "Load File") + self.Bind(wx.EVT_BUTTON, self.OnLoadFile, btn) + subbox.Add(btn, 1, wx.GROW | wx.ALL, 2) - btn = wxButton(self, 1203, "With Widgets") - EVT_BUTTON(self, 1203, self.OnWithWidgets) - subbox.Add(btn, 1, wxGROW | wxALL, 2) + btn = wx.Button(self, -1, "Load URL") + self.Bind(wx.EVT_BUTTON, self.OnLoadURL, btn) + subbox.Add(btn, 1, wx.GROW | wx.ALL, 2) - btn = wxButton(self, 1204, "Back") - EVT_BUTTON(self, 1204, self.OnBack) - subbox.Add(btn, 1, wxGROW | wxALL, 2) + btn = wx.Button(self, -1, "With Widgets") + self.Bind(wx.EVT_BUTTON, self.OnWithWidgets, btn) + subbox.Add(btn, 1, wx.GROW | wx.ALL, 2) - btn = wxButton(self, 1205, "Forward") - EVT_BUTTON(self, 1205, self.OnForward) - subbox.Add(btn, 1, wxGROW | wxALL, 2) + btn = wx.Button(self, -1, "Back") + self.Bind(wx.EVT_BUTTON, self.OnBack, btn) + subbox.Add(btn, 1, wx.GROW | wx.ALL, 2) - btn = wxButton(self, 1207, "Print") - EVT_BUTTON(self, 1207, self.OnPrint) - subbox.Add(btn, 1, wxGROW | wxALL, 2) + btn = wx.Button(self, -1, "Forward") + self.Bind(wx.EVT_BUTTON, self.OnForward, btn) + subbox.Add(btn, 1, wx.GROW | wx.ALL, 2) - btn = wxButton(self, 1206, "View Source") - EVT_BUTTON(self, 1206, self.OnViewSource) - subbox.Add(btn, 1, wxGROW | wxALL, 2) + btn = wx.Button(self, -1, "Print") + self.Bind(wx.EVT_BUTTON, self.OnPrint, btn) + subbox.Add(btn, 1, wx.GROW | wx.ALL, 2) - self.box.Add(subbox, 0, wxGROW) + btn = wx.Button(self, -1, "View Source") + self.Bind(wx.EVT_BUTTON, self.OnViewSource, btn) + subbox.Add(btn, 1, wx.GROW | wx.ALL, 2) + + self.box.Add(subbox, 0, wx.GROW) self.SetSizer(self.box) - self.SetAutoLayout(true) + self.SetAutoLayout(True) # A button with this ID is created on the widget test page. - EVT_BUTTON(self, wxID_OK, self.OnOk) + self.Bind(wx.EVT_BUTTON, self.OnOk, id=wx.ID_OK) self.OnShowDefault(None) -## def __del__(self): -## print 'TestHtmlPanel.__del__' - + def ShutdownDemo(self): + # put the frame title back + if self.frame: + self.frame.SetTitle(self.titleBase) def OnShowDefault(self, event): @@ -111,10 +147,22 @@ class TestHtmlPanel(wxPanel): def OnLoadFile(self, event): - dlg = wxFileDialog(self, wildcard = '*.htm*', style=wxOPEN) + dlg = wx.FileDialog(self, wildcard = '*.htm*', style=wx.OPEN) + if dlg.ShowModal(): path = dlg.GetPath() self.html.LoadPage(path) + + dlg.Destroy() + + + def OnLoadURL(self, event): + dlg = wx.TextEntryDialog(self, "Enter a URL") + + if dlg.ShowModal(): + url = dlg.GetValue() + self.html.LoadPage(url) + dlg.Destroy() @@ -129,18 +177,20 @@ class TestHtmlPanel(wxPanel): def OnBack(self, event): if not self.html.HistoryBack(): - wxMessageBox("No more items in history!") + wx.MessageBox("No more items in history!") def OnForward(self, event): if not self.html.HistoryForward(): - wxMessageBox("No more items in history!") + wx.MessageBox("No more items in history!") def OnViewSource(self, event): - from wxPython.lib.dialogs import wxScrolledMessageDialog + import wx.lib.dialogs + source = self.html.GetParser().GetSource() - dlg = wxScrolledMessageDialog(self, source, 'HTML Source') + + dlg = wx.lib.dialogs.ScrolledMessageDialog(self, source, 'HTML Source') dlg.ShowModal() dlg.Destroy() @@ -153,24 +203,33 @@ class TestHtmlPanel(wxPanel): def runTest(frame, nb, log): win = TestHtmlPanel(nb, frame, log) + print wx.Window_FindFocus() return win #---------------------------------------------------------------------- +overview = """
+wxHtmlWindow is capable of parsing and rendering most +simple HTML tags. +
It is not intended to be a high-end HTML browser. If you're +looking for something like that see the IEHtmlWin class, which +wraps the core MSIE HTML viewer. -overview = """\ -wxHtmlWindow is capable of parsing and rendering most simple HTML tags. - -It is not intended to be a high-end HTML browser. If you're looking for something like that try http://www.mozilla.org - there's a chance you'll be able to make their widget wxWindows-compatible. I'm sure everyone will enjoy your work in that case... - + """ +if __name__ == '__main__': + import sys,os + import run + run.main(['', os.path.basename(sys.argv[0])]) +