1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxHelpController demo
4 // Author: Karsten Ballueder
8 // Copyright: (c) Karsten Ballueder, Julian Smart
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
12 // ============================================================================
14 // ============================================================================
16 // ----------------------------------------------------------------------------
18 // ----------------------------------------------------------------------------
20 // For compilers that support precompilation, includes "wx/wx.h".
21 #include "wx/wxprec.h"
27 // for all others, include the necessary headers (this file is usually all you
28 // need because it includes almost all "standard" wxWindows headers
33 # include "wx/image.h"
35 # include "wx/cshelp.h"
38 # include "wx/tooltip.h"
41 // define this to 1 to use HTML help even under Windows (by default, Windows
42 // version will use WinHelp).
43 // Please also see samples/html/helpview.
45 #define USE_HTML_HELP 1
47 // Use old-style HTML help if 1
48 #define USE_OLD_HTML_HELP 0
52 #define USE_HTML_HELP 0
56 #include "wx/filesys.h"
57 #include "wx/fs_zip.h"
60 #include "wx/generic/helpwxht.h"
63 #include "wx/html/helpctrl.h"
66 #if wxUSE_MS_HTML_HELP
67 #include "wx/msw/helpchm.h"
70 #if wxUSE_MS_HTML_HELP && wxUSE_WXHTML_HELP
71 #include "wx/msw/helpbest.h"
74 // ----------------------------------------------------------------------------
76 // ----------------------------------------------------------------------------
77 // the application icon
78 #if defined(__WXGTK__) || defined(__WXMOTIF__) || defined(__WXMAC__) || defined(__WXMGL__)
79 #include "mondrian.xpm"
82 // ----------------------------------------------------------------------------
84 // ----------------------------------------------------------------------------
86 // Define a new application type, each program should derive a class from wxApp
87 class MyApp
: public wxApp
90 // override base class virtuals
91 // ----------------------------
93 // this one is called on application startup and is a good place for the app
94 // initialization (doing it here and not in the ctor allows to have an error
95 // return: if OnInit() returns false, the application terminates)
96 virtual bool OnInit();
98 // do some clean up here
102 // Define a new frame type: this is going to be our main frame
103 class MyFrame
: public wxFrame
107 MyFrame(const wxString
& title
, const wxPoint
& pos
, const wxSize
& size
);
109 wxHelpController
& GetHelpController() { return m_help
; }
112 #if USE_OLD_HTML_HELP
113 wxHelpControllerHtml
& GetHtmlHelpController() { return m_htmlHelp
; }
115 wxHtmlHelpController
& GetAdvancedHtmlHelpController() { return m_advancedHtmlHelp
; }
117 #if wxUSE_MS_HTML_HELP
118 wxCHMHelpController
& GetMSHtmlHelpController() { return m_msHtmlHelp
; }
120 #if wxUSE_MS_HTML_HELP && wxUSE_WXHTML_HELP
121 wxBestHelpController
& GetBestHelpController() { return m_bestHelp
; }
124 // event handlers (these functions should _not_ be virtual)
125 void OnQuit(wxCommandEvent
& event
);
126 void OnHelp(wxCommandEvent
& event
);
127 void OnHtmlHelp(wxCommandEvent
& event
);
128 void OnAdvancedHtmlHelp(wxCommandEvent
& event
);
129 void OnMSHtmlHelp(wxCommandEvent
& event
);
130 void OnBestHelp(wxCommandEvent
& event
);
132 void OnShowContextHelp(wxCommandEvent
& event
);
133 void OnShowDialogContextHelp(wxCommandEvent
& event
);
135 void ShowHelp(int commandId
, wxHelpControllerBase
& helpController
);
138 wxHelpController m_help
;
141 #if USE_OLD_HTML_HELP
142 wxHelpControllerHtml m_htmlHelp
;
144 wxHtmlHelpController m_advancedHtmlHelp
;
147 #if wxUSE_MS_HTML_HELP
148 wxCHMHelpController m_msHtmlHelp
;
151 #if wxUSE_MS_HTML_HELP && wxUSE_WXHTML_HELP
152 wxBestHelpController m_bestHelp
;
155 // any class wishing to process wxWindows events must use this macro
156 DECLARE_EVENT_TABLE()
159 // A custom modal dialog
160 class MyModalDialog
: public wxDialog
163 MyModalDialog(wxWindow
*parent
);
167 DECLARE_EVENT_TABLE()
170 // ----------------------------------------------------------------------------
172 // ----------------------------------------------------------------------------
174 // IDs for the controls and the menu commands
180 HelpDemo_Help_Classes
,
181 HelpDemo_Help_Functions
,
183 HelpDemo_Help_Search
,
184 HelpDemo_Help_ContextHelp
,
185 HelpDemo_Help_DialogContextHelp
,
187 HelpDemo_Html_Help_Index
,
188 HelpDemo_Html_Help_Classes
,
189 HelpDemo_Html_Help_Functions
,
190 HelpDemo_Html_Help_Help
,
191 HelpDemo_Html_Help_Search
,
193 HelpDemo_Advanced_Html_Help_Index
,
194 HelpDemo_Advanced_Html_Help_Classes
,
195 HelpDemo_Advanced_Html_Help_Functions
,
196 HelpDemo_Advanced_Html_Help_Help
,
197 HelpDemo_Advanced_Html_Help_Search
,
199 HelpDemo_MS_Html_Help_Index
,
200 HelpDemo_MS_Html_Help_Classes
,
201 HelpDemo_MS_Html_Help_Functions
,
202 HelpDemo_MS_Html_Help_Help
,
203 HelpDemo_MS_Html_Help_Search
,
205 HelpDemo_Best_Help_Index
,
206 HelpDemo_Best_Help_Classes
,
207 HelpDemo_Best_Help_Functions
,
208 HelpDemo_Best_Help_Help
,
209 HelpDemo_Best_Help_Search
,
213 HelpDemo_Help_Netscape
,
214 // controls start here (the numbers are, of course, arbitrary)
215 HelpDemo_Text
= 1000,
218 // ----------------------------------------------------------------------------
219 // event tables and other macros for wxWindows
220 // ----------------------------------------------------------------------------
222 // the event tables connect the wxWindows events with the functions (event
223 // handlers) which process them. It can be also done at run-time, but for the
224 // simple menu events like this the static method is much simpler.
225 BEGIN_EVENT_TABLE(MyFrame
, wxFrame
)
226 EVT_MENU(HelpDemo_Quit
, MyFrame::OnQuit
)
227 EVT_MENU(HelpDemo_Help_Index
, MyFrame::OnHelp
)
228 EVT_MENU(HelpDemo_Help_Classes
, MyFrame::OnHelp
)
229 EVT_MENU(HelpDemo_Help_Functions
, MyFrame::OnHelp
)
230 EVT_MENU(HelpDemo_Help_Help
, MyFrame::OnHelp
)
231 EVT_MENU(HelpDemo_Help_Search
, MyFrame::OnHelp
)
232 EVT_MENU(HelpDemo_Help_ContextHelp
, MyFrame::OnShowContextHelp
)
233 EVT_MENU(HelpDemo_Help_DialogContextHelp
, MyFrame::OnShowDialogContextHelp
)
235 EVT_MENU(HelpDemo_Html_Help_Index
, MyFrame::OnHtmlHelp
)
236 EVT_MENU(HelpDemo_Html_Help_Classes
, MyFrame::OnHtmlHelp
)
237 EVT_MENU(HelpDemo_Html_Help_Functions
, MyFrame::OnHtmlHelp
)
238 EVT_MENU(HelpDemo_Html_Help_Help
, MyFrame::OnHtmlHelp
)
239 EVT_MENU(HelpDemo_Html_Help_Search
, MyFrame::OnHtmlHelp
)
241 EVT_MENU(HelpDemo_Advanced_Html_Help_Index
, MyFrame::OnAdvancedHtmlHelp
)
242 EVT_MENU(HelpDemo_Advanced_Html_Help_Classes
, MyFrame::OnAdvancedHtmlHelp
)
243 EVT_MENU(HelpDemo_Advanced_Html_Help_Functions
, MyFrame::OnAdvancedHtmlHelp
)
244 EVT_MENU(HelpDemo_Advanced_Html_Help_Help
, MyFrame::OnAdvancedHtmlHelp
)
245 EVT_MENU(HelpDemo_Advanced_Html_Help_Search
, MyFrame::OnAdvancedHtmlHelp
)
247 EVT_MENU(HelpDemo_MS_Html_Help_Index
, MyFrame::OnMSHtmlHelp
)
248 EVT_MENU(HelpDemo_MS_Html_Help_Classes
, MyFrame::OnMSHtmlHelp
)
249 EVT_MENU(HelpDemo_MS_Html_Help_Functions
, MyFrame::OnMSHtmlHelp
)
250 EVT_MENU(HelpDemo_MS_Html_Help_Help
, MyFrame::OnMSHtmlHelp
)
251 EVT_MENU(HelpDemo_MS_Html_Help_Search
, MyFrame::OnMSHtmlHelp
)
253 EVT_MENU(HelpDemo_Best_Help_Index
, MyFrame::OnBestHelp
)
255 EVT_MENU(HelpDemo_Help_KDE
, MyFrame::OnHelp
)
256 EVT_MENU(HelpDemo_Help_GNOME
, MyFrame::OnHelp
)
257 EVT_MENU(HelpDemo_Help_Netscape
, MyFrame::OnHelp
)
260 // Create a new application object: this macro will allow wxWindows to create
261 // the application object during program execution (it's better than using a
262 // static object for many reasons) and also declares the accessor function
263 // wxGetApp() which will return the reference of the right type (i.e. MyApp and
267 // ============================================================================
269 // ============================================================================
271 // ----------------------------------------------------------------------------
272 // the application class
273 // ----------------------------------------------------------------------------
275 // `Main program' equivalent: the program execution "starts" here
278 // Create a simple help provider to make SetHelpText() do something.
279 // Note that this must be set before any SetHelpText() calls are made.
280 //wxHelpProvider::Set(new wxSimpleHelpProvider);
281 wxHelpControllerHelpProvider
* provider
= new wxHelpControllerHelpProvider
;
282 wxHelpProvider::Set(provider
);
286 // Required for images in the online documentation
287 wxImage::AddHandler(new wxGIFHandler
);
289 // Required for advanced HTML help
290 #if wxUSE_STREAMS && wxUSE_ZIPSTREAM && wxUSE_ZLIB
291 wxFileSystem::AddHandler(new wxZipFSHandler
);
297 // Create the main application window
298 MyFrame
*frame
= new MyFrame("HelpDemo wxWindows App",
299 wxPoint(50, 50), wxSize(450, 340));
301 #if wxUSE_MS_HTML_HELP
302 provider
->SetHelpController(& frame
->GetMSHtmlHelpController());
304 provider
->SetHelpController(& frame
->GetHelpController());
310 // initialise the help system: this means that we'll use doc.hlp file under
311 // Windows and that the HTML docs are in the subdirectory doc for platforms
313 if ( !frame
->GetHelpController().Initialize("doc") )
315 wxLogError(wxT("Cannot initialize the help system, aborting."));
320 #if wxUSE_MS_HTML_HELP
321 if( !frame
->GetMSHtmlHelpController().Initialize("doc") )
323 wxLogError(wxT("Cannot initialize the MS HTML Help system."));
327 #if wxUSE_MS_HTML_HELP && wxUSE_WXHTML_HELP
328 // you need to call Initialize in order to use wxBestHelpController
329 if( !frame
->GetBestHelpController().Initialize("doc") )
331 wxLogError(wxT("Cannot initialize the best help system, aborting."));
336 // initialise the standard HTML help system: this means that the HTML docs are in the
337 // subdirectory doc for platforms using HTML help
338 #if USE_OLD_HTML_HELP
339 if ( !frame
->GetHtmlHelpController().Initialize("doc") )
341 wxLogError(wxT("Cannot initialize the HTML help system, aborting."));
347 // initialise the advanced HTML help system: this means that the HTML docs are in .htb
349 if ( !frame
->GetAdvancedHtmlHelpController().Initialize("doc") )
351 wxLogError(wxT("Cannot initialize the advanced HTML help system, aborting."));
358 // defined(__WXMSW__) && wxUSE_MS_HTML_HELP
359 wxString
path(wxGetCwd());
360 if ( !frame
->GetMSHtmlHelpController().Initialize(path
+ "\\doc.chm") )
362 wxLogError("Cannot initialize the MS HTML help system, aborting.");
374 delete wxHelpProvider::Set(NULL
);
379 // ----------------------------------------------------------------------------
381 // ----------------------------------------------------------------------------
384 MyFrame::MyFrame(const wxString
& title
, const wxPoint
& pos
, const wxSize
& size
)
385 : wxFrame((wxFrame
*)NULL
, 300, title
, pos
, size
)
387 // set the frame icon
388 SetIcon(wxICON(mondrian
));
391 wxMenu
*menuFile
= new wxMenu
;
393 menuFile
->Append(HelpDemo_Help_Index
, "&Help Index...");
394 menuFile
->Append(HelpDemo_Help_Classes
, "&Help on Classes...");
395 menuFile
->Append(HelpDemo_Help_Functions
, "&Help on Functions...");
396 menuFile
->Append(HelpDemo_Help_ContextHelp
, "&Context Help...");
397 menuFile
->Append(HelpDemo_Help_DialogContextHelp
, "&Dialog Context Help...\tCtrl-H");
398 menuFile
->Append(HelpDemo_Help_Help
, "&About Help Demo...");
399 menuFile
->Append(HelpDemo_Help_Search
, "&Search help...");
401 #if USE_OLD_HTML_HELP
402 menuFile
->AppendSeparator();
403 menuFile
->Append(HelpDemo_Html_Help_Index
, "HTML &Help Index...");
404 menuFile
->Append(HelpDemo_Html_Help_Classes
, "HTML &Help on Classes...");
405 menuFile
->Append(HelpDemo_Html_Help_Functions
, "HTML &Help on Functions...");
406 menuFile
->Append(HelpDemo_Html_Help_Help
, "HTML &About Help Demo...");
407 menuFile
->Append(HelpDemo_Html_Help_Search
, "HTML &Search help...");
409 menuFile
->AppendSeparator();
410 menuFile
->Append(HelpDemo_Advanced_Html_Help_Index
, "Advanced HTML &Help Index...");
411 menuFile
->Append(HelpDemo_Advanced_Html_Help_Classes
, "Advanced HTML &Help on Classes...");
412 menuFile
->Append(HelpDemo_Advanced_Html_Help_Functions
, "Advanced HTML &Help on Functions...");
413 menuFile
->Append(HelpDemo_Advanced_Html_Help_Help
, "Advanced HTML &About Help Demo...");
414 menuFile
->Append(HelpDemo_Advanced_Html_Help_Search
, "Advanced HTML &Search help...");
417 #if wxUSE_MS_HTML_HELP
418 menuFile
->AppendSeparator();
419 menuFile
->Append(HelpDemo_MS_Html_Help_Index
, "MS HTML &Help Index...");
420 menuFile
->Append(HelpDemo_MS_Html_Help_Classes
, "MS HTML &Help on Classes...");
421 menuFile
->Append(HelpDemo_MS_Html_Help_Functions
, "MS HTML &Help on Functions...");
422 menuFile
->Append(HelpDemo_MS_Html_Help_Help
, "MS HTML &About Help Demo...");
423 menuFile
->Append(HelpDemo_MS_Html_Help_Search
, "MS HTML &Search help...");
426 #if wxUSE_MS_HTML_HELP && wxUSE_WXHTML_HELP
427 menuFile
->AppendSeparator();
428 menuFile
->Append(HelpDemo_Best_Help_Index
, "Best &Help Index...");
433 menuFile
->AppendSeparator();
434 menuFile
->Append(HelpDemo_Help_KDE
, "Use &KDE");
435 menuFile
->Append(HelpDemo_Help_GNOME
, "Use &GNOME");
436 menuFile
->Append(HelpDemo_Help_Netscape
, "Use &Netscape");
439 menuFile
->AppendSeparator();
440 menuFile
->Append(HelpDemo_Quit
, "E&xit");
442 // now append the freshly created menu to the menu bar...
443 wxMenuBar
*menuBar
= new wxMenuBar
;
444 menuBar
->Append(menuFile
, "&File");
446 // ... and attach this menu bar to the frame
449 // create a status bar just for fun (by default with 1 pane only)
451 SetStatusText("Welcome to wxWindows!");
453 // now create some controls
455 // a panel first - if there were several controls, it would allow us to
456 // navigate between them from the keyboard
457 wxPanel
*panel
= new wxPanel(this, 301, wxPoint(0, 0), wxSize(400, 200));
458 //panel->SetHelpText(_("This panel just holds a static text control."));
459 panel
->SetHelpText(wxContextId(300));
461 // and a static control whose parent is the panel
462 wxStaticText
* staticText
= new wxStaticText(panel
, 302, "Hello, world!", wxPoint(10, 10));
463 staticText
->SetHelpText(_("This static text control isn't doing a lot right now."));
469 void MyFrame::OnQuit(wxCommandEvent
& WXUNUSED(event
))
471 // TRUE is to force the frame to close
475 void MyFrame::OnHelp(wxCommandEvent
& event
)
477 ShowHelp(event
.GetId(), m_help
);
480 void MyFrame::OnShowContextHelp(wxCommandEvent
& event
)
482 // This starts context help mode, then the user
483 // clicks on a window to send a help message
484 wxContextHelp
contextHelp(this);
487 void MyFrame::OnShowDialogContextHelp(wxCommandEvent
& event
)
489 MyModalDialog
dialog(this);
493 void MyFrame::OnHtmlHelp(wxCommandEvent
& event
)
495 #if USE_HTML_HELP && USE_OLD_HTML_HELP
496 ShowHelp(event
.GetId(), m_htmlHelp
);
500 void MyFrame::OnAdvancedHtmlHelp(wxCommandEvent
& event
)
503 ShowHelp(event
.GetId(), m_advancedHtmlHelp
);
507 void MyFrame::OnMSHtmlHelp(wxCommandEvent
& event
)
509 #if wxUSE_MS_HTML_HELP
510 ShowHelp(event
.GetId(), m_msHtmlHelp
);
514 void MyFrame::OnBestHelp(wxCommandEvent
& event
)
516 #if wxUSE_MS_HTML_HELP && wxUSE_WXHTML_HELP
517 ShowHelp(event
.GetId(), m_bestHelp
);
522 Notes: ShowHelp uses section ids for displaying particular topics,
523 but you might want to use a unique keyword to display a topic, instead.
525 Section ids are specified as follows for the different formats.
529 The [MAP] section specifies the topic to integer id mapping, e.g.
537 The identifier name corresponds to the label used for that topic.
538 You could also put these in a .h file and #include it in both the MAP
539 section and your C++ source.
541 Note that Tex2RTF doesn't currently generate the MAP section automatically.
545 The [MAP] section specifies the HTML filename root to integer id mapping, e.g.
553 The identifier name corresponds to the HTML filename used for that topic.
554 You could also put these in a .h file and #include it in both the MAP
555 section and your C++ source.
557 Note that Tex2RTF doesn't currently generate the MAP section automatically.
559 Simple wxHTML Help and External HTML Help
561 A wxhelp.map file is used, for example:
563 0 wx.htm ; wxWindows: Help index; additional keywords like overview
564 1 wx204.htm ; wxWindows Function Reference
565 2 wx34.htm ; wxWindows Class Reference
567 Note that Tex2RTF doesn't currently generate the MAP section automatically.
571 An extension to the .hhc file format is used, specifying a new parameter
574 <OBJECT type="text/sitemap">
575 <param name="Local" value="doc2.htm#classes">
576 <param name="Name" value="Classes">
577 <param name="ID" value=2>
580 Again, this is not generated automatically by Tex2RTF, though it could
581 be added quite easily.
583 Unfortunately adding the ID parameters appears to interfere with MS HTML Help,
584 so you should not try to compile a .chm file from a .hhc file with
585 this extension, or the contents will be messed up.
588 void MyFrame::ShowHelp(int commandId
, wxHelpControllerBase
& helpController
)
592 case HelpDemo_Help_Classes
:
593 case HelpDemo_Html_Help_Classes
:
594 case HelpDemo_Advanced_Html_Help_Classes
:
595 case HelpDemo_MS_Html_Help_Classes
:
596 case HelpDemo_Best_Help_Classes
:
597 helpController
.DisplaySection(2);
598 //helpController.DisplaySection("Classes"); // An alternative form for most controllers
601 case HelpDemo_Help_Functions
:
602 case HelpDemo_Html_Help_Functions
:
603 case HelpDemo_Advanced_Html_Help_Functions
:
604 case HelpDemo_MS_Html_Help_Functions
:
605 helpController
.DisplaySection(1);
606 //helpController.DisplaySection("Functions"); // An alternative form for most controllers
608 case HelpDemo_Help_Help
:
609 case HelpDemo_Html_Help_Help
:
610 case HelpDemo_Advanced_Html_Help_Help
:
611 case HelpDemo_MS_Html_Help_Help
:
612 case HelpDemo_Best_Help_Help
:
613 helpController
.DisplaySection(3);
614 //helpController.DisplaySection("About"); // An alternative form for most controllers
617 case HelpDemo_Help_Search
:
618 case HelpDemo_Html_Help_Search
:
619 case HelpDemo_Advanced_Html_Help_Search
:
620 case HelpDemo_MS_Html_Help_Search
:
621 case HelpDemo_Best_Help_Search
:
623 wxString key
= wxGetTextFromUser("Search for?",
624 "Search help for keyword",
628 helpController
.KeywordSearch(key
);
632 case HelpDemo_Help_Index
:
633 case HelpDemo_Html_Help_Index
:
634 case HelpDemo_Advanced_Html_Help_Index
:
635 case HelpDemo_MS_Html_Help_Index
:
636 case HelpDemo_Best_Help_Index
:
637 helpController
.DisplayContents();
640 // These three calls are only used by wxExtHelpController
642 case HelpDemo_Help_KDE
:
643 helpController
.SetViewer("kdehelp");
645 case HelpDemo_Help_GNOME
:
646 helpController
.SetViewer("gnome-help-browser");
648 case HelpDemo_Help_Netscape
:
649 helpController
.SetViewer("netscape", wxHELP_NETSCAPE
);
656 // ----------------------------------------------------------------------------
658 // Demonstrates context-sensitive help
659 // ----------------------------------------------------------------------------
661 BEGIN_EVENT_TABLE(MyModalDialog
, wxDialog
)
664 MyModalDialog::MyModalDialog(wxWindow
*parent
)
667 // Add the context-sensitive help button on the caption for MSW
669 SetExtraStyle(wxDIALOG_EX_CONTEXTHELP
);
672 wxDialog::Create(parent
, -1, wxString("Modal dialog"));
674 wxBoxSizer
*sizerTop
= new wxBoxSizer(wxVERTICAL
);
675 wxBoxSizer
*sizerRow
= new wxBoxSizer(wxHORIZONTAL
);
677 wxButton
* btnOK
= new wxButton(this, wxID_OK
, "&OK");
678 btnOK
->SetHelpText(_("The OK button confirms the dialog choices."));
680 wxButton
* btnCancel
= new wxButton(this, wxID_CANCEL
, "&Cancel");
681 btnCancel
->SetHelpText(_("The Cancel button cancels the dialog."));
683 sizerRow
->Add(btnOK
, 0, wxALIGN_CENTER
| wxALL
, 5);
684 sizerRow
->Add(btnCancel
, 0, wxALIGN_CENTER
| wxALL
, 5);
686 // Add explicit context-sensitive help button for non-MSW
688 sizerRow
->Add(new wxContextHelpButton(this), 0, wxALIGN_CENTER
| wxALL
, 5);
691 wxTextCtrl
*text
= new wxTextCtrl(this, -1, wxT("A demo text control"),
692 wxDefaultPosition
, wxSize(300, 100),
694 text
->SetHelpText(_("Type text here if you have got nothing more interesting to do"));
695 sizerTop
->Add(text
, 0, wxEXPAND
|wxALIGN_CENTER_VERTICAL
|wxALL
, 5 );
696 sizerTop
->Add(sizerRow
, 0, wxALIGN_RIGHT
|wxALIGN_CENTER_VERTICAL
|wxALL
, 5 );
701 sizerTop
->SetSizeHints(this);