Mercurial > mercurial > hgweb_searcher2.cgi
diff src/preview.cpp @ 3:75fefb53d983
update preview.
author | pyon@macmini |
---|---|
date | Sat, 09 Apr 2011 12:48:20 +0900 |
parents | e0cf49906039 |
children | d924b09ea2f3 |
line wrap: on
line diff
--- a/src/preview.cpp Thu Apr 07 19:56:47 2011 +0900 +++ b/src/preview.cpp Sat Apr 09 12:48:20 2011 +0900 @@ -1,5 +1,5 @@ // Filename : preview.cpp -// Last Change: 07-Apr-2011. +// Last Change: 09-Apr-2011. // #include "preview.h" @@ -8,95 +8,74 @@ // need because it includes almost all "standard" wxWidgets headers) #ifndef WX_PRECOMP #include "wx/utils.h" + #include "wx/dir.h" #endif - -MyFramePreview::MyFramePreview( wxWindow* parent, wxWindowID id, const wxString& title, const wxPoint& pos, const wxSize& size, long style ) : wxFrame( parent, id, title, pos, size, style ) +// 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->SetSizeHints( wxDefaultSize, wxDefaultSize ); + this->SetSize( 1600, 900 ); wxBoxSizer* bSizer; bSizer = new wxBoxSizer( wxHORIZONTAL ); + // LeftPain ( thumbnail ) wxBoxSizer* bSizerL; bSizerL = new wxBoxSizer( wxVERTICAL ); - m_staticText1 = new wxStaticText( this, wxID_ANY, wxT("MyLabel"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticText1->Wrap( -1 ); - bSizerL->Add( m_staticText1, 0, wxALL, 5 ); - + 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, 5 ); - - m_staticText2 = new wxStaticText( this, wxID_ANY, wxT("MyLabel"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticText2->Wrap( -1 ); - bSizerL->Add( m_staticText2, 0, wxALL, 5 ); - + 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, 5 ); - - m_staticText3 = new wxStaticText( this, wxID_ANY, wxT("MyLabel"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticText3->Wrap( -1 ); - bSizerL->Add( m_staticText3, 0, wxALL, 5 ); - + 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, 5 ); - - m_staticText4 = new wxStaticText( this, wxID_ANY, wxT("MyLabel"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticText4->Wrap( -1 ); - bSizerL->Add( m_staticText4, 0, wxALL, 5 ); - + 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, 5 ); - - m_staticText5 = new wxStaticText( this, wxID_ANY, wxT("MyLabel"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticText5->Wrap( -1 ); - bSizerL->Add( m_staticText5, 0, wxALL, 5 ); - + 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, 5 ); + bSizerL->Add( m_bitmap5, 0, wxALL|wxALIGN_CENTRE, 5 ); bSizer->Add( bSizerL, 0, wxEXPAND, 5 ); + // MainPain ( preview ) m_scrolledWindow = new wxScrolledWindow( this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxHSCROLL|wxVSCROLL ); m_scrolledWindow->SetScrollRate( 5, 5 ); 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 ); + // RightPain ( manip ) wxBoxSizer* bSizerR; bSizerR = new wxBoxSizer( wxVERTICAL ); m_staticText = new wxStaticText( this, wxID_ANY, wxT("倍率"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticText->Wrap( -1 ); bSizerR->Add( m_staticText, 0, wxALL, 5 ); - m_textCtrl = new wxTextCtrl( this, ID_MGNFY, wxT("100%"), wxDefaultPosition, wxDefaultSize, wxTE_PROCESS_ENTER ); m_textCtrl->SetMaxLength( 4 ); bSizerR->Add( m_textCtrl, 0, wxALL, 5 ); - m_staticTextLarge = new wxStaticText( this, wxID_ANY, wxT("[+]"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticTextLarge->Wrap( -1 ); bSizerR->Add( m_staticTextLarge, 0, wxALL, 5 ); - m_slider = new wxSlider( this, ID_SLDR, 0, 0, 100, wxDefaultPosition, wxDefaultSize, wxSL_LEFT|wxSL_VERTICAL ); bSizerR->Add( m_slider, 0, wxALL, 5 ); - m_staticTextSmall = new wxStaticText( this, wxID_ANY, wxT("[-]"), wxDefaultPosition, wxDefaultSize, 0 ); - m_staticTextSmall->Wrap( -1 ); bSizerR->Add( m_staticTextSmall, 0, wxALL, 5 ); - bSizerR->Add( 0, 0, 1, wxEXPAND, 5 ); m_buttonPrint = new wxButton( this, ID_PRINT, wxT("印刷"), wxDefaultPosition, wxDefaultSize, 0 ); bSizerR->Add( m_buttonPrint, 0, wxALL, 5 ); - m_buttonPrintAll = new wxButton( this, ID_PRTALL, wxT("一括印刷"), wxDefaultPosition, wxDefaultSize, 0 ); bSizerR->Add( m_buttonPrintAll, 0, wxALL, 5 ); - m_buttonClose = new wxButton( this, ID_CLSFRM, wxT("閉じる"), wxDefaultPosition, wxDefaultSize, 0 ); bSizerR->Add( m_buttonClose, 0, wxALL, 5 ); @@ -106,9 +85,58 @@ this->Layout(); this->Centre( wxBOTH ); + + LoadImages( wxEmptyString ); } -MyFramePreview::~MyFramePreview() +// destructor +FramePreview::~FramePreview() { } +// Event Table +BEGIN_EVENT_TABLE( FramePreview, wxFrame ) + //EVT_BUTTON( ID_PRINT, FramePreview::PrintImage ) + //EVT_BUTTON( ID_PRTALL, FramePreview::PrintAllImages ) + EVT_BUTTON( ID_CLSFRM, FramePreview::CloseFrame ) +END_EVENT_TABLE() + +// Event Handlers +void FramePreview::CloseFrame(wxCommandEvent& WXUNUSED(event)) +{ + this->Close(); + return; +} + +// Functions +void FramePreview::LoadImages(wxString path) +{ + path = wxGetCwd() + wxT("/testdrive"); // now test! + wxDir dir(path); + wxString file; + 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 ); + + 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; +}