/** * Looking Glass * Copyright © 2017-2022 The Looking Glass Authors * https://looking-glass.io * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the Free * Software Foundation; either version 2 of the License, or (at your option) * any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for * more details. * * You should have received a copy of the GNU General Public License along * with this program; if not, write to the Free Software Foundation, Inc., 59 * Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _H_I_OVERLAY_ #define _H_I_OVERLAY_ #include <stdbool.h> #include "common/types.h" struct LG_OverlayOps { /* internal name of the overlay for debugging */ const char * name; /* called very early to allow for option registration, optional */ void (*earlyInit)(void); /* called when the overlay is registered */ bool (*init)(void ** udata, const void * params); /* final free */ void (*free)(void * udata); /* return true if realtime rendering is required when in jitRender mode * optional, if omitted assumes false */ bool (*needs_render)(void * udata, bool interactive); /* return true if the overlay currently requires overlay mode * optional, if omitted assumes false */ bool (*needs_overlay)(void * udata); /* perform the actual drawing/rendering * * `interactive` is true if the application is currently in overlay interaction * mode. * * `windowRects` is an array of window rects that were rendered using screen * coordinates. Will be `NULL` if the information is not required. * * `maxRects` is the length of `windowRects`, or 0 if `windowRects` is `NULL` * * returns the number of rects written to `windowRects`, or -1 if there is not * enough room left. */ int (*render)(void * udata, bool interactive, struct Rect * windowRects, int maxRects); /* called 25 times a second by the application * * Note: This may not run in the same context as `render`! * * return true if the frame needs to be rendered * optional, if omitted assumes false */ bool (*tick)(void * udata, unsigned long long tickCount); /* TODO: add load/save settings capabillity */ }; #define ASSERT_LG_OVERLAY_VALID(x) \ DEBUG_ASSERT((x)->name ); \ DEBUG_ASSERT((x)->init ); \ DEBUG_ASSERT((x)->free ); \ DEBUG_ASSERT((x)->render); #endif