static inline void switch_calc_fps(switch_fps_t *fpsP, float fps, int samplerate)
{
- fpsP->fps = fps;
- fpsP->ms = (int)(1000 / fps);
- fpsP->samples = (int)(samplerate / fps);
+ /*
+ implicit/truncf() - leave us with equal-or-smaller ms and thus equal-or-bigger fps, which is better for quality (than roundf()).
+ also equal-or-bigger fps is better for things like (int)fps
+ */
+ fpsP->ms = (int)(1000.0f / fps);
+ fpsP->fps = 1000.0f / fpsP->ms;
+ fpsP->samples = (int)(samplerate / 1000 * fpsP->ms); // samplerate 99.99% is a factor of 1000, so we safe here with integer div by 1000
return;
}
#define switch_calc_video_fps(fpsP, fps) switch_calc_fps(fpsP, fps, 90000)
member->blanks++;
- if (member->blanks == member->conference->video_fps.fps || (member->blanks % (int)(member->conference->video_fps.fps * 10)) == 0) {
+ if (member->blanks == (int)member->conference->video_fps.fps || (member->blanks % (int)(member->conference->video_fps.fps * 10)) == 0) {
switch_core_session_request_video_refresh(member->session);
member->good_img = 0;
}
- if (member->blanks == member->conference->video_fps.fps * 5) {
+ if (member->blanks == (int)(member->conference->video_fps.fps * 5)) {
member->blackouts++;
conference_video_check_avatar(member, SWITCH_TRUE);
conference_video_clear_managed_kps(member);
}
if ((kps_in = switch_calc_bitrate(vid_params.width, vid_params.height,
- member->conference->video_quality, (int)(member->conference->video_fps.fps))) < 512) {
+ member->conference->video_quality, member->conference->video_fps.fps)) < 512) {
kps_in = 512;
}
if (layer) {
- kps = switch_calc_bitrate(screen_w, screen_h, member->conference->video_quality, (int)(member->conference->video_fps.fps));
+ kps = switch_calc_bitrate(screen_w, screen_h, member->conference->video_quality, member->conference->video_fps.fps);
} else {
kps = kps_in;
}
if (imember->channel && !switch_channel_test_flag(imember->channel, CF_VIDEO_BITRATE_UNMANAGABLE) &&
conference_utils_test_flag(conference, CFLAG_MANAGE_INBOUND_VIDEO_BITRATE)) {
switch_core_media_get_vid_params(imember->session, &vid_params);
- kps = switch_calc_bitrate(vid_params.width, vid_params.height, conference->video_quality, (int)(imember->conference->video_fps.fps));
+ kps = switch_calc_bitrate(vid_params.width, vid_params.height, conference->video_quality, imember->conference->video_fps.fps);
conference_video_set_incoming_bitrate(imember, kps, SWITCH_TRUE);
}
}
break;
}
size = switch_queue_size(canvas->video_queue);
- } while(size > canvas->conference->video_fps.fps / 2);
+ } while(size > (int)(canvas->conference->video_fps.fps / 2));
*imgP = img;
}
if (frame->img && (((member->video_layer_id > -1) && canvas_id > -1) || member->canvas) &&
conference_utils_member_test_flag(member, MFLAG_CAN_BE_SEEN) &&
!conference_utils_member_test_flag(member, MFLAG_HOLD) &&
- switch_queue_size(member->video_queue) < member->conference->video_fps.fps &&
+ switch_queue_size(member->video_queue) < (int)member->conference->video_fps.fps &&
!member->conference->canvases[canvas_id]->playing_video_file) {
if (conference_utils_member_test_flag(member, MFLAG_FLIP_VIDEO) ||
switch_rtp_engine_t *v_engine;
int buflen = SWITCH_RTP_MAX_BUF_LEN;
switch_timer_t timer = { 0 };
- int fps;
switch_video_read_flag_t read_flags = SVR_BLOCK;
switch_core_session_t *b_session = NULL;
switch_fps_t fps_data = { 0 };
+ float fps;
switch_image_t *last_frame = NULL;
if (switch_core_session_read_lock(session) != SWITCH_STATUS_SUCCESS) {
if (smh->video_write_fh && smh->video_write_fh->mm.source_fps) {
- fps = (int) smh->video_write_fh->mm.source_fps;
- } else {
+ fps = smh->video_write_fh->mm.source_fps;
+ } else if (video_globals.fps) {
fps = video_globals.fps;
- }
-
- if (!fps) {
+ } else {
fps = 15;
}
-
-
switch_calc_video_fps(&fps_data, fps);
+
switch_core_timer_init(&timer, "soft", fps_data.ms, fps_data.samples, switch_core_session_get_pool(session));
while (smh->video_write_thread_running > 0 &&
switch_img_fill(last_frame, 0, 0, last_frame->d_w, last_frame->d_h, &bgcolor);
fr.img = last_frame;
- for (x = 0; x < fps_data.fps / 2; x++) {
+ for (x = 0; x < (int)(fps_data.fps / 2); x++) {
switch_core_timer_next(&timer);
fr.timestamp = timer.samplecount;
fr.flags = SFF_USE_VIDEO_TIMESTAMP|SFF_RAW_RTP|SFF_RAW_RTP_PARSE_FRAME;
switch_frame_t frame = { 0 };
switch_timer_t timer = { 0 };
switch_mm_t mm = { 0 };
- int fps = 15;
int vw = 1280;
int vh = 720;
int last_w = 0, last_h = 0, other_last_w = 0, other_last_h = 0;
switch_fps_t fps_data = { 0 };
+ float fps;
switch_rgb_color_t color = { 0 };
switch_color_set_rgb(&color, "#000000");
switch_core_media_bug_get_media_params(bug, &mm);
- if (mm.fps) {
- fps = (int) mm.fps;
- }
-
if (mm.vw) vw = mm.vw;
if (mm.vh) vh = mm.vh;
+ if (mm.fps) {
+ fps = mm.fps;
+ } else {
+ fps = 15;
+ }
switch_calc_video_fps(&fps_data, fps);
+
switch_core_timer_init(&timer, "soft", fps_data.ms, fps_data.samples, NULL);
while (bug->ready) {