-Subproject commit bb575c1ac8b1496394732800898c27a3a812f0a9
+Subproject commit b3aaee8df3039891d79f4f673e6a8050d3fb65b5
VideoFormat video_format;
if (video_frame) {
- if (video_frame->GetFlags() & bmdFrameHasNoInputSource) {
- // TODO: Make a way to propagate this flag down to the theme code,
- // independent of the signal resolution.
- fprintf(stderr, "Warning: No input signal detected\n");
- }
+ video_format.has_signal = !(video_frame->GetFlags() & bmdFrameHasNoInputSource);
int width = video_frame->GetWidth();
int height = video_frame->GetHeight();
clock_gettime(CLOCK_MONOTONIC, &frame_upload_start);
}
userdata->last_interlaced = video_format.interlaced;
+ userdata->last_has_signal = video_format.has_signal;
userdata->last_frame_rate_nom = video_format.frame_rate_nom;
userdata->last_frame_rate_den = video_format.frame_rate_den;
RefCountedFrame new_frame(video_frame);
userdata[i].last_width[1] = 0;
userdata[i].last_height[1] = 0;
userdata[i].last_interlaced = false;
+ userdata[i].last_has_signal = false;
for (unsigned field = 0; field < 2; ++field) {
glBindTexture(GL_TEXTURE_2D, userdata[i].tex_y[field]);
check_error();
// The second set is only used for the second field of interlaced inputs.
GLuint tex_y[2], tex_cbcr[2];
GLuint last_width[2], last_height[2];
- bool last_interlaced;
+ bool last_interlaced, last_has_signal;
unsigned last_frame_rate_nom, last_frame_rate_den;
};
InputStateInfo(const InputState& input_state);
unsigned last_width[MAX_CARDS], last_height[MAX_CARDS];
- bool last_interlaced[MAX_CARDS];
+ bool last_interlaced[MAX_CARDS], last_has_signal[MAX_CARDS];
unsigned last_frame_rate_nom[MAX_CARDS], last_frame_rate_den[MAX_CARDS];
};
if (frame.frame == nullptr) {
last_width[signal_num] = last_height[signal_num] = 0;
last_interlaced[signal_num] = false;
+ last_has_signal[signal_num] = false;
continue;
}
const PBOFrameAllocator::Userdata *userdata = (const PBOFrameAllocator::Userdata *)frame.frame->userdata;
last_width[signal_num] = userdata->last_width[frame.field_number];
last_height[signal_num] = userdata->last_height[frame.field_number];
last_interlaced[signal_num] = userdata->last_interlaced;
+ last_has_signal[signal_num] = userdata->last_has_signal;
last_frame_rate_nom[signal_num] = userdata->last_frame_rate_nom;
last_frame_rate_den[signal_num] = userdata->last_frame_rate_den;
}
return 1;
}
+int InputStateInfo_get_has_signal(lua_State* L)
+{
+ assert(lua_gettop(L) == 2);
+ InputStateInfo *input_state_info = get_input_state_info(L, 1);
+ Theme *theme = get_theme_updata(L);
+ int signal_num = theme->map_signal(luaL_checknumber(L, 2));
+ lua_pushboolean(L, input_state_info->last_has_signal[signal_num]);
+ return 1;
+}
+
int InputStateInfo_get_frame_rate_nom(lua_State* L)
{
assert(lua_gettop(L) == 2);
{ "get_width", InputStateInfo_get_width },
{ "get_height", InputStateInfo_get_height },
{ "get_interlaced", InputStateInfo_get_interlaced },
+ { "get_has_signal", InputStateInfo_get_has_signal },
{ "get_frame_rate_nom", InputStateInfo_get_frame_rate_nom },
{ "get_frame_rate_den", InputStateInfo_get_frame_rate_den },
{ NULL, NULL }
-- to the next.
local FADE_SIGNAL_NUM = 4
--- Last width/height/resolution for each channel, if we have it.
+-- Last width/height/frame rate for each channel, if we have it.
-- Note that unlike the values we get from Nageru, the resolution is per
-- frame and not per field, since we deinterlace.
local last_resolution = {}
-- Helper function to write e.g. “720p60”.
function get_channel_resolution(signal_num)
if last_resolution[signal_num] then
- if last_resolution[signal_num].height == 0 or
- last_resolution[signal_num].height == 525 then
+ if not last_resolution[signal_num].has_signal then
return "no signal"
elseif last_resolution[signal_num].interlaced then
return last_resolution[signal_num].height .. "i" .. get_frame_rate(signal_num)
width = signals:get_width(signal_num),
height = signals:get_height(signal_num),
interlaced = signals:get_interlaced(signal_num),
+ has_signal = signals:get_has_signal(signal_num),
frame_rate_nom = signals:get_frame_rate_nom(signal_num),
frame_rate_den = signals:get_frame_rate_den(signal_num)
}