Added some docstrings.

Added wx.DefaultDateTime.
Fixed CalendarCtrl.HitTest


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@25798 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Robin Dunn 2004-02-14 03:11:36 +00:00
parent 78ca56690e
commit 856bf319b5
6 changed files with 34791 additions and 33731 deletions

File diff suppressed because it is too large Load Diff

View File

@ -48,6 +48,8 @@ public:
"self._setCallbackInfo(self, PyApp)
self._setOORInfo(self)";
DocStr(wxPyApp,
"Create a new application object, starting the bootstrap process.");
%extend {
wxPyApp() {
wxPythonApp = new wxPyApp();
@ -188,7 +190,7 @@ public:
"Get the current exit behaviour setting.");
#if 0
// Get display mode that is used use. This is only used in framebuffer
// Get display mode that is in use. This is only used in framebuffer
// wxWin ports (such as wxMGL).
virtual wxVideoMode GetDisplayMode() const;

View File

@ -80,13 +80,13 @@ public:
void SetDefault();
#ifdef __WXMSW__
// show the image in the button in addition to the label
void SetImageLabel(const wxBitmap& bitmap);
// #ifdef __WXMSW__
// // show the image in the button in addition to the label
// void SetImageLabel(const wxBitmap& bitmap);
// set the margins around the image
void SetImageMargins(wxCoord x, wxCoord y);
#endif
// // set the margins around the image
// void SetImageMargins(wxCoord x, wxCoord y);
// #endif
DocStr(GetDefaultButtonSize, "Returns the default button size for this platform.");
static wxSize GetDefaultSize();
@ -97,7 +97,30 @@ public:
//---------------------------------------------------------------------------
DocStr(wxBitmapButton, "A Buttont that contains a bitmap.");
DocStr(wxBitmapButton,
"A Button that contains a bitmap. A bitmap button can be supplied with a
single bitmap, and wxWindows will draw all button states using this bitmap. If
the application needs more control, additional bitmaps for the selected state,
unpressed focused state, and greyed-out state may be supplied.
");
RefDoc(wxButton, "
Styles
wx.BU_AUTODRAW: If this is specified, the button will be drawn
automatically using the label bitmap only, providing a
3D-look border. If this style is not specified, the button
will be drawn without borders and using all provided
bitmaps. WIN32 only.
wx.BU_LEFT: Left-justifies the label. WIN32 only.
wx.BU_TOP: Aligns the label to the top of the button. WIN32 only.
wx.BU_RIGHT: Right-justifies the bitmap label. WIN32 only.
wx.BU_BOTTOM: Aligns the label to the bottom of the button. WIN32 only.
wx.BU_EXACTFIT: Creates the button as small as possible instead of making
it of the standard size (which is the default behaviour.)
Events
EVT_BUTTON: Sent when the button is clicked.
");
class wxBitmapButton : public wxButton
{
@ -105,7 +128,7 @@ public:
%pythonAppend wxBitmapButton "self._setOORInfo(self)"
%pythonAppend wxBitmapButton() ""
DocStr(wxBitmapButton, "Create and show a button.")
DocStr(wxBitmapButton, "Create and show a button with a bitmap for the label.")
wxBitmapButton(wxWindow* parent, wxWindowID id, const wxBitmap& bitmap,
const wxPoint& pos = wxDefaultPosition,
const wxSize& size = wxDefaultSize,

View File

@ -580,7 +580,10 @@ public:
// is the date valid (True even for non initialized objects)?
inline bool IsValid() const;
%pythoncode { Ok = IsValid }
%pythoncode { def __nonzero__(self): return self.Ok() };
// get the number of seconds since the Unix epoch - returns (time_t)-1
// if the value is out of range
inline time_t GetTicks() const;
@ -1092,5 +1095,9 @@ long wxGetUTCTime();
long wxGetCurrentTime();
wxLongLong wxGetLocalTimeMillis();
%immutable;
const wxDateTime wxDefaultDateTime;
%mutable;
//---------------------------------------------------------------------------
//---------------------------------------------------------------------------

View File

@ -288,6 +288,7 @@
%rename(GetUTCTime) wxGetUTCTime;
%rename(GetCurrentTime) wxGetCurrentTime;
%rename(GetLocalTimeMillis) wxGetLocalTimeMillis;
%rename(DefaultDateTime) wxDefaultDateTime;
%rename(DF_INVALID) wxDF_INVALID;
%rename(DF_TEXT) wxDF_TEXT;
%rename(DF_BITMAP) wxDF_BITMAP;

View File

@ -60,21 +60,22 @@ enum wxCalendarDateBorder
//---------------------------------------------------------------------------
DocStr(wxCalendarDateAttr,
"A set of customization attributes for a calendar date, which can be used to
control the look of the Calendar object.");
class wxCalendarDateAttr
{
public:
// ctors
wxCalendarDateAttr(const wxColour& colText,
DocStr(wxCalendarDateAttr,
"Create a CalendarDateAttr.");
wxCalendarDateAttr(const wxColour& colText = wxNullColour,
const wxColour& colBack = wxNullColour,
const wxColour& colBorder = wxNullColour,
const wxFont& font = wxNullFont,
wxCalendarDateBorder border = wxCAL_BORDER_NONE);
%name(CalendarDateAttrBorder)
wxCalendarDateAttr(wxCalendarDateBorder border,
const wxColour& colBorder = wxNullColour);
// setters
void SetTextColour(const wxColour& colText);
void SetBackgroundColour(const wxColour& colBack);
@ -139,13 +140,66 @@ EVT_CALENDAR_WEEKDAY_CLICKED = wx.PyEventBinder( wxEVT_CALENDAR_WEEKDAY_CLICKED,
MAKE_CONST_WXSTRING(CalendarNameStr);
DocStr(wxCalendarCtrl,
"The calendar control allows the user to pick a date interactively.");
RefDoc(wxCalendarCtrl,
"The CalendarCtrl displays a window containing several parts: the control to
pick the month and the year at the top (either or both of them may be
disabled) and a month area below them which shows all the days in the
month. The user can move the current selection using the keyboard and select
the date (generating EVT_CALENDAR event) by pressing <Return> or double
clicking it.
It has advanced possibilities for the customization of its display. All global
settings (such as colours and fonts used) can, of course, be changed. But
also, the display style for each day in the month can be set independently
using CalendarDateAttr class.
An item without custom attributes is drawn with the default colours and font
and without border, but setting custom attributes with SetAttr allows to
modify its appearance. Just create a custom attribute object and set it for
the day you want to be displayed specially A day may be marked as being a
holiday, (even if it is not recognized as one by wx.DateTime) by using the
SetHoliday method.
As the attributes are specified for each day, they may change when the month
is changed, so you will often want to update them in an EVT_CALENDAR_MONTH
event handler.
Styles
CAL_SUNDAY_FIRST: Show Sunday as the first day in the week
CAL_MONDAY_FIRST: Show Monday as the first day in the week
CAL_SHOW_HOLIDAYS: Highlight holidays in the calendar
CAL_NO_YEAR_CHANGE: Disable the year changing
CAL_NO_MONTH_CHANGE: Disable the month (and, implicitly, the year) changing
CAL_SHOW_SURROUNDING_WEEKS: Show the neighbouring weeks in the previous and next months
CAL_SEQUENTIAL_MONTH_SELECTION: Use alternative, more compact, style for the month and year selection controls.
The default calendar style is wxCAL_SHOW_HOLIDAYS.
Events
EVT_CALENDAR: A day was double clicked in the calendar.
EVT_CALENDAR_SEL_CHANGED: The selected date changed.
EVT_CALENDAR_DAY: The selected day changed.
EVT_CALENDAR_MONTH: The selected month changed.
EVT_CALENDAR_YEAR: The selected year changed.
EVT_CALENDAR_WEEKDAY_CLICKED: User clicked on the week day header
Note that changing the selected date will result in either of
EVT_CALENDAR_DAY, MONTH or YEAR events and an EVT_CALENDAR_SEL_CHANGED event.
");
class wxCalendarCtrl : public wxControl
{
public:
%pythonAppend wxCalendarCtrl "self._setOORInfo(self)"
%pythonAppend wxCalendarCtrl() ""
DocStr(wxCalendarCtrl, "Create and show a calendar control.");
wxCalendarCtrl(wxWindow *parent,
wxWindowID id,
const wxDateTime& date = wxDefaultDateTime,
@ -153,8 +207,12 @@ public:
const wxSize& size = wxDefaultSize,
long style = wxCAL_SHOW_HOLIDAYS | wxWANTS_CHARS,
const wxString& name = wxPyCalendarNameStr);
DocStr(wxCalendarCtrl(), "Precreate a CalendarCtrl for 2-phase creation.");
%name(PreCalendarCtrl)wxCalendarCtrl();
DocStr(Create, "Acutally create the GUI portion of the CalendarCtrl for 2-phase creation.");
bool Create(wxWindow *parent,
wxWindowID id,
const wxDateTime& date = wxDefaultDateTime,
@ -164,86 +222,153 @@ public:
const wxString& name = wxPyCalendarNameStr);
// set/get the current date
// ------------------------
DocDeclStr(
void, SetDate(const wxDateTime& date),
"Sets the current date.");
void SetDate(const wxDateTime& date);
const wxDateTime& GetDate() const;
// set/get the range in which selection can occur
// ---------------------------------------------
bool SetLowerDateLimit(const wxDateTime& date = wxDefaultDateTime);
const wxDateTime& GetLowerDateLimit() const;
bool SetUpperDateLimit(const wxDateTime& date = wxDefaultDateTime);
const wxDateTime& GetUpperDateLimit() const;
bool SetDateRange(const wxDateTime& lowerdate = wxDefaultDateTime,
const wxDateTime& upperdate = wxDefaultDateTime);
DocDeclStr(
const wxDateTime&, GetDate() const,
"Gets the currently selected date.");
// calendar mode
// -------------
DocDeclStr(
bool, SetLowerDateLimit(const wxDateTime& date = wxDefaultDateTime),
"set the range in which selection can occur");
DocDeclStr(
bool, SetUpperDateLimit(const wxDateTime& date = wxDefaultDateTime),
"set the range in which selection can occur");
DocDeclStr(
const wxDateTime&, GetLowerDateLimit() const,
"get the range in which selection can occur");
DocDeclStr(
const wxDateTime&, GetUpperDateLimit() const,
"get the range in which selection can occur");
// some calendar styles can't be changed after the control creation by
// just using SetWindowStyle() and Refresh() and the functions below
// should be used instead for them
// corresponds to wxCAL_NO_YEAR_CHANGE bit
void EnableYearChange(bool enable = True);
// corresponds to wxCAL_NO_MONTH_CHANGE bit
void EnableMonthChange(bool enable = True);
// corresponds to wxCAL_SHOW_HOLIDAYS bit
void EnableHolidayDisplay(bool display = True);
// customization
// -------------
// header colours are used for painting the weekdays at the top
void SetHeaderColours(const wxColour& colFg, const wxColour& colBg);
wxColour GetHeaderColourFg() const;
wxColour GetHeaderColourBg() const;
// highlight colour is used for the currently selected date
void SetHighlightColours(const wxColour& colFg, const wxColour& colBg);
wxColour GetHighlightColourFg() const;
wxColour GetHighlightColourBg() const;
// holiday colour is used for the holidays (if style & wxCAL_SHOW_HOLIDAYS)
void SetHolidayColours(const wxColour& colFg, const wxColour& colBg);
wxColour GetHolidayColourFg() const;
wxColour GetHolidayColourBg() const;
// an item without custom attributes is drawn with the default colours and
// font and without border, setting custom attributes allows to modify this
//
// the day parameter should be in 1..31 range, for days 29, 30, 31 the
// corresponding attribute is just unused if there is no such day in the
// current month
wxCalendarDateAttr *GetAttr(size_t day) const;
void SetAttr(size_t day, wxCalendarDateAttr *attr);
void SetHoliday(size_t day);
void ResetAttr(size_t day);
// returns one of wxCAL_HITTEST_XXX constants and fills either date or wd
// with the corresponding value (none for NOWHERE, the date for DAY and wd
// for HEADER)
wxCalendarHitTestResult HitTest(const wxPoint& pos,
wxDateTime *date = NULL,
wxDateTime::WeekDay *wd = NULL);
DocDeclStr(
bool, SetDateRange(const wxDateTime& lowerdate = wxDefaultDateTime,
const wxDateTime& upperdate = wxDefaultDateTime),
"set the range in which selection can occur");
bool Enable(bool enable = True);
bool Show(bool show = True);
// get the currently shown control for month/year
wxControl *GetMonthControl() const;
wxControl *GetYearControl() const;
DocDeclStr(
void, EnableYearChange(bool enable = True),
"This function should be used instead of changing CAL_NO_YEAR_CHANGE\n"
"style bit directly. It allows or disallows the user to change the year\n"
"interactively.");
DocDeclStr(
void, EnableMonthChange(bool enable = True),
"This function should be used instead of changing CAL_NO_MONTH_CHANGE style\n"
"bit. It allows or disallows the user to change the month interactively. Note\n"
"that if the month can not be changed, the year can not be changed either.");
DocDeclStr(
void, EnableHolidayDisplay(bool display = True),
"This function should be used instead of changing CAL_SHOW_HOLIDAYS style\n"
"bit directly. It enables or disables the special highlighting of the holidays.");
DocDeclStr(
void, SetHeaderColours(const wxColour& colFg, const wxColour& colBg),
"header colours are used for painting the weekdays at the top");
DocDeclStr(
wxColour, GetHeaderColourFg() const,
"header colours are used for painting the weekdays at the top");
DocDeclStr(
wxColour, GetHeaderColourBg() const,
"header colours are used for painting the weekdays at the top");
DocDeclStr(
void, SetHighlightColours(const wxColour& colFg, const wxColour& colBg),
"highlight colour is used for the currently selected date");
DocDeclStr(
wxColour, GetHighlightColourFg() const,
"highlight colour is used for the currently selected date");
DocDeclStr(
wxColour, GetHighlightColourBg() const,
"highlight colour is used for the currently selected date");
DocDeclStr(
void, SetHolidayColours(const wxColour& colFg, const wxColour& colBg),
"holiday colour is used for the holidays (if CAL_SHOW_HOLIDAYS style is used)");
DocDeclStr(
wxColour, GetHolidayColourFg() const,
"holiday colour is used for the holidays (if CAL_SHOW_HOLIDAYS style is used)");
DocDeclStr(
wxColour, GetHolidayColourBg() const,
"holiday colour is used for the holidays (if CAL_SHOW_HOLIDAYS style is used)");
DocDeclStr(
wxCalendarDateAttr*, GetAttr(size_t day) const,
"Returns the attribute for the given date (should be in the range 1...31).\n"
"The returned value may be None");
DocDeclStr(
void, SetAttr(size_t day, wxCalendarDateAttr *attr),
"Associates the attribute with the specified date (in the range 1...31).\n"
"If the attribute passed is None, the items attribute is cleared.");
DocDeclStr(
void, SetHoliday(size_t day),
"Marks the specified day as being a holiday in the current month.");
DocDeclStr(
void, ResetAttr(size_t day),
"Clears any attributes associated with the given day (in the range 1...31).");
DocAStr(HitTest,
"HitTest(Point pos) -> (result, date, weekday)",
"Returns 3-tuple with information about the given position on the calendar
control. The first value of the tuple is a result code and determines the
validity of the remaining two values. The result codes are:
CAL_HITTEST_NOWHERE: hit outside of anything
CAL_HITTEST_HEADER: hit on the header, weekday is valid
CAL_HITTEST_DAY: hit on a day in the calendar, date is set.
");
%extend {
PyObject* HitTest(const wxPoint& pos) {
wxDateTime* date = new wxDateTime;
wxDateTime::WeekDay wd;
wxCalendarHitTestResult result = self->HitTest(pos, date, &wd);
wxPyBeginBlockThreads();
PyObject* tup = PyTuple_New(3);
PyTuple_SET_ITEM(tup, 0, PyInt_FromLong(result));
PyTuple_SET_ITEM(tup, 1, wxPyConstructObject(date, wxT("wxDateTime"), 1));
PyTuple_SET_ITEM(tup, 2, PyInt_FromLong(wd));
wxPyEndBlockThreads();
return tup;
}
}
DocDeclStr(
wxControl*, GetMonthControl() const,
"get the currently shown control for month");
DocDeclStr(
wxControl*, GetYearControl() const,
"get the currently shown control for year");
};