27 #include "hugin_config.h"
49 #include <pano13/queryfeature.h>
73 #define PF_STYLE (wxMAXIMIZE_BOX | wxMINIMIZE_BOX | wxRESIZE_BORDER | wxSYSTEM_MENU | wxCAPTION | wxCLOSE_BOX | wxCLIP_CHILDREN)
76 : wxFrame(frame,-1, _(
"Panorama preview"), wxDefaultPosition, wxDefaultSize,
83 m_ToolBar = wxXmlResource::Get()->LoadToolBar(
this, wxT(
"preview_toolbar"));
91 new wxStaticBox(
this, -1, _(
"displayed images")),
94 m_ButtonPanel =
new wxScrolledWindow(
this, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL);
107 wxFlexGridSizer * flexSizer =
new wxFlexGridSizer(2,0,5,5);
108 flexSizer->AddGrowableCol(0);
109 flexSizer->AddGrowableRow(0);
125 wxDefaultPosition, wxDefaultSize,
126 wxSL_VERTICAL | wxSL_AUTOTICKS,
132 m_VFOVSlider->SetToolTip(_(
"drag to change the vertical field of view"));
138 wxDefaultPosition, wxDefaultSize,
139 wxSL_HORIZONTAL | wxSL_AUTOTICKS,
146 m_HFOVSlider->SetToolTip(_(
"drag to change the horizontal field of view"));
156 wxStaticBoxSizer * blendModeSizer =
new wxStaticBoxSizer(
157 new wxStaticBox(
this, -1, _(
"Preview Options")),
160 blendModeSizer->Add(
new wxStaticText(
this, -1, _(
"projection (f):")),
162 wxALL | wxALIGN_CENTER_VERTICAL,
165 wxDefaultPosition, wxDefaultSize);
169 int nP = panoProjectionFormatCount();
170 for(
int n=0; n < nP; n++) {
171 pano_projection_features proj;
172 if (panoProjectionFeaturesQuery(n, &proj)) {
173 wxString str2(proj.name, wxConvLocal);
181 wxALL | wxALIGN_CENTER_VERTICAL,
186 blendModeSizer->Add(
new wxStaticText(
this, -1, _(
"Blend mode:")),
188 wxALL | wxALIGN_CENTER_VERTICAL,
194 int oldMode = wxConfigBase::Get()->Read(wxT(
"/PreviewFrame/blendMode"), 0l);
195 if (oldMode > 1) oldMode = 0;
197 wxDefaultPosition, wxDefaultSize,
204 wxALL | wxALIGN_CENTER_VERTICAL,
209 blendModeSizer->Add(
new wxStaticText(
this, -1, _(
"Output:")),
211 wxALL | wxALIGN_CENTER_VERTICAL,
217 wxDefaultPosition, wxDefaultSize,
223 wxALL | wxALIGN_CENTER_VERTICAL,
228 blendModeSizer->Add(
new wxStaticText(
this, -1, _(
"EV:")),
230 wxALL | wxALIGN_CENTER_VERTICAL,
234 wxArtProvider::GetBitmap(wxART_REDO));
244 wxDefaultPosition,wxSize(50,-1), wxTE_PROCESS_ENTER);
248 wxLEFT | wxTOP | wxBOTTOM | wxALIGN_CENTER_VERTICAL,
253 wxDefaultSize, wxSP_VERTICAL);
261 blendModeSizer->Add(
new wxStaticText(
this, wxID_ANY, _(
"Range compression:")), 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, 5);
263 wxDefaultPosition, wxSize(30, -1), wxTE_PROCESS_ENTER);
274 m_topsizer->Add(blendModeSizer, 0, wxEXPAND | wxALL, 5);
277 new wxStaticBox(
this, -1, _(
"Projection Parameters")),
281 wxArtProvider::GetBitmap(wxART_REDO));
282 resetProjButton->SetToolTip(_(
"Resets the projection's parameters to their default values."));
284 m_projParamSizer->Add(resetProjButton, 0, wxLEFT | wxRIGHT | wxALIGN_CENTER_VERTICAL, 5);
290 for (
int i=0; i < PANO_PROJECTION_MAX_PARMS; i++) {
295 wxALL | wxALIGN_CENTER_VERTICAL,
298 wxDefaultPosition, wxSize(35,-1), wxTE_PROCESS_ENTER);
303 wxALL | wxALIGN_CENTER_VERTICAL,
309 wxALL | wxALIGN_CENTER_VERTICAL,
318 wxConfigBase * config = wxConfigBase::Get();
322 int widths[3] = {-3, 150, 150};
323 SetStatusWidths(3, widths);
324 SetStatusText(_(
"Left click to define new center point, right click to move point to horizon."),0);
325 SetStatusText(wxT(
""),1);
326 SetStatusText(wxT(
""),2);
334 wxIconBundle myIcons(
huginApp::Get()->GetXRCPath() + wxT(
"data/hugin.ico"),wxBITMAP_TYPE_ICO);
337 wxIcon myIcon(
huginApp::Get()->GetXRCPath() + wxT(
"data/hugin.png"),wxBITMAP_TYPE_PNG);
347 long aup = config->Read(wxT(
"/PreviewFrame/autoUpdate"),0l);
350 m_ToolBar->ToggleTool(XRCID(
"preview_auto_update_tool"), aup !=0);
357 if (config->Read(wxT(
"/PreviewFrame/isShown"), 0l) != 0) {
360 SetStatusText(_(
"Center panorama with left mouse button, set horizon with right button"),0);
361 wxAcceleratorEntry entries[3];
367 entries[1].Set(wxACCEL_CMD,(
int)
'Z',
ID_UNDO);
368 entries[2].Set(wxACCEL_CMD,(
int)
'R',
ID_REDO);
369 wxAcceleratorTable accel(3, entries);
370 SetAcceleratorTable(accel);
394 wxConfigBase * config = wxConfigBase::Get();
398 if ( (!this->IsIconized()) && (! this->IsMaximized()) && this->IsShown()) {
399 config->Write(wxT(
"/PreviewFrame/isShown"), 1l);
401 config->Write(wxT(
"/PreviewFrame/isShown"), 0l);
404 bool checked =
m_ToolBar->GetToolState(XRCID(
"preview_auto_update_tool"));
405 config->Write(wxT(
"/PreviewFrame/autoUpdate"), checked ? 1l: 0l);
406 config->Write(wxT(
"/PreviewFrame/blendMode"),
m_BlendModeChoice->GetSelection());
407 for (
int i=0; i < PANO_PROJECTION_MAX_PARMS; i++)
421 if (
id >= 0 &&
id < nImg) {
423 activeImages.insert(
id);
425 activeImages.erase(
id);
464 m_ToolBar->EnableTool(XRCID(
"preview_center_tool"), activeImgs);
465 m_ToolBar->EnableTool(XRCID(
"preview_fit_pano_tool"), activeImgs);
466 m_ToolBar->EnableTool(XRCID(
"preview_update_tool"), activeImgs);
467 m_ToolBar->EnableTool(XRCID(
"preview_num_transform"), activeImgs);
472 bool relayout =
false;
480 for (i=0; i < nParam; i++) {
481 const pano_projection_parameter * pp = & (opts.
m_projFeatures.parm[i]);
482 wxString str2(pp->name, wxConvLocal);
483 str2 = wxGetTranslation(str2);
487 for(;i < PANO_PROJECTION_MAX_PARMS; i++) {
501 assert((
int) params.size() == nParam);
502 for (
int i=0; i < nParam; i++) {
512 SetStatusText(_(
"Center panorama with left mouse button, set horizon with right button"),0);
513 SetStatusText(wxString::Format(wxT(
"%.1f x %.1f"), opts.
getHFOV(), opts.
getVFOV()),2);
533 for (
int i=nrButtons-1; i>=(int)nrImages; i--)
542 if ( nrImages >= nrButtons ) {
543 for(HuginBase::UIntSet::const_iterator it = changed.begin(); it != changed.end(); ++it){
544 if (*it >= nrButtons) {
549 wxString::Format(wxT(
" %d "),*it),
550 wxDefaultPosition, wxDefaultSize,
566 for (
unsigned i=0; i < nrImages; i++) {
586 if (event.CanVeto()) {
606 void PreviewFrame::OnProjectionChanged()
612 case PanoramaOptions::RECTILINEAR: Ip = _(
"Rectilinear");
break;
613 case PanoramaOptions::CYLINDRICAL: Ip = _(
"Cylindrical");
break;
614 case PanoramaOptions::EQUIRECTANGULAR: Ip = _(
"Equirectangular");
break;
616 opt.projectionFormat = (PanoramaOptions::ProjectionFormat) lt;
620 DEBUG_DEBUG (
"Projection changed: " << lt <<
":" << Ip )
651 if (
m_ToolBar->GetToolState(XRCID(
"preview_auto_update_tool"))) {
682 displayedImgs.insert(i);
710 wxXmlResource::Get()->LoadDialog(&dlg,
this, wxT(
"dlg_numtrans"));
711 dlg.CentreOnParent();
712 if (dlg.ShowModal() == wxID_OK ) {
713 wxString text = XRCCTRL(dlg,
"numtrans_yaw", wxTextCtrl)->GetValue();
716 wxLogError(_(
"Yaw value must be numeric."));
719 text = XRCCTRL(dlg,
"numtrans_pitch", wxTextCtrl)->GetValue();
722 wxLogError(_(
"Pitch value must be numeric."));
725 text = XRCCTRL(dlg,
"numtrans_roll", wxTextCtrl)->GetValue();
728 wxLogError(_(
"Roll value must be numeric."));
750 wxLogError(_(
"Value must be numeric."));
771 wxLogError(_(
"Value must be numeric."));
776 wxLogError(_(
"Value for range compression is outside of valid range."));
794 for (
int i = 0; i < nParam; i++)
799 DEBUG_INFO(
"param " << i <<
": = " << text.mb_str(wxConvLocal));
805 wxLogError(_(
"Value must be numeric."));
837 DEBUG_DEBUG(
"VFOV changed (slider): " << e.GetInt());
842 for (
int i = 0; i < nParam; i++) {
845 para[i] = e.GetInt();
861 int sel = e.GetSelection();
873 DEBUG_WARN(
"wxChoice event from unknown object received");
944 DEBUG_WARN(
"wxChoice event from unknown object received");
961 DEBUG_WARN(
"wxChoice event from unknown object received");
971 msg = wxGetTranslation(wxString(
m_message.c_str(), wxConvLocal));
974 msg.Append(wxT(
" "));
978 GetStatusBar()->SetStatusText(msg, 0);
987 ShowFullScreen(!IsFullScreen(), wxFULLSCREEN_NOBORDER | wxFULLSCREEN_NOCAPTION);
990 GetToolBar()->Show(
true);
999 wxCommandEvent dummy(wxEVT_COMMAND_MENU_SELECTED, XRCID(
"ID_EDITUNDO"));
1000 m_parent->GetEventHandler()->AddPendingEvent(dummy);
1012 wxCommandEvent dummy(wxEVT_COMMAND_MENU_SELECTED, XRCID(
"ID_EDITREDO"));
1013 m_parent->GetEventHandler()->AddPendingEvent(dummy);
void OnShowAll(wxCommandEvent &e)
HuginBase::Panorama & m_pano
PanoramaOptions::ProjectionFormat getProjection() const
void OnUpdate(wxCommandEvent &event)
bool Create(wxWindow *parent, wxWindowID id=wxID_ANY, const wxPoint &pos=wxDefaultPosition, const wxSize &size=wxDefaultSize, long style=wxTAB_TRAVERSAL, const wxString &name=wxT("panel"))
double outputRangeCompression
void setHeight(unsigned int h)
set panorama height
pano_projection_features m_projFeatures
static double calcMeanExposure(const PanoramaData &pano)
bool str2double(const wxString &s, double &d)
void OnBlendChoice(wxCommandEvent &e)
center panorama horizontically
void OnNumTransform(wxCommandEvent &e)
void OnTextCtrlChanged(wxCommandEvent &e)
std::vector< wxStaticText * > m_projParamNamesLabel
bool fovCalcSupported(ProjectionFormat f) const
true, if FOV calcuations are supported for projection f
bool removeObserver(PanoramaObserver *observer)
remove a panorama observer.
virtual ~PreviewFrame()
dtor.
wxSpinButton * m_exposureSpinBut
unsigned int getHeight() const
get panorama height
std::vector< wxSlider * > m_projParamSlider
wxChoice * m_ProjectionChoice
bool set_contains(const _Container &c, const typename _Container::key_type &key)
#define DEBUG_ASSERT(cond)
void setProjectionParameters(const std::vector< double > ¶ms)
set the optional parameters (they need to be of the correct size)
include file for the hugin project
virtual void run()
runs the algorithm.
void panoramaImagesChanged(HuginBase::Panorama &pano, const HuginBase::UIntSet &changed)
notifies about changes to images
void OnRangeCompressionTextChanged(wxCommandEvent &e)
std::string doubleToString(double d, int digits)
convert a double to a string, suitable for display within a GUI.
static huginApp * Get()
hack.. kind of a pseudo singleton...
std::set< unsigned int > UIntSet
void OnCenterHorizontally(wxCommandEvent &e)
void OnIncreaseExposure(wxSpinEvent &e)
void Init(PreviewFrame *parent, HuginBase::Panorama *pano)
void OnUndo(wxCommandEvent &e)
event handler for undo
void resetProjectionParameters()
sets the optional parameters to their default values
std::size_t getNrOfImages() const
number of images.
void SetAutoUpdate(bool enabled)
void StoreFramePosition(wxTopLevelWindow *frame, const wxString &basename)
Store window size and position in configfile/registry.
void OnRedo(wxCommandEvent &e)
event handler for redo
virtual double getResultHeight()
void OnExposureTextChanged(wxCommandEvent &e)
void OnProjectionChoice(wxCommandEvent &e)
void SetBlendMode(BlendMode b)
void OnShowNone(wxCommandEvent &e)
wxBitmapButton * m_defaultExposureBut
void RestoreFramePosition(wxTopLevelWindow *frame, const wxString &basename)
Restore window size and position from configfile/registry.
std::vector< wxToggleButton * > m_ToggleButtons
static GlobalCmdHist & getInstance()
std::vector< wxTextCtrl * > m_projParamTextCtrl
void OnChangeFOV(wxScrollEvent &e)
wxBoxSizer * m_ButtonSizer
void addCommand(PanoCommand *command, bool execute=true)
Adds a command to the history.
wxScrolledWindow * m_ButtonPanel
void panoramaChanged(HuginBase::Panorama &pano)
Notification about a Panorama change.
straighten panorama horizontically
UIntSet getActiveImages() const
get active images
void OnStraighten(wxCommandEvent &e)
void setHFOV(double h, bool keepView=true)
set the horizontal field of view.
void addObserver(PanoramaObserver *o)
add a panorama observer.
include file for the hugin project
const PanoramaOptions & getOptions() const
returns the options for this panorama
Handle EVT_KILL_FOCUS and convert it to a EVT_TEXT_ENTER event.
virtual double getResultHorizontalFOV()
void OnClose(wxCloseEvent &e)
PreviewFrame(wxFrame *frame, HuginBase::Panorama &pano)
ctor.
void OnChangeDisplayedImgs(wxCommandEvent &e)
const std::vector< double > & getProjectionParameters() const
Get the optional projection parameters.
wxSpinButton * m_rangeCompressionSpinBut
void OnFitPano(wxCommandEvent &e)
void OnProjParameterReset(wxCommandEvent &e)
event handler for reset projection parameters
void OnOutputChoice(wxCommandEvent &e)
const SrcPanoImage & getImage(std::size_t nr) const
get a panorama image, counting starts with 0
wxStaticBoxSizer * m_projParamSizer
void OnRangeCompressionIncrease(wxSpinEvent &e)
void OnRangeCompressionDecrease(wxSpinEvent &e)
A preview panel that renders the pictures using the panotools library.
void OnDefaultExposure(wxCommandEvent &e)
PreviewPanel * m_PreviewPanel
ProjectionFormat
Projection of final panorama.
wxTextCtrl * m_exposureTextCtrl
void setProjection(ProjectionFormat f)
set the Projection format and adjust the hfov/vfov if nessecary
wxStaticBoxSizer * m_ToggleButtonSizer
void OnAutoPreviewToggle(wxCommandEvent &e)
wxTextCtrl * m_rangeCompressionTextCtrl
void updateProgressDisplay()
update the display
void OnDecreaseExposure(wxSpinEvent &e)
wxChoice * m_BlendModeChoice
void OnFullScreen(wxCommandEvent &e)
event handler for full screen
wxChoice * m_outputModeChoice
double outputExposureValue