]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/wxHtmlWindow.py
Applied patch [ 827011 ] Event-based processing of item tooltips in wxTreeCtrl
[wxWidgets.git] / wxPython / demo / wxHtmlWindow.py
index 942dea61342a8b24654146df29cc486748706e13..a7b8c01e1a74cbd8095d330e47a0675bf7c1e60f 100644 (file)
@@ -1,28 +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
 
 
 from Main import opj
 
+##wxTrap()
+
 #----------------------------------------------------------------------
 
 # This shows how to catch the OnLinkClicked non-event.  (It's a virtual
 # method in the C++ code...)
 #----------------------------------------------------------------------
 
 # 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):
     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
         self.log = log
-        EVT_SCROLLWIN( self, self.OnScroll )
+        self.Bind(wx.EVT_SCROLLWIN, self.OnScroll )
 
     def OnScroll( self, event ):
 
     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()
 
         event.Skip()
 
-
     def OnLinkClicked(self, linkinfo):
         self.log.WriteText('OnLinkClicked: %s\n' % linkinfo.GetHref())
 
     def OnLinkClicked(self, linkinfo):
         self.log.WriteText('OnLinkClicked: %s\n' % linkinfo.GetHref())
 
@@ -43,66 +48,90 @@ class MyHtmlWindow(wxHtmlWindow):
         self.base_OnCellClicked(cell, x, y, evt)
 
 
         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):
     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]
         self.log = log
         self.frame = frame
         self.cwd = os.path.split(sys.argv[0])[0]
+
         if not self.cwd:
             self.cwd = os.getcwd()
         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 = MyHtmlWindow(self, -1, log)
-        self.html.SetRelatedFrame(frame, "wxPython: (A Demonstration) -- %s")
+        self.html.SetRelatedFrame(frame, self.titleBase + " -- %s")
         self.html.SetRelatedStatusBar(0)
 
         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.SetSizer(self.box)
-        self.SetAutoLayout(true)
+        self.SetAutoLayout(True)
 
         # A button with this ID is created on the widget test page.
 
         # 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)
 
 
 
         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):
 
 
     def OnShowDefault(self, event):
@@ -111,10 +140,22 @@ class TestHtmlPanel(wxPanel):
 
 
     def OnLoadFile(self, event):
 
 
     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)
         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()
 
 
         dlg.Destroy()
 
 
@@ -129,18 +170,20 @@ class TestHtmlPanel(wxPanel):
 
     def OnBack(self, event):
         if not self.html.HistoryBack():
 
     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():
 
 
     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):
 
 
     def OnViewSource(self, event):
-        from wxPython.lib.dialogs import wxScrolledMessageDialog
+        import  wx.lib.dialogs  as  dlgs
+
         source = self.html.GetParser().GetSource()
         source = self.html.GetParser().GetSource()
-        dlg = wxScrolledMessageDialog(self, source, 'HTML Source')
+
+        dlg = dlgs.wxScrolledMessageDialog(self, source, 'HTML Source')
         dlg.ShowModal()
         dlg.Destroy()
 
         dlg.ShowModal()
         dlg.Destroy()
 
@@ -153,24 +196,33 @@ class TestHtmlPanel(wxPanel):
 
 def runTest(frame, nb, log):
     win = TestHtmlPanel(nb, frame, log)
 
 def runTest(frame, nb, log):
     win = TestHtmlPanel(nb, frame, log)
+    print wx.Window_FindFocus()
     return win
 
 
 #----------------------------------------------------------------------
 
 
     return win
 
 
 #----------------------------------------------------------------------
 
 
+overview = """<html><body>
+<h2>wxHtmlWindow</h2>
 
 
+<p>wxHtmlWindow is capable of parsing and rendering most
+simple HTML tags.
 
 
+<p>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...
-
+</body></html>
 """
 
 
 
 """
 
 
 
+if __name__ == '__main__':
+    import sys,os
+    import run
+    run.main(['', os.path.basename(sys.argv[0])])
+