Отримати поточний рівень гучності в OS X Terminal CLI?


17

Я хотів би перевірити поточний рівень гучності від CLI на моєму Mac. Я знаю, що можу це встановити так:

osascript -e 'set volume <N>'

Але це, мабуть, не спрацює при спробі отримати поточний рівень гучності.

$ osascript -e 'get volume'
4:10: execution error: The variable volume is not defined. (-2753)

Відповіді:


18

Ви повинні виявити, що get volume settingsповерне об'єкт, що містить, між іншим, вихідний обсяг і гучність сповіщення. Так, наприклад, ви можете зробити це для отримання всього об'єкта:

osascript -e 'get volume settings'

а точніше, можливо, це захоплює лише вихідний об'єм (наприклад, замість гучності сповіщення):

osascript -e 'set ovol to output volume of (get volume settings)'

... але зауважте, що не всі аудіопристрої матимуть прямий програмний контроль над налаштуваннями гучності. Наприклад, ваш звуковий дисплей повинен мати контроль; однак, на платформі Firewire або USB вводу / виводу, ймовірно, не було б цих налаштувань під контролем програмного забезпечення (оскільки вони можуть бути фізичними ручками). Якщо конкретний параметр не знаходиться під контролем програмного забезпечення, він відображатиметься в об'єкті, поверненому з get volume settings"відсутнім значенням" або чимось подібним.


get volume settingsнасправді не розрізняє 0, 0,1 та 0,01. Він не показує десяткових значень, що робить його марним.
Acumenus

@ABB, чудова пропозиція. Дякуємо за ваш внесок.
ghoti

5

Я здійснив дуже скромний сценарій башти з назвою "чут". По мірі того, як мені набридло об'єм sys, який вимагає плаваючої точки в якості входу (від 0 до 10 кроку 0,1), але виводить ціле число з кроком 14, що становить від 0 до 100.

Подивіться цифри ... Якщо когось цікавить: http://github.com/docgyneco69/chut

У всій красі:

#!/bin/bash
## CHUT script
## Note: regex [[:digit:]] requires a relatively recent shell
## easy to change with a sed cmd if needed
## applescript arg is not fully bullet proofed for sneaky cmds
## but as no outside arg is passed by the script I kept the usual
## arg format for code readibility (and pure laziness)

# init _x and curr_vol with defaults values (muting)
_x='- 100' ; curr_vol='0' ;

function _usage {echo -e "CHUT is a simple cmd exe to change the system audio volume.
USAGE chut [][-][--][+][++]
      no arg will mute (default)
      [-][+] [--][++] to decrease or increase the volume
      [+++] to set to the maximum
      [-h][--help] display this message
NOTE sys sets volume as float (0-10/0.1) but outputs int (0-100/14)" ; exit 1 ; } ;

# set _x by looping $1 then break as we only use 1st arg, -h or --help to print usage
while [[ "$1" ]]; do case "$1" in
    "-h"|"--help")  _usage      ;;
    "-")        _x='- 0.5'  ;;
    "--")       _x='- 1.0'  ;;
    "+")        _x='+ 0.5'  ;;
    "++")       _x='+ 1.0'  ;;
    "+++")      _x='+ 100'  ;;
    *)      _x='- 100'  ;; # unrecognized values will mute
esac ; break ; done ;

# get current volume value from system (sys volume is 0 to 100 step 14)
curr_vol=$(/usr/bin/osascript -e "get volume settings" | cut -d ',' -f1 | tr -dc [[:digit:]]) ;

# set new volume via _x - use bc for floating point, escape potential errors, 
# print value with one decimal - test & echo the new volume value via applescript
curr_vol=$( printf "%.1f" "$( echo "$curr_vol / 14 $_x" | bc -l 2>&-)" ) ;
(/usr/bin/osascript -e "set Volume "\"$curr_vol"\" ") && \
echo $(/usr/bin/osascript -e "get volume settings" | cut -d ',' -f1 | tr -dc [[:digit:]]) ;

exit 0 ;

0

Отримання та налаштування гучності за допомогою тієї самої шкали 1..100:

# Get current volume as a number from 0 to 100
current_vol=$(osascript -e 'output volume of (get volume settings)')

# Prank co-worker by playing loud noise/music
osascript -e "set volume output volume 100"
afplay sabotage.m4a

# (Re-)set to saved volume as a number from 0 to 100
osascript -e "set volume output volume $current_vol"
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.