#include "ffmpeg_capture.h"
#include "flags.h"
#include "input_mapping.h"
+#include "metrics.h"
#include "pbo_frame_allocator.h"
#include "ref_counted_gl_sync.h"
#include "resampling_queue.h"
desired_output_card_index = global_flags.output_card;
set_output_card_internal(global_flags.output_card);
}
+
+ global_metrics.register_int_metric("frames_output_total", &metric_frames_output_total);
+ global_metrics.register_int_metric("frames_output_dropped", &metric_frames_output_dropped);
+ global_metrics.register_double_metric("uptime_seconds", &metric_uptime_seconds);
}
Mixer::~Mixer()
case PixelFormat_8BitBGRA: {
size_t field_start = video_offset + video_format.stride * field_start_line;
upload_texture(userdata->tex_rgba[field], video_format.width, video_format.height, video_format.stride, interlaced_stride, GL_BGRA, GL_UNSIGNED_INT_8_8_8_8_REV, field_start);
+ // These could be asked to deliver mipmaps at any time.
+ glBindTexture(GL_TEXTURE_2D, userdata->tex_rgba[field]);
+ check_error();
+ glGenerateMipmap(GL_TEXTURE_2D);
+ check_error();
+ glBindTexture(GL_TEXTURE_2D, 0);
+ check_error();
break;
}
default:
now = steady_clock::now();
double elapsed = duration<double>(now - start).count();
+
+ metric_frames_output_total = frame_num;
+ metric_frames_output_dropped = stats_dropped_frames;
+ metric_uptime_seconds = elapsed;
+
if (frame_num % 100 == 0) {
printf("%d frames (%d dropped) in %.3f seconds = %.1f fps (%.1f ms/frame)",
frame_num, stats_dropped_frames, elapsed, frame_num / elapsed,