]> git.saurik.com Git - wxWidgets.git/blob - utils/dialoged/src/reseditr.h
wxArrayString documentation added
[wxWidgets.git] / utils / dialoged / src / reseditr.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: reseditr.h
3 // Purpose: Resource editor class
4 // Author: Julian Smart
5 // Modified by:
6 // Created: 04/01/98
7 // RCS-ID: $Id$
8 // Copyright: (c) Julian Smart
9 // Licence: wxWindows license
10 /////////////////////////////////////////////////////////////////////////////
11
12 #ifndef _RESEDITR_H_
13 #define _RESEDITR_H_
14
15 #define wxDIALOG_EDITOR_VERSION 1.6
16
17 #ifdef __GNUG__
18 #pragma interface "reseditr.h"
19 #endif
20
21 #include "wx/wx.h"
22 #include "wx/string.h"
23 #include "wx/layout.h"
24 #include "wx/resource.h"
25 #include "wx/toolbar.h"
26 #include "wx/imaglist.h"
27 #include "wx/treectrl.h"
28 #include "wx/proplist.h"
29 #include "symbtabl.h"
30 #include "winstyle.h"
31
32 #define RESED_DELETE 1
33 #define RESED_RECREATE 3
34 #define RESED_CLEAR 4
35 #define RESED_NEW_DIALOG 5
36 #define RESED_NEW_PANEL 6
37 #define RESED_TEST 10
38
39 #define RESED_CONTENTS 20
40
41 #define IDC_TREECTRL 100
42 #define IDC_LISTCTRL 101
43
44 // For control list ('palette')
45 #define RESED_POINTER 0
46 #define RESED_BUTTON 1
47 #define RESED_BMPBUTTON 2
48 #define RESED_STATICTEXT 3
49 #define RESED_STATICBMP 4
50 #define RESED_STATICBOX 5
51 #define RESED_TEXTCTRL_SINGLE 6
52 #define RESED_TEXTCTRL_MULTIPLE 7
53 #define RESED_LISTBOX 8
54 #define RESED_CHOICE 9
55 #define RESED_COMBOBOX 10
56 #define RESED_CHECKBOX 11
57 #define RESED_SLIDER 12
58 #define RESED_GAUGE 13
59 #define RESED_RADIOBOX 14
60 #define RESED_RADIOBUTTON 15
61 #define RESED_SCROLLBAR 16
62 #define RESED_TREECTRL 17
63 #define RESED_LISTCTRL 18
64 #define RESED_SPINBUTTON 19
65
66 /*
67 * Controls loading, saving, user interface of resource editor(s).
68 */
69
70 class wxResourceEditorFrame;
71 class EditorToolBar;
72 class wxWindowPropertyInfo;
73 class wxResourceEditorProjectTree;
74 class wxResourceEditorControlList;
75
76 #ifdef __WXMSW__
77 #define wxHelpController wxWinHelpController
78 #else
79 #define wxHelpController wxHTMLHelpController;
80 #endif
81
82 class wxHelpController;
83
84 /*
85 * The resourceTable contains a list of wxItemResources (which each may
86 * have further children, defining e.g. a dialog box with controls).
87 *
88 * We need to associate actual windows with each wxItemResource,
89 * instead of the current 'one current window' scheme.
90 *
91 * - We create a new dialog, create a wxItemResource,
92 * associate the dialog with wxItemResource via a hash table.
93 * Must be a hash table in case dialog is deleted without
94 * telling the resource manager.
95 * - When we save the resource after editing/closing the dialog,
96 * we check the wxItemResource/wxDialog and children for
97 * consistency (throw away items no longer in the wxDialog,
98 * create any new wxItemResources).
99 * - We save the wxItemResources via the wxPropertyInfo classes,
100 * so devolve the code to the appropriate class.
101 * This involves creating a new temporary wxPropertyInfo for
102 * the purpose.
103 *
104 * We currently assume we only create one instance of a window for
105 * each wxItemResource. We will need to relax this when we're editing
106 * in situ.
107 *
108 *
109 */
110
111 class wxResourceTableWithSaving: public wxResourceTable
112 {
113 public:
114 wxResourceTableWithSaving():wxResourceTable()
115 {
116 // Add all known window styles
117 m_styleTable.Init();
118 }
119 virtual bool Save(const wxString& filename);
120 virtual bool SaveResource(ostream& stream, wxItemResource* item, wxItemResource* parentItem);
121
122 void GeneratePanelStyleString(long windowStyle, char *buf);
123 void GenerateDialogStyleString(long windowStyle, char *buf);
124
125 /*
126 void GenerateRadioBoxStyleString(long windowStyle, char *buf);
127 void GenerateMessageStyleString(long windowStyle, char *buf);
128 void GenerateTextStyleString(long windowStyle, char *buf);
129 void GenerateButtonStyleString(long windowStyle, char *buf);
130 void GenerateCheckBoxStyleString(long windowStyle, char *buf);
131 void GenerateRadioButtonStyleString(long windowStyle, char *buf);
132 void GenerateListBoxStyleString(long windowStyle, char *buf);
133 void GenerateSliderStyleString(long windowStyle, char *buf);
134 void GenerateGroupBoxStyleString(long windowStyle, char *buf);
135 void GenerateGaugeStyleString(long windowStyle, char *buf);
136 void GenerateChoiceStyleString(long windowStyle, char *buf);
137 void GenerateComboBoxStyleString(long windowStyle, char *buf);
138 void GenerateScrollBarStyleString(long windowStyle, char *buf);
139 */
140
141 void GenerateControlStyleString(const wxString& windowClass, long windowStyle, char *buf);
142
143 /*
144 bool GenerateStyle(char *buf, long windowStyle, long flag, char *strStyle);
145 */
146
147 void OutputFont(ostream& stream, const wxFont& font);
148 wxControl *CreateItem(wxPanel *panel, const wxItemResource *childResource, const wxItemResource* parentResource);
149
150 protected:
151 wxWindowStyleTable m_styleTable;
152 };
153
154 class wxResourceEditorScrolledWindow;
155
156 class wxResourceManager: public wxObject
157 {
158 friend class wxResourceEditorFrame;
159
160 public:
161 wxResourceManager();
162 ~wxResourceManager();
163
164 // Operations
165
166 // Initializes the resource manager
167 bool Initialize();
168
169 // Load/save window size etc.
170 bool LoadOptions();
171 bool SaveOptions();
172
173 // Show or hide the resource editor frame, which displays a list
174 // of resources with ability to edit them.
175 virtual bool ShowResourceEditor(bool show, wxWindow *parent = NULL, const char *title = "wxWindows Dialog Editor");
176
177 virtual bool Save();
178 virtual bool SaveAs();
179 virtual bool Save(const wxString& filename);
180 virtual bool Load(const wxString& filename);
181 virtual bool Clear(bool deleteWindows = TRUE, bool force = TRUE);
182 virtual void SetFrameTitle(const wxString& filename);
183 virtual void ClearCurrentDialog();
184 virtual bool New(bool loadFromFile = TRUE, const wxString& filename = "");
185 virtual bool SaveIfModified();
186 virtual void AlignItems(int flag);
187 virtual void CopySize();
188 virtual void ToBackOrFront(bool toBack);
189 virtual wxWindow *FindParentOfSelection();
190
191 virtual wxFrame *OnCreateEditorFrame(const char *title);
192 virtual wxMenuBar *OnCreateEditorMenuBar(wxFrame *parent);
193 virtual wxResourceEditorScrolledWindow *OnCreateEditorPanel(wxFrame *parent);
194 virtual wxToolBar *OnCreateToolBar(wxFrame *parent);
195
196 // Create a window information object for the give window
197 wxWindowPropertyInfo* CreatePropertyInfoForWindow(wxWindow *win);
198 // Edit the given window
199 void EditWindow(wxWindow *win);
200
201 virtual void UpdateResourceList();
202 virtual void AddItemsRecursively(long parent, wxItemResource *resource);
203 virtual bool EditSelectedResource();
204 virtual bool Edit(wxItemResource *res);
205 virtual bool CreateNewPanel();
206 virtual bool CreatePanelItem(wxItemResource *panelResource, wxPanel *panel, char *itemType, int x = 10, int y = 10, bool isBitmap = FALSE);
207 virtual bool DeleteSelection();
208 virtual bool TestCurrentDialog(wxWindow* parent);
209
210 // Saves the window info into the resource, and deletes the
211 // handler. Doesn't actually disassociate the window from
212 // the resources. Replaces OnClose.
213 virtual bool SaveInfoAndDeleteHandler(wxWindow* win);
214
215 // Destroys the window. If this is the 'current' panel, NULLs the
216 // variable.
217 virtual bool DeleteWindow(wxWindow* win);
218 virtual bool DeleteResource(wxItemResource *res);
219 virtual bool DeleteResource(wxWindow *win);
220
221 // Add bitmap resource if there isn't already one with this filename.
222 virtual wxString AddBitmapResource(const wxString& filename);
223
224 // Delete the bitmap resource if it isn't being used by another resource.
225 virtual void PossiblyDeleteBitmapResource(const wxString& resourceName);
226
227 // Helper function for above
228 virtual bool IsBitmapResourceUsed(const wxString& resourceName);
229
230 wxItemResource *FindBitmapResourceByFilename(const wxString& filename);
231
232 wxString FindBitmapFilenameForResource(wxItemResource *resource);
233
234 // Is this window identifier in use?
235 bool IsSymbolUsed(wxItemResource* thisResource, wxWindowID id) ;
236
237 // Is this window identifier compatible with the given name? (i.e.
238 // does it already exist under a different name)
239 bool IsIdentifierOK(const wxString& name, wxWindowID id);
240
241 // Change all integer ids that match oldId, to newId.
242 // This is necessary if an id is changed for one resource - all resources
243 // must be changed.
244 void ChangeIds(int oldId, int newId);
245
246 // If any resource ids were missing (or their symbol was missing),
247 // repair them i.e. give them new ids. Returns TRUE if any resource
248 // needed repairing.
249 bool RepairResourceIds();
250
251 // Deletes 'win' and creates a new window from the resource that
252 // was associated with it. E.g. if you can't change properties on the
253 // fly, you'll need to delete the window and create it again.
254 virtual wxWindow *RecreateWindowFromResource(wxWindow *win, wxWindowPropertyInfo *info = NULL);
255
256 virtual bool RecreateSelection();
257
258 // Need to search through resource table removing this from
259 // any resource which has this as a parent.
260 virtual bool RemoveResourceFromParent(wxItemResource *res);
261
262 virtual bool EditDialog(wxDialog *dialog, wxWindow *parent);
263
264 void AddSelection(wxWindow *win);
265 void RemoveSelection(wxWindow *win);
266
267 virtual void MakeUniqueName(char *prefix, char *buf);
268
269 // (Dis)associate resource<->physical window
270 // Doesn't delete any windows.
271 virtual void AssociateResource(wxItemResource *resource, wxWindow *win);
272 virtual bool DisassociateResource(wxItemResource *resource);
273 virtual bool DisassociateResource(wxWindow *win);
274 virtual bool DisassociateWindows();
275 virtual wxItemResource *FindResourceForWindow(wxWindow *win);
276 virtual wxWindow *FindWindowForResource(wxItemResource *resource);
277
278 virtual bool InstantiateAllResourcesFromWindows();
279 virtual bool InstantiateResourceFromWindow(wxItemResource *resource, wxWindow *window, bool recurse = FALSE);
280
281 // Accessors
282 inline void SetEditorFrame(wxFrame *fr) { m_editorFrame = fr; }
283 inline void SetEditorToolBar(EditorToolBar *tb) { m_editorToolBar = tb; }
284 inline wxFrame *GetEditorFrame() const { return m_editorFrame; }
285 inline wxResourceEditorProjectTree *GetEditorResourceTree() const { return m_editorResourceTree; }
286 inline wxResourceEditorControlList *GetEditorControlList() const { return m_editorControlList; }
287 inline wxList& GetSelections() { return m_selections; }
288 inline wxMenu *GetPopupMenu() const { return m_popupMenu; }
289 #ifdef __WXMSW__
290 inline wxHelpController *GetHelpController() const { return m_helpController; }
291 #endif
292
293 inline void Modify(bool mod = TRUE) { m_modified = mod; }
294 inline bool Modified() const { return m_modified; }
295
296 inline wxResourceTable& GetResourceTable() { return m_resourceTable; }
297 inline wxHashTable& GetResourceAssociations() { return m_resourceAssociations; }
298
299 inline wxString GetCurrentFilename() const { return m_currentFilename; }
300 static wxResourceManager* GetCurrentResourceManager() { return sm_currentResourceManager; }
301
302 inline void SetSymbolFilename(const wxString& s) { m_symbolFilename = s; }
303 inline wxString GetSymbolFilename() const { return m_symbolFilename; }
304
305 inline wxRect& GetPropertyWindowSize() { return m_propertyWindowSize; }
306 inline wxRect& GetResourceEditorWindowSize() { return m_resourceEditorWindowSize; }
307
308 wxResourceSymbolTable& GetSymbolTable() { return m_symbolTable; }
309
310 // Generate a window id and a first stab at a name
311 int GenerateWindowId(const wxString& prefix, wxString& idName) ;
312
313 // Member variables
314 protected:
315 #ifdef __WXMSW__
316 wxHelpController* m_helpController;
317 #endif
318 wxResourceTableWithSaving m_resourceTable;
319 wxFrame* m_editorFrame;
320 wxResourceEditorScrolledWindow* m_editorPanel;
321 wxMenu* m_popupMenu;
322 wxResourceEditorProjectTree* m_editorResourceTree;
323 wxResourceEditorControlList* m_editorControlList;
324 EditorToolBar* m_editorToolBar;
325 int m_nameCounter;
326 int m_symbolIdCounter; // For generating window ids
327 bool m_modified;
328 wxHashTable m_resourceAssociations;
329 wxList m_selections;
330 wxString m_currentFilename;
331 wxBitmap* m_bitmapImage; // Default for static bitmaps/buttons
332
333 wxImageList m_imageList;
334 long m_rootDialogItem; // Root of dialog hierarchy in tree (unused)
335
336 // Options to be saved/restored
337 wxString m_optionsResourceFilename; // e.g. dialoged.ini, .dialogrc
338 wxRect m_propertyWindowSize;
339 wxRect m_resourceEditorWindowSize;
340 static wxResourceManager* sm_currentResourceManager;
341
342 // Symbol table with identifiers for controls
343 wxResourceSymbolTable m_symbolTable;
344 // Filename for include file, e.g. resource.h
345 wxString m_symbolFilename;
346 };
347
348
349 class wxResourceEditorFrame: public wxFrame
350 {
351 public:
352 DECLARE_CLASS(wxResourceEditorFrame)
353
354 wxResourceManager *manager;
355 wxResourceEditorFrame(wxResourceManager *resMan, wxFrame *parent, const wxString& title,
356 const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxSize(600, 400),
357 long style = wxDEFAULT_FRAME_STYLE, const wxString& name = "frame");
358 ~wxResourceEditorFrame();
359
360 void OnCloseWindow(wxCloseEvent& event);
361
362 void OnNew(wxCommandEvent& event);
363 void OnOpen(wxCommandEvent& event);
364 void OnNewDialog(wxCommandEvent& event);
365 void OnClear(wxCommandEvent& event);
366 void OnSave(wxCommandEvent& event);
367 void OnSaveAs(wxCommandEvent& event);
368 void OnExit(wxCommandEvent& event);
369 void OnAbout(wxCommandEvent& event);
370 void OnContents(wxCommandEvent& event);
371 void OnDeleteSelection(wxCommandEvent& event);
372 void OnRecreateSelection(wxCommandEvent& event);
373 void OnTest(wxCommandEvent& event);
374
375 DECLARE_EVENT_TABLE()
376 };
377
378 class wxResourceEditorScrolledWindow: public wxScrolledWindow
379 {
380 public:
381 wxResourceEditorScrolledWindow(wxWindow *parent, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize,
382 long style = 0);
383 ~wxResourceEditorScrolledWindow();
384
385 void OnScroll(wxScrollEvent& event);
386 void OnPaint(wxPaintEvent& event);
387
388 void DrawTitle(wxDC& dc);
389
390 // Accessors
391 inline int GetMarginX() { return m_marginX; }
392 inline int GetMarginY() { return m_marginY; }
393
394 public:
395 wxWindow* m_childWindow;
396 private:
397 int m_marginX, m_marginY;
398
399 DECLARE_EVENT_TABLE()
400 };
401
402 #define OBJECT_MENU_EDIT 1
403 #define OBJECT_MENU_DELETE 2
404
405 /*
406 * Main toolbar
407 *
408 */
409
410 class EditorToolBar: public wxToolBar
411 {
412 public:
413 EditorToolBar(wxFrame *frame, const wxPoint& pos = wxPoint(0, 0), const wxSize& size = wxSize(0, 0),
414 long style = wxTB_HORIZONTAL);
415 bool OnLeftClick(int toolIndex, bool toggled);
416 void OnMouseEnter(int toolIndex);
417
418 DECLARE_EVENT_TABLE()
419 };
420
421 // Toolbar ids
422 #define TOOLBAR_LOAD_FILE 1
423 #define TOOLBAR_SAVE_FILE 2
424 #define TOOLBAR_NEW 3
425 #define TOOLBAR_TREE 5
426 #define TOOLBAR_HELP 6
427
428 // Formatting tools
429 #define TOOLBAR_FORMAT_HORIZ 10
430 #define TOOLBAR_FORMAT_HORIZ_LEFT_ALIGN 11
431 #define TOOLBAR_FORMAT_HORIZ_RIGHT_ALIGN 12
432 #define TOOLBAR_FORMAT_VERT 13
433 #define TOOLBAR_FORMAT_VERT_TOP_ALIGN 14
434 #define TOOLBAR_FORMAT_VERT_BOT_ALIGN 15
435
436 #define TOOLBAR_TO_FRONT 16
437 #define TOOLBAR_TO_BACK 17
438 #define TOOLBAR_COPY_SIZE 18
439
440 /*
441 * this class is used to store data associated with a tree item
442 */
443 class wxResourceTreeData : public wxTreeItemData
444 {
445 public:
446 wxResourceTreeData(wxItemResource *resource) { m_resource = resource; }
447
448 wxItemResource *GetResource() const { return m_resource; }
449
450 private:
451 wxItemResource *m_resource;
452 };
453
454 #endif
455