By Robert O'Connor
This is a patch to wxTip Provider classes used by the "Tip of the day" dialog.
See wx-dev archives August 2002 for discussion of the functionality design.
It does 5 things:
-Support for comments inside the tips file. The pound character (#) is used, as recommended by Vadim.
-Allows optional easy translation support to tips, by marking them as translatable for gettext, by enclosing them in a _(""). Program will translate these tips at runtime from the active catalog.
-Blank lines or lines with just spaces are automatically skipped (I had to put this in, I keep wondering why I get blank tips sometimes and it is because the text file had a empty blank line at the end of the text file).
-There is a pluggable virtual function to preprocess to modify the tip in a derived class, in case something specialized is desired, such as variable expansion, etc, as recommended by Julian and Vadim.
-Now resets the tip counter if the previous tip is past the end of the file (ie you removed some tips, or changed tip files), as discussed on wx-dev.
This patch updates:
-The classes.
-The class documentation and the Tip-of-the-day topic overview documentation.
-The dialogs example, placing some new strings for the tips.txt file which demonstrate how to use the Tip-of-the-day features for in practice.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@16887 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
	
		
			
				
	
	
		
			89 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| ///////////////////////////////////////////////////////////////////////////////
 | |
| // Name:        tipdlg.h
 | |
| // Purpose:     declaration of wxTipDialog
 | |
| // Author:      Vadim Zeitlin
 | |
| // Modified by:
 | |
| // Created:     28.06.99
 | |
| // RCS-ID:      $Id$
 | |
| // Copyright:   (c) Vadim Zeitlin
 | |
| // Licence:     wxWindows licence
 | |
| ///////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #ifndef _WX_TIPDLG_H_
 | |
| #define _WX_TIPDLG_H_
 | |
| 
 | |
| #if defined(__GNUG__) && !defined(__APPLE__)
 | |
|     #pragma interface "tipdlg.h"
 | |
| #endif
 | |
| 
 | |
| // ----------------------------------------------------------------------------
 | |
| // headers which we must include here
 | |
| // ----------------------------------------------------------------------------
 | |
| 
 | |
| #include "wx/defs.h"
 | |
| 
 | |
| #if wxUSE_STARTUP_TIPS
 | |
| 
 | |
| #include "wx/textfile.h"
 | |
| 
 | |
| // ----------------------------------------------------------------------------
 | |
| // wxTipProvider - a class which is used by wxTipDialog to get the text of the
 | |
| // tips
 | |
| // ----------------------------------------------------------------------------
 | |
| 
 | |
| // the abstract base class: it provides the tips, i.e. implements the GetTip()
 | |
| // function which returns the new tip each time it's called. To support this,
 | |
| // wxTipProvider evidently needs some internal state which is the tip "index"
 | |
| // and which should be saved/restored by the program to not always show one and
 | |
| // the same tip (of course, you may use random starting position as well...)
 | |
| class WXDLLEXPORT wxTipProvider
 | |
| {
 | |
| public:
 | |
|     wxTipProvider(size_t currentTip) { m_currentTip = currentTip; }
 | |
| 
 | |
|     // get the current tip and update the internal state to return the next tip
 | |
|     // when called for the next time
 | |
|     virtual wxString GetTip() = 0;  
 | |
| 
 | |
|     // get the current tip "index" (or whatever allows the tip provider to know
 | |
|     // from where to start the next time)
 | |
|     size_t GetCurrentTip() const { return m_currentTip; }
 | |
| 
 | |
|     // Allows any user-derived class to optionally override this function to 
 | |
|     // modify the tip as soon as it is read. If return wxEmptyString, then 
 | |
|     // the tip is skipped, and the next one is read.
 | |
|     virtual wxString PreprocessTip(const wxString& tip) { return tip; }
 | |
| 
 | |
|     // virtual dtor for the base class
 | |
|     virtual ~wxTipProvider() { }
 | |
| 
 | |
| protected:
 | |
|     size_t m_currentTip;
 | |
| };
 | |
| 
 | |
| // a function which returns an implementation of wxTipProvider using the
 | |
| // specified text file as the source of tips (each line is a tip).
 | |
| //
 | |
| // NB: the caller is responsible for deleting the pointer!
 | |
| WXDLLEXPORT wxTipProvider *wxCreateFileTipProvider(const wxString& filename,
 | |
|                                                    size_t currentTip);
 | |
| 
 | |
| // ----------------------------------------------------------------------------
 | |
| // wxTipDialog
 | |
| // ----------------------------------------------------------------------------
 | |
| 
 | |
| // A dialog which shows a "tip" - a short and helpful messages describing to
 | |
| // the user some program characteristic. Many programs show the tips at
 | |
| // startup, so the dialog has "Show tips on startup" checkbox which allows to
 | |
| // the user to disable this (however, it's the program which should show, or
 | |
| // not, the dialog on startup depending on its value, not this class).
 | |
| //
 | |
| // The function returns TRUE if this checkbox is checked, FALSE otherwise.
 | |
| WXDLLEXPORT bool wxShowTip(wxWindow *parent,
 | |
|                            wxTipProvider *tipProvider,
 | |
|                            bool showAtStartup = TRUE);
 | |
| 
 | |
| #endif // wxUSE_STARTUP_TIPS
 | |
| 
 | |
| #endif // _WX_TIPDLG_H_
 |