X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/2f9be7879ee3f1ec65e625563ff74944ef903967..156194e1d525407e90c21552f8f7aa05756e0ddc:/wxPython/demo/wxHtmlWindow.py?ds=sidebyside diff --git a/wxPython/demo/wxHtmlWindow.py b/wxPython/demo/wxHtmlWindow.py index 69d1d12e02..a7b8c01e1a 100644 --- a/wxPython/demo/wxHtmlWindow.py +++ b/wxPython/demo/wxHtmlWindow.py @@ -1,26 +1,33 @@ +# 11/18/2003 - Jeff Grimmett (grimmtooth@softhome.net) +# +# o Updated for wx namespace +# -import sys, os +import os +import sys -from wxPython.wx import * -from wxPython.html import * -import wxPython.lib.wxpTag +import wx +import wx.html as html + +from Main import opj + +##wxTrap() #---------------------------------------------------------------------- # 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()) @@ -32,88 +39,129 @@ class MyHtmlWindow(wxHtmlWindow): self.log.WriteText('OnSetTitle: %s\n' % title) self.base_OnSetTitle(title) -## def __del__(self): -## print 'MyHtmlWindow.__del__' + def OnCellMouseHover(self, cell, x, y): + self.log.WriteText('OnCellMouseHover: %s, (%d %d)\n' % (cell, x, y)) + self.base_OnCellMouseHover(cell, x, y) + + def OnCellClicked(self, cell, x, y, evt): + self.log.WriteText('OnCellClicked: %s, (%d %d)\n' % (cell, x, y)) + self.base_OnCellClicked(cell, x, y, evt) + + +# 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 -class TestHtmlPanel(wxPanel): + # 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 = wx.BoxSizer(wx.VERTICAL) + self.box.Add(self.html, 1, wx.GROW) - self.box = wxBoxSizer(wxVERTICAL) - self.box.Add(self.html, 1, wxGROW) + subbox = wx.BoxSizer(wx.HORIZONTAL) - subbox = wxBoxSizer(wxHORIZONTAL) -## btn = wxButton(self, 1201, "Show Default") -## EVT_BUTTON(self, 1201, self.OnShowDefault) -## 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, 1202, "Load File") - EVT_BUTTON(self, 1202, self.OnLoadFile) - 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, 1203, "With Widgets") - EVT_BUTTON(self, 1203, self.OnWithWidgets) - 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, 1204, "Back") - EVT_BUTTON(self, 1204, self.OnBack) - 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, 1205, "Forward") - EVT_BUTTON(self, 1205, self.OnForward) - 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, 1207, "Print") - EVT_BUTTON(self, 1207, self.OnPrint) - 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) - btn = wxButton(self, 1206, "View Source") - EVT_BUTTON(self, 1206, self.OnViewSource) - subbox.Add(btn, 1, wxGROW | wxALL, 2) + 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, wxGROW) + 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): - name = os.path.join(self.cwd, 'data/test.htm') + name = os.path.join(self.cwd, opj('data/test.htm')) self.html.LoadPage(name) 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() def OnWithWidgets(self, event): os.chdir(self.cwd) - name = os.path.join(self.cwd, 'data/widgetTest.htm') + name = os.path.join(self.cwd, opj('data/widgetTest.htm')) self.html.LoadPage(name) @@ -122,18 +170,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 as dlgs + source = self.html.GetParser().GetSource() - dlg = wxScrolledMessageDialog(self, source, 'HTML Source') + + dlg = dlgs.wxScrolledMessageDialog(self, source, 'HTML Source') dlg.ShowModal() dlg.Destroy() @@ -146,24 +196,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])]) +