aboutsummaryrefslogtreecommitdiff
path: root/draw.c
diff options
context:
space:
mode:
authorfoswret <foswret@posteo.com>2025-12-11 20:22:55 -0600
committerfoswret <foswret@posteo.com>2025-12-11 20:22:55 -0600
commitde77826633fc128b915e999a9adf10f088b4d3f3 (patch)
tree65cbe77d7c04cc7fc3bb84a64e6b80889675a0d8 /draw.c
parent0ea73247a8ba4036567a9dc28b6133d4b58507b3 (diff)
added src/, updated README.md
Diffstat (limited to 'draw.c')
-rw-r--r--draw.c94
1 files changed, 0 insertions, 94 deletions
diff --git a/draw.c b/draw.c
deleted file mode 100644
index 51f9367..0000000
--- a/draw.c
+++ /dev/null
@@ -1,94 +0,0 @@
-#include <stdio.h>
-#include <cairo/cairo.h>
-
-struct dimensions {
- double pw; /* paper width */
- double ph; /* paper height */
- double mw; /* month width */
- double mh; /* month height */
- double bw; /* day box width */
- double bh; /* day box height */
- double r; /* rows */
- double c; /* columns */
- double m; /* margin */
-};
-
-
-int draw_calendar(cairo_t *c, double x, double y, struct dimensions d) {
- double x1, y1, x2, y2;
- x1 = x;
- y1 = y;
- x2 = d.pw - x1; /* Set the line endpoint to right side of the page */
-
- for (int i = 0; i < d.r + 1; i++) { /* Draw Horizontal Lines */
- cairo_move_to (c, x, y);
- cairo_line_to (c, x2, y);
- y = y + d.bh;
- }
-
- x = x1;
- y = y1;
- y2 = y1 + d.mh; /* Set the line endpoint as the bottom of the month */
- for (int i = 0; i < d.c + 1; i++) { /* Draw Vertical Lines */
- cairo_move_to (c, x, y);
- cairo_line_to (c, x, y2);
- x = x + d.bw;
- }
- cairo_stroke(c);
- return(0);
-}
-
-
-
-int draw_numbers(cairo_t *c, double x, double y, struct dimensions d, int wd, int nd) {
- char str[20];
- cairo_text_extents_t te;
- cairo_font_extents_t fe;
-
- cairo_select_font_face (c, "sans-serif",
- CAIRO_FONT_SLANT_NORMAL, CAIRO_FONT_WEIGHT_BOLD);
- cairo_set_font_size (c, d.bw / 2);
-
- int iterative = 0;
- cairo_font_extents (c, &fe);
- double xi = x;
- int current_weekday = wd;
- x = d.m + (wd * d.bw);
- for (int j = 0; j < d.r; j++) {
- y = y + d.bh - ((d.bh - fe.ascent) / 2);
- for (int k = current_weekday; k < d.c; k++) {
- if (iterative < nd) {
- snprintf(str, sizeof(str), "%d", iterative + 1);
- cairo_text_extents (c, str, &te);
- double box_margins = (d.bw - te.width) / 2;
-
- cairo_move_to(c, x + box_margins - te.x_bearing, y); /* center the number within the box */
- cairo_show_text(c, str);
- cairo_move_to(c, x, y); /* Sort of backtrack to realign with the spacing of the boxes */
- x = x + d.bw;
- iterative++;
- current_weekday++;
- }
- }
- current_weekday = 0;
- y = y - (d.bh - ((d.bh - fe.ascent) / 2));
- y = y + d.bh;
- x = xi;
- }
- return(0);
-}
-
-
-
-int draw_month_name(cairo_t *c, char *name, struct dimensions d) {
- double x, y = d.m;
- cairo_set_font_size(c, 1.0);
- cairo_text_extents_t te;
- cairo_text_extents(c, name, &te);
- x = (d.pw / 2) - (te.width / 2);
- y = 1.5;
- cairo_move_to(c, x, y);
- cairo_show_text(c, &name[0]);
- return(0);
-}
-