X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fwx%2Fplayer_information.cc;h=2139d830dae77b6bd15662c09373d806dbbd1d48;hb=0e28e29976f7b61ba8d76140a4a7ebc8fa8e80a4;hp=e79e716227286ea6c5bcbde67cc83833e5d58971;hpb=709a3af8ac11cdeb688f2d77209e036a88b3c714;p=dcpomatic.git diff --git a/src/wx/player_information.cc b/src/wx/player_information.cc index e79e71622..2139d830d 100644 --- a/src/wx/player_information.cc +++ b/src/wx/player_information.cc @@ -22,11 +22,17 @@ #include "wx_util.h" #include "film_viewer.h" #include "lib/playlist.h" +#include "lib/compose.hpp" +#include "lib/video_content.h" #include "lib/dcp_content.h" using std::cout; +using std::string; using boost::shared_ptr; using boost::dynamic_pointer_cast; +using boost::optional; + +static int const dcp_lines = 4; PlayerInformation::PlayerInformation (wxWindow* parent, FilmViewer* viewer) : wxPanel (parent) @@ -36,38 +42,95 @@ PlayerInformation::PlayerInformation (wxWindow* parent, FilmViewer* viewer) wxFont title_font (*wxNORMAL_FONT); title_font.SetWeight (wxFONTWEIGHT_BOLD); + _dcp = new wxStaticText*[dcp_lines]; + { wxSizer* s = new wxBoxSizer (wxVERTICAL); add_label_to_sizer(s, this, _("DCP"), false, 0)->SetFont(title_font); - _cpl_name = add_label_to_sizer(s, this, wxT(""), false, 0); + for (int i = 0; i < dcp_lines; ++i) { + _dcp[i] = add_label_to_sizer(s, this, wxT(""), false, 0); + } _sizer->Add (s, 1, wxEXPAND | wxALL, 6); } { wxSizer* s = new wxBoxSizer (wxVERTICAL); add_label_to_sizer(s, this, _("Performance"), false, 0)->SetFont(title_font); - _decoded_fps = add_label_to_sizer(s, this, wxT(""), false, 0); + _dropped = add_label_to_sizer(s, this, wxT(""), false, 0); + _decode_resolution = add_label_to_sizer(s, this, wxT(""), false, 0); _sizer->Add (s, 1, wxEXPAND | wxALL, 6); } SetSizerAndFit (_sizer); - update (); + triggered_update (); + + Bind (wxEVT_TIMER, boost::bind (&PlayerInformation::periodic_update, this)); + _timer.reset (new wxTimer (this)); + _timer->Start (500); +} + +void +PlayerInformation::periodic_update () +{ + checked_set (_dropped, wxString::Format(_("Dropped frames: %d"), _viewer->dropped())); } void -PlayerInformation::update () +PlayerInformation::triggered_update () { - wxString cpl_name; + shared_ptr dcp; if (_viewer->film()) { ContentList content = _viewer->film()->content(); if (content.size() == 1) { - shared_ptr dcp = dynamic_pointer_cast(content.front()); - if (dcp) { - cpl_name = std_to_wx (dcp->name()); - } + dcp = dynamic_pointer_cast(content.front()); + } + } + + if (!dcp) { + checked_set (_dcp[0], _("No DCP loaded.")); + for (int r = 1; r < dcp_lines; ++r) { + checked_set (_dcp[r], wxT("")); } + checked_set (_decode_resolution, wxT("")); + return; + } + + int r = 0; + checked_set (_dcp[r++], std_to_wx(dcp->name())); + + if (dcp->needs_assets()) { + checked_set (_dcp[r], _("Needs OV")); + return; + } + + if (dcp->needs_kdm()) { + checked_set (_dcp[r], _("Needs KDM")); + return; + } + + DCPOMATIC_ASSERT (dcp->video); + + checked_set (_dcp[r++], wxString::Format(_("Size: %dx%d"), dcp->video->size().width, dcp->video->size().height)); + + optional vfr; + vfr = dcp->video_frame_rate (); + DCPOMATIC_ASSERT (vfr); + + string const len = String::compose( + wx_to_std(_("Length: %1 (%2 frames)")), + time_to_hmsf(dcp->full_length(), lrint(*vfr)), + dcp->full_length().frames_round(*vfr) + ); + + checked_set (_dcp[r++], std_to_wx(len)); + + dcp::Size decode = dcp->video->size(); + optional reduction = _viewer->dcp_decode_reduction(); + if (reduction) { + decode.width /= pow(2, *reduction); + decode.height /= pow(2, *reduction); } - checked_set (_cpl_name, cpl_name); + checked_set (_decode_resolution, wxString::Format(_("Decode resolution: %dx%d"), decode.width, decode.height)); }