summaryrefslogtreecommitdiff
path: root/ar/.local/bin/setmonitor
diff options
context:
space:
mode:
authorTheSiahxyz <164138827+TheSiahxyz@users.noreply.github.com>2025-01-25 16:59:57 +0900
committerTheSiahxyz <164138827+TheSiahxyz@users.noreply.github.com>2025-01-25 16:59:57 +0900
commit53bccfc0ef68cea3e1dc0ac0570871c34076af65 (patch)
tree9e485045a1b83ee5efff6c0c9d6aaf46ab96fd4f /ar/.local/bin/setmonitor
parent75368fd96d4a8e8854357599ff03bfb0c18c6c31 (diff)
modified x11/xprofile, modified bin/setmonitor
Diffstat (limited to 'ar/.local/bin/setmonitor')
-rwxr-xr-xar/.local/bin/setmonitor24
1 files changed, 16 insertions, 8 deletions
diff --git a/ar/.local/bin/setmonitor b/ar/.local/bin/setmonitor
index 66e2284..9fe36c9 100755
--- a/ar/.local/bin/setmonitor
+++ b/ar/.local/bin/setmonitor
@@ -1,9 +1,17 @@
#!/bin/sh
# Parse connected displays
-default="--mode 1920x1080 --rotate normal --scale 1.0x1.0 --dpi 96"
+default="--mode 1920x1080 --rotate normal --scale 1.0x1.0"
+default_dpi=96
+displays=$(xrandr -q | grep -w "connected")
+x=$(echo "$displays" | grep "mm" | sed -E "s/.* ([0-9]+)mm x ([0-9]+)mm.*/\1/")
+y=$(echo "$displays" | grep "mm" | sed -E "s/.* ([0-9]+)mm x ([0-9]+)mm.*/\2/")
+calx=$(((1920 + (x / 10) - 1) / (x / 10))) # Ceiling for x
+caly=$(((1080 + (y / 10) - 1) / (y / 10))) # Ceiling for y
+dpi=$(if [ "$calx" -gt "$caly" ]; then echo "$calx"; else echo "$caly"; fi)
+dpi=$(if [ "$dpi" -lt "$default_dpi" ]; then echo "$default_dpi"; else echo "$dpi"; fi)
-for connected in $(xrandr -q | grep "\sconnected" | awk '{print $1}'); do
+for connected in $(echo "$displays" | cut -d ' ' -f 1); do
case $connected in
eDP*) edp="$connected" ;;
HDMI*) hdmi="$connected" ;;
@@ -15,20 +23,20 @@ done
# If the lid is closed, turn off the laptop's screen
if grep -q "disabled" /sys/class/drm/card0-eDP-1/enabled || grep -q "closed" /proc/acpi/button/lid/LID/state; then
if [ -n "$hdmi" ] && [ -z "$dp" ] && [ -n "$edp" ]; then
- xrandr --output "$edp" --off --output "$hdmi" --primary $default
+ xrandr --output "$edp" --off --output "$hdmi" --primary $default --dpi "$dpi"
elif [ -z "$hdmi" ] && [ -n "$dp" ] && [ -n "$edp" ]; then
- xrandr --output "$edp" --off --output "$dp" --primary $default
+ xrandr --output "$edp" --off --output "$dp" --primary $default --dpi "$dpi"
else
- xrandr --output "$edp" --off --output "$display" --primary $default
+ xrandr --output "$edp" --off --output "$display" --primary $default --dpi "$dpi"
fi
else
# Apply display settings when lid is open
if [ -n "$hdmi" ] && [ -z "$dp" ] && [ -n "$edp" ]; then
- xrandr --output "$edp" --pos 1920x0 $default --output "$hdmi" --primary --pos 0x0 $default
+ xrandr --output "$edp" --pos 1920x0 $default --dpi "$dpi" --output "$hdmi" --primary --pos 0x0 $default --dpi "$dpi"
elif [ -z "$hdmi" ] && [ -n "$dp" ] && [ -n "$edp" ]; then
- xrandr --output "$edp" --pos 1920x0 $default --output "$dp" --primary --pos 0x0 $default
+ xrandr --output "$edp" --pos 1920x0 $default --dpi "$dpi" --output "$dp" --primary --pos 0x0 $default --dpi "$dpi"
elif [ -z "$hdmi" ] && [ -z "$dp" ] && [ -n "$edp" ]; then
- xrandr --output "$edp" --primary $default
+ xrandr --output "$edp" --primary $default --dpi "$dpi"
else
xrandr --output "$display" --primary --auto
fi