fix: privacy mode 2, resolution changed (#9027)

Signed-off-by: fufesou <linlong1266@gmail.com>
This commit is contained in:
fufesou 2024-08-11 23:28:02 +08:00 committed by GitHub
parent 6625aca994
commit 99d7b62d79
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -540,7 +540,7 @@ fn run(vs: VideoService) -> ResultType<()> {
VRamEncoder::set_fallback_gdi(display_idx, true);
bail!("SWITCH");
}
check_privacy_mode_changed(&sp, c.privacy_mode_id)?;
check_privacy_mode_changed(&sp, display_idx, &c)?;
#[cfg(windows)]
{
if crate::platform::windows::desktop_changed()
@ -659,7 +659,7 @@ fn run(vs: VideoService) -> ResultType<()> {
let timeout_millis = 3_000u64;
let wait_begin = Instant::now();
while wait_begin.elapsed().as_millis() < timeout_millis as _ {
check_privacy_mode_changed(&sp, c.privacy_mode_id)?;
check_privacy_mode_changed(&sp, display_idx, &c)?;
frame_controller.try_wait_next(&mut fetched_conn_ids, 300);
// break if all connections have received current frame
if fetched_conn_ids.len() >= frame_controller.send_conn_ids.len() {
@ -876,9 +876,13 @@ fn check_change_scale(hardware: bool) -> ResultType<()> {
Ok(())
}
fn check_privacy_mode_changed(sp: &GenericService, privacy_mode_id: i32) -> ResultType<()> {
fn check_privacy_mode_changed(
sp: &GenericService,
display_idx: usize,
ci: &CapturerInfo,
) -> ResultType<()> {
let privacy_mode_id_2 = get_privacy_mode_conn_id().unwrap_or(INVALID_PRIVACY_MODE_CONN_ID);
if privacy_mode_id != privacy_mode_id_2 {
if ci.privacy_mode_id != privacy_mode_id_2 {
if privacy_mode_id_2 != INVALID_PRIVACY_MODE_CONN_ID {
let msg_out = crate::common::make_privacy_mode_msg(
back_notification::PrivacyModeState::PrvOnByOther,
@ -887,6 +891,7 @@ fn check_privacy_mode_changed(sp: &GenericService, privacy_mode_id: i32) -> Resu
sp.send_to_others(msg_out, privacy_mode_id_2);
}
log::info!("switch due to privacy mode changed");
try_broadcast_display_changed(&sp, display_idx, ci, true).ok();
bail!("SWITCH");
}
Ok(())