2010-09-29 20 views

risposta

6

È possibile analizzare l'output di xset q con DISPLAY set, ma non è abbastanza.

$ 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 
+0

Grazie, questo è il trucco. Non è la soluzione più elegante, ma il controllo dell'output per "Monitor è acceso/spento" funziona. –

+1

Questo va bene, ma si basa su un server X disponibile. Se hai solo una console (cosa rara di questi tempi, ammettiamolo), non funzionerà. – Gabe

+0

Nel mio caso va bene. Gestisco un browser Gtk-WebKit a schermo intero che fa filtrare la memoria come un setaccio, quindi dopo che lo schermo è stato spento per un po 'posso tranquillamente uccidere e riavviare il browser ;-) Ovviamente sarebbe bello non avere quelle perdite in primo luogo ... –

0

non ho fatto qualsiasi sviluppo desktop in età, ma la memoria mi dice che la maggior parte degli screensaver linux venivano eseguiti da xscreensaver - forse verificare se il processo è in esecuzione , o passando attraverso il suo codice sorgente per vedere se uno stato del sistema viene impostato, o chiedere al maillista del progetto darebbe dei risultati. Naturalmente KDE e Gnome potrebbe dispongono di implementazioni screensaver separati ormai - c'è molto poco uniformità quando si tratta di linux GUI, purtroppo ...

9

OK, controllare xset source code. Le parti di codice rilevanti sono

#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"); 
      } 
     } 
    } 
} 

Solo nel caso qualcuno altro ha bisogno di questo ;-)

0

sto usando questo script per leggere le informazioni DPMS. Funziona alla grande! È scritto in PHP, ma puoi vedere l'idea di come funziona.

<?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}'"); 
?> 
0

Ho realizzato un'implementazione equivalente del codice di Günter in Python con 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 

Il campione di chiamata è my github.