herbe

[fork] notifications
Log | Files | Refs | README | LICENSE

commit ba24eb9d586534730e20629dba675cc6abf2ef72
parent 45c030065aa79089463169fcf6a8d3393cedf455
Author: Samuel Dudik <samuel.dudik@gmail.com>
Date:   Wed, 29 Jul 2020 15:09:34 +0200

Add an option to specify 'corner'

Diffstat:
Mconfig.h | 21++++++++++++---------
Mmain.c | 33+++++++++++++++++++++++++--------
2 files changed, 37 insertions(+), 17 deletions(-)

diff --git a/config.h b/config.h @@ -1,13 +1,16 @@ -unsigned long background_color = 0xFFFFFF; -unsigned long border_color = 0xFF0000; +const static char *background_color = "#FFFFFF"; +const static char *border_color = "#FF0000"; const static char *font_style = "Inconsolata:style=Medium:size=13"; -const static char *font_color = "#000000"; +const static char *font_color = "#00FF00"; -const static unsigned int width = 325; -const static unsigned int height = 50; -const static unsigned int border_size = 5; -const static unsigned int pos_x = 1920 - width - border_size - 30; -const static unsigned int pos_y = 50; +const static unsigned short width = 325; +const static unsigned short height = 50; +const static unsigned short border_size = 5; +const static unsigned short pos_x = 50; +const static unsigned short pos_y = 50; -const static int duration = 5; +enum corners { top_left, top_right, down_right, down_left }; +enum corners corner = top_right; + +const static short duration = 5; diff --git a/main.c b/main.c @@ -20,27 +20,41 @@ int main(int argc, char *argv[]) int screen = DefaultScreen(display); int window_width = DisplayWidth(display, screen); - int widnow_height = DisplayHeight(display, screen); + int window_height = DisplayHeight(display, screen); + + XftColor color; Window root = RootWindow(display, screen); XSetWindowAttributes attributes; attributes.override_redirect = True; - attributes.background_pixel = background_color; - attributes.border_pixel = border_color; + XftColorAllocName(display, DefaultVisual(display, screen), DefaultColormap(display, screen), background_color, &color); + attributes.background_pixel = color.pixel; + XftColorAllocName(display, DefaultVisual(display, screen), DefaultColormap(display, screen), border_color, &color); + attributes.border_pixel = color.pixel; - XftColor color; - char *status = "Ahoj volam sa samko netahaj mi stolicku lebo ta ujebem ty hovafoooooo"; XftFont *font = XftFontOpenName(display, screen, font_style); + unsigned short x = pos_x; + unsigned short y = pos_y; + switch (corner) { + case down_right: + y = window_height - height + 5; + case top_right: + x = window_width - width - border_size * 2 - pos_x; + break; + case down_left: + y = window_height - height + 5; + } + Window window = XCreateWindow( - display, root, pos_x, - pos_y, width, font->ascent + 10 + border_size, border_size, + display, root, x, + y, width, font->ascent + 10 + border_size, border_size, DefaultDepth(display, screen), CopyFromParent, DefaultVisual(display, screen), CWOverrideRedirect | CWBackPixel | CWBorderPixel, &attributes); XftDraw *draw = XftDrawCreate(display, window, DefaultVisual(display, screen), DefaultColormap(display, screen)); - XftColorAllocName(display, DefaultVisual(display, screen), DefaultColormap(display, screen), "#000000", &color); + XftColorAllocName(display, DefaultVisual(display, screen), DefaultColormap(display, screen), font_color, &color); XMapWindow(display, window); @@ -49,4 +63,7 @@ int main(int argc, char *argv[]) XNextEvent(display, &event); sleep(duration); + + XCloseDisplay(display); + return 0; }