X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/04c4c93f00e0329ab4b076137198f451fb4e3dc6..41f6f17d01562aa09bdbcc6b02241b62f1d06b75:/samples/artprov/artbrows.cpp diff --git a/samples/artprov/artbrows.cpp b/samples/artprov/artbrows.cpp index 359130f9a4..599c36c9c3 100644 --- a/samples/artprov/artbrows.cpp +++ b/samples/artprov/artbrows.cpp @@ -9,10 +9,6 @@ // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "artbrows.h" -#endif - // For compilers that support precompilation, includes "wx/wx.h". #include "wx/wxprec.h" @@ -25,6 +21,7 @@ #include "wx/choice.h" #endif +#include "wx/listctrl.h" #include "wx/sizer.h" #include "wx/imaglist.h" #include "wx/listctrl.h" @@ -32,7 +29,7 @@ #include "artbrows.h" #define ART_CLIENT(id) \ - choice->Append(#id, (void*)id); + choice->Append(_T(#id), (void*)id); #define ART_ICON(id) \ { \ int ind; \ @@ -41,7 +38,7 @@ ind = images->Add(icon); \ else \ ind = 0; \ - list->InsertItem(index, #id, ind); \ + list->InsertItem(index, _T(#id), ind); \ list->SetItemData(index, (long)id); \ index++; \ } @@ -82,7 +79,6 @@ static void FillBitmaps(wxImageList *images, wxListCtrl *list, ART_ICON(wxART_GO_DOWN) ART_ICON(wxART_GO_TO_PARENT) ART_ICON(wxART_GO_HOME) - ART_ICON(wxART_FILE_OPEN) ART_ICON(wxART_PRINT) ART_ICON(wxART_HELP) ART_ICON(wxART_TIP) @@ -90,11 +86,30 @@ static void FillBitmaps(wxImageList *images, wxListCtrl *list, ART_ICON(wxART_LIST_VIEW) ART_ICON(wxART_NEW_DIR) ART_ICON(wxART_FOLDER) + ART_ICON(wxART_FOLDER_OPEN); ART_ICON(wxART_GO_DIR_UP) ART_ICON(wxART_EXECUTABLE_FILE) ART_ICON(wxART_NORMAL_FILE) ART_ICON(wxART_TICK_MARK) ART_ICON(wxART_CROSS_MARK) + ART_ICON(wxART_MISSING_IMAGE) + ART_ICON(wxART_NEW); + ART_ICON(wxART_FILE_OPEN) + ART_ICON(wxART_FILE_SAVE) + ART_ICON(wxART_FILE_SAVE_AS) + ART_ICON(wxART_DELETE); + ART_ICON(wxART_COPY) + ART_ICON(wxART_CUT) + ART_ICON(wxART_PASTE) + ART_ICON(wxART_UNDO) + ART_ICON(wxART_REDO) + ART_ICON(wxART_QUIT) + ART_ICON(wxART_FIND) + ART_ICON(wxART_FIND_AND_REPLACE) + ART_ICON(wxART_HARDDISK) + ART_ICON(wxART_FLOPPY) + ART_ICON(wxART_CDROM) + ART_ICON(wxART_REMOVABLE) } @@ -105,48 +120,49 @@ static void FillBitmaps(wxImageList *images, wxListCtrl *list, #include "null.xpm" BEGIN_EVENT_TABLE(wxArtBrowserDialog, wxDialog) - EVT_LIST_ITEM_SELECTED(-1, wxArtBrowserDialog::OnSelectItem) - EVT_CHOICE(-1, wxArtBrowserDialog::OnChooseClient) + EVT_LIST_ITEM_SELECTED(wxID_ANY, wxArtBrowserDialog::OnSelectItem) + EVT_CHOICE(wxID_ANY, wxArtBrowserDialog::OnChooseClient) END_EVENT_TABLE() wxArtBrowserDialog::wxArtBrowserDialog(wxWindow *parent) - : wxDialog(parent, -1, _T("Art resources browser"), - wxDefaultPosition, wxDefaultSize, + : wxDialog(parent, wxID_ANY, _T("Art resources browser"), + wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE|wxRESIZE_BORDER) { wxSizer *sizer = new wxBoxSizer(wxVERTICAL); wxSizer *subsizer; - - wxChoice *choice = new wxChoice(this, -1); + + wxChoice *choice = new wxChoice(this, wxID_ANY); FillClients(choice); - + subsizer = new wxBoxSizer(wxHORIZONTAL); - subsizer->Add(new wxStaticText(this, -1, _T("Client:")), 0, wxALIGN_CENTER_VERTICAL); + subsizer->Add(new wxStaticText(this, wxID_ANY, _T("Client:")), 0, wxALIGN_CENTER_VERTICAL); subsizer->Add(choice, 1, wxLEFT, 5); sizer->Add(subsizer, 0, wxALL | wxEXPAND, 10); subsizer = new wxBoxSizer(wxHORIZONTAL); - - m_list = new wxListCtrl(this, -1, wxDefaultPosition, wxSize(250, 300), + + m_list = new wxListCtrl(this, wxID_ANY, wxDefaultPosition, wxSize(250, 300), wxLC_REPORT | wxSUNKEN_BORDER); m_list->InsertColumn(0, _T("wxArtID")); subsizer->Add(m_list, 1, wxEXPAND | wxRIGHT, 10); - + wxSizer *subsub = new wxBoxSizer(wxVERTICAL); - m_canvas = new wxStaticBitmap(this, -1, wxBitmap(null_xpm)); + m_text = new wxStaticText(this, wxID_ANY, wxT("Size: 333x333")); + subsub->Add(m_text); + + m_canvas = new wxStaticBitmap(this, wxID_ANY, wxBitmap(null_xpm)); subsub->Add(m_canvas); subsub->Add(100, 100); subsizer->Add(subsub); sizer->Add(subsizer, 1, wxEXPAND | wxLEFT|wxRIGHT, 10); - + wxButton *ok = new wxButton(this, wxID_OK, _T("Close")); ok->SetDefault(); sizer->Add(ok, 0, wxALIGN_RIGHT | wxALL, 10); - - SetSizer(sizer); - SetAutoLayout(TRUE); - sizer->Fit(this); + + SetSizerAndFit(sizer); choice->SetSelection(6/*wxART_MESSAGE_BOX*/); SetArtClient(wxART_MESSAGE_BOX); @@ -156,25 +172,29 @@ wxArtBrowserDialog::wxArtBrowserDialog(wxWindow *parent) void wxArtBrowserDialog::SetArtClient(const wxArtClient& client) { wxBusyCursor bcur; - + wxImageList *img = new wxImageList(16, 16); img->Add(wxIcon(null_xpm)); int index = 0; + long sel = m_list->GetNextItem(-1, wxLIST_NEXT_ALL, wxLIST_STATE_FOCUSED); + if (sel < 0) sel = 0; + m_list->DeleteAllItems(); FillBitmaps(img, m_list, index, client, wxSize(16, 16)); m_list->AssignImageList(img, wxIMAGE_LIST_SMALL); m_list->SetColumnWidth(0, wxLIST_AUTOSIZE); + m_list->SetItemState(sel, wxLIST_STATE_FOCUSED, wxLIST_STATE_FOCUSED); + m_client = client; + SetArtBitmap((const wxChar*)m_list->GetItemData(sel), m_client); } void wxArtBrowserDialog::OnSelectItem(wxListEvent &event) { const wxChar *data = (const wxChar*)event.GetData(); - wxBitmap bmp = wxArtProvider::GetBitmap(data, m_client); - m_canvas->SetBitmap(bmp); - m_canvas->SetSize(bmp.GetWidth(), bmp.GetHeight()); + SetArtBitmap(data, m_client, wxDefaultSize); } void wxArtBrowserDialog::OnChooseClient(wxCommandEvent &event) @@ -182,3 +202,12 @@ void wxArtBrowserDialog::OnChooseClient(wxCommandEvent &event) const wxChar *data = (const wxChar*)event.GetClientData(); SetArtClient(data); } + +void wxArtBrowserDialog::SetArtBitmap(const wxArtID& id, const wxArtClient& client, const wxSize& size) +{ + wxBitmap bmp = wxArtProvider::GetBitmap(id, client, size); + m_canvas->SetSize(bmp.GetWidth(), bmp.GetHeight()); + m_canvas->SetBitmap(bmp); + m_text->SetLabel(wxString::Format(wxT("Size: %d x %d"), bmp.GetWidth(), bmp.GetHeight())); + Refresh(); +}