Listing the "Blender Foundation" as copyright holder implied the Blender Foundation holds copyright to files which may include work from many developers. While keeping copyright on headers makes sense for isolated libraries, Blender's own code may be refactored or moved between files in a way that makes the per file copyright holders less meaningful. Copyright references to the "Blender Foundation" have been replaced with "Blender Authors", with the exception of `./extern/` since these this contains libraries which are more isolated, any changed to license headers there can be handled on a case-by-case basis. Some directories in `./intern/` have also been excluded: - `./intern/cycles/` it's own `AUTHORS` file is planned. - `./intern/opensubdiv/`. An "AUTHORS" file has been added, using the chromium projects authors file as a template. Design task: #110784 Ref !110783.
192 lines
4.9 KiB
C
192 lines
4.9 KiB
C
/* SPDX-FileCopyrightText: 2007 Blender Authors
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
|
|
/** \file
|
|
* \ingroup wm
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
struct ARegion;
|
|
struct GHOST_TabletData;
|
|
struct ScrArea;
|
|
enum wmOperatorCallContext;
|
|
|
|
#ifdef WITH_XR_OPENXR
|
|
struct wmXrActionData;
|
|
#endif
|
|
|
|
/* wmKeyMap is in DNA_windowmanager.h, it's saveable */
|
|
|
|
/** Custom types for handlers, for signaling, freeing */
|
|
enum eWM_EventHandlerType {
|
|
WM_HANDLER_TYPE_GIZMO = 1,
|
|
WM_HANDLER_TYPE_UI,
|
|
WM_HANDLER_TYPE_OP,
|
|
WM_HANDLER_TYPE_DROPBOX,
|
|
WM_HANDLER_TYPE_KEYMAP,
|
|
};
|
|
|
|
using EventHandlerPoll = bool (*)(const ARegion *region, const wmEvent *event);
|
|
|
|
struct wmEventHandler {
|
|
wmEventHandler *next, *prev;
|
|
|
|
eWM_EventHandlerType type;
|
|
eWM_EventHandlerFlag flag;
|
|
|
|
EventHandlerPoll poll;
|
|
};
|
|
|
|
/** Run after the keymap item runs. */
|
|
struct wmEventHandler_KeymapPost {
|
|
void (*post_fn)(wmKeyMap *keymap, wmKeyMapItem *kmi, void *user_data);
|
|
void *user_data;
|
|
};
|
|
|
|
/** Support for a getter function that looks up the keymap each access. */
|
|
struct wmEventHandler_KeymapDynamic {
|
|
wmEventHandler_KeymapDynamicFn keymap_fn;
|
|
void *user_data;
|
|
};
|
|
|
|
/** #WM_HANDLER_TYPE_KEYMAP */
|
|
struct wmEventHandler_Keymap {
|
|
wmEventHandler head;
|
|
|
|
/** Pointer to builtin/custom keymaps (never NULL). */
|
|
wmKeyMap *keymap;
|
|
|
|
wmEventHandler_KeymapPost post;
|
|
wmEventHandler_KeymapDynamic dynamic;
|
|
|
|
bToolRef *keymap_tool;
|
|
};
|
|
|
|
/** #WM_HANDLER_TYPE_GIZMO */
|
|
struct wmEventHandler_Gizmo {
|
|
wmEventHandler head;
|
|
|
|
/** Gizmo handler (never NULL). */
|
|
struct wmGizmoMap *gizmo_map;
|
|
};
|
|
|
|
/** #WM_HANDLER_TYPE_UI */
|
|
struct wmEventHandler_UI {
|
|
wmEventHandler head;
|
|
|
|
wmUIHandlerFunc handle_fn; /* callback receiving events */
|
|
wmUIHandlerRemoveFunc remove_fn; /* callback when handler is removed */
|
|
void *user_data; /* user data pointer */
|
|
|
|
/** Store context for this handler for derived/modal handlers. */
|
|
struct {
|
|
ScrArea *area;
|
|
ARegion *region;
|
|
ARegion *menu;
|
|
} context;
|
|
};
|
|
|
|
/** #WM_HANDLER_TYPE_OP */
|
|
struct wmEventHandler_Op {
|
|
wmEventHandler head;
|
|
|
|
/** Operator can be NULL. */
|
|
wmOperator *op;
|
|
|
|
/** Hack, special case for file-select. */
|
|
bool is_fileselect;
|
|
|
|
/** Store context for this handler for derived/modal handlers. */
|
|
struct {
|
|
/* To override the window, and hence the screen. Set for few cases only, usually window/screen
|
|
* can be taken from current context. */
|
|
wmWindow *win;
|
|
|
|
ScrArea *area;
|
|
ARegion *region;
|
|
short region_type;
|
|
} context;
|
|
};
|
|
|
|
/** #WM_HANDLER_TYPE_DROPBOX */
|
|
struct wmEventHandler_Dropbox {
|
|
wmEventHandler head;
|
|
|
|
/** Never NULL. */
|
|
ListBase *dropboxes;
|
|
};
|
|
|
|
/* `wm_event_system.cc` */
|
|
|
|
void wm_event_free_all(wmWindow *win);
|
|
void wm_event_free(wmEvent *event);
|
|
void wm_event_free_handler(wmEventHandler *handler);
|
|
|
|
/**
|
|
* Goes over entire hierarchy: events -> window -> screen -> area -> region.
|
|
*
|
|
* \note Called in main loop.
|
|
*/
|
|
void wm_event_do_handlers(bContext *C);
|
|
|
|
/**
|
|
* Windows store own event queues #wmWindow.event_queue (no #bContext here).
|
|
*/
|
|
void wm_event_add_ghostevent(wmWindowManager *wm, wmWindow *win, int type, void *customdata);
|
|
#ifdef WITH_XR_OPENXR
|
|
void wm_event_add_xrevent(wmWindow *win, wmXrActionData *actiondata, short val);
|
|
#endif
|
|
|
|
void wm_event_do_depsgraph(bContext *C, bool is_after_open_file);
|
|
/**
|
|
* Was part of #wm_event_do_notifiers,
|
|
* split out so it can be called once before entering the #WM_main loop.
|
|
* This ensures operators don't run before the UI and depsgraph are initialized.
|
|
*/
|
|
void wm_event_do_refresh_wm_and_depsgraph(bContext *C);
|
|
/**
|
|
* Called in main-loop.
|
|
*/
|
|
void wm_event_do_notifiers(bContext *C);
|
|
|
|
void wm_event_handler_ui_cancel_ex(bContext *C,
|
|
wmWindow *win,
|
|
ARegion *region,
|
|
bool reactivate_button);
|
|
|
|
/* `wm_event_query.cc` */
|
|
|
|
/**
|
|
* Applies the global tablet pressure correction curve.
|
|
*/
|
|
float wm_pressure_curve(float raw_pressure);
|
|
void wm_tablet_data_from_ghost(const GHOST_TabletData *tablet_data, wmTabletData *wmtab);
|
|
|
|
/* wm_dropbox.c */
|
|
|
|
void wm_dropbox_free();
|
|
/**
|
|
* Additional work to cleanly end dragging. Additional because this doesn't actually remove the
|
|
* drag items. Should be called whenever dragging is stopped
|
|
* (successful or not, also when canceled).
|
|
*/
|
|
void wm_drags_exit(wmWindowManager *wm, wmWindow *win);
|
|
void wm_drop_prepare(bContext *C, wmDrag *drag, wmDropBox *drop);
|
|
void wm_drop_end(bContext *C, wmDrag *drag, wmDropBox *drop);
|
|
/**
|
|
* Called in inner handler loop, region context.
|
|
*/
|
|
void wm_drags_check_ops(bContext *C, const wmEvent *event);
|
|
/**
|
|
* The operator of a dropbox should always be executed in the context determined by the mouse
|
|
* coordinates. The dropbox poll should check the context area and region as needed.
|
|
* So this always returns #WM_OP_INVOKE_DEFAULT.
|
|
*/
|
|
wmOperatorCallContext wm_drop_operator_context_get(const wmDropBox *drop);
|
|
/**
|
|
* Called in #wm_draw_window_onscreen.
|
|
*/
|
|
void wm_drags_draw(bContext *C, wmWindow *win);
|