diff options
| author | Carl Hetherington <cth@carlh.net> | 2015-05-04 01:35:54 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2015-05-04 01:35:54 +0100 |
| commit | 258da8a37c21a87ba5a7aa1c3e6243280d5c8d10 (patch) | |
| tree | 5fa70a510fdbfc59c7294fa5d8a6f8f20f92e180 /src | |
| parent | d440d6d72a4522de2ba83a3bc1de93296f14cef2 (diff) | |
701e75b87018ab1ec831f84b5325a0c76bd9f6ba from master; content properties dialog.
Diffstat (limited to 'src')
| -rw-r--r-- | src/wx/content_menu.cc | 27 | ||||
| -rw-r--r-- | src/wx/content_menu.h | 7 | ||||
| -rw-r--r-- | src/wx/content_properties_dialog.cc | 74 | ||||
| -rw-r--r-- | src/wx/content_properties_dialog.h | 33 | ||||
| -rw-r--r-- | src/wx/wscript | 1 |
5 files changed, 133 insertions, 9 deletions
diff --git a/src/wx/content_menu.cc b/src/wx/content_menu.cc index 23767bbe7..daadab7d7 100644 --- a/src/wx/content_menu.cc +++ b/src/wx/content_menu.cc @@ -17,8 +17,12 @@ */ -#include <wx/wx.h> -#include <wx/dirdlg.h> +#include "content_menu.h" +#include "repeat_dialog.h" +#include "wx_util.h" +#include "timeline_video_content_view.h" +#include "timeline_audio_content_view.h" +#include "content_properties_dialog.h" #include "lib/playlist.h" #include "lib/film.h" #include "lib/image_content.h" @@ -27,11 +31,8 @@ #include "lib/job_manager.h" #include "lib/exceptions.h" #include "lib/dcp_content.h" -#include "content_menu.h" -#include "repeat_dialog.h" -#include "wx_util.h" -#include "timeline_video_content_view.h" -#include "timeline_audio_content_view.h" +#include <wx/wx.h> +#include <wx/dirdlg.h> using std::cout; using std::vector; @@ -43,6 +44,7 @@ enum { ID_repeat = 1, ID_join, ID_find_missing, + ID_properties, ID_re_examine, ID_kdm, ID_remove @@ -55,6 +57,7 @@ ContentMenu::ContentMenu (wxWindow* p) _repeat = _menu->Append (ID_repeat, _("Repeat...")); _join = _menu->Append (ID_join, _("Join")); _find_missing = _menu->Append (ID_find_missing, _("Find missing...")); + _properties = _menu->Append (ID_properties, _("Properties...")); _re_examine = _menu->Append (ID_re_examine, _("Re-examine...")); _kdm = _menu->Append (ID_kdm, _("Add KDM...")); _menu->AppendSeparator (); @@ -63,6 +66,7 @@ ContentMenu::ContentMenu (wxWindow* p) _parent->Bind (wxEVT_COMMAND_MENU_SELECTED, boost::bind (&ContentMenu::repeat, this), ID_repeat); _parent->Bind (wxEVT_COMMAND_MENU_SELECTED, boost::bind (&ContentMenu::join, this), ID_join); _parent->Bind (wxEVT_COMMAND_MENU_SELECTED, boost::bind (&ContentMenu::find_missing, this), ID_find_missing); + _parent->Bind (wxEVT_COMMAND_MENU_SELECTED, boost::bind (&ContentMenu::properties, this), ID_properties); _parent->Bind (wxEVT_COMMAND_MENU_SELECTED, boost::bind (&ContentMenu::re_examine, this), ID_re_examine); _parent->Bind (wxEVT_COMMAND_MENU_SELECTED, boost::bind (&ContentMenu::kdm, this), ID_kdm); _parent->Bind (wxEVT_COMMAND_MENU_SELECTED, boost::bind (&ContentMenu::remove, this), ID_remove); @@ -91,6 +95,7 @@ ContentMenu::popup (weak_ptr<Film> f, ContentList c, TimelineContentViewList v, _join->Enable (n > 1); _find_missing->Enable (_content.size() == 1 && !_content.front()->paths_valid ()); + _properties->Enable (_content.size() == 1); _re_examine->Enable (!_content.empty ()); if (_content.size() == 1) { @@ -315,3 +320,11 @@ ContentMenu::kdm () d->Destroy (); } + +void +ContentMenu::properties () +{ + ContentPropertiesDialog* d = new ContentPropertiesDialog (_parent, _content.front ()); + d->ShowModal (); + d->Destroy (); +} diff --git a/src/wx/content_menu.h b/src/wx/content_menu.h index 5f2a7f7b6..a0ac3f481 100644 --- a/src/wx/content_menu.h +++ b/src/wx/content_menu.h @@ -20,13 +20,14 @@ #ifndef DCPOMATIC_CONTENT_MENU_H #define DCPOMATIC_CONTENT_MENU_H +#include "timeline_content_view.h" +#include "lib/types.h" #include <wx/wx.h> #include <boost/shared_ptr.hpp> #include <boost/weak_ptr.hpp> -#include "timeline_content_view.h" -#include "lib/types.h" class Film; +class Job; class ContentMenu : public boost::noncopyable { @@ -40,6 +41,7 @@ private: void repeat (); void join (); void find_missing (); + void properties (); void re_examine (); void kdm (); void remove (); @@ -54,6 +56,7 @@ private: wxMenuItem* _repeat; wxMenuItem* _join; wxMenuItem* _find_missing; + wxMenuItem* _properties; wxMenuItem* _re_examine; wxMenuItem* _kdm; wxMenuItem* _remove; diff --git a/src/wx/content_properties_dialog.cc b/src/wx/content_properties_dialog.cc new file mode 100644 index 000000000..06184413e --- /dev/null +++ b/src/wx/content_properties_dialog.cc @@ -0,0 +1,74 @@ +/* + Copyright (C) 2015 Carl Hetherington <cth@carlh.net> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + +*/ + +#include "content_properties_dialog.h" +#include "wx_util.h" +#include "lib/raw_convert.h" +#include "lib/content.h" +#include "lib/video_content.h" +#include "lib/audio_content.h" + +using std::string; +using boost::shared_ptr; +using boost::dynamic_pointer_cast; + +ContentPropertiesDialog::ContentPropertiesDialog (wxWindow* parent, shared_ptr<Content> content) + : TableDialog (parent, _("Content Properties"), 2, false) +{ + string n = content->path(0).string(); + boost::algorithm::replace_all (n, "&", "&&"); + add_property (_("Filename"), std_to_wx (n)); + + shared_ptr<VideoContent> video = dynamic_pointer_cast<VideoContent> (content); + if (video) { + add_property ( + _("Video length"), + std_to_wx (raw_convert<string> (video->video_length ().frames (video->video_frame_rate ()))) + " " + _("video frames") + ); + add_property ( + _("Video size"), + std_to_wx (raw_convert<string> (video->video_size().width) + "x" + raw_convert<string> (video->video_size().height)) + ); + add_property ( + _("Video frame rate"), + std_to_wx (raw_convert<string> (video->video_frame_rate())) + " " + _("frames per second") + ); + } + + shared_ptr<AudioContent> audio = dynamic_pointer_cast<AudioContent> (content); + if (audio) { + add_property ( + _("Audio channels"), + std_to_wx (raw_convert<string> (audio->audio_channels ())) + ); + add_property ( + _("Audio length"), + std_to_wx (raw_convert<string> (audio->audio_length().frames (audio->audio_frame_rate ()))) + " " + _("audio frames") + ); + } + + layout (); +} + +void +ContentPropertiesDialog::add_property (wxString k, wxString v) +{ + add (k, true); + add (new wxStaticText (this, wxID_ANY, v)); +} diff --git a/src/wx/content_properties_dialog.h b/src/wx/content_properties_dialog.h new file mode 100644 index 000000000..5c5efa1e8 --- /dev/null +++ b/src/wx/content_properties_dialog.h @@ -0,0 +1,33 @@ +/* + Copyright (C) 2015 Carl Hetherington <cth@carlh.net> + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + +*/ + +#include "table_dialog.h" +#include <boost/shared_ptr.hpp> + +class Content; + +class ContentPropertiesDialog : public TableDialog +{ +public: + ContentPropertiesDialog (wxWindow* parent, boost::shared_ptr<Content> content); + +private: + void add_property (wxString k, wxString v); +}; + diff --git a/src/wx/wscript b/src/wx/wscript index 1b701bb07..7b5904b4b 100644 --- a/src/wx/wscript +++ b/src/wx/wscript @@ -16,6 +16,7 @@ sources = """ content_colour_conversion_dialog.cc content_menu.cc content_panel.cc + content_properties_dialog.cc content_sub_panel.cc dcp_panel.cc image_sequence_dialog.cc |
