Mercurial > mercurial > hgweb_searcher2.cgi
diff src/preview.cpp @ 4:d924b09ea2f3
thumbnail by ListCtrl & ImageList.
author | pyon@macmini |
---|---|
date | Sat, 09 Apr 2011 15:03:03 +0900 |
parents | 75fefb53d983 |
children | 0f566397974e |
line wrap: on
line diff
--- a/src/preview.cpp Sat Apr 09 12:48:20 2011 +0900 +++ b/src/preview.cpp Sat Apr 09 15:03:03 2011 +0900 @@ -15,7 +15,7 @@ // constructor FramePreview::FramePreview( wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, long style ) : wxFrame( parent, id, title, pos, size, style ) { - this->SetSize( 1600, 900 ); + this->SetSize( 1600, 950 ); wxBoxSizer* bSizer; bSizer = new wxBoxSizer( wxHORIZONTAL ); @@ -24,35 +24,20 @@ wxBoxSizer* bSizerL; bSizerL = new wxBoxSizer( wxVERTICAL ); - m_staticText1 = new wxStaticText( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_staticText1, 0, wxTOP|wxALIGN_CENTRE, 5 ); - m_bitmap1 = new wxStaticBitmap( this, ID_IMG1, wxNullBitmap, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_bitmap1, 0, wxALL|wxALIGN_CENTRE, 5 ); - m_staticText2 = new wxStaticText( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_staticText2, 0, wxTOP|wxALIGN_CENTRE, 5 ); - m_bitmap2 = new wxStaticBitmap( this, ID_IMG2, wxNullBitmap, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_bitmap2, 0, wxALL|wxALIGN_CENTRE, 5 ); - m_staticText3 = new wxStaticText( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_staticText3, 0, wxTOP|wxALIGN_CENTRE, 5 ); - m_bitmap3 = new wxStaticBitmap( this, ID_IMG3, wxNullBitmap, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_bitmap3, 0, wxALL|wxALIGN_CENTRE, 5 ); - m_staticText4 = new wxStaticText( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_staticText4, 0, wxTOP|wxALIGN_CENTRE, 5 ); - m_bitmap4 = new wxStaticBitmap( this, ID_IMG4, wxNullBitmap, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_bitmap4, 0, wxALL|wxALIGN_CENTRE, 5 ); - m_staticText5 = new wxStaticText( this, wxID_ANY, wxEmptyString, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_staticText5, 0, wxTOP|wxALIGN_CENTRE, 5 ); - m_bitmap5 = new wxStaticBitmap( this, ID_IMG5, wxNullBitmap, wxDefaultPosition, wxDefaultSize, 0 ); - bSizerL->Add( m_bitmap5, 0, wxALL|wxALIGN_CENTRE, 5 ); + m_listCtrl = new wxListCtrl( this, wxID_ANY, wxDefaultPosition, wxSize( 140, 900 ), wxLC_ICON|wxLC_SINGLE_SEL ); + bSizerL->Add( m_listCtrl, 1, wxEXPAND|wxALL|wxALIGN_CENTRE, 5 ); + m_imageList = new wxImageList( 105, 148 ); + m_listCtrl->AssignImageList( m_imageList, wxIMAGE_LIST_NORMAL ); bSizer->Add( bSizerL, 0, wxEXPAND, 5 ); // MainPain ( preview ) m_scrolledWindow = new wxScrolledWindow( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxVSCROLL ); - m_scrolledWindow->SetScrollRate( 5, 5 ); + m_scrolledWindow->SetScrollbars( 10, 10, 83, 117 ); + //m_scrolledWindow->SetScrollRate( 5, 5 ); + m_bitmap = new wxStaticBitmap( m_scrolledWindow, ID_IMG, wxNullBitmap, wxDefaultPosition, wxDefaultSize, 0 ); bSizer->Add( m_scrolledWindow, 1, wxEXPAND | wxALL, 5 ); - m_bitmap = new wxStaticBitmap( this, ID_IMG, wxNullBitmap, wxDefaultPosition, wxDefaultSize, 0 ); - bSizer->Add( m_bitmap, 0, wxALL, 5 ); + //bSizer->Add( m_bitmap, 0, wxALL, 5 ); // RightPain ( manip ) wxBoxSizer* bSizerR; @@ -117,26 +102,24 @@ if ( !dir.IsOpened() ) return; bool cout = dir.GetFirst( &file, wxT("*.jpg"), wxDIR_FILES ); - SetThumbnail( this->m_staticText1, this->m_bitmap1, path, file ); - dir.GetNext( &file ); - SetThumbnail( this->m_staticText2, this->m_bitmap2, path, file ); - dir.GetNext( &file ); - SetThumbnail( this->m_staticText3, this->m_bitmap3, path, file ); - dir.GetNext( &file ); - SetThumbnail( this->m_staticText4, this->m_bitmap4, path, file ); - dir.GetNext( &file ); - SetThumbnail( this->m_staticText5, this->m_bitmap5, path, file ); + if ( cout ) { + wxString mfile = path + wxFILE_SEP_PATH + file; + wxImage img( mfile, wxBITMAP_TYPE_JPEG ); + wxBitmap bmp( img.Scale( 640, 877, wxIMAGE_QUALITY_HIGH ) ); + m_bitmap->SetBitmap( bmp); + } + int i=0; + while ( cout ) { + m_listCtrl->InsertItem( i, file, i ); + file = path + wxFILE_SEP_PATH + file; + wxImage img( file, wxBITMAP_TYPE_JPEG ); + wxBitmap bmp( img.Scale( 105, 148, wxIMAGE_QUALITY_HIGH ) ); + m_imageList->Add( bmp ); + i++; + cout = dir.GetNext( &file ); + } return; } -void FramePreview::SetThumbnail( wxStaticText* st, wxStaticBitmap* sb, wxString path, wxString file ) -{ - st->SetLabel(file); - file = path + wxFILE_SEP_PATH + file; - wxImage img( file, wxBITMAP_TYPE_JPEG ); - wxBitmap bmp( img.Scale( 105, 148, wxIMAGE_QUALITY_HIGH ) ); - sb->SetBitmap( bmp ); - return; -}