]> git.saurik.com Git - wxWidgets.git/blame_incremental - interface/fs_mem.h
removed a TODO comments, it actually doesn't seem necessary to optimize the use of...
[wxWidgets.git] / interface / fs_mem.h
... / ...
CommitLineData
1/////////////////////////////////////////////////////////////////////////////
2// Name: fs_mem.h
3// Purpose: interface of wxMemoryFSHandler
4// Author: wxWidgets team
5// RCS-ID: $Id$
6// Licence: wxWindows license
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxMemoryFSHandler
11 @wxheader{fs_mem.h}
12
13 This wxFileSystem handler can store arbitrary
14 data in memory stream and make them accessible via URL. It is particularly
15 suitable for storing bitmaps from resources or included XPM files so that
16 they can be used with wxHTML.
17
18 Filenames are prefixed with "memory:", e.g. "memory:myfile.html".
19
20 Example:
21
22 @code
23 #ifndef __WXMSW__
24 #include "logo.xpm"
25 #endif
26
27 void MyFrame::OnAbout(wxCommandEvent&)
28 {
29 wxBusyCursor bcur;
30 wxFileSystem::AddHandler(new wxMemoryFSHandler);
31 wxMemoryFSHandler::AddFile("logo.pcx", wxBITMAP(logo), wxBITMAP_TYPE_PCX);
32 wxMemoryFSHandler::AddFile("about.htm",
33 "htmlbodyAbout: "
34 "img src=\"memory:logo.pcx\"/body/html");
35
36 wxDialog dlg(this, -1, wxString(_("About")));
37 wxBoxSizer *topsizer;
38 wxHtmlWindow *html;
39 topsizer = new wxBoxSizer(wxVERTICAL);
40 html = new wxHtmlWindow(, -1, wxDefaultPosition,
41 wxSize(380, 160), wxHW_SCROLLBAR_NEVER);
42 html-SetBorders(0);
43 html-LoadPage("memory:about.htm");
44 html-SetSize(html-GetInternalRepresentation()-GetWidth(),
45 html-GetInternalRepresentation()-GetHeight());
46 topsizer-Add(html, 1, wxALL, 10);
47 topsizer-Add(new wxStaticLine(, -1), 0, wxEXPAND | wxLEFT | wxRIGHT, 10);
48 topsizer-Add(new wxButton(, wxID_OK, "Ok"),
49 0, wxALL | wxALIGN_RIGHT, 15);
50 dlg.SetAutoLayout(@true);
51 dlg.SetSizer(topsizer);
52 topsizer-Fit();
53 dlg.Centre();
54 dlg.ShowModal();
55
56 wxMemoryFSHandler::RemoveFile("logo.pcx");
57 wxMemoryFSHandler::RemoveFile("about.htm");
58 }
59 @endcode
60
61 @library{wxbase}
62 @category{FIXME}
63
64 @see wxMemoryFSHandler::AddFileWithMimeType
65*/
66class wxMemoryFSHandler : public wxFileSystemHandler
67{
68public:
69 /**
70 Constructor.
71 */
72 wxMemoryFSHandler();
73
74 //@{
75 /**
76 Add file to list of files stored in memory. Stored
77 data (bitmap, text or raw data)
78 will be copied into private memory stream and available under
79 name "memory:" + @e filename.
80 The @a type argument is one of @c wxBITMAP_TYPE_XXX constants.
81 Note that you must use a @a type value (aka image format)
82 that wxWidgets can save (e.g. JPG, PNG, see wxImage
83 documentation())!
84
85 @see AddFileWithMimeType()
86 */
87 static void AddFile(const wxString& filename, wxImage& image,
88 long type);
89 static void AddFile(const wxString& filename,
90 const wxBitmap& bitmap,
91 long type);
92 //@}
93
94 //@{
95 /**
96 Like AddFile(), but lets you explicitly
97 specify added file's MIME type. This version should be used whenever you know
98 the MIME type, because it makes accessing the files faster.
99
100 @wxsince{2.8.5}
101
102 @see AddFile()
103 */
104 static void AddFileWithMimeType(const wxString& filename,
105 const wxString& textdata,
106 const wxString& mimetype);
107 static void AddFileWithMimeType(const wxString& filename,
108 const void* binarydata,
109 size_t size,
110 const wxString& mimetype);
111 //@}
112
113 /**
114 Remove file from memory FS and free occupied memory.
115 */
116 static void RemoveFile(const wxString& filename);
117};
118