diff options
author | Mattias Andrée <maandree@operamail.com> | 2014-02-26 01:03:26 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2014-02-26 01:03:26 +0100 |
commit | 1b19db603c37080f3ca4141d4a69c4ca4a075409 (patch) | |
tree | f339d15f3df94d09450450b83b0dd4858a7a9ce7 /src | |
parent | partial strut dock (diff) | |
download | xpybar-1b19db603c37080f3ca4141d4a69c4ca4a075409.tar.gz xpybar-1b19db603c37080f3ca4141d4a69c4ca4a075409.tar.bz2 xpybar-1b19db603c37080f3ca4141d4a69c4ca4a075409.tar.xz |
place a black panel either on the top or the bottom
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to '')
-rwxr-xr-x | src/__main__.py | 33 |
1 files changed, 27 insertions, 6 deletions
diff --git a/src/__main__.py b/src/__main__.py index ad195f4..36ee486 100755 --- a/src/__main__.py +++ b/src/__main__.py @@ -1,12 +1,20 @@ #!/usr/bin/env python3 -import time -import Xlib.display, Xlib.Xatom +import time, sys +import Xlib.display, Xlib.Xatom, Xlib.ext.randr, Xlib.X + +WIDTH, HEIGHT, LEFT, TOP, Y = 1600, 12, 1600, 24, 1200 - 24 - 12 display = Xlib.display.Display() screen = display.screen() -window = screen.root.create_window(0, 0, 100, 100, 0, screen.root_depth) +window = screen.root.create_window(LEFT, Y, WIDTH, HEIGHT, 0, screen.root_depth, + Xlib.X.InputOutput, Xlib.X.CopyFromParent, + event_mask = ( + Xlib.X.StructureNotifyMask | + Xlib.X.ButtonReleaseMask + ), + colormap = Xlib.X.CopyFromParent) window.set_wm_name('xpybar') window.set_wm_icon_name('xpybar') @@ -14,21 +22,34 @@ window.set_wm_class('bar', 'xpybar') _CARD = display.intern_atom("CARDINAL") _PSTRUT = display.intern_atom("_NET_WM_STRUT_PARTIAL") -window.change_property(_PSTRUT, _CARD, 32, [0, 60, 0, 0, 0, 0, 24, 767, 0, 0, 0, 0]) +window.change_property(_PSTRUT, _CARD, 32, topx(LEFT, TOP, WIDTH, HEIGHT)) + +top = lambda x, y, width, height : [0, 0, y + height, 0, 0, 0, 0, 0, x, x + width, 0, 0] +bottom = lambda x, y, width, height : [0, 0, 0, y + height, 0, 0, 0, 0, 0, 0, x, x + width] _ATOM = display.intern_atom("ATOM") _TYPE = display.intern_atom("_NET_WM_WINDOW_TYPE") _DOCK = display.intern_atom("_NET_WM_WINDOW_TYPE_DOCK") window.change_property(_TYPE, _ATOM, 32, [_DOCK]) +gc = window.create_gc() window.map() display.flush() -time.sleep(1) +e = None +while True: + try: + e = display.next_event() + if e.type == Xlib.X.DestroyNotify: + break + except KeyboardInterrupt: + break + gc.change(foreground = screen.black_pixel) + window.fill_rectangle(gc, 0, 0, 1600, 12) + display.flush() window.unmap() display.flush() display.close() - |