X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fplayer_information.cc;h=4e95e0956fb208de2e17b57553923beb2f1744ce;hb=6ebec6b3ca11a7062ae19176096b1b157275d015;hp=6bb138c055587e98047a95e5eba4c9b5eefbc73a;hpb=e20996d81f0bb17ca922c065ef7480ab43de1b0e;p=dcpomatic.git diff --git a/src/wx/player_information.cc b/src/wx/player_information.cc index 6bb138c05..4e95e0956 100644 --- a/src/wx/player_information.cc +++ b/src/wx/player_information.cc @@ -42,7 +42,7 @@ using boost::optional; static int const dcp_lines = 6; -PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr viewer) +PlayerInformation::PlayerInformation(wxWindow* parent, FilmViewer const& viewer) : wxPanel (parent) , _viewer (viewer) , _sizer (new wxBoxSizer (wxHORIZONTAL)) @@ -72,6 +72,20 @@ PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr vie _sizer->Add (s, 1, wxEXPAND | wxALL, 6); } + { + _kdm_panel = new wxPanel(this, wxID_ANY); + auto s = new wxBoxSizer(wxVERTICAL); + add_label_to_sizer(s, _kdm_panel, _("KDM"), false, 0)->SetFont(title_font); + auto g = new wxGridBagSizer(0, DCPOMATIC_SIZER_GAP); + add_label_to_sizer(g, _kdm_panel, _("Valid from"), true, wxGBPosition(0, 0)); + _kdm_from = add_label_to_sizer(g, _kdm_panel, wxT(""), false, wxGBPosition(0, 1)); + add_label_to_sizer(g, _kdm_panel, _("Valid to"), true, wxGBPosition(1, 0)); + _kdm_to = add_label_to_sizer(g, _kdm_panel, wxT(""), false, wxGBPosition(1, 1)); + s->Add(g, 1, wxEXPAND | wxLEFT, DCPOMATIC_SIZER_GAP); + _kdm_panel->SetSizer(s); + _sizer->Add(_kdm_panel, 1, wxEXPAND | wxALL, 6); + } + { auto s = new wxBoxSizer (wxVERTICAL); add_label_to_sizer(s, this, _("Performance"), false, 0)->SetFont(title_font); @@ -93,30 +107,22 @@ PlayerInformation::PlayerInformation (wxWindow* parent, weak_ptr vie void PlayerInformation::periodic_update () { - auto fv = _viewer.lock (); - if (fv) { - auto s = wxString::Format(_("Dropped frames: %d"), fv->dropped() + fv->errored()); - if (fv->errored() == 1) { - s += wxString::Format(_(" (%d error)"), fv->errored()); - } else if (fv->errored() > 1) { - s += wxString::Format(_(" (%d errors)"), fv->errored()); - } - checked_set (_dropped, s); + auto s = wxString::Format(_("Dropped frames: %d"), _viewer.dropped() + _viewer.errored()); + if (_viewer.errored() == 1) { + s += wxString::Format(_(" (%d error)"), _viewer.errored()); + } else if (_viewer.errored() > 1) { + s += wxString::Format(_(" (%d errors)"), _viewer.errored()); } + checked_set (_dropped, s); } void PlayerInformation::triggered_update () { - auto fv = _viewer.lock (); - if (!fv) { - return; - } - shared_ptr dcp; - if (fv->film()) { - auto content = fv->film()->content(); + if (_viewer.film()) { + auto content = _viewer.film()->content(); if (content.size() == 1) { dcp = dynamic_pointer_cast(content.front()); } @@ -128,11 +134,20 @@ PlayerInformation::triggered_update () checked_set (_dcp[r], wxT("")); } checked_set (_decode_resolution, wxT("")); + _kdm_panel->Hide(); return; } int r = 0; - checked_set (_dcp[r++], std_to_wx(dcp->name())); + checked_set(_dcp[r], std_to_wx(dcp->name())); + wxString tooltip; + for (auto directory: dcp->directories()) { + tooltip += std_to_wx(directory.string()) + "\n"; + } + if (!tooltip.empty()) { + _dcp[r]->SetToolTip(tooltip.substr(0, tooltip.length() - 1)); + } + ++r; if (dcp->needs_assets()) { checked_set (_dcp[r], _("Needs OV")); @@ -165,14 +180,14 @@ PlayerInformation::triggered_update () auto const len = String::compose( wx_to_std(_("Length: %1 (%2 frames)")), - time_to_hmsf(dcp->full_length(fv->film()), lrint(*vfr)), - dcp->full_length(fv->film()).frames_round(*vfr) + time_to_hmsf(dcp->full_length(_viewer.film()), lrint(*vfr)), + dcp->full_length(_viewer.film()).frames_round(*vfr) ); checked_set (_dcp[r++], std_to_wx(len)); auto decode = dcp->video->size(); - auto reduction = fv->dcp_decode_reduction(); + auto reduction = _viewer.dcp_decode_reduction(); if (reduction) { decode.width /= pow(2, *reduction); decode.height /= pow(2, *reduction); @@ -182,5 +197,16 @@ PlayerInformation::triggered_update () DCPOMATIC_ASSERT(r <= dcp_lines); + if (dcp->encrypted() && dcp->kdm()) { + _kdm_panel->Show(); + auto const kdm = *dcp->kdm(); + auto const before = kdm.not_valid_before(); + checked_set(_kdm_from, wxString::Format(_("%s %s"), std_to_wx(before.date()), std_to_wx(before.time_of_day(true, false)))); + auto const after = kdm.not_valid_after(); + checked_set(_kdm_to, wxString::Format(_("%s %s"), std_to_wx(after.date()), std_to_wx(after.time_of_day(true, false)))); + } else { + _kdm_panel->Hide(); + } + _sizer->Layout (); }