From 5383bc66ac53ceccd321e6a671a529a5e5f6519c Mon Sep 17 00:00:00 2001 From: Federico Rampazzo Date: Wed, 9 Dec 2020 02:45:33 +0000 Subject: [PATCH] Swapped vent color and lowered area tresholds to handle overlapping arrows --- Cargo.lock | 6 +++--- joystick-mapper-among-us/src/vent.rs | 6 +++--- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index a1db9cc..dd3715f 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -320,7 +320,7 @@ checksum = "dc6f3ad7b9d11a0c00842ff8de1b60ee58661048eb8049ed33c73594f359d7e6" [[package]] name = "joystick-mapper" -version = "0.2.0" +version = "0.3.0" dependencies = [ "joystick-mapper-lib", "serde", @@ -329,7 +329,7 @@ dependencies = [ [[package]] name = "joystick-mapper-among-us" -version = "0.2.0" +version = "0.3.0" dependencies = [ "enigo", "joystick-mapper-lib", @@ -341,7 +341,7 @@ dependencies = [ [[package]] name = "joystick-mapper-lib" -version = "0.2.0" +version = "0.3.0" dependencies = [ "enigo", "fxhash", diff --git a/joystick-mapper-among-us/src/vent.rs b/joystick-mapper-among-us/src/vent.rs index e503219..55bfcde 100644 --- a/joystick-mapper-among-us/src/vent.rs +++ b/joystick-mapper-among-us/src/vent.rs @@ -28,9 +28,9 @@ pub fn select_vent( let mut mask_emergency: Mat = Mat::default(); let mut mask_all = Mat::default(); // venting arrows have two colors, this will give us, half an arrow - let target = (184, 179, 169); + let target = (218, 215, 209); // the dark part of the arrow is 184, 179, 169 // during an emergency the screen flashes red changing the color of the arrow - let target_emergency = (116, 112, 201); + let target_emergency = (137, 135, 226); // the dark part of the arrow is 116, 112, 201 let delta = 1; let lower_color_mat = Mat::new_from_bytes(1, 4, CV_8UC1, &[target.0 - delta, target.1 - delta, target.2 - delta, 255]); let upper_color_mat = Mat::new_from_bytes(1, 4, CV_8UC1, &[target.0 + delta, target.1 + delta, target.2 + delta, 255]); @@ -83,7 +83,7 @@ pub fn select_vent( vents.sort_by(|a, b| b.0.partial_cmp(&a.0).expect("NaN sorting vents by area")); let max_area = vents[0].0; for (i, vent) in vents.iter().enumerate() { - if vent.0 / max_area < 0.9 { + if vent.0 / max_area < 0.5 { vents.truncate(i); break; }