есть способ проверить программно (через ioctl() и т. Д.) Или путем чтения файла в/sys,/proc или/dev), был ли экран закрыт заставку консоли Linux?Как проверить, что заставка экрана консоли Linux закрыта экраном
Спасибо и наилучшие пожелания,
Гюнтер
есть способ проверить программно (через ioctl() и т. Д.) Или путем чтения файла в/sys,/proc или/dev), был ли экран закрыт заставку консоли Linux?Как проверить, что заставка экрана консоли Linux закрыта экраном
Спасибо и наилучшие пожелания,
Гюнтер
Вы можете разобрать вывод xset q
с DISPLAY
набором, но это не красиво.
$ xset q
Keyboard Control:
auto repeat: on key click percent: 0 LED mask: 00000000
XKB indicators:
00: Caps Lock: off 01: Num Lock: off 02: Scroll Lock: off
03: Compose: off 04: Kana: off 05: Sleep: off
06: Suspend: off 07: Mute: off 08: Misc: off
09: Mail: off 10: Charging: off 11: Shift Lock: off
12: Group 2: off 13: Mouse Keys: off
auto repeat delay: 250 repeat rate: 30
auto repeating keys: 00ffffffdffffbbf
fadfffefffedffff
9fffffffffffffff
fff7ffffffffffff
bell percent: 50 bell pitch: 400 bell duration: 100
Pointer Control:
acceleration: 20/10 threshold: 4
Screen Saver:
prefer blanking: yes allow exposures: yes
timeout: 0 cycle: 600
Colors:
default colormap: 0x20 BlackPixel: 0 WhitePixel: 16777215
Font Path:
/usr/share/fonts/misc,/usr/share/fonts/100dpi:unscaled,/usr/share/fonts/75dpi:unscaled,/usr/share/fonts/TTF,/usr/share/fonts/Type1,/usr/share/fonts/misc/,/usr/share/fonts/TTF/,/usr/share/fonts/Type1/,/usr/share/fonts/100dpi/,/usr/share/fonts/75dpi/,built-ins
DPMS (Energy Star):
Standby: 1200 Suspend: 1800 Off: 0
DPMS is Enabled
Monitor is On
Font cache:
Server does not have the FontCache Extension
Я не сделал никакого развития рабочего стола в возрасте, но память мне подсказывает, что большинство Linux заставок были выполнены XScreenSaver - может проверить, работает ли процесс , или через свой исходный код, чтобы увидеть, что какое-либо системное состояние будет установлено, или запрос на проект maillist даст некоторые результаты. , конечно, KDE и Gnome могут иметь отдельные реализации заставки теперь - очень мало единообразия, когда дело доходит до Linux ГПИ, к сожалению ...
Хорошо, отметьте xset source code. Соответствующие кодовые части
#include <X11/extensions/dpms.h>
...
Display* dpy = XOpenDisplay(NULL);
...
int dummy;
CARD16 standby, suspend, off;
BOOL onoff;
CARD16 state;
printf("DPMS (Energy Star):\n");
if (DPMSQueryExtension(dpy, &dummy, &dummy))
{
if (DPMSCapable(dpy))
{
DPMSGetTimeouts(dpy, &standby, &suspend, &off);
printf (" Standby: %d Suspend: %d Off: %d\n",
standby, suspend, off);
DPMSInfo(dpy, &state, &onoff);
if (onoff)
{
printf(" DPMS is Enabled\n");
switch (state)
{
case DPMSModeOn:
printf(" Monitor is On\n");
break;
case DPMSModeStandby:
printf(" Monitor is in Standby\n");
break;
case DPMSModeSuspend:
printf(" Monitor is in Suspend\n");
break;
case DPMSModeOff:
printf(" Monitor is Off\n");
break;
default:
printf(" Unrecognized response from server\n");
}
}
}
}
Только в случае, если кто-то нуждается в этом ;-)
Я использую этот скрипт для чтения DPMS информации. Он отлично работает! Его написано на PHP, но вы можете понять, как это работает.
<?php
if (!$pid = exec('pidof X'))
return !trigger_error(E_USER_WARNING,'Could not find pid of X');
if (!$data = file_get_contents("/proc/$pid/cmdline"))
return !trigger_error(E_USER_WARNING,"Cound not read pid info (/proc/$pid/cmdline)");
$data = explode(chr(0),$data);
foreach($data as $key => $line) {
if ($line == "-auth") {
$auth = $data[$key+1];
break;
}
}
if (!isset($auth))
return !trigger_error(E_USER_WARNING,'Could not find XAUTHORITY in xinit process environment');
echo exec("export DISPLAY=:0; export XAUTHORITY={$auth}; export PATH=\${PATH}:/usr/X11R6/bin; xset -q | grep \"Monitor is\" | awk '{print $3}'");
?>
Я сделал эквивалентную реализацию кода Гюнтера в Python с помощью ctypes.
import ctypes
import struct
ctypes.cdll.LoadLibrary('libXext.so')
libXext = ctypes.CDLL('libXext.so')
DPMSFAIL = -1
DPMSModeOn = 0
DPMSModeStandby = 1
DPMSModeSuspend = 2
DPMSModeOff = 3
def get_DPMS_state(display_name_in_byte_string=b':0'):
state = DPMSFAIL
if not isinstance(display_name_in_byte_string, bytes):
raise TypeError
display_name = ctypes.c_char_p()
display_name.value = display_name_in_byte_string
libXext.XOpenDisplay.restype = ctypes.c_void_p
display = ctypes.c_void_p(libXext.XOpenDisplay(display_name))
dummy1_i_p = ctypes.create_string_buffer(8)
dummy2_i_p = ctypes.create_string_buffer(8)
if display.value:
if libXext.DPMSQueryExtension(display, dummy1_i_p, dummy2_i_p)\
and libXext.DPMSCapable(display):
onoff_p = ctypes.create_string_buffer(1)
state_p = ctypes.create_string_buffer(2)
if libXext.DPMSInfo(display, state_p, onoff_p):
onoff = struct.unpack('B', onoff_p.raw)[0]
if onoff:
state = struct.unpack('H', state_p.raw)[0]
libXext.XCloseDisplay(display)
return state
Образец звонка на my github.
Спасибо, это делает трюк. Не самое элегантное решение, но проверка выходных данных для «Monitor on on off» работает. –
Это нормально, но он зависит от наличия X-сервера. Если у вас просто есть консоль (что редко бывает в наши дни, по общему признанию), это не сработает. – Gabe
В моем случае это нормально. Я запускаю полноэкранный браузер Gtk-WebKit, который пропускает память, как сито, поэтому после того, как экран был отключен на некоторое время, я могу безопасно убить и перезапустить браузер ;-) Конечно, было бы неплохо не иметь эти утечки в первую очередь ... –