338 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			338 lines
		
	
	
		
			15 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * $Id$
 | |
|  *
 | |
|  * ***** BEGIN GPL LICENSE BLOCK *****
 | |
|  *
 | |
|  * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
 | |
|  *
 | |
|  * The Original Code is Copyright (C) 2007 Blender Foundation.
 | |
|  * All rights reserved.
 | |
|  *
 | |
|  * 
 | |
|  * Contributor(s): Blender Foundation
 | |
|  *
 | |
|  * ***** END GPL LICENSE BLOCK *****
 | |
|  */
 | |
| #ifndef WM_API_H
 | |
| #define WM_API_H
 | |
| 
 | |
| /** \file WM_api.h
 | |
|  *  \ingroup wm
 | |
|  *
 | |
|  *  \page wmpage windowmanager
 | |
|  *  \section wmabout About windowmanager
 | |
|  *  \ref wm handles events received from \ref GHOST and manages
 | |
|  *  the screens, areas and input for Blender
 | |
|  *  \section wmnote NOTE
 | |
|  *  \todo document
 | |
|  */
 | |
| 
 | |
| /* dna-savable wmStructs here */
 | |
| #include "DNA_windowmanager_types.h"
 | |
| #include "WM_keymap.h"
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| struct bContext;
 | |
| struct IDProperty;
 | |
| struct wmEvent;
 | |
| struct wmEventHandler;
 | |
| struct wmGesture;
 | |
| struct wmJob;
 | |
| struct wmNotifier;
 | |
| struct wmOperatorType;
 | |
| struct wmOperator;
 | |
| struct rcti;
 | |
| struct PointerRNA;
 | |
| struct EnumPropertyItem;
 | |
| struct MenuType;
 | |
| struct wmDropBox;
 | |
| struct wmDrag;
 | |
| struct ImBuf;
 | |
| 
 | |
| typedef struct wmJob wmJob;
 | |
| 
 | |
| /* general API */
 | |
| void		WM_setprefsize		(int stax, int stay, int sizx, int sizy);
 | |
| void		WM_setinitialstate_fullscreen(void);
 | |
| void		WM_setinitialstate_normal(void);
 | |
| 
 | |
| void		WM_init				(struct bContext *C, int argc, const char **argv);
 | |
| void		WM_exit				(struct bContext *C);
 | |
| void		WM_main				(struct bContext *C);
 | |
| 
 | |
| int 		WM_init_game		(struct bContext *C);
 | |
| void		WM_init_splash		(struct bContext *C);
 | |
| 
 | |
| 
 | |
| void		WM_check			(struct bContext *C);
 | |
| 
 | |
| struct wmWindow	*WM_window_open	(struct bContext *C, struct rcti *rect);
 | |
| 
 | |
| 			/* defines for 'type' WM_window_open_temp */
 | |
| #define WM_WINDOW_RENDER		0
 | |
| #define WM_WINDOW_USERPREFS		1
 | |
| #define WM_WINDOW_FILESEL		2
 | |
| 
 | |
| void		WM_window_open_temp	(struct bContext *C, struct rcti *position, int type);
 | |
| 
 | |
| 
 | |
| 
 | |
| 			/* files */
 | |
| int			WM_read_homefile_exec(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_read_homefile	(struct bContext *C, struct ReportList *reports, short from_memory);
 | |
| int			WM_write_homefile	(struct bContext *C, struct wmOperator *op);
 | |
| void		WM_read_file		(struct bContext *C, const char *filepath, struct ReportList *reports);
 | |
| int			WM_write_file		(struct bContext *C, const char *target, int fileflags, struct ReportList *reports, int copy);
 | |
| void		WM_read_autosavefile(struct bContext *C);
 | |
| void		WM_autosave_init	(struct wmWindowManager *wm);
 | |
| 
 | |
| 			/* mouse cursors */
 | |
| void		WM_cursor_set		(struct wmWindow *win, int curs);
 | |
| void		WM_cursor_modal		(struct wmWindow *win, int curs);
 | |
| void		WM_cursor_restore	(struct wmWindow *win);
 | |
| void		WM_cursor_wait		(int val);
 | |
| void		WM_cursor_grab(struct wmWindow *win, int wrap, int hide, int *bounds);
 | |
| void		WM_cursor_ungrab(struct wmWindow *win);
 | |
| void		WM_timecursor		(struct wmWindow *win, int nr);
 | |
| 
 | |
| void		*WM_paint_cursor_activate(struct wmWindowManager *wm, int (*poll)(struct bContext *C), void (*draw)(struct bContext *C, int, int, void *customdata), void *customdata);
 | |
| void		WM_paint_cursor_end(struct wmWindowManager *wm, void *handle);
 | |
| 
 | |
| void		WM_cursor_warp		(struct wmWindow *win, int x, int y);
 | |
| 
 | |
| 			/* event map */
 | |
| int			WM_userdef_event_map(int kmitype);
 | |
| 
 | |
| 			/* handlers */
 | |
| 
 | |
| struct wmEventHandler *WM_event_add_keymap_handler(ListBase *handlers, wmKeyMap *keymap);
 | |
| 						/* boundbox, optional subwindow boundbox for offset */
 | |
| struct wmEventHandler *WM_event_add_keymap_handler_bb(ListBase *handlers, wmKeyMap *keymap, rcti *bb, rcti *swinbb);
 | |
| 						/* priority not implemented, it adds in begin */
 | |
| struct wmEventHandler *WM_event_add_keymap_handler_priority(ListBase *handlers, wmKeyMap *keymap, int priority);
 | |
| 
 | |
| void		WM_event_remove_keymap_handler(ListBase *handlers, wmKeyMap *keymap);
 | |
| 
 | |
| struct wmEventHandler *WM_event_add_ui_handler(const struct bContext *C, ListBase *handlers,
 | |
| 			int (*func)(struct bContext *C, struct wmEvent *event, void *userdata),
 | |
| 			void (*remove)(struct bContext *C, void *userdata), void *userdata);
 | |
| void		WM_event_remove_ui_handler(ListBase *handlers,
 | |
| 			int (*func)(struct bContext *C, struct wmEvent *event, void *userdata),
 | |
| 			void (*remove)(struct bContext *C, void *userdata), void *userdata, int postpone);
 | |
| void		WM_event_remove_area_handler(struct ListBase *handlers, void *area);
 | |
| 
 | |
| struct wmEventHandler *WM_event_add_modal_handler(struct bContext *C, struct wmOperator *op);
 | |
| void		WM_event_remove_handlers(struct bContext *C, ListBase *handlers);
 | |
| 
 | |
| struct wmEventHandler *WM_event_add_dropbox_handler(ListBase *handlers, ListBase *dropboxes);
 | |
| 
 | |
| 			/* mouse */
 | |
| void		WM_event_add_mousemove(struct bContext *C);
 | |
| int			WM_modal_tweak_exit(struct wmEvent *evt, int tweak_event);
 | |
| 
 | |
| 			/* notifiers */
 | |
| void		WM_event_add_notifier(const struct bContext *C, unsigned int type, void *reference);
 | |
| void		WM_main_add_notifier(unsigned int type, void *reference);
 | |
| 
 | |
| void		wm_event_add		(struct wmWindow *win, struct wmEvent *event_to_add); /* XXX only for warning */
 | |
| 
 | |
| 			/* at maximum, every timestep seconds it triggers event_type events */
 | |
| struct wmTimer *WM_event_add_timer(struct wmWindowManager *wm, struct wmWindow *win, int event_type, double timestep);
 | |
| void		WM_event_remove_timer(struct wmWindowManager *wm, struct wmWindow *win, struct wmTimer *timer);
 | |
| void		WM_event_timer_sleep(struct wmWindowManager *wm, struct wmWindow *win, struct wmTimer *timer, int dosleep);
 | |
| 
 | |
| 		/* operator api, default callbacks */
 | |
| 			/* invoke callback, uses enum property named "type" */
 | |
| int			WM_menu_invoke			(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_enum_search_invoke(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| 			/* invoke callback, confirm menu + exec */
 | |
| int			WM_operator_confirm		(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| 		/* invoke callback, file selector "filepath" unset + exec */
 | |
| int			WM_operator_filesel		(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| 			/* poll callback, context checks */
 | |
| int			WM_operator_winactive	(struct bContext *C);
 | |
| 			/* invoke callback, exec + redo popup */
 | |
| int			WM_operator_props_popup	(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int 		WM_operator_props_dialog_popup (struct bContext *C, struct wmOperator *op, int width, int height);
 | |
| int			WM_operator_redo_popup	(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_operator_ui_popup	(struct bContext *C, struct wmOperator *op, int width, int height);
 | |
| 
 | |
| int			WM_operator_confirm_message(struct bContext *C, struct wmOperator *op, const char *message);
 | |
| 
 | |
| 		/* operator api */
 | |
| void		WM_operator_free		(struct wmOperator *op);
 | |
| void		WM_operator_stack_clear(struct wmWindowManager *wm);
 | |
| 
 | |
| struct wmOperatorType *WM_operatortype_find(const char *idnamem, int quiet);
 | |
| struct GHashIterator *WM_operatortype_iter(void);
 | |
| void		WM_operatortype_append	(void (*opfunc)(struct wmOperatorType*));
 | |
| void		WM_operatortype_append_ptr	(void (*opfunc)(struct wmOperatorType*, void *), void *userdata);
 | |
| void		WM_operatortype_append_macro_ptr	(void (*opfunc)(struct wmOperatorType*, void *), void *userdata);
 | |
| int			WM_operatortype_remove(const char *idname);
 | |
| 
 | |
| struct wmOperatorType *WM_operatortype_append_macro(const char *idname, const char *name, int flag);
 | |
| struct wmOperatorTypeMacro *WM_operatortype_macro_define(struct wmOperatorType *ot, const char *idname);
 | |
| 
 | |
| 
 | |
| int			WM_operator_poll		(struct bContext *C, struct wmOperatorType *ot);
 | |
| int			WM_operator_poll_context(struct bContext *C, struct wmOperatorType *ot, int context);
 | |
| int			WM_operator_call		(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_operator_repeat		(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_operator_repeat_check(const struct bContext *C, struct wmOperator *op);
 | |
| int			WM_operator_name_call	(struct bContext *C, const char *opstring, int context, struct PointerRNA *properties);
 | |
| int			WM_operator_call_py(struct bContext *C, struct wmOperatorType *ot, int context, struct PointerRNA *properties, struct ReportList *reports);
 | |
| 
 | |
| void		WM_operator_properties_alloc(struct PointerRNA **ptr, struct IDProperty **properties, const char *opstring); /* used for keymap and macro items */
 | |
| void		WM_operator_properties_sanitize(struct PointerRNA *ptr, const short no_context); /* make props context sensitive or not */
 | |
| void		WM_operator_properties_create(struct PointerRNA *ptr, const char *opstring);
 | |
| void		WM_operator_properties_create_ptr(struct PointerRNA *ptr, struct wmOperatorType *ot);
 | |
| void		WM_operator_properties_free(struct PointerRNA *ptr);
 | |
| void		WM_operator_properties_filesel(struct wmOperatorType *ot, int filter, short type, short action, short flag);
 | |
| void		WM_operator_properties_gesture_border(struct wmOperatorType *ot, int extend);
 | |
| void		WM_operator_properties_gesture_straightline(struct wmOperatorType *ot, int cursor);
 | |
| void		WM_operator_properties_select_all(struct wmOperatorType *ot);
 | |
| 
 | |
| wmOperator *WM_operator_last_redo(const struct bContext *C);
 | |
| 
 | |
| /* MOVE THIS SOMEWHERE ELSE */
 | |
| #define	SEL_TOGGLE		0
 | |
| #define	SEL_SELECT		1
 | |
| #define SEL_DESELECT	2
 | |
| #define SEL_INVERT		3
 | |
| 
 | |
| 
 | |
| /* flags for WM_operator_properties_filesel */
 | |
| #define WM_FILESEL_RELPATH		(1 << 0)
 | |
| 
 | |
| #define WM_FILESEL_DIRECTORY	(1 << 1)
 | |
| #define WM_FILESEL_FILENAME		(1 << 2)
 | |
| #define WM_FILESEL_FILEPATH		(1 << 3)
 | |
| #define WM_FILESEL_FILES		(1 << 4)
 | |
| 
 | |
| 
 | |
| 		/* operator as a python command (resultuing string must be free'd) */
 | |
| char		*WM_operator_pystring(struct bContext *C, struct wmOperatorType *ot, struct PointerRNA *opptr, int all_args);
 | |
| void		WM_operator_bl_idname(char *to, const char *from);
 | |
| void		WM_operator_py_idname(char *to, const char *from);
 | |
| 
 | |
| /* *************** menu types ******************** */
 | |
| void				WM_menutype_init(void);
 | |
| struct MenuType		*WM_menutype_find(const char *idname, int quiet);
 | |
| int					WM_menutype_add(struct MenuType* mt);
 | |
| int					WM_menutype_contains(struct MenuType* mt);
 | |
| void				WM_menutype_freelink(struct MenuType* mt);
 | |
| void				WM_menutype_free(void);
 | |
| 
 | |
| 			/* default operator callbacks for border/circle/lasso */
 | |
| int			WM_border_select_invoke	(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_border_select_modal	(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_border_select_cancel(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_gesture_circle_invoke(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_circle_modal(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_circle_cancel(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_gesture_lines_invoke(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_lines_modal(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_lines_cancel(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_gesture_lasso_invoke(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_lasso_modal(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_lasso_cancel(struct bContext *C, struct wmOperator *op);
 | |
| int			WM_gesture_straightline_invoke(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_straightline_modal(struct bContext *C, struct wmOperator *op, struct wmEvent *event);
 | |
| int			WM_gesture_straightline_cancel(struct bContext *C, struct wmOperator *op);
 | |
| 
 | |
| 			/* default operator for arearegions, generates event */
 | |
| void		WM_OT_tweak_gesture(struct wmOperatorType *ot);
 | |
| 
 | |
| 			/* Gesture manager API */
 | |
| struct wmGesture *WM_gesture_new(struct bContext *C, struct wmEvent *event, int type);
 | |
| void		WM_gesture_end(struct bContext *C, struct wmGesture *gesture);
 | |
| void		WM_gestures_remove(struct bContext *C);
 | |
| 
 | |
| 			/* fileselecting support */
 | |
| void		WM_event_add_fileselect(struct bContext *C, struct wmOperator *op);
 | |
| void		WM_event_fileselect_event(struct bContext *C, void *ophandle, int eventval);
 | |
| 
 | |
| 			/* drag and drop */
 | |
| struct wmDrag		*WM_event_start_drag(struct bContext *C, int icon, int type, void *poin, double value);
 | |
| void				WM_event_drag_image(struct wmDrag *, struct ImBuf *, float scale, int sx, int sy);
 | |
| 
 | |
| struct wmDropBox	*WM_dropbox_add(ListBase *lb, const char *idname, int (*poll)(struct bContext *, struct wmDrag *, struct wmEvent *event),
 | |
| 						  void (*copy)(struct wmDrag *, struct wmDropBox *));
 | |
| ListBase	*WM_dropboxmap_find(const char *idname, int spaceid, int regionid);
 | |
| 
 | |
| 			/* Set a subwindow active in pixelspace view, with optional scissor subset */
 | |
| void		wmSubWindowSet			(struct wmWindow *win, int swinid);
 | |
| void		wmSubWindowScissorSet	(struct wmWindow *win, int swinid, struct rcti *srct);
 | |
| 
 | |
| 			/* OpenGL utilities with safety check + working in modelview matrix mode */
 | |
| void		wmFrustum			(float x1, float x2, float y1, float y2, float n, float f);
 | |
| void		wmOrtho				(float x1, float x2, float y1, float y2, float n, float f);
 | |
| void		wmOrtho2			(float x1, float x2, float y1, float y2);
 | |
| 
 | |
| 			/* utilities */
 | |
| void		WM_set_framebuffer_index_color(int index);
 | |
| int			WM_framebuffer_to_index(unsigned int col);
 | |
| 
 | |
| 			/* threaded Jobs Manager */
 | |
| #define WM_JOB_PRIORITY		1
 | |
| #define WM_JOB_EXCL_RENDER	2
 | |
| #define WM_JOB_PROGRESS		4
 | |
| #define WM_JOB_SUSPEND		8
 | |
| 
 | |
| struct wmJob *WM_jobs_get(struct wmWindowManager *wm, struct wmWindow *win, void *owner, const char *name, int flag);
 | |
| 
 | |
| int			WM_jobs_test(struct wmWindowManager *wm, void *owner);
 | |
| float		WM_jobs_progress(struct wmWindowManager *wm, void *owner);
 | |
| char		*WM_jobs_name(struct wmWindowManager *wm, void *owner);
 | |
| 
 | |
| void		WM_jobs_customdata(struct wmJob *, void *customdata, void (*free)(void *));
 | |
| void		WM_jobs_timer(struct wmJob *, double timestep, unsigned int note, unsigned int endnote);
 | |
| void		WM_jobs_callbacks(struct wmJob *, 
 | |
| 							  void (*startjob)(void *, short *, short *, float *),
 | |
| 							  void (*initjob)(void *),
 | |
| 							  void (*update)(void *),
 | |
| 							  void (*endjob)(void *));
 | |
| 
 | |
| void		WM_jobs_start(struct wmWindowManager *wm, struct wmJob *);
 | |
| void		WM_jobs_stop(struct wmWindowManager *wm, void *owner, void *startjob);
 | |
| void		WM_jobs_kill(struct wmWindowManager *wm, void *owner, void (*)(void *, short int *, short int *, float *));
 | |
| void		WM_jobs_stop_all(struct wmWindowManager *wm);
 | |
| 
 | |
| 			/* clipboard */
 | |
| char		*WM_clipboard_text_get(int selection);
 | |
| void		WM_clipboard_text_set(char *buf, int selection);
 | |
| 
 | |
| 			/* progress */
 | |
| void		WM_progress_set(struct wmWindow *win, float progress);
 | |
| void		WM_progress_clear(struct wmWindow *win);
 | |
| 
 | |
| #ifdef WIN32
 | |
| 			/* Windows System Console */
 | |
| void		WM_console_toggle(struct bContext *C, short show);
 | |
| #endif
 | |
| 
 | |
| /* debugging only, convenience function to write on crash */
 | |
| int write_crash_blend(void);
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* WM_API_H */
 | |
| 
 |