1 /*-*- c++ -*-********************************************************
2 * wxLwindow.h : a scrolled Window for displaying/entering rich text*
4 * (C) 1998,1999 by Karsten Ballüder (Ballueder@usa.net) *
7 *******************************************************************/
12 # pragma interface "wxlwindow.h"
21 #ifndef WXLOWIN_MENU_FIRST
22 # define WXLOWIN_MENU_FIRST 12000
27 WXLOWIN_MENU_LARGER
= WXLOWIN_MENU_FIRST
,
29 WXLOWIN_MENU_UNDERLINE_ON
,
30 WXLOWIN_MENU_UNDERLINE_OFF
,
32 WXLOWIN_MENU_BOLD_OFF
,
33 WXLOWIN_MENU_ITALICS_ON
,
34 WXLOWIN_MENU_ITALICS_OFF
,
36 WXLOWIN_MENU_TYPEWRITER
,
37 WXLOWIN_MENU_SANSSERIF
,
40 WXLOWIN_MENU_DBLCLICK
,
41 WXLOWIN_MENU_LAST
= WXLOWIN_MENU_DBLCLICK
45 This class is a rich text editing widget.
47 class wxLayoutWindow
: public wxScrolledWindow
51 @param parent parent window to display this panel in
53 wxLayoutWindow(wxWindow
*parent
);
56 virtual ~wxLayoutWindow();
58 /**@name Editing functionality */
60 /// Clears the window and sets default parameters.
61 void Clear(int family
= wxROMAN
,
66 char const *fg
="black",
67 char const *bg
="white")
69 GetLayoutList()->Clear(family
,size
,style
,weight
,underline
,fg
,bg
);
70 SetBackgroundColour(*GetLayoutList()->GetDefaults()->GetBGColour());
75 /// Enable or disable editing, i.e. processing of keystrokes.
76 void SetEditable(bool toggle
) { m_Editable
= toggle
; }
77 /// Query whether list can be edited by user.
78 bool IsEditable(void) const { return m_Editable
; }
82 void EnablePopup(bool enable
= true) { m_DoPopupMenu
= enable
; }
84 /** Redraws the window.
85 @param scrollToCursor if true, scroll the window so that the
86 cursor becomes visible
88 void DoPaint(bool scrollToCursor
= false);
91 virtual long MSWGetDlgCode();
94 /// if exact == false, assume 50% extra size for the future
95 void ResizeScrollbars(bool exact
= false); // don't change this to true!
97 /// if the flag is true, we send events when user clicks on embedded objects
98 inline void SetMouseTracking(bool doIt
= true) { m_doSendEvents
= doIt
; }
100 /* Returns a pointer to the wxLayoutList object.
103 wxLayoutList
* GetLayoutList(void) { return m_llist
; }
105 /**@name Callbacks */
107 void OnPaint(wxPaintEvent
&event
);
108 void OnChar(wxKeyEvent
& event
);
109 void OnMenu(wxCommandEvent
& event
);
110 void OnLeftMouseClick(wxMouseEvent
& event
) { OnMouse(WXLOWIN_MENU_LCLICK
, event
); }
111 void OnRightMouseClick(wxMouseEvent
& event
) { OnMouse(WXLOWIN_MENU_RCLICK
, event
); }
112 void OnMouseDblClick(wxMouseEvent
& event
) { OnMouse(WXLOWIN_MENU_DBLCLICK
, event
); }
113 void OnSetFocus(wxFocusEvent
&ev
);
114 void OnKillFocus(wxFocusEvent
&ev
);
117 /// Creates a wxMenu for use as a format popup.
118 static wxMenu
* MakeFormatMenu(void);
120 void SetDirty(void) { m_Dirty
= true; }
122 /**@name Dirty flag handling for optimisations. */
124 /// Query whether window needs redrawing.
125 bool IsDirty(void) const { return m_Dirty
; }
126 /// Reset dirty flag.
127 void ResetDirty(void) { m_Dirty
= false; }
130 /// generic function for mouse events processing
131 void OnMouse(int eventId
, wxMouseEvent
& event
);
133 /// for sending events
135 /// Shall we send events?
137 /// Where does the current view start?
138 int m_ViewStartX
; int m_ViewStartY
;
139 /// Do we currently have the focus?
141 /// do we handle clicks of the right mouse button?
144 wxMenu
* m_PopupMenu
;
145 /// for derived classes, set when mouse is clicked
146 wxPoint m_ClickPosition
;
147 /// for scrollbar calculations:
152 /// The layout list to be displayed.
153 wxLayoutList
*m_llist
;
155 /// Can user edit the window?
161 wxPoint m_bitmapSize
;
163 DECLARE_EVENT_TABLE()