diff options
Diffstat (limited to 'ar')
| -rw-r--r-- | ar/.config/x11/xprofile | 26 | ||||
| -rwxr-xr-x | ar/.local/bin/setmonitor | 24 |
2 files changed, 17 insertions, 33 deletions
diff --git a/ar/.config/x11/xprofile b/ar/.config/x11/xprofile index c8de159..400d8c3 100644 --- a/ar/.config/x11/xprofile +++ b/ar/.config/x11/xprofile @@ -1,16 +1,8 @@ #!/bin/sh -default="--mode 1920x1080 --rotate normal --scale 1.0x1.0" -default_dpi=96 # adjust the number if the resolution is higher than 1920x1080 or monitor size is bigger than 24" -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 $(echo "$displays" | cut -d ' ' -f 1); do +default="--mode 1920x1080 --rotate normal --scale 1.0x1.0 --dpi 96" + +for connected in $(xrandr -q | grep -w "connected" | cut -d ' ' -f 1); do case $connected in eDP*) edp="$connected" ;; HDMI*) hdmi="$connected" ;; @@ -22,20 +14,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 --dpi "$dpi" + xrandr --output "$edp" --off --output "$hdmi" --primary $default elif [ -z "$hdmi" ] && [ -n "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --off --output "$dp" --primary $default --dpi "$dpi" + xrandr --output "$edp" --off --output "$dp" --primary $default else - xrandr --output "$edp" --off --output "$display" --primary $default --dpi "$dpi" + xrandr --output "$edp" --off --output "$display" --auto --primary $default fi else # Apply display settings when lid is open if [ -n "$hdmi" ] && [ -z "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --pos 1920x0 $default --dpi "$dpi" --output "$hdmi" --primary --pos 0x0 $default --dpi "$dpi" + xrandr --output "$edp" --pos 1920x0 $default --output "$hdmi" --primary --pos 0x0 $default elif [ -z "$hdmi" ] && [ -n "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --pos 1920x0 $default --dpi "$dpi" --output "$dp" --primary --pos 0x0 $default --dpi "$dpi" + xrandr --output "$edp" --pos 1920x0 $default --output "$dp" --primary --pos 0x0 $default elif [ -z "$hdmi" ] && [ -z "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --primary $default --dpi "$dpi" + xrandr --output "$edp" --primary $default else xrandr --output "$display" --primary --auto fi diff --git a/ar/.local/bin/setmonitor b/ar/.local/bin/setmonitor index 9fe36c9..18c054a 100755 --- a/ar/.local/bin/setmonitor +++ b/ar/.local/bin/setmonitor @@ -1,17 +1,9 @@ #!/bin/sh # Parse connected displays -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) +default="--mode 1920x1080 --rotate normal --scale 1.0x1.0 --dpi 96" -for connected in $(echo "$displays" | cut -d ' ' -f 1); do +for connected in $(xrandr -q | grep -w "connected" | cut -d ' ' -f 1); do case $connected in eDP*) edp="$connected" ;; HDMI*) hdmi="$connected" ;; @@ -23,20 +15,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 --dpi "$dpi" + xrandr --output "$edp" --off --output "$hdmi" --primary $default elif [ -z "$hdmi" ] && [ -n "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --off --output "$dp" --primary $default --dpi "$dpi" + xrandr --output "$edp" --off --output "$dp" --primary $default else - xrandr --output "$edp" --off --output "$display" --primary $default --dpi "$dpi" + xrandr --output "$edp" --off --output "$display" --auto --primary $default fi else # Apply display settings when lid is open if [ -n "$hdmi" ] && [ -z "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --pos 1920x0 $default --dpi "$dpi" --output "$hdmi" --primary --pos 0x0 $default --dpi "$dpi" + xrandr --output "$edp" --pos 1920x0 $default --output "$hdmi" --primary --pos 0x0 $default elif [ -z "$hdmi" ] && [ -n "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --pos 1920x0 $default --dpi "$dpi" --output "$dp" --primary --pos 0x0 $default --dpi "$dpi" + xrandr --output "$edp" --pos 1920x0 $default --output "$dp" --primary --pos 0x0 $default elif [ -z "$hdmi" ] && [ -z "$dp" ] && [ -n "$edp" ]; then - xrandr --output "$edp" --primary $default --dpi "$dpi" + xrandr --output "$edp" --primary $default else xrandr --output "$display" --primary --auto fi |
