2011-02-21 07:25:24 +00:00
|
|
|
/*
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
* 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,
|
2010-02-12 13:34:04 +00:00
|
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
|
|
|
|
* All rights reserved.
|
|
|
|
*/
|
|
|
|
|
2019-02-18 08:08:12 +11:00
|
|
|
/** \file
|
|
|
|
* \ingroup editorui
|
2011-02-21 07:25:24 +00:00
|
|
|
*/
|
|
|
|
|
2012-02-17 18:59:41 +00:00
|
|
|
#ifndef __UI_INTERFACE_H__
|
|
|
|
#define __UI_INTERFACE_H__
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2013-09-01 15:01:15 +00:00
|
|
|
#include "BLI_compiler_attrs.h"
|
2013-05-28 19:35:26 +00:00
|
|
|
#include "BLI_sys_types.h" /* size_t */
|
2009-07-21 01:26:17 +00:00
|
|
|
#include "RNA_types.h"
|
|
|
|
|
2020-02-17 15:06:56 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Struct Declarations */
|
|
|
|
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
struct ARegion;
|
|
|
|
struct AutoComplete;
|
2019-09-06 01:22:35 +02:00
|
|
|
struct FileSelectParams;
|
2019-01-28 21:08:24 +11:00
|
|
|
struct ID;
|
|
|
|
struct IDProperty;
|
|
|
|
struct ImBuf;
|
|
|
|
struct Image;
|
|
|
|
struct ImageUser;
|
|
|
|
struct ListBase;
|
|
|
|
struct MTex;
|
2009-03-29 19:44:39 +00:00
|
|
|
struct Panel;
|
2009-04-11 01:52:27 +00:00
|
|
|
struct PanelType;
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
struct PointerRNA;
|
|
|
|
struct PropertyRNA;
|
2008-12-29 13:38:08 +00:00
|
|
|
struct ReportList;
|
2020-04-14 18:46:13 +10:00
|
|
|
struct ResultBLF;
|
2019-01-28 21:08:24 +11:00
|
|
|
struct ScrArea;
|
|
|
|
struct bContext;
|
|
|
|
struct bContextStore;
|
|
|
|
struct bNode;
|
|
|
|
struct bNodeSocket;
|
|
|
|
struct bNodeTree;
|
|
|
|
struct bScreen;
|
2009-04-09 18:11:18 +00:00
|
|
|
struct rcti;
|
2019-01-28 21:08:24 +11:00
|
|
|
struct uiFontStyle;
|
This commit frees list ui items from their dependencies to Panel, and hence from all the limitations this implied (mostly, the "only one list per panel" one).
It introduces a new (py-extendable and registrable) RNA type, UIList (roughly similar to Panel one), which currently contains only "standard" list's scroll pos and size (but may be expended to include e.g. some filtering data, etc.). This now makes lists completely independent from Panels!
This UIList has a draw_item callback which allows to customize items' drawing from python, that all addons can now use. Incidentally, this also greatly simplifies the C code of this widget, as we do not code any "special case" here anymore!
To make all this work, other changes were also necessary:
* Now all buttons (uiBut struct) have a 'custom_data' void pointer, used currently to store the uiList struct associated with a given uiLayoutListBox.
* DynamicPaintSurface now exposes a new bool, use_color_preview (readonly), saying whether that surface has some 3D view preview data or not.
* UILayout class has now four new (static) functions, to get the actual icon of any RNA object (important e.g. with materials or textures), and to get an enum item's UI name, description and icon.
* UILayout's label() func now takes an optional 'icon_value' integer parameter, which if not zero will override the 'icon' one (mandatory to use "custom" icons as generated for material/texture/... previews).
Note: not sure whether we should add that one to all UILayout's prop funcs?
Note: will update addons using template list asap.
2012-12-28 09:20:16 +00:00
|
|
|
struct uiList;
|
2009-04-27 18:05:58 +00:00
|
|
|
struct uiStyle;
|
2009-07-03 11:46:46 +00:00
|
|
|
struct uiWidgetColors;
|
2014-07-21 12:02:05 +02:00
|
|
|
struct wmDrag;
|
2019-01-28 21:08:24 +11:00
|
|
|
struct wmDropBox;
|
|
|
|
struct wmEvent;
|
2014-07-21 12:02:05 +02:00
|
|
|
struct wmEvent;
|
2018-07-14 23:49:00 +02:00
|
|
|
struct wmGizmo;
|
2019-01-28 21:08:24 +11:00
|
|
|
struct wmKeyConfig;
|
2018-05-20 22:34:18 +02:00
|
|
|
struct wmKeyMap;
|
2018-07-08 11:57:59 +02:00
|
|
|
struct wmKeyMapItem;
|
2019-01-28 21:08:24 +11:00
|
|
|
struct wmMsgBus;
|
|
|
|
struct wmOperator;
|
|
|
|
struct wmOperatorType;
|
|
|
|
struct wmWindow;
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
typedef struct uiBlock uiBlock;
|
2019-01-28 21:08:24 +11:00
|
|
|
typedef struct uiBut uiBut;
|
2009-04-22 18:39:44 +00:00
|
|
|
typedef struct uiLayout uiLayout;
|
2019-01-28 21:08:24 +11:00
|
|
|
typedef struct uiPopupBlockHandle uiPopupBlockHandle;
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
|
|
|
|
/* Defines */
|
|
|
|
|
2013-09-11 05:06:27 +00:00
|
|
|
/* char for splitting strings, aligning shortcuts in menus, users never see */
|
2019-04-17 06:17:24 +02:00
|
|
|
#define UI_SEP_CHAR '|'
|
2013-09-11 05:06:27 +00:00
|
|
|
#define UI_SEP_CHAR_S "|"
|
|
|
|
|
2011-11-07 22:28:49 +00:00
|
|
|
/* names */
|
2012-05-12 20:39:39 +00:00
|
|
|
#define UI_MAX_DRAW_STR 400
|
|
|
|
#define UI_MAX_NAME_STR 128
|
2015-07-03 15:07:46 +02:00
|
|
|
#define UI_MAX_SHORTCUT_STR 64
|
2011-11-07 22:28:49 +00:00
|
|
|
|
2019-04-23 16:43:50 +10:00
|
|
|
/**
|
|
|
|
* For #ARegion.overlap regions, pass events though if they don't overlap
|
|
|
|
* the regions contents (the usable part of the #View2D and buttons).
|
|
|
|
*
|
2019-08-31 01:19:22 +10:00
|
|
|
* The margin is needed so it's not possible to accidentally click in between buttons.
|
2019-04-23 16:43:50 +10:00
|
|
|
*/
|
|
|
|
#define UI_REGION_OVERLAP_MARGIN (U.widget_unit / 3)
|
|
|
|
|
2013-02-07 02:03:31 +00:00
|
|
|
/* use for clamping popups within the screen */
|
|
|
|
#define UI_SCREEN_MARGIN 10
|
|
|
|
|
2013-11-21 14:43:08 +01:00
|
|
|
/* uiBlock->dt and uiBut->dt */
|
2014-11-09 21:20:40 +01:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_EMBOSS = 0, /* use widget style for drawing */
|
|
|
|
UI_EMBOSS_NONE = 1, /* Nothing, only icon and/or text */
|
|
|
|
UI_EMBOSS_PULLDOWN = 2, /* Pulldown menu style */
|
|
|
|
UI_EMBOSS_RADIAL = 3, /* Pie Menu */
|
2018-05-13 12:57:31 +02:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_EMBOSS_UNDEFINED = 255, /* For layout engine, use emboss from block. */
|
2014-11-09 21:20:40 +01:00
|
|
|
};
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
|
|
|
/* uiBlock->direction */
|
2014-11-09 21:20:40 +01:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_DIR_UP = 1 << 0,
|
|
|
|
UI_DIR_DOWN = 1 << 1,
|
|
|
|
UI_DIR_LEFT = 1 << 2,
|
|
|
|
UI_DIR_RIGHT = 1 << 3,
|
|
|
|
UI_DIR_CENTER_X = 1 << 4,
|
|
|
|
UI_DIR_CENTER_Y = 1 << 5,
|
|
|
|
|
|
|
|
UI_DIR_ALL = UI_DIR_UP | UI_DIR_DOWN | UI_DIR_LEFT | UI_DIR_RIGHT,
|
2014-11-09 21:20:40 +01:00
|
|
|
};
|
2013-06-25 10:30:07 +00:00
|
|
|
|
|
|
|
#if 0
|
2009-02-27 10:22:40 +00:00
|
|
|
/* uiBlock->autofill (not yet used) */
|
2019-04-17 06:17:24 +02:00
|
|
|
# define UI_BLOCK_COLLUMNS 1
|
|
|
|
# define UI_BLOCK_ROWS 2
|
2013-06-25 10:30:07 +00:00
|
|
|
#endif
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2019-01-14 15:58:40 +11:00
|
|
|
/** #uiBlock.flag (controls) */
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_BLOCK_LOOP = 1 << 0,
|
|
|
|
UI_BLOCK_IS_FLIP = 1 << 1,
|
|
|
|
UI_BLOCK_NO_FLIP = 1 << 2,
|
|
|
|
UI_BLOCK_NUMSELECT = 1 << 3,
|
|
|
|
/** Don't apply window clipping. */
|
|
|
|
UI_BLOCK_NO_WIN_CLIP = 1 << 4,
|
|
|
|
UI_BLOCK_CLIPBOTTOM = 1 << 5,
|
|
|
|
UI_BLOCK_CLIPTOP = 1 << 6,
|
|
|
|
UI_BLOCK_MOVEMOUSE_QUIT = 1 << 7,
|
|
|
|
UI_BLOCK_KEEP_OPEN = 1 << 8,
|
|
|
|
UI_BLOCK_POPUP = 1 << 9,
|
|
|
|
UI_BLOCK_OUT_1 = 1 << 10,
|
|
|
|
UI_BLOCK_SEARCH_MENU = 1 << 11,
|
|
|
|
UI_BLOCK_POPUP_MEMORY = 1 << 12,
|
|
|
|
/* Stop handling mouse events. */
|
|
|
|
UI_BLOCK_CLIP_EVENTS = 1 << 13,
|
|
|
|
|
|
|
|
/* block->flag bits 14-17 are identical to but->drawflag bits */
|
|
|
|
|
|
|
|
UI_BLOCK_POPUP_HOLD = 1 << 18,
|
|
|
|
UI_BLOCK_LIST_ITEM = 1 << 19,
|
|
|
|
UI_BLOCK_RADIAL = 1 << 20,
|
|
|
|
UI_BLOCK_POPOVER = 1 << 21,
|
|
|
|
UI_BLOCK_POPOVER_ONCE = 1 << 22,
|
|
|
|
/** Always show keymaps, even for non-menus. */
|
|
|
|
UI_BLOCK_SHOW_SHORTCUT_ALWAYS = 1 << 23,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
|
|
|
|
|
|
|
/** #uiPopupBlockHandle.menuretval */
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
/** Cancel all menus cascading. */
|
|
|
|
UI_RETURN_CANCEL = 1 << 0,
|
|
|
|
/** Choice made. */
|
|
|
|
UI_RETURN_OK = 1 << 1,
|
|
|
|
/** Left the menu. */
|
|
|
|
UI_RETURN_OUT = 1 << 2,
|
|
|
|
/** Let the parent handle this event. */
|
|
|
|
UI_RETURN_OUT_PARENT = 1 << 3,
|
|
|
|
/** Update the button that opened. */
|
|
|
|
UI_RETURN_UPDATE = 1 << 4,
|
|
|
|
/** Popup is ok to be handled. */
|
|
|
|
UI_RETURN_POPUP_OK = 1 << 5,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
|
|
|
/* panel controls */
|
2019-01-14 15:58:40 +11:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_PNL_SOLID = 1 << 1,
|
|
|
|
UI_PNL_CLOSE = 1 << 5,
|
|
|
|
UI_PNL_SCALE = 1 << 9,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2013-11-21 14:43:08 +01:00
|
|
|
/* but->flag - general state flags. */
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
/** Warning, the first 6 flags are internal. */
|
|
|
|
UI_BUT_ICON_SUBMENU = 1 << 6,
|
|
|
|
UI_BUT_ICON_PREVIEW = 1 << 7,
|
|
|
|
|
|
|
|
UI_BUT_NODE_LINK = 1 << 8,
|
|
|
|
UI_BUT_NODE_ACTIVE = 1 << 9,
|
|
|
|
UI_BUT_DRAG_LOCK = 1 << 10,
|
|
|
|
/** Grayed out and un-editable. */
|
|
|
|
UI_BUT_DISABLED = 1 << 11,
|
|
|
|
|
|
|
|
UI_BUT_ANIMATED = 1 << 13,
|
|
|
|
UI_BUT_ANIMATED_KEY = 1 << 14,
|
|
|
|
UI_BUT_DRIVEN = 1 << 15,
|
|
|
|
UI_BUT_REDALERT = 1 << 16,
|
|
|
|
/** Grayed out but still editable. */
|
|
|
|
UI_BUT_INACTIVE = 1 << 17,
|
|
|
|
UI_BUT_LAST_ACTIVE = 1 << 18,
|
|
|
|
UI_BUT_UNDO = 1 << 19,
|
|
|
|
UI_BUT_IMMEDIATE = 1 << 20,
|
|
|
|
UI_BUT_NO_UTF8 = 1 << 21,
|
|
|
|
|
|
|
|
/** For popups, pressing return activates this button, overriding the highlighted button.
|
|
|
|
* For non-popups this is just used as a display hint for the user to let them
|
|
|
|
* know the action which is activated when pressing return (file selector for eg). */
|
|
|
|
UI_BUT_ACTIVE_DEFAULT = 1 << 23,
|
|
|
|
|
|
|
|
/** This but is "inside" a list item (currently used to change theme colors). */
|
|
|
|
UI_BUT_LIST_ITEM = 1 << 24,
|
|
|
|
/** edit this button as well as the active button (not just dragging) */
|
|
|
|
UI_BUT_DRAG_MULTI = 1 << 25,
|
|
|
|
/** Use for popups to start editing the button on initialization. */
|
|
|
|
UI_BUT_ACTIVATE_ON_INIT = 1 << 26,
|
|
|
|
|
|
|
|
/** #uiBut.str contains #UI_SEP_CHAR, used for key shortcuts */
|
|
|
|
UI_BUT_HAS_SEP_CHAR = 1 << 27,
|
|
|
|
/** Don't run updates while dragging (needed in rare cases). */
|
|
|
|
UI_BUT_UPDATE_DELAY = 1 << 28,
|
|
|
|
/** When widget is in textedit mode, update value on each char stroke */
|
|
|
|
UI_BUT_TEXTEDIT_UPDATE = 1 << 29,
|
|
|
|
/** Show 'x' icon to clear/unlink value of text or search button. */
|
|
|
|
UI_BUT_VALUE_CLEAR = 1 << 30,
|
|
|
|
|
|
|
|
/** RNA property of the button is overridden from linked reference data. */
|
|
|
|
UI_BUT_OVERRIDEN = 1u << 31u,
|
2013-11-21 14:43:08 +01:00
|
|
|
};
|
2012-05-12 20:39:39 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
#define UI_PANEL_WIDTH 340
|
|
|
|
#define UI_COMPACT_PANEL_WIDTH 160
|
2019-05-15 16:17:23 +02:00
|
|
|
#define UI_SIDEBAR_PANEL_WIDTH 220
|
2018-11-25 16:21:35 +01:00
|
|
|
#define UI_NAVIGATION_REGION_WIDTH UI_COMPACT_PANEL_WIDTH
|
2019-01-17 14:31:18 +01:00
|
|
|
#define UI_NARROW_NAVIGATION_REGION_WIDTH 100
|
2009-04-09 18:11:18 +00:00
|
|
|
|
2014-01-04 13:54:39 -06:00
|
|
|
#define UI_PANEL_CATEGORY_MARGIN_WIDTH (U.widget_unit * 1.0f)
|
2013-12-17 03:21:55 +11:00
|
|
|
|
2020-05-26 15:39:49 -04:00
|
|
|
#define UI_PANEL_BOX_STYLE_MARGIN (U.widget_unit * 0.2f)
|
|
|
|
|
2013-11-21 14:43:08 +01:00
|
|
|
/* but->drawflag - these flags should only affect how the button is drawn. */
|
2013-11-21 16:51:29 +01:00
|
|
|
/* Note: currently, these flags _are not passed_ to the widget's state() or draw() functions
|
|
|
|
* (except for the 'align' ones)!
|
|
|
|
*/
|
2013-11-21 14:43:08 +01:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
/** Text and icon alignment (by default, they are centered). */
|
|
|
|
UI_BUT_TEXT_LEFT = 1 << 1,
|
|
|
|
UI_BUT_ICON_LEFT = 1 << 2,
|
|
|
|
UI_BUT_TEXT_RIGHT = 1 << 3,
|
|
|
|
/** Prevent the button to show any tooltip. */
|
|
|
|
UI_BUT_NO_TOOLTIP = 1 << 4,
|
UI: Better split layout support for checkboxes
Makes the following layout changes possible:
{F8473498} {F8473499} {F8473502}
The next commit will contain many layout changes to make good use of
these new possibilities. The result should be more consistent, easier to
read and should give a more organized impression. Additionally, it
should be possible to replace many sub-panels with compacter layouts.
Main changes:
* Checkboxes now respect the property split layouts
* Add support for row and column headers (i.e.
`uiLayout.column(heading="Foo")`, `uiLayout.row(heading="Bar")`). If the
first property added to this layout doesn't insert anything into the label
split column, the heading is inserted there. Otherwise, it's inserted as own
item.
* Add support for manually inserting decorators for an existing item
(`uiLayout.prop_decorator()`). That way layout creators can manually insert
this, which was the only way I saw to support property split layouts with a
checkbox before the actual property. {F8471883}
* Autogenerated layouts for operator properties look bad if there are only
checkboxes (which only use half the region width). So before creating the
layout, we iterate over visible properties and disable split layout if all
are booleans. I think this is fine, if needed we could also add layout hints
to operators.
* `uiTemplateOperatorPropertyButs()` now handles macros itself, the caller
used to be responsible for this. Code that didn't handle these so far never
used macros I think, so this change should be invisible.
* Remove manual property split layout from autogenerated operator properties
layout.
* Padding of checkboxes is tweaked to make their label visually more connected
to the checkboxes.
* Support split layout for menus (should work for `uiLayout.menu()`,
`.operator_menu_enum()`, `.prop_menu_enum()`, maybe more)
Maniphest Task: https://developer.blender.org/T65965
Differential Revision: https://developer.blender.org/D7427
Reviewed by: Brecht Van Lommel, William Reynish, Pablo Vazques
2020-04-17 16:40:25 +02:00
|
|
|
/** Do not add the usual horizontal padding for text drawing. */
|
|
|
|
UI_BUT_NO_TEXT_PADDING = 1 << 5,
|
2019-04-17 06:17:24 +02:00
|
|
|
|
|
|
|
/* Button align flag, for drawing groups together.
|
|
|
|
* Used in 'uiBlock.flag', take care! */
|
|
|
|
UI_BUT_ALIGN_TOP = 1 << 14,
|
|
|
|
UI_BUT_ALIGN_LEFT = 1 << 15,
|
|
|
|
UI_BUT_ALIGN_RIGHT = 1 << 16,
|
|
|
|
UI_BUT_ALIGN_DOWN = 1 << 17,
|
|
|
|
UI_BUT_ALIGN = UI_BUT_ALIGN_TOP | UI_BUT_ALIGN_LEFT | UI_BUT_ALIGN_RIGHT | UI_BUT_ALIGN_DOWN,
|
|
|
|
/* end bits shared with 'uiBlock.flag' */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Warning - HACK!
|
|
|
|
* Needed for buttons which are not TOP/LEFT aligned,
|
|
|
|
* but have some top/left corner stitched to some other TOP/LEFT-aligned button,
|
|
|
|
* because of 'corrective' hack in widget_roundbox_set()... */
|
|
|
|
UI_BUT_ALIGN_STITCH_TOP = 1 << 18,
|
|
|
|
UI_BUT_ALIGN_STITCH_LEFT = 1 << 19,
|
|
|
|
UI_BUT_ALIGN_ALL = UI_BUT_ALIGN | UI_BUT_ALIGN_STITCH_TOP | UI_BUT_ALIGN_STITCH_LEFT,
|
|
|
|
|
|
|
|
/** This but is "inside" a box item (currently used to change theme colors). */
|
|
|
|
UI_BUT_BOX_ITEM = 1 << 20,
|
|
|
|
|
|
|
|
/** Active left part of number button */
|
|
|
|
UI_BUT_ACTIVE_LEFT = 1 << 21,
|
|
|
|
/** Active right part of number button */
|
|
|
|
UI_BUT_ACTIVE_RIGHT = 1 << 22,
|
|
|
|
|
|
|
|
/* (also used by search buttons to enforce shortcut display for their items). */
|
|
|
|
/** Button has shortcut text. */
|
|
|
|
UI_BUT_HAS_SHORTCUT = 1 << 23,
|
|
|
|
|
|
|
|
/** Reverse order of consecutive off/on icons */
|
|
|
|
UI_BUT_ICON_REVERSE = 1 << 24,
|
|
|
|
|
|
|
|
/** Value is animated, but the current value differs from the animated one. */
|
|
|
|
UI_BUT_ANIMATED_CHANGED = 1 << 25,
|
2019-05-20 12:14:48 +02:00
|
|
|
|
|
|
|
/* Draw the checkbox buttons inverted. */
|
|
|
|
UI_BUT_CHECKBOX_INVERT = 1 << 26,
|
2013-11-21 14:43:08 +01:00
|
|
|
};
|
2012-05-23 14:24:40 +00:00
|
|
|
|
2012-12-13 01:21:12 +00:00
|
|
|
/* scale fixed button widths by this to account for DPI */
|
Holiday coding log :)
Nice formatted version (pictures soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.66/Usability
Short list of main changes:
- Transparent region option (over main region), added code to blend in/out such panels.
- Min size window now 640 x 480
- Fixed DPI for ui - lots of cleanup and changes everywhere. Icon image need correct size still, layer-in-use icon needs remake.
- Macbook retina support, use command line --no-native-pixels to disable it
- Timeline Marker label was drawing wrong
- Trackpad and magic mouse: supports zoom (hold ctrl)
- Fix for splash position: removed ghost function and made window size update after creation immediate
- Fast undo buffer save now adds UI as well. Could be checked for regular file save even...
Quit.blend and temp file saving use this now.
- Dixed filename in window on reading quit.blend or temp saves, and they now add a warning in window title: "(Recovered)"
- New Userpref option "Keep Session" - this always saves quit.blend, and loads on start.
This allows keeping UI and data without actual saves, until you actually save.
When you load startup.blend and quit, it recognises the quit.blend as a startup (no file name in header)
- Added 3D view copy/paste buffers (selected objects). Shortcuts ctrl-c, ctrl-v (OSX, cmd-c, cmd-v).
Coded partial file saving for it. Could be used for other purposes. Todo: use OS clipboards.
- User preferences (themes, keymaps, user settings) now can be saved as a separate file.
Old option is called "Save Startup File" the new one "Save User Settings".
To visualise this difference, the 'save startup file' button has been removed from user preferences window. That option is available as CTRL+U and in File menu still.
- OSX: fixed bug that stopped giving mouse events outside window.
This also fixes "Continuous Grab" for OSX. (error since 2009)
2012-12-12 18:58:11 +00:00
|
|
|
|
2018-04-28 20:39:18 +02:00
|
|
|
#define UI_DPI_FAC (U.dpi_fac)
|
2011-08-05 10:45:32 +00:00
|
|
|
/* 16 to copy ICON_DEFAULT_HEIGHT */
|
2012-12-13 01:21:12 +00:00
|
|
|
#define UI_DPI_ICON_SIZE ((float)16 * UI_DPI_FAC)
|
2011-05-05 15:21:43 +00:00
|
|
|
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
/* Button types, bits stored in 1 value... and a short even!
|
2012-03-03 16:31:46 +00:00
|
|
|
* - bits 0-4: bitnr (0-31)
|
|
|
|
* - bits 5-7: pointer type
|
|
|
|
* - bit 8: for 'bit'
|
|
|
|
* - bit 9-15: button type (now 6 bits, 64 types)
|
|
|
|
* */
|
2012-09-11 23:10:23 +00:00
|
|
|
typedef enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_BUT_POIN_CHAR = 32,
|
|
|
|
UI_BUT_POIN_SHORT = 64,
|
|
|
|
UI_BUT_POIN_INT = 96,
|
|
|
|
UI_BUT_POIN_FLOAT = 128,
|
|
|
|
/* UI_BUT_POIN_FUNCTION = 192, */ /*UNUSED*/
|
|
|
|
UI_BUT_POIN_BIT = 256, /* OR'd with a bit index*/
|
2012-09-11 23:10:23 +00:00
|
|
|
} eButPointerType;
|
2012-05-12 20:39:39 +00:00
|
|
|
|
2012-09-14 05:44:47 +00:00
|
|
|
/* requires (but->poin != NULL) */
|
2012-09-12 00:32:33 +00:00
|
|
|
#define UI_BUT_POIN_TYPES (UI_BUT_POIN_FLOAT | UI_BUT_POIN_SHORT | UI_BUT_POIN_CHAR)
|
2012-05-12 20:39:39 +00:00
|
|
|
|
2012-07-18 17:29:15 +00:00
|
|
|
/* assigned to but->type, OR'd with the flags above when passing args */
|
2012-09-10 06:05:19 +00:00
|
|
|
typedef enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_BTYPE_BUT = 1 << 9,
|
|
|
|
UI_BTYPE_ROW = 2 << 9,
|
|
|
|
UI_BTYPE_TEXT = 3 << 9,
|
|
|
|
/** dropdown list */
|
|
|
|
UI_BTYPE_MENU = 4 << 9,
|
|
|
|
UI_BTYPE_BUT_MENU = 5 << 9,
|
|
|
|
/** number button */
|
|
|
|
UI_BTYPE_NUM = 6 << 9,
|
|
|
|
/** number slider */
|
|
|
|
UI_BTYPE_NUM_SLIDER = 7 << 9,
|
|
|
|
UI_BTYPE_TOGGLE = 8 << 9,
|
|
|
|
UI_BTYPE_TOGGLE_N = 9 << 9,
|
|
|
|
UI_BTYPE_ICON_TOGGLE = 10 << 9,
|
|
|
|
UI_BTYPE_ICON_TOGGLE_N = 11 << 9,
|
|
|
|
/** same as regular toggle, but no on/off state displayed */
|
|
|
|
UI_BTYPE_BUT_TOGGLE = 12 << 9,
|
|
|
|
/** similar to toggle, display a 'tick' */
|
|
|
|
UI_BTYPE_CHECKBOX = 13 << 9,
|
|
|
|
UI_BTYPE_CHECKBOX_N = 14 << 9,
|
|
|
|
UI_BTYPE_COLOR = 15 << 9,
|
|
|
|
UI_BTYPE_TAB = 16 << 9,
|
|
|
|
UI_BTYPE_POPOVER = 17 << 9,
|
|
|
|
UI_BTYPE_SCROLL = 18 << 9,
|
|
|
|
UI_BTYPE_BLOCK = 19 << 9,
|
|
|
|
UI_BTYPE_LABEL = 20 << 9,
|
|
|
|
UI_BTYPE_KEY_EVENT = 24 << 9,
|
|
|
|
UI_BTYPE_HSVCUBE = 26 << 9,
|
|
|
|
/** menu (often used in headers), **_MENU /w different draw-type */
|
|
|
|
UI_BTYPE_PULLDOWN = 27 << 9,
|
|
|
|
UI_BTYPE_ROUNDBOX = 28 << 9,
|
|
|
|
UI_BTYPE_COLORBAND = 30 << 9,
|
|
|
|
/** sphere widget (used to input a unit-vector, aka normal) */
|
|
|
|
UI_BTYPE_UNITVEC = 31 << 9,
|
|
|
|
UI_BTYPE_CURVE = 32 << 9,
|
2019-11-20 16:12:32 -05:00
|
|
|
/** Profile editing widget */
|
|
|
|
UI_BTYPE_CURVEPROFILE = 33 << 9,
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_BTYPE_LISTBOX = 36 << 9,
|
|
|
|
UI_BTYPE_LISTROW = 37 << 9,
|
|
|
|
UI_BTYPE_HSVCIRCLE = 38 << 9,
|
|
|
|
UI_BTYPE_TRACK_PREVIEW = 40 << 9,
|
|
|
|
|
|
|
|
/** Buttons with value >= #UI_BTYPE_SEARCH_MENU don't get undo pushes. */
|
|
|
|
UI_BTYPE_SEARCH_MENU = 41 << 9,
|
|
|
|
UI_BTYPE_EXTRA = 42 << 9,
|
|
|
|
UI_BTYPE_HOTKEY_EVENT = 46 << 9,
|
|
|
|
/** Non-interactive image, used for splash screen */
|
|
|
|
UI_BTYPE_IMAGE = 47 << 9,
|
|
|
|
UI_BTYPE_HISTOGRAM = 48 << 9,
|
|
|
|
UI_BTYPE_WAVEFORM = 49 << 9,
|
|
|
|
UI_BTYPE_VECTORSCOPE = 50 << 9,
|
|
|
|
UI_BTYPE_PROGRESS_BAR = 51 << 9,
|
|
|
|
UI_BTYPE_NODE_SOCKET = 53 << 9,
|
|
|
|
UI_BTYPE_SEPR = 54 << 9,
|
|
|
|
UI_BTYPE_SEPR_LINE = 55 << 9,
|
|
|
|
/** Dynamically fill available space. */
|
|
|
|
UI_BTYPE_SEPR_SPACER = 56 << 9,
|
|
|
|
/** Resize handle (resize uilist). */
|
|
|
|
UI_BTYPE_GRIP = 57 << 9,
|
2012-09-10 06:05:19 +00:00
|
|
|
} eButType;
|
2012-05-12 20:39:39 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
#define BUTTYPE (63 << 9)
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2019-01-14 15:58:40 +11:00
|
|
|
/** Gradient types, for color picker #UI_BTYPE_HSVCUBE etc. */
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_GRAD_SV = 0,
|
|
|
|
UI_GRAD_HV = 1,
|
|
|
|
UI_GRAD_HS = 2,
|
|
|
|
UI_GRAD_H = 3,
|
|
|
|
UI_GRAD_S = 4,
|
|
|
|
UI_GRAD_V = 5,
|
|
|
|
|
|
|
|
UI_GRAD_V_ALT = 9,
|
|
|
|
UI_GRAD_L_ALT = 10,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
2010-01-21 00:00:45 +00:00
|
|
|
|
2014-07-21 12:02:05 +02:00
|
|
|
#define UI_PALETTE_COLOR 20
|
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Drawing
|
|
|
|
*
|
|
|
|
* Functions to draw various shapes, taking theme settings into account.
|
|
|
|
* Used for code that draws its own UI style elements. */
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_draw_anti_tria(
|
|
|
|
float x1, float y1, float x2, float y2, float x3, float y3, const float color[4]);
|
2018-04-22 18:56:06 +02:00
|
|
|
void UI_draw_anti_fan(float tri_array[][2], unsigned int length, const float color[4]);
|
2018-04-22 19:02:17 +02:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_draw_roundbox_corner_set(int type);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_draw_roundbox_aa(
|
|
|
|
bool filled, float minx, float miny, float maxx, float maxy, float rad, const float color[4]);
|
|
|
|
void UI_draw_roundbox_4fv(
|
|
|
|
bool filled, float minx, float miny, float maxx, float maxy, float rad, const float col[4]);
|
2020-02-15 10:45:46 +11:00
|
|
|
void UI_draw_roundbox_3ub_alpha(bool filled,
|
|
|
|
float minx,
|
|
|
|
float miny,
|
|
|
|
float maxx,
|
|
|
|
float maxy,
|
|
|
|
float rad,
|
|
|
|
const unsigned char col[3],
|
|
|
|
unsigned char alpha);
|
|
|
|
void UI_draw_roundbox_3fv_alpha(bool filled,
|
|
|
|
float minx,
|
|
|
|
float miny,
|
|
|
|
float maxx,
|
|
|
|
float maxy,
|
|
|
|
float rad,
|
|
|
|
const float col[3],
|
|
|
|
float alpha);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_draw_roundbox_shade_x(bool filled,
|
|
|
|
float minx,
|
|
|
|
float miny,
|
|
|
|
float maxx,
|
|
|
|
float maxy,
|
|
|
|
float rad,
|
|
|
|
float shadetop,
|
|
|
|
float shadedown,
|
|
|
|
const float col[4]);
|
2017-04-06 19:15:26 -04:00
|
|
|
|
|
|
|
#if 0 /* unused */
|
2019-04-17 08:24:14 +02:00
|
|
|
int UI_draw_roundbox_corner_get(void);
|
|
|
|
void UI_draw_roundbox_shade_y(bool filled,
|
|
|
|
float minx,
|
|
|
|
float miny,
|
|
|
|
float maxx,
|
|
|
|
float maxy,
|
|
|
|
float rad,
|
|
|
|
float shadeleft,
|
|
|
|
float shaderight,
|
|
|
|
const float col[4]);
|
2017-04-06 19:15:26 -04:00
|
|
|
#endif
|
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_draw_box_shadow(unsigned char alpha, float minx, float miny, float maxx, float maxy);
|
2017-02-06 16:54:26 +01:00
|
|
|
void UI_draw_text_underline(int pos_x, int pos_y, int len, int height, const float color[4]);
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_draw_safe_areas(uint pos,
|
|
|
|
float x1,
|
|
|
|
float x2,
|
|
|
|
float y1,
|
|
|
|
float y2,
|
|
|
|
const float title_aspect[2],
|
|
|
|
const float action_aspect[2]);
|
2015-01-19 16:30:35 +11:00
|
|
|
|
2019-01-14 15:58:40 +11:00
|
|
|
/** State for scrolldrawing. */
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_SCROLL_PRESSED = 1 << 0,
|
|
|
|
UI_SCROLL_ARROWS = 1 << 1,
|
|
|
|
UI_SCROLL_NO_OUTLINE = 1 << 2,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_draw_widget_scroll(struct uiWidgetColors *wcol,
|
|
|
|
const struct rcti *rect,
|
|
|
|
const struct rcti *slider,
|
|
|
|
int state);
|
2009-07-03 10:54:39 +00:00
|
|
|
|
2015-05-04 21:12:28 +02:00
|
|
|
/* Shortening string helper. */
|
2019-04-17 06:17:24 +02:00
|
|
|
float UI_text_clip_middle_ex(const struct uiFontStyle *fstyle,
|
|
|
|
char *str,
|
|
|
|
float okwidth,
|
|
|
|
const float minwidth,
|
|
|
|
const size_t max_len,
|
|
|
|
const char rpart_sep);
|
2015-05-04 21:12:28 +02:00
|
|
|
|
2019-01-14 15:58:40 +11:00
|
|
|
/**
|
|
|
|
* Callbacks
|
2011-11-24 13:51:31 +00:00
|
|
|
*
|
2014-11-09 21:20:40 +01:00
|
|
|
* UI_block_func_handle_set/ButmFunc are for handling events through a callback.
|
2011-11-24 13:51:31 +00:00
|
|
|
* HandleFunc gets the retval passed on, and ButmFunc gets a2. The latter is
|
|
|
|
* mostly for compatibility with older code.
|
|
|
|
*
|
2019-01-14 15:58:40 +11:00
|
|
|
* - #UI_but_func_complete_set is for tab completion.
|
2011-11-24 13:51:31 +00:00
|
|
|
*
|
2019-01-14 15:58:40 +11:00
|
|
|
* - #uiButSearchFunc is for name buttons, showing a popup with matches
|
2011-11-24 13:51:31 +00:00
|
|
|
*
|
2019-01-14 15:58:40 +11:00
|
|
|
* - #UI_block_func_set and UI_but_func_set are callbacks run when a button is used,
|
|
|
|
* in case events, operators or RNA are not sufficient to handle the button.
|
2011-11-24 13:51:31 +00:00
|
|
|
*
|
2019-01-14 15:58:40 +11:00
|
|
|
* - #UI_but_funcN_set will free the argument with MEM_freeN. */
|
2011-11-24 13:51:31 +00:00
|
|
|
|
|
|
|
typedef struct uiSearchItems uiSearchItems;
|
|
|
|
|
|
|
|
typedef void (*uiButHandleFunc)(struct bContext *C, void *arg1, void *arg2);
|
|
|
|
typedef void (*uiButHandleRenameFunc)(struct bContext *C, void *arg, char *origstr);
|
|
|
|
typedef void (*uiButHandleNFunc)(struct bContext *C, void *argN, void *arg2);
|
2017-11-02 04:30:07 +11:00
|
|
|
typedef void (*uiButHandleHoldFunc)(struct bContext *C, struct ARegion *butregion, uiBut *but);
|
2013-11-22 01:35:38 +01:00
|
|
|
typedef int (*uiButCompleteFunc)(struct bContext *C, char *str, void *arg);
|
2020-03-24 11:34:18 +11:00
|
|
|
|
2020-05-07 23:16:05 +10:00
|
|
|
/* Search types. */
|
|
|
|
typedef struct ARegion *(*uiButSearchCreateFn)(struct bContext *C,
|
|
|
|
struct ARegion *butregion,
|
|
|
|
uiBut *but);
|
|
|
|
typedef void (*uiButSearchUpdateFn)(const struct bContext *C,
|
|
|
|
void *arg,
|
|
|
|
const char *str,
|
|
|
|
uiSearchItems *items);
|
|
|
|
typedef void (*uiButSearchArgFreeFn)(void *arg);
|
2020-05-07 23:16:22 +10:00
|
|
|
typedef bool (*uiButSearchContextMenuFn)(struct bContext *C,
|
|
|
|
void *arg,
|
|
|
|
void *active,
|
|
|
|
const struct wmEvent *event);
|
2020-05-11 18:37:43 +10:00
|
|
|
typedef struct ARegion *(*uiButSearchTooltipFn)(struct bContext *C,
|
|
|
|
struct ARegion *region,
|
|
|
|
void *arg,
|
|
|
|
void *active);
|
2020-03-24 11:34:18 +11:00
|
|
|
|
2015-02-11 00:06:03 +01:00
|
|
|
/* Must return allocated string. */
|
|
|
|
typedef char *(*uiButToolTipFunc)(struct bContext *C, void *argN, const char *tip);
|
2019-03-01 13:14:16 -03:00
|
|
|
typedef int (*uiButPushedStateFunc)(struct bContext *C, void *arg);
|
2015-02-11 00:06:03 +01:00
|
|
|
|
2011-11-24 13:51:31 +00:00
|
|
|
typedef void (*uiBlockHandleFunc)(struct bContext *C, void *arg, int event);
|
|
|
|
|
2009-04-22 18:39:44 +00:00
|
|
|
/* Menu Callbacks */
|
2009-01-25 20:22:05 +00:00
|
|
|
|
2009-04-22 18:39:44 +00:00
|
|
|
typedef void (*uiMenuCreateFunc)(struct bContext *C, struct uiLayout *layout, void *arg1);
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
typedef void (*uiMenuHandleFunc)(struct bContext *C, void *arg, int event);
|
2015-11-16 06:26:25 +11:00
|
|
|
/**
|
|
|
|
* Used for cycling menu values without opening the menu (Ctrl-Wheel).
|
|
|
|
* \param direction: forward or backwards [1 / -1].
|
|
|
|
* \param arg1: uiBut.poin (as with #uiMenuCreateFunc).
|
|
|
|
* \return true when the button was changed.
|
|
|
|
*/
|
|
|
|
typedef bool (*uiMenuStepFunc)(struct bContext *C, int direction, void *arg1);
|
2009-01-25 20:22:05 +00:00
|
|
|
|
2018-06-30 10:36:40 +02:00
|
|
|
/* interface_query.c */
|
2018-09-05 13:52:19 +10:00
|
|
|
bool UI_but_has_tooltip_label(const uiBut *but);
|
2018-06-30 10:58:56 +02:00
|
|
|
bool UI_but_is_tool(const uiBut *but);
|
2019-09-04 16:19:48 +02:00
|
|
|
bool UI_but_is_utf8(const uiBut *but);
|
2019-04-17 06:17:24 +02:00
|
|
|
#define UI_but_is_decorator(but) ((but)->func == ui_but_anim_decorate_cb)
|
2018-06-30 10:58:56 +02:00
|
|
|
|
2019-09-20 19:53:17 +10:00
|
|
|
bool UI_block_is_empty_ex(const uiBlock *block, const bool skip_title);
|
2018-06-30 10:36:40 +02:00
|
|
|
bool UI_block_is_empty(const uiBlock *block);
|
2019-04-25 14:40:53 +02:00
|
|
|
bool UI_block_can_add_separator(const uiBlock *block);
|
2018-06-30 10:36:40 +02:00
|
|
|
|
2017-11-03 20:26:35 +11:00
|
|
|
/* interface_region_menu_popup.c */
|
2019-01-14 15:58:40 +11:00
|
|
|
/**
|
|
|
|
* Popup Menus
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
*
|
|
|
|
* Functions used to create popup menus. For more extended menus the
|
2014-11-09 21:20:40 +01:00
|
|
|
* UI_popup_menu_begin/End functions can be used to define own items with
|
2011-01-02 11:06:50 +00:00
|
|
|
* the uiItem functions in between. If it is a simple confirmation menu
|
2019-01-14 15:58:40 +11:00
|
|
|
* or similar, popups can be created with a single function call.
|
|
|
|
*/
|
2009-04-22 18:39:44 +00:00
|
|
|
typedef struct uiPopupMenu uiPopupMenu;
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
uiPopupMenu *UI_popup_menu_begin(struct bContext *C, const char *title, int icon) ATTR_NONNULL();
|
|
|
|
uiPopupMenu *UI_popup_menu_begin_ex(struct bContext *C,
|
|
|
|
const char *title,
|
|
|
|
const char *block_name,
|
|
|
|
int icon) ATTR_NONNULL();
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_popup_menu_end(struct bContext *C, struct uiPopupMenu *head);
|
2018-06-23 10:31:10 +02:00
|
|
|
bool UI_popup_menu_end_or_cancel(struct bContext *C, struct uiPopupMenu *head);
|
2014-11-09 21:20:40 +01:00
|
|
|
struct uiLayout *UI_popup_menu_layout(uiPopupMenu *head);
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_popup_menu_reports(struct bContext *C, struct ReportList *reports) ATTR_NONNULL();
|
2019-04-17 06:17:24 +02:00
|
|
|
int UI_popup_menu_invoke(struct bContext *C, const char *idname, struct ReportList *reports)
|
|
|
|
ATTR_NONNULL(1, 2);
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
|
2016-09-01 16:25:42 +02:00
|
|
|
void UI_popup_menu_retval_set(const uiBlock *block, const int retval, const bool enable);
|
2017-11-02 04:30:07 +11:00
|
|
|
void UI_popup_menu_but_set(uiPopupMenu *pup, struct ARegion *butregion, uiBut *but);
|
2016-09-01 16:25:42 +02:00
|
|
|
|
2018-04-22 17:16:39 +02:00
|
|
|
/* interface_region_popover.c */
|
|
|
|
|
|
|
|
typedef struct uiPopover uiPopover;
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
int UI_popover_panel_invoke(struct bContext *C,
|
|
|
|
const char *idname,
|
|
|
|
bool keep_open,
|
|
|
|
struct ReportList *reports);
|
2018-05-23 19:46:40 +02:00
|
|
|
|
2019-07-30 10:57:47 +10:00
|
|
|
uiPopover *UI_popover_begin(struct bContext *C, int menu_width, bool from_active_button)
|
|
|
|
ATTR_NONNULL(1);
|
2018-05-20 22:34:18 +02:00
|
|
|
void UI_popover_end(struct bContext *C, struct uiPopover *head, struct wmKeyMap *keymap);
|
2018-04-22 17:16:39 +02:00
|
|
|
struct uiLayout *UI_popover_layout(uiPopover *head);
|
2018-05-19 19:16:47 +02:00
|
|
|
void UI_popover_once_clear(uiPopover *pup);
|
2018-04-22 17:16:39 +02:00
|
|
|
|
2017-11-03 20:26:35 +11:00
|
|
|
/* interface_region_menu_pie.c */
|
Pie Menus C code backend.
This commit merges the code in the pie-menu branch.
As per decisions taken the last few days, there are no pie menus
included and there will be an official add-on including overrides of
some keys with pie menus. However, people will now be able to use the
new code in python.
Full Documentation is in http://wiki.blender.org/index.php/Dev:Ref/
Thanks:
Campbell Barton, Dalai Felinto and Ton Roosendaal for the code review
and design comments
Jonathan Williamson, Pawel Lyczkowski, Pablo Vazquez among others for
suggestions during the development.
Special Thanks to Sean Olson, for his support, suggestions, testing and
merciless bugging so that I would finish the pie menu code. Without him
we wouldn't be here. Also to the rest of the developers of the original
python add-on, Patrick Moore and Dan Eicher and finally to Matt Ebb, who
did the research and first implementation and whose code I used to get
started.
2014-08-11 10:39:59 +02:00
|
|
|
/* Pie menus */
|
|
|
|
typedef struct uiPieMenu uiPieMenu;
|
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
int UI_pie_menu_invoke(struct bContext *C, const char *idname, const struct wmEvent *event);
|
2019-04-17 06:17:24 +02:00
|
|
|
int UI_pie_menu_invoke_from_operator_enum(struct bContext *C,
|
|
|
|
const char *title,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
const struct wmEvent *event);
|
|
|
|
int UI_pie_menu_invoke_from_rna_enum(struct bContext *C,
|
|
|
|
const char *title,
|
|
|
|
const char *path,
|
|
|
|
const struct wmEvent *event);
|
|
|
|
|
|
|
|
struct uiPieMenu *UI_pie_menu_begin(struct bContext *C,
|
|
|
|
const char *title,
|
|
|
|
int icon,
|
|
|
|
const struct wmEvent *event) ATTR_NONNULL();
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_pie_menu_end(struct bContext *C, uiPieMenu *pie);
|
|
|
|
struct uiLayout *UI_pie_menu_layout(struct uiPieMenu *pie);
|
2017-11-03 20:26:35 +11:00
|
|
|
|
|
|
|
/* interface_region_menu_popup.c */
|
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Popup Blocks
|
|
|
|
*
|
|
|
|
* Functions used to create popup blocks. These are like popup menus
|
|
|
|
* but allow using all button types and creating an own layout. */
|
2020-03-06 16:56:42 +01:00
|
|
|
typedef uiBlock *(*uiBlockCreateFunc)(struct bContext *C, struct ARegion *region, void *arg1);
|
2013-02-19 13:37:48 +00:00
|
|
|
typedef void (*uiBlockCancelFunc)(struct bContext *C, void *arg1);
|
2009-02-04 11:52:16 +00:00
|
|
|
|
2019-05-14 15:38:51 +02:00
|
|
|
void UI_popup_block_invoke(struct bContext *C,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
void (*arg_free)(void *arg));
|
|
|
|
void UI_popup_block_invoke_ex(struct bContext *C,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
void (*arg_free)(void *arg),
|
2020-05-07 21:35:36 +10:00
|
|
|
bool can_refresh);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_popup_block_ex(struct bContext *C,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
uiBlockHandleFunc popup_func,
|
|
|
|
uiBlockCancelFunc cancel_func,
|
|
|
|
void *arg,
|
|
|
|
struct wmOperator *op);
|
|
|
|
#if 0 /* UNUSED */
|
2019-04-17 08:24:14 +02:00
|
|
|
void uiPupBlockOperator(struct bContext *C,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
struct wmOperator *op,
|
|
|
|
int opcontext);
|
2019-01-15 23:24:20 +11:00
|
|
|
#endif
|
2009-01-25 20:22:05 +00:00
|
|
|
|
2015-06-08 15:57:42 +10:00
|
|
|
void UI_popup_block_close(struct bContext *C, struct wmWindow *win, uiBlock *block);
|
2009-11-23 13:58:55 +00:00
|
|
|
|
2020-03-06 16:22:28 +01:00
|
|
|
bool UI_popup_block_name_exists(const struct bScreen *screen, const char *name);
|
2019-01-04 14:23:49 +01:00
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Blocks
|
|
|
|
*
|
|
|
|
* Functions for creating, drawing and freeing blocks. A Block is a
|
|
|
|
* container of buttons and used for various purposes.
|
2018-06-01 18:19:39 +02:00
|
|
|
*
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
* Begin/Define Buttons/End/Draw is the typical order in which these
|
|
|
|
* function should be called, though for popup blocks Draw is left out.
|
|
|
|
* Freeing blocks is done by the screen/ module automatically.
|
|
|
|
*
|
|
|
|
* */
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
uiBlock *UI_block_begin(const struct bContext *C,
|
|
|
|
struct ARegion *region,
|
|
|
|
const char *name,
|
|
|
|
short dt);
|
2017-10-12 14:43:45 +02:00
|
|
|
void UI_block_end_ex(const struct bContext *C, uiBlock *block, const int xy[2], int r_xy[2]);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_end(const struct bContext *C, uiBlock *block);
|
|
|
|
void UI_block_draw(const struct bContext *C, struct uiBlock *block);
|
2018-04-29 12:24:08 +02:00
|
|
|
void UI_blocklist_update_window_matrix(const struct bContext *C, const struct ListBase *lb);
|
|
|
|
void UI_blocklist_draw(const struct bContext *C, const struct ListBase *lb);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_update_from_old(const struct bContext *C, struct uiBlock *block);
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
|
2018-09-11 10:56:08 +10:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_BLOCK_THEME_STYLE_REGULAR = 0,
|
|
|
|
UI_BLOCK_THEME_STYLE_POPUP = 1,
|
2018-09-11 10:56:08 +10:00
|
|
|
};
|
|
|
|
void UI_block_theme_style_set(uiBlock *block, char theme_style);
|
Outliner Visibility Update
See T61578 for discussions and mockups.
Visibility Options
==================
We are adding more granular control over restriction columns in the outliner,
exposing "indirect only" and "holdout" as options, and change the way
users enable/disable collections in a viewlayer.
We also rename the object viewport restriction to hide instance.
So the options we have are:
Collection
----------
* Render Visibility
* Instance Visibility
* Selectable
(View) Layer Collection
-----------------------
* Enable
* Holdout
* Indirect Only
* Viewport
Shortcuts
=========
Isolate Collection
------------------
* Ctr + click isolates the collection.
It turns all its parents and children "visible", and all the other
collections "invisible".
If ALL the collections were already properly set, we re-set the
collections to their default value.
Set Collection Inside Collections and Objects
---------------------------------------------
* Shift + click: Set/unset inside collections and objects.
We only set objects values as well when we are in View Layer mode and
(obviously) when the objects have a matching property.
Icons
=====
Little reminder that we will need better icons for holdout, indirect only, and
probably instanced (nothing wrong with the current, but it differs from
the proposal when it is turned off).
Also, we need to decide where do we want the modifier/bones/... icons to
be (in which column) and ideally make sure their icons match the ones we
use for collections/objects.
At the moment those are using the screen icon, which is not being used
by collections.
Reviewers: brecht, billrey
Subscribers: pablovazquez
Differential Revision: https://developer.blender.org/D4823
2019-05-04 14:14:37 -03:00
|
|
|
char UI_block_emboss_get(uiBlock *block);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_emboss_set(uiBlock *block, char dt);
|
2.5
More cleanup!
- removed old UI font completely, including from uiBeginBlock
- emboss hints for uiBlock only have three types now;
Regular, Pulldown, or "Nothing" (only icon/text)
- removed old font path from Userdef
- removed all old button theme hinting
- removed old "auto block" to merge buttons in groups
(was only in use for radiosity buttons)
And went over all warnings. One hooray for make giving clean output :)
Well, we need uniform definitions for warnings, so people at least fix
them... here's the real bad bugs I found:
- in mesh code, a call to editmesh mixed *em and *me
- in armature, ED_util.h was not included, so no warnings for wrong call
to ED_undo_push()
- The extern Py api .h was not included in the bpy_interface.c, showing
a several calls using different args.
Further just added the missing includes, and removed unused vars.
2009-04-14 15:59:52 +00:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_free(const struct bContext *C, uiBlock *block);
|
|
|
|
void UI_blocklist_free(const struct bContext *C, struct ListBase *lb);
|
|
|
|
void UI_blocklist_free_inactive(const struct bContext *C, struct ListBase *lb);
|
|
|
|
void UI_screen_free_active_but(const struct bContext *C, struct bScreen *screen);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_region_set(uiBlock *block, struct ARegion *region);
|
UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
This means the layout engine now works at button level, and makes it
easier to write templates. Otherwise you had to store all info and
create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
These can contain regular buttons, and can be put in a Free layout,
which means you can specify manual coordinates, but still get nested
correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
in the last added layout specifier, i.e. one level up in the layout
hierarchy. This doesn't work well in always, so now when creating things
like rows or columns it always returns a layout which you have to add
the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
required width/height of all nested layouts, and then in the second
pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
buttons).
* Moved some more space variables into Style.
2009-05-15 11:19:59 +00:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_lock_set(uiBlock *block, bool val, const char *lockstr);
|
|
|
|
void UI_block_lock_clear(uiBlock *block);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
|
|
|
/* automatic aligning, horiz or verical */
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_align_begin(uiBlock *block);
|
|
|
|
void UI_block_align_end(uiBlock *block);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2009-11-23 13:58:55 +00:00
|
|
|
/* block bounds/position calculation */
|
2012-09-10 07:03:30 +00:00
|
|
|
typedef enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_BLOCK_BOUNDS_NONE = 0,
|
|
|
|
UI_BLOCK_BOUNDS = 1,
|
|
|
|
UI_BLOCK_BOUNDS_TEXT,
|
|
|
|
UI_BLOCK_BOUNDS_POPUP_MOUSE,
|
|
|
|
UI_BLOCK_BOUNDS_POPUP_MENU,
|
|
|
|
UI_BLOCK_BOUNDS_POPUP_CENTER,
|
|
|
|
UI_BLOCK_BOUNDS_PIE_CENTER,
|
2009-11-23 13:58:55 +00:00
|
|
|
} eBlockBoundsCalc;
|
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_bounds_set_normal(struct uiBlock *block, int addval);
|
|
|
|
void UI_block_bounds_set_text(uiBlock *block, int addval);
|
2019-03-13 16:35:24 +11:00
|
|
|
void UI_block_bounds_set_popup(uiBlock *block, int addval, const int bounds_offset[2]);
|
|
|
|
void UI_block_bounds_set_menu(uiBlock *block, int addval, const int bounds_offset[2]);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_bounds_set_centered(uiBlock *block, int addval);
|
|
|
|
void UI_block_bounds_set_explicit(uiBlock *block, int minx, int miny, int maxx, int maxy);
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
int UI_blocklist_min_y_get(struct ListBase *lb);
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_block_direction_set(uiBlock *block, char direction);
|
|
|
|
void UI_block_order_flip(uiBlock *block);
|
|
|
|
void UI_block_flag_enable(uiBlock *block, int flag);
|
|
|
|
void UI_block_flag_disable(uiBlock *block, int flag);
|
|
|
|
void UI_block_translate(uiBlock *block, int x, int y);
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
int UI_but_return_value_get(uiBut *but);
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_drag_set_id(uiBut *but, struct ID *id);
|
|
|
|
void UI_but_drag_set_rna(uiBut *but, struct PointerRNA *ptr);
|
|
|
|
void UI_but_drag_set_path(uiBut *but, const char *path, const bool use_free);
|
|
|
|
void UI_but_drag_set_name(uiBut *but, const char *name);
|
|
|
|
void UI_but_drag_set_value(uiBut *but);
|
|
|
|
void UI_but_drag_set_image(
|
|
|
|
uiBut *but, const char *path, int icon, struct ImBuf *ima, float scale, const bool use_free);
|
Drag and drop 2.5 integration! Finally, slashdot regulars can use
Blender too now! :)
** Drag works as follows:
- drag-able items are defined by the standard interface ui toolkit
- each button can get this feature, via uiButSetDragXXX(but, ...).
There are calls to define drag-able images, ID blocks, RNA paths,
file paths, and so on. By default you drag an icon, exceptionally
an ImBuf
- Drag items are registered centrally in the WM, it allows more drag
items simultaneous too, but not implemented
** Drop works as follows:
- On mouse release, and if drag items exist in the WM, it converts
the mouse event to an EVT_DROP type. This event then gets the full
drag info as customdata
- drop regions are defined with WM_dropbox_add(), similar to keymaps
you can make a "drop map" this way, which become 'drop map handlers'
in the queues.
- next to that the UI kit handles some common button types (like
accepting ID or names) to be catching a drop event too.
- Every "drop box" has two callbacks:
- poll() = check if the event drag data is relevant for this box
- copy() = fill in custom properties in the dropbox to initialize
an operator
- The dropbox handler then calls its standard Operator with its
dropbox properties.
** Currently implemented
Drag items:
- ID icons in browse buttons
- ID icons in context menu of properties region
- ID icons in outliner and rna viewer
- FileBrowser icons
- FileBrowser preview images
Drag-able icons are subtly visualized by making them brighter a bit
on mouse-over. In case the icon is a button or UI element too (most
cases), the drag-able feature will make the item react to
mouse-release instead of mouse-press.
Drop options:
- UI buttons: ID and text buttons (paste name)
- View3d: Object ID drop copies object
- View3d: Material ID drop assigns to object under cursor
- View3d: Image ID drop assigns to object UV texture under cursor
- Sequencer: Path drop will add either Image or Movie strip
- Image window: Path drop will open image
** Drag and drop Notes:
- Dropping into another Blender window (from same application) works
too. I've added code that passes on mousemoves and clicks to other
windows, without activating them though. This does make using multi-window
Blender a bit friendler.
- Dropping a file path to an image, is not the same as dropping an
Image ID... keep this in mind. Sequencer for example wants paths to
be dropped, textures in 3d window wants an Image ID.
- Although drop boxes could be defined via Python, I suggest they're
part of the UI and editor design (= how we want an editor to work), and
not default offered configurable like keymaps.
- At the moment only one item can be dragged at a time. This is for
several reasons.... For one, Blender doesn't have a well defined
uniform way to define "what is selected" (files, outliner items, etc).
Secondly there's potential conflicts on what todo when you drop mixed
drag sets on spots. All undefined stuff... nice for later.
- Example to bypass the above: a collection of images that form a strip,
should be represented in filewindow as a single sequence anyway.
This then will fit well and gets handled neatly by design.
- Another option to check is to allow multiple options per drop... it
could show the operator as a sort of menu, allowing arrow or scrollwheel
to choose. For time being I'd prefer to try to design a singular drop
though, just offer only one drop action per data type on given spots.
- What does work already, but a tad slow, is to use a function that
detects an object (type) under cursor, so a drag item's option can be
further refined (like drop object on object = parent). (disabled)
** More notes
- Added saving for Region layouts (like split points for toolbar)
- Label buttons now handle mouse over
- File list: added full path entry for drop feature.
- Filesel bugfix: wm_operator_exec() got called there and fully handled,
while WM event code tried same. Added new OPERATOR_HANDLED flag for this.
Maybe python needs it too?
- Cocoa: added window move event, so multi-win setups work OK (didnt save).
- Interface_handlers.c: removed win->active
- Severe area copy bug: area handlers were not set to NULL
- Filesel bugfix: next/prev folder list was not copied on area copies
** Leftover todos
- Cocoa windows seem to hang on cases still... needs check
- Cocoa 'draw overlap' swap doesn't work
- Cocoa window loses focus permanently on using Spotlight
(for these reasons, makefile building has Carbon as default atm)
- ListView templates in UI cannot become dragged yet, needs review...
it consists of two overlapping UI elements, preventing handling icon clicks.
- There's already Ghost library code to handle dropping from OS
into Blender window. I've noticed this code is unfinished for Macs, but
seems to be complete for Windows. Needs test... currently, an external
drop event will print in console when succesfully delivered to Blender's WM.
2010-01-26 18:18:21 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
bool UI_but_active_drop_name(struct bContext *C);
|
|
|
|
bool UI_but_active_drop_color(struct bContext *C);
|
Drag and drop 2.5 integration! Finally, slashdot regulars can use
Blender too now! :)
** Drag works as follows:
- drag-able items are defined by the standard interface ui toolkit
- each button can get this feature, via uiButSetDragXXX(but, ...).
There are calls to define drag-able images, ID blocks, RNA paths,
file paths, and so on. By default you drag an icon, exceptionally
an ImBuf
- Drag items are registered centrally in the WM, it allows more drag
items simultaneous too, but not implemented
** Drop works as follows:
- On mouse release, and if drag items exist in the WM, it converts
the mouse event to an EVT_DROP type. This event then gets the full
drag info as customdata
- drop regions are defined with WM_dropbox_add(), similar to keymaps
you can make a "drop map" this way, which become 'drop map handlers'
in the queues.
- next to that the UI kit handles some common button types (like
accepting ID or names) to be catching a drop event too.
- Every "drop box" has two callbacks:
- poll() = check if the event drag data is relevant for this box
- copy() = fill in custom properties in the dropbox to initialize
an operator
- The dropbox handler then calls its standard Operator with its
dropbox properties.
** Currently implemented
Drag items:
- ID icons in browse buttons
- ID icons in context menu of properties region
- ID icons in outliner and rna viewer
- FileBrowser icons
- FileBrowser preview images
Drag-able icons are subtly visualized by making them brighter a bit
on mouse-over. In case the icon is a button or UI element too (most
cases), the drag-able feature will make the item react to
mouse-release instead of mouse-press.
Drop options:
- UI buttons: ID and text buttons (paste name)
- View3d: Object ID drop copies object
- View3d: Material ID drop assigns to object under cursor
- View3d: Image ID drop assigns to object UV texture under cursor
- Sequencer: Path drop will add either Image or Movie strip
- Image window: Path drop will open image
** Drag and drop Notes:
- Dropping into another Blender window (from same application) works
too. I've added code that passes on mousemoves and clicks to other
windows, without activating them though. This does make using multi-window
Blender a bit friendler.
- Dropping a file path to an image, is not the same as dropping an
Image ID... keep this in mind. Sequencer for example wants paths to
be dropped, textures in 3d window wants an Image ID.
- Although drop boxes could be defined via Python, I suggest they're
part of the UI and editor design (= how we want an editor to work), and
not default offered configurable like keymaps.
- At the moment only one item can be dragged at a time. This is for
several reasons.... For one, Blender doesn't have a well defined
uniform way to define "what is selected" (files, outliner items, etc).
Secondly there's potential conflicts on what todo when you drop mixed
drag sets on spots. All undefined stuff... nice for later.
- Example to bypass the above: a collection of images that form a strip,
should be represented in filewindow as a single sequence anyway.
This then will fit well and gets handled neatly by design.
- Another option to check is to allow multiple options per drop... it
could show the operator as a sort of menu, allowing arrow or scrollwheel
to choose. For time being I'd prefer to try to design a singular drop
though, just offer only one drop action per data type on given spots.
- What does work already, but a tad slow, is to use a function that
detects an object (type) under cursor, so a drag item's option can be
further refined (like drop object on object = parent). (disabled)
** More notes
- Added saving for Region layouts (like split points for toolbar)
- Label buttons now handle mouse over
- File list: added full path entry for drop feature.
- Filesel bugfix: wm_operator_exec() got called there and fully handled,
while WM event code tried same. Added new OPERATOR_HANDLED flag for this.
Maybe python needs it too?
- Cocoa: added window move event, so multi-win setups work OK (didnt save).
- Interface_handlers.c: removed win->active
- Severe area copy bug: area handlers were not set to NULL
- Filesel bugfix: next/prev folder list was not copied on area copies
** Leftover todos
- Cocoa windows seem to hang on cases still... needs check
- Cocoa 'draw overlap' swap doesn't work
- Cocoa window loses focus permanently on using Spotlight
(for these reasons, makefile building has Carbon as default atm)
- ListView templates in UI cannot become dragged yet, needs review...
it consists of two overlapping UI elements, preventing handling icon clicks.
- There's already Ghost library code to handle dropping from OS
into Blender window. I've noticed this code is unfinished for Macs, but
seems to be complete for Windows. Needs test... currently, an external
drop event will print in console when succesfully delivered to Blender's WM.
2010-01-26 18:18:21 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_flag_enable(uiBut *but, int flag);
|
|
|
|
void UI_but_flag_disable(uiBut *but, int flag);
|
|
|
|
bool UI_but_flag_is_set(uiBut *but, int flag);
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_drawflag_enable(uiBut *but, int flag);
|
|
|
|
void UI_but_drawflag_disable(uiBut *but, int flag);
|
2012-05-23 14:24:40 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_type_set_menu_from_pulldown(uiBut *but);
|
2014-02-12 00:08:54 +11:00
|
|
|
|
2009-07-25 13:40:59 +00:00
|
|
|
/* special button case, only draw it when used actively, for outliner etc */
|
2020-02-13 16:18:11 +11:00
|
|
|
bool UI_but_active_only_ex(const struct bContext *C,
|
2020-03-06 16:56:42 +01:00
|
|
|
struct ARegion *region,
|
2020-02-13 16:18:11 +11:00
|
|
|
uiBlock *block,
|
|
|
|
uiBut *but,
|
2020-02-14 16:17:01 +01:00
|
|
|
const bool remove_on_failure);
|
2020-03-06 16:56:42 +01:00
|
|
|
bool UI_but_active_only(const struct bContext *C,
|
|
|
|
struct ARegion *region,
|
|
|
|
uiBlock *block,
|
|
|
|
uiBut *but);
|
2019-04-17 06:17:24 +02:00
|
|
|
bool UI_block_active_only_flagged_buttons(const struct bContext *C,
|
2020-03-06 16:56:42 +01:00
|
|
|
struct ARegion *region,
|
2019-04-17 06:17:24 +02:00
|
|
|
struct uiBlock *block);
|
2009-07-25 13:40:59 +00:00
|
|
|
|
2020-03-06 16:56:42 +01:00
|
|
|
void UI_but_execute(const struct bContext *C, struct ARegion *region, uiBut *but);
|
2013-02-22 05:56:20 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
bool UI_but_online_manual_id(const uiBut *but,
|
|
|
|
char *r_str,
|
|
|
|
size_t maxlength) ATTR_WARN_UNUSED_RESULT;
|
|
|
|
bool UI_but_online_manual_id_from_active(const struct bContext *C,
|
|
|
|
char *r_str,
|
|
|
|
size_t maxlength) ATTR_WARN_UNUSED_RESULT;
|
2020-06-11 17:24:00 +10:00
|
|
|
bool UI_but_is_userdef(const uiBut *but);
|
2009-07-25 13:40:59 +00:00
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Buttons
|
|
|
|
*
|
|
|
|
* Functions to define various types of buttons in a block. Postfixes:
|
|
|
|
* - F: float
|
|
|
|
* - I: int
|
|
|
|
* - S: short
|
|
|
|
* - C: char
|
|
|
|
* - R: RNA
|
|
|
|
* - O: operator */
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
uiBut *uiDefBut(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x1,
|
|
|
|
int y1,
|
|
|
|
short x2,
|
|
|
|
short y2,
|
|
|
|
void *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButF(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButBitF(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButI(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
int *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButBitI(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
int *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButS(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButBitS(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButC(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
char *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButBitC(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
char *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButR(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
int index,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButR_prop(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
int index,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButO(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
const char *opname,
|
|
|
|
int opcontext,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefButO_ptr(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
int opcontext,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
|
|
|
|
uiBut *uiDefIconBut(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x1,
|
|
|
|
int y1,
|
|
|
|
short x2,
|
|
|
|
short y2,
|
|
|
|
void *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButF(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButBitF(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButI(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
int *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButBitI(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
int *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButS(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButBitS(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButC(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
char *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButBitC(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
char *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButR(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
int index,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButR_prop(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
PropertyRNA *prop,
|
|
|
|
int index,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButO(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
const char *opname,
|
|
|
|
int opcontext,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconButO_ptr(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
int opcontext,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
2020-03-14 11:05:09 -07:00
|
|
|
uiBut *uiDefButImage(
|
|
|
|
uiBlock *block, void *imbuf, int x, int y, short width, short height, const uchar color[4]);
|
2020-03-15 17:32:06 +11:00
|
|
|
uiBut *uiDefButAlert(uiBlock *block, int icon, int x, int y, short width, short height);
|
2019-04-17 06:17:24 +02:00
|
|
|
uiBut *uiDefIconTextBut(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x1,
|
|
|
|
int y1,
|
|
|
|
short x2,
|
|
|
|
short y2,
|
|
|
|
void *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButF(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButBitF(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButI(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
int *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButBitI(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
int *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButS(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButBitS(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButC(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
char *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButBitC(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int bit,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
char *poin,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButR(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
int index,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButR_prop(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
int index,
|
|
|
|
float min,
|
|
|
|
float max,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButO(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
const char *opname,
|
|
|
|
int opcontext,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextButO_ptr(uiBlock *block,
|
|
|
|
int type,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
int opcontext,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* for passing inputs to ButO buttons */
|
2014-11-09 21:20:40 +01:00
|
|
|
struct PointerRNA *UI_but_operator_ptr_get(uiBut *but);
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_but_unit_type_set(uiBut *but, const int unit_type);
|
|
|
|
int UI_but_unit_type_get(const uiBut *but);
|
2010-12-10 04:10:21 +00:00
|
|
|
|
UI translation from inside Blender UI: first part.
This commit reshapes a bit runtime button info getter, by adding a new uiButGetStrInfo() which accepts a variable number of uiStringInfo parameters, and tries to fill them with the requested strings, for the given button (label, tip, context, RNA identifier, keymap, etc.). Currently used mostly by existing ui_tooltip_create(), and new UI_OT_edittranslation_init operator.
It also adds a few getters (to get RNA i18n context, and current language iso code).
Finally, it adds to C operators needed for the py ui_translation addon:
*UI_OT_edittranslation_init, which gathers requested data and launch the py operator.
*UI_OT_reloadtranslation, which forces a full reload of the whole UI translation (including rechecking the directory containing mo files).
For the first operator to work, it also adds a new user preferences path: i18n_branches_directory, to point to the /branch part of a bf-translation checkout.
2012-07-09 14:25:35 +00:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
BUT_GET_RNAPROP_IDENTIFIER = 1,
|
|
|
|
BUT_GET_RNASTRUCT_IDENTIFIER,
|
|
|
|
BUT_GET_RNAENUM_IDENTIFIER,
|
|
|
|
BUT_GET_LABEL,
|
|
|
|
BUT_GET_RNA_LABEL,
|
|
|
|
BUT_GET_RNAENUM_LABEL,
|
|
|
|
BUT_GET_RNA_LABEL_CONTEXT, /* Context specified in CTX_XXX_ macros are just unreachable! */
|
|
|
|
BUT_GET_TIP,
|
|
|
|
BUT_GET_RNA_TIP,
|
|
|
|
BUT_GET_RNAENUM_TIP,
|
|
|
|
BUT_GET_OP_KEYMAP,
|
|
|
|
BUT_GET_PROP_KEYMAP,
|
UI translation from inside Blender UI: first part.
This commit reshapes a bit runtime button info getter, by adding a new uiButGetStrInfo() which accepts a variable number of uiStringInfo parameters, and tries to fill them with the requested strings, for the given button (label, tip, context, RNA identifier, keymap, etc.). Currently used mostly by existing ui_tooltip_create(), and new UI_OT_edittranslation_init operator.
It also adds a few getters (to get RNA i18n context, and current language iso code).
Finally, it adds to C operators needed for the py ui_translation addon:
*UI_OT_edittranslation_init, which gathers requested data and launch the py operator.
*UI_OT_reloadtranslation, which forces a full reload of the whole UI translation (including rechecking the directory containing mo files).
For the first operator to work, it also adds a new user preferences path: i18n_branches_directory, to point to the /branch part of a bf-translation checkout.
2012-07-09 14:25:35 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct uiStringInfo {
|
2019-04-17 06:17:24 +02:00
|
|
|
int type;
|
|
|
|
char *strinfo;
|
2018-06-04 09:31:30 +02:00
|
|
|
} uiStringInfo;
|
UI translation from inside Blender UI: first part.
This commit reshapes a bit runtime button info getter, by adding a new uiButGetStrInfo() which accepts a variable number of uiStringInfo parameters, and tries to fill them with the requested strings, for the given button (label, tip, context, RNA identifier, keymap, etc.). Currently used mostly by existing ui_tooltip_create(), and new UI_OT_edittranslation_init operator.
It also adds a few getters (to get RNA i18n context, and current language iso code).
Finally, it adds to C operators needed for the py ui_translation addon:
*UI_OT_edittranslation_init, which gathers requested data and launch the py operator.
*UI_OT_reloadtranslation, which forces a full reload of the whole UI translation (including rechecking the directory containing mo files).
For the first operator to work, it also adds a new user preferences path: i18n_branches_directory, to point to the /branch part of a bf-translation checkout.
2012-07-09 14:25:35 +00:00
|
|
|
|
|
|
|
/* Note: Expects pointers to uiStringInfo structs as parameters.
|
|
|
|
* Will fill them with translated strings, when possible.
|
|
|
|
* Strings in uiStringInfo must be MEM_freeN'ed by caller. */
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_but_string_info_get(struct bContext *C, uiBut *but, ...) ATTR_SENTINEL(0);
|
UI translation from inside Blender UI: first part.
This commit reshapes a bit runtime button info getter, by adding a new uiButGetStrInfo() which accepts a variable number of uiStringInfo parameters, and tries to fill them with the requested strings, for the given button (label, tip, context, RNA identifier, keymap, etc.). Currently used mostly by existing ui_tooltip_create(), and new UI_OT_edittranslation_init operator.
It also adds a few getters (to get RNA i18n context, and current language iso code).
Finally, it adds to C operators needed for the py ui_translation addon:
*UI_OT_edittranslation_init, which gathers requested data and launch the py operator.
*UI_OT_reloadtranslation, which forces a full reload of the whole UI translation (including rechecking the directory containing mo files).
For the first operator to work, it also adds a new user preferences path: i18n_branches_directory, to point to the /branch part of a bf-translation checkout.
2012-07-09 14:25:35 +00:00
|
|
|
|
|
|
|
/* Edit i18n stuff. */
|
|
|
|
/* Name of the main py op from i18n addon. */
|
|
|
|
#define EDTSRC_I18N_OP_NAME "UI_OT_edittranslation"
|
|
|
|
|
2019-01-14 15:58:40 +11:00
|
|
|
/**
|
|
|
|
* Special Buttons
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
*
|
2012-03-01 12:20:18 +00:00
|
|
|
* Buttons with a more specific purpose:
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
* - MenuBut: buttons that popup a menu (in headers usually).
|
|
|
|
* - PulldownBut: like MenuBut, but creating a uiBlock (for compatibility).
|
|
|
|
* - BlockBut: buttons that popup a block with more buttons.
|
|
|
|
* - KeyevtBut: buttons that can be used to turn key events into values.
|
2009-02-04 11:52:16 +00:00
|
|
|
* - PickerButtons: buttons like the color picker (for code sharing).
|
2019-01-14 15:58:40 +11:00
|
|
|
* - AutoButR: RNA property button with type automatically defined.
|
|
|
|
*/
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_ID_RENAME = 1 << 0,
|
|
|
|
UI_ID_BROWSE = 1 << 1,
|
|
|
|
UI_ID_ADD_NEW = 1 << 2,
|
|
|
|
UI_ID_ALONE = 1 << 4,
|
|
|
|
UI_ID_OPEN = 1 << 3,
|
|
|
|
UI_ID_DELETE = 1 << 5,
|
|
|
|
UI_ID_LOCAL = 1 << 6,
|
|
|
|
UI_ID_AUTO_NAME = 1 << 7,
|
|
|
|
UI_ID_FAKE_USER = 1 << 8,
|
|
|
|
UI_ID_PIN = 1 << 9,
|
|
|
|
UI_ID_PREVIEWS = 1 << 10,
|
|
|
|
UI_ID_OVERRIDE = 1 << 11,
|
|
|
|
UI_ID_FULL = UI_ID_RENAME | UI_ID_BROWSE | UI_ID_ADD_NEW | UI_ID_OPEN | UI_ID_ALONE |
|
|
|
|
UI_ID_DELETE | UI_ID_LOCAL,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
2.5: ID datablock button back, previously known as std_libbuttons. The
way this worked in 2.4x wasn't really clean, with events going all over
the place and using dubious variables such as G.but->lockpoin or
G.sima->menunr. It works as follows now, for example:
xco= uiDefIDPoinButs(block, CTX_data_main(C), NULL, (ID**)&sima->image, ID_IM, &sima->pin, xco, yco,
sima_idpoin_handle, UI_ID_BROWSE|UI_ID_RENAME|UI_ID_ADD_NEW|UI_ID_OPEN|UI_ID_DELETE|UI_ID_ALONE|UI_ID_PIN);
The last two parameters are a callback function, and a list of events
or functionalities that are supported. The callback function will then
get the ID pointer + event to handle.
2009-02-06 16:40:14 +00:00
|
|
|
|
2018-01-03 21:54:02 +11:00
|
|
|
/**
|
|
|
|
* Ways to limit what is displayed in ID-search popup.
|
|
|
|
* \note We may want to add LOCAL, LIBRARY ... as needed.
|
|
|
|
*/
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_TEMPLATE_ID_FILTER_ALL = 0,
|
|
|
|
UI_TEMPLATE_ID_FILTER_AVAILABLE = 1,
|
2018-01-03 21:54:02 +11:00
|
|
|
};
|
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
int UI_icon_from_id(struct ID *id);
|
|
|
|
int UI_icon_from_report_type(int type);
|
2009-09-16 01:15:30 +00:00
|
|
|
|
2018-07-08 11:57:59 +02:00
|
|
|
int UI_icon_from_event_type(short event_type, short event_value);
|
|
|
|
int UI_icon_from_keymap_item(const struct wmKeyMapItem *kmi, int r_icon_mod[4]);
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
uiBut *uiDefPulldownBut(uiBlock *block,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefMenuBut(uiBlock *block,
|
|
|
|
uiMenuCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextMenuBut(uiBlock *block,
|
|
|
|
uiMenuCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconMenuBut(uiBlock *block,
|
|
|
|
uiMenuCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
|
|
|
|
uiBut *uiDefBlockBut(uiBlock *block,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
void *func_arg1,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefBlockButN(uiBlock *block,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
void *argN,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
|
|
|
|
uiBut *uiDefIconBlockBut(uiBlock *block,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefIconTextBlockBut(uiBlock *block,
|
|
|
|
uiBlockCreateFunc func,
|
|
|
|
void *arg,
|
|
|
|
int icon,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
const char *tip);
|
|
|
|
|
|
|
|
uiBut *uiDefKeyevtButS(uiBlock *block,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *spoin,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefHotKeyevtButS(uiBlock *block,
|
|
|
|
int retval,
|
|
|
|
const char *str,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
short *keypoin,
|
|
|
|
short *modkeypoin,
|
|
|
|
const char *tip);
|
|
|
|
|
|
|
|
uiBut *uiDefSearchBut(uiBlock *block,
|
|
|
|
void *arg,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int maxlen,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
|
|
|
uiBut *uiDefSearchButO_ptr(uiBlock *block,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
struct IDProperty *properties,
|
|
|
|
void *arg,
|
|
|
|
int retval,
|
|
|
|
int icon,
|
|
|
|
int maxlen,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
short width,
|
|
|
|
short height,
|
|
|
|
float a1,
|
|
|
|
float a2,
|
|
|
|
const char *tip);
|
UI: New Global Top-Bar (WIP)
== Main Features/Changes for Users
* Add horizontal bar at top of all non-temp windows, consisting out of two horizontal sub-bars.
* Upper sub-bar contains global menus (File, Render, etc.), tabs for workspaces and scene selector.
* Lower sub-bar contains object mode selector, screen-layout and render-layer selector. Later operator and/or tool settings will be placed here.
* Individual sections of the topbar are individually scrollable.
* Workspace tabs can be double- or ctrl-clicked for renaming and contain 'x' icon for deleting.
* Top-bar should scale nicely with DPI.
* The lower half of the top-bar can be hided by dragging the lower top-bar edge up. Better hiding options are planned (e.g. hide in fullscreen modes).
* Info editors at the top of the window and using the full window width with be replaced by the top-bar.
* In fullscreen modes, no more info editor is added on top, the top-bar replaces it.
== Technical Features/Changes
* Adds initial support for global areas
A global area is part of the window, not part of the regular screen-layout.
I've added a macro iterator to iterate over both, global and screen-layout level areas. When iterating over areas, from now on developers should always consider if they have to include global areas.
* Adds a TOPBAR editor type
The editor type is hidden in the UI editor type menu.
* Adds a variation of the ID template to display IDs as tab buttons (template_ID_tabs in BPY)
* Does various changes to RNA button creation code to improve their appearance in the horizontal top-bar.
* Adds support for dynamically sized regions. That is, regions that scale automatically to the layout bounds.
The code for this is currently a big hack (it's based on drawing the UI multiple times). This should definitely be improved.
* Adds a template for displaying operator properties optimized for the top-bar. This will probably change a lot still and is in fact disabled in code.
Since the final top-bar design depends a lot on other 2.8 designs (mainly tool-system and workspaces), we decided to not show the operator or tool settings in the top-bar for now. That means most of the lower sub-bar is empty for the time being.
NOTE: Top-bar or global area data is not written to files or SDNA. They are simply added to the window when opening Blender or reading a file. This allows us doing changes to the top-bar without having to care for compatibility.
== ToDo's
It's a bit hard to predict all the ToDo's here are the known main ones:
* Add options for the new active-tool system and for operator redo to the topbar.
* Automatically hide the top-bar in fullscreen modes.
* General visual polish.
* Top-bar drag & drop support (WIP in temp-tab_drag_drop).
* Improve dynamic regions (should also fix some layout glitches).
* Make internal terminology consistent.
* Enable topbar file writing once design is more advanced.
* Address TODO's and XXX's in code :)
Thanks @brecht for the review! And @sergey for the complaining ;)
Differential Revision: D2758
2018-04-20 17:14:03 +02:00
|
|
|
|
|
|
|
/* For uiDefAutoButsRNA */
|
|
|
|
typedef enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
/* Keep current layout for aligning label with property button. */
|
|
|
|
UI_BUT_LABEL_ALIGN_NONE,
|
|
|
|
/* Align label and property button vertically. */
|
|
|
|
UI_BUT_LABEL_ALIGN_COLUMN,
|
|
|
|
/* Split layout into a column for the label and one for property button. */
|
|
|
|
UI_BUT_LABEL_ALIGN_SPLIT_COLUMN,
|
UI: New Global Top-Bar (WIP)
== Main Features/Changes for Users
* Add horizontal bar at top of all non-temp windows, consisting out of two horizontal sub-bars.
* Upper sub-bar contains global menus (File, Render, etc.), tabs for workspaces and scene selector.
* Lower sub-bar contains object mode selector, screen-layout and render-layer selector. Later operator and/or tool settings will be placed here.
* Individual sections of the topbar are individually scrollable.
* Workspace tabs can be double- or ctrl-clicked for renaming and contain 'x' icon for deleting.
* Top-bar should scale nicely with DPI.
* The lower half of the top-bar can be hided by dragging the lower top-bar edge up. Better hiding options are planned (e.g. hide in fullscreen modes).
* Info editors at the top of the window and using the full window width with be replaced by the top-bar.
* In fullscreen modes, no more info editor is added on top, the top-bar replaces it.
== Technical Features/Changes
* Adds initial support for global areas
A global area is part of the window, not part of the regular screen-layout.
I've added a macro iterator to iterate over both, global and screen-layout level areas. When iterating over areas, from now on developers should always consider if they have to include global areas.
* Adds a TOPBAR editor type
The editor type is hidden in the UI editor type menu.
* Adds a variation of the ID template to display IDs as tab buttons (template_ID_tabs in BPY)
* Does various changes to RNA button creation code to improve their appearance in the horizontal top-bar.
* Adds support for dynamically sized regions. That is, regions that scale automatically to the layout bounds.
The code for this is currently a big hack (it's based on drawing the UI multiple times). This should definitely be improved.
* Adds a template for displaying operator properties optimized for the top-bar. This will probably change a lot still and is in fact disabled in code.
Since the final top-bar design depends a lot on other 2.8 designs (mainly tool-system and workspaces), we decided to not show the operator or tool settings in the top-bar for now. That means most of the lower sub-bar is empty for the time being.
NOTE: Top-bar or global area data is not written to files or SDNA. They are simply added to the window when opening Blender or reading a file. This allows us doing changes to the top-bar without having to care for compatibility.
== ToDo's
It's a bit hard to predict all the ToDo's here are the known main ones:
* Add options for the new active-tool system and for operator redo to the topbar.
* Automatically hide the top-bar in fullscreen modes.
* General visual polish.
* Top-bar drag & drop support (WIP in temp-tab_drag_drop).
* Improve dynamic regions (should also fix some layout glitches).
* Make internal terminology consistent.
* Enable topbar file writing once design is more advanced.
* Address TODO's and XXX's in code :)
Thanks @brecht for the review! And @sergey for the complaining ;)
Differential Revision: D2758
2018-04-20 17:14:03 +02:00
|
|
|
} eButLabelAlign;
|
|
|
|
|
|
|
|
/* Return info for uiDefAutoButsRNA */
|
|
|
|
typedef enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
/* Returns when no buttons were added */
|
|
|
|
UI_PROP_BUTS_NONE_ADDED = 1 << 0,
|
|
|
|
/* Returned when any property failed the custom check callback (check_prop) */
|
|
|
|
UI_PROP_BUTS_ANY_FAILED_CHECK = 1 << 1,
|
UI: New Global Top-Bar (WIP)
== Main Features/Changes for Users
* Add horizontal bar at top of all non-temp windows, consisting out of two horizontal sub-bars.
* Upper sub-bar contains global menus (File, Render, etc.), tabs for workspaces and scene selector.
* Lower sub-bar contains object mode selector, screen-layout and render-layer selector. Later operator and/or tool settings will be placed here.
* Individual sections of the topbar are individually scrollable.
* Workspace tabs can be double- or ctrl-clicked for renaming and contain 'x' icon for deleting.
* Top-bar should scale nicely with DPI.
* The lower half of the top-bar can be hided by dragging the lower top-bar edge up. Better hiding options are planned (e.g. hide in fullscreen modes).
* Info editors at the top of the window and using the full window width with be replaced by the top-bar.
* In fullscreen modes, no more info editor is added on top, the top-bar replaces it.
== Technical Features/Changes
* Adds initial support for global areas
A global area is part of the window, not part of the regular screen-layout.
I've added a macro iterator to iterate over both, global and screen-layout level areas. When iterating over areas, from now on developers should always consider if they have to include global areas.
* Adds a TOPBAR editor type
The editor type is hidden in the UI editor type menu.
* Adds a variation of the ID template to display IDs as tab buttons (template_ID_tabs in BPY)
* Does various changes to RNA button creation code to improve their appearance in the horizontal top-bar.
* Adds support for dynamically sized regions. That is, regions that scale automatically to the layout bounds.
The code for this is currently a big hack (it's based on drawing the UI multiple times). This should definitely be improved.
* Adds a template for displaying operator properties optimized for the top-bar. This will probably change a lot still and is in fact disabled in code.
Since the final top-bar design depends a lot on other 2.8 designs (mainly tool-system and workspaces), we decided to not show the operator or tool settings in the top-bar for now. That means most of the lower sub-bar is empty for the time being.
NOTE: Top-bar or global area data is not written to files or SDNA. They are simply added to the window when opening Blender or reading a file. This allows us doing changes to the top-bar without having to care for compatibility.
== ToDo's
It's a bit hard to predict all the ToDo's here are the known main ones:
* Add options for the new active-tool system and for operator redo to the topbar.
* Automatically hide the top-bar in fullscreen modes.
* General visual polish.
* Top-bar drag & drop support (WIP in temp-tab_drag_drop).
* Improve dynamic regions (should also fix some layout glitches).
* Make internal terminology consistent.
* Enable topbar file writing once design is more advanced.
* Address TODO's and XXX's in code :)
Thanks @brecht for the review! And @sergey for the complaining ;)
Differential Revision: D2758
2018-04-20 17:14:03 +02:00
|
|
|
} eAutoPropButsReturn;
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
uiBut *uiDefAutoButR(uiBlock *block,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
int index,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
int x1,
|
|
|
|
int y1,
|
|
|
|
int x2,
|
|
|
|
int y2);
|
|
|
|
eAutoPropButsReturn uiDefAutoButsRNA(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
bool (*check_prop)(struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
void *user_data),
|
|
|
|
void *user_data,
|
|
|
|
struct PropertyRNA *prop_activate_init,
|
|
|
|
eButLabelAlign label_align,
|
|
|
|
const bool compact);
|
2009-02-04 11:52:16 +00:00
|
|
|
|
2012-05-12 20:39:39 +00:00
|
|
|
/* use inside searchfunc to add items */
|
2020-03-24 11:34:18 +11:00
|
|
|
bool UI_search_item_add(uiSearchItems *items, const char *name, void *poin, int iconid, int state);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_func_search_set(uiBut *but,
|
2020-05-07 23:16:05 +10:00
|
|
|
uiButSearchCreateFn search_create_fn,
|
|
|
|
uiButSearchUpdateFn search_update_fn,
|
2019-04-17 06:17:24 +02:00
|
|
|
void *arg,
|
2020-05-07 23:16:05 +10:00
|
|
|
uiButSearchArgFreeFn search_arg_free_fn,
|
2020-05-08 12:01:35 +10:00
|
|
|
uiButHandleFunc search_exec_fn,
|
2019-04-17 06:17:24 +02:00
|
|
|
void *active);
|
2020-05-07 23:16:22 +10:00
|
|
|
void UI_but_func_search_set_context_menu(uiBut *but, uiButSearchContextMenuFn context_menu_fn);
|
2020-05-11 18:37:43 +10:00
|
|
|
void UI_but_func_search_set_tooltip(uiBut *but, uiButSearchTooltipFn tooltip_fn);
|
2020-05-07 23:16:16 +10:00
|
|
|
void UI_but_func_search_set_sep_string(uiBut *but, const char *search_sep_string);
|
|
|
|
|
2012-05-12 20:39:39 +00:00
|
|
|
/* height in pixels, it's using hardcoded values still */
|
2019-04-17 06:17:24 +02:00
|
|
|
int UI_searchbox_size_y(void);
|
|
|
|
int UI_searchbox_size_x(void);
|
2013-05-02 04:59:52 +00:00
|
|
|
/* check if a string is in an existing search box */
|
2019-04-17 06:17:24 +02:00
|
|
|
int UI_search_items_find_index(uiSearchItems *items, const char *name);
|
2009-06-02 18:10:06 +00:00
|
|
|
|
2020-04-16 15:09:49 +02:00
|
|
|
void UI_but_node_link_set(uiBut *but, struct bNodeSocket *socket, const float draw_color[4]);
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_block_func_handle_set(uiBlock *block, uiBlockHandleFunc func, void *arg);
|
|
|
|
void UI_block_func_butmenu_set(uiBlock *block, uiMenuHandleFunc func, void *arg);
|
|
|
|
void UI_block_func_set(uiBlock *block, uiButHandleFunc func, void *arg1, void *arg2);
|
|
|
|
void UI_block_funcN_set(uiBlock *block, uiButHandleNFunc funcN, void *argN, void *arg2);
|
2009-07-25 13:40:59 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_func_rename_set(uiBut *but, uiButHandleRenameFunc func, void *arg1);
|
|
|
|
void UI_but_func_set(uiBut *but, uiButHandleFunc func, void *arg1, void *arg2);
|
|
|
|
void UI_but_funcN_set(uiBut *but, uiButHandleNFunc funcN, void *argN, void *arg2);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_func_complete_set(uiBut *but, uiButCompleteFunc func, void *arg);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_func_drawextra_set(
|
|
|
|
uiBlock *block,
|
|
|
|
void (*func)(const struct bContext *C, void *, void *, void *, struct rcti *rect),
|
|
|
|
void *arg1,
|
|
|
|
void *arg2);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_func_menu_step_set(uiBut *but, uiMenuStepFunc func);
|
2015-11-16 06:26:25 +11:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_but_func_tooltip_set(uiBut *but, uiButToolTipFunc func, void *argN);
|
|
|
|
void UI_but_tooltip_refresh(struct bContext *C, uiBut *but);
|
|
|
|
void UI_but_tooltip_timer_remove(struct bContext *C, uiBut *but);
|
2015-02-11 00:06:03 +01:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
bool UI_textbutton_activate_rna(const struct bContext *C,
|
2020-03-06 16:56:42 +01:00
|
|
|
struct ARegion *region,
|
2019-04-17 06:17:24 +02:00
|
|
|
const void *rna_poin_data,
|
|
|
|
const char *rna_prop_id);
|
2013-11-22 01:35:38 +01:00
|
|
|
bool UI_textbutton_activate_but(const struct bContext *C, uiBut *but);
|
2013-03-24 13:43:40 +00:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_but_focus_on_enter_event(struct wmWindow *win, uiBut *but);
|
2011-02-15 01:24:12 +00:00
|
|
|
|
2017-11-02 04:30:07 +11:00
|
|
|
void UI_but_func_hold_set(uiBut *but, uiButHandleHoldFunc func, void *argN);
|
|
|
|
|
2019-03-01 13:14:16 -03:00
|
|
|
void UI_but_func_pushed_state_set(uiBut *but, uiButPushedStateFunc func, void *arg);
|
|
|
|
|
2019-09-09 16:34:16 +02:00
|
|
|
PointerRNA *UI_but_extra_operator_icon_add(uiBut *but,
|
|
|
|
const char *opname,
|
|
|
|
short opcontext,
|
|
|
|
int icon);
|
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Autocomplete
|
|
|
|
*
|
|
|
|
* Tab complete helper functions, for use in uiButCompleteFunc callbacks.
|
|
|
|
* Call begin once, then multiple times do_name with all possibilities,
|
|
|
|
* and finally end to finish and get the completed name. */
|
|
|
|
|
|
|
|
typedef struct AutoComplete AutoComplete;
|
|
|
|
|
2013-11-19 16:31:48 +01:00
|
|
|
#define AUTOCOMPLETE_NO_MATCH 0
|
|
|
|
#define AUTOCOMPLETE_FULL_MATCH 1
|
|
|
|
#define AUTOCOMPLETE_PARTIAL_MATCH 2
|
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
AutoComplete *UI_autocomplete_begin(const char *startname, size_t maxlen);
|
|
|
|
void UI_autocomplete_update_name(AutoComplete *autocpl, const char *name);
|
|
|
|
int UI_autocomplete_end(AutoComplete *autocpl, char *autoname);
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
|
|
|
|
/* Panels
|
|
|
|
*
|
|
|
|
* Functions for creating, freeing and drawing panels. The API here
|
|
|
|
* could use a good cleanup, though how they will function in 2.5 is
|
|
|
|
* not clear yet so we postpone that. */
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
2020-03-06 16:56:42 +01:00
|
|
|
void UI_panels_begin(const struct bContext *C, struct ARegion *region);
|
|
|
|
void UI_panels_end(const struct bContext *C, struct ARegion *region, int *r_x, int *r_y);
|
|
|
|
void UI_panels_draw(const struct bContext *C, struct ARegion *region);
|
2009-04-16 21:39:45 +00:00
|
|
|
|
2018-06-03 13:32:36 +02:00
|
|
|
struct Panel *UI_panel_find_by_type(struct ListBase *lb, struct PanelType *pt);
|
2020-04-03 13:25:03 +02:00
|
|
|
struct Panel *UI_panel_begin(struct ScrArea *area,
|
2020-03-06 16:56:42 +01:00
|
|
|
struct ARegion *region,
|
2019-04-17 06:17:24 +02:00
|
|
|
struct ListBase *lb,
|
|
|
|
uiBlock *block,
|
|
|
|
struct PanelType *pt,
|
2020-04-03 22:20:25 -05:00
|
|
|
struct Panel *panel,
|
2019-04-17 06:17:24 +02:00
|
|
|
bool *r_open);
|
2020-04-03 13:25:03 +02:00
|
|
|
void UI_panel_end(const struct ScrArea *area,
|
2020-03-06 16:56:42 +01:00
|
|
|
const struct ARegion *region,
|
2020-01-21 16:02:30 +01:00
|
|
|
uiBlock *block,
|
|
|
|
int width,
|
|
|
|
int height,
|
|
|
|
bool open);
|
2020-05-26 15:39:49 -04:00
|
|
|
|
2020-03-06 16:56:42 +01:00
|
|
|
void UI_panels_scale(struct ARegion *region, float new_width);
|
2019-03-25 12:19:55 +11:00
|
|
|
void UI_panel_label_offset(struct uiBlock *block, int *r_x, int *r_y);
|
2020-04-03 22:20:25 -05:00
|
|
|
int UI_panel_size_y(const struct Panel *panel);
|
2020-04-30 18:58:05 +02:00
|
|
|
bool UI_panel_is_dragging(const struct Panel *panel);
|
2009-04-02 01:39:33 +00:00
|
|
|
|
2020-03-06 16:56:42 +01:00
|
|
|
bool UI_panel_category_is_visible(const struct ARegion *region);
|
|
|
|
void UI_panel_category_add(struct ARegion *region, const char *name);
|
|
|
|
struct PanelCategoryDyn *UI_panel_category_find(struct ARegion *region, const char *idname);
|
|
|
|
struct PanelCategoryStack *UI_panel_category_active_find(struct ARegion *region,
|
|
|
|
const char *idname);
|
|
|
|
const char *UI_panel_category_active_get(struct ARegion *region, bool set_fallback);
|
|
|
|
void UI_panel_category_active_set(struct ARegion *region, const char *idname);
|
|
|
|
void UI_panel_category_active_set_default(struct ARegion *region, const char *idname);
|
|
|
|
struct PanelCategoryDyn *UI_panel_category_find_mouse_over_ex(struct ARegion *region,
|
2019-04-17 06:17:24 +02:00
|
|
|
const int x,
|
|
|
|
const int y);
|
2020-03-06 16:56:42 +01:00
|
|
|
struct PanelCategoryDyn *UI_panel_category_find_mouse_over(struct ARegion *region,
|
2019-04-17 06:17:24 +02:00
|
|
|
const struct wmEvent *event);
|
2020-03-06 16:56:42 +01:00
|
|
|
void UI_panel_category_clear_all(struct ARegion *region);
|
|
|
|
void UI_panel_category_draw_all(struct ARegion *region, const char *category_id_active);
|
2013-12-17 03:21:55 +11:00
|
|
|
|
2018-05-23 19:46:40 +02:00
|
|
|
struct PanelType *UI_paneltype_find(int space_id, int region_id, const char *idname);
|
|
|
|
|
2020-05-26 15:39:49 -04:00
|
|
|
/* Polyinstantiated panels for representing a list of data. */
|
|
|
|
struct Panel *UI_panel_add_instanced(struct ScrArea *area,
|
|
|
|
struct ARegion *region,
|
|
|
|
struct ListBase *panels,
|
|
|
|
char *panel_idname,
|
|
|
|
int list_index);
|
|
|
|
void UI_panels_free_instanced(struct bContext *C, struct ARegion *region);
|
|
|
|
|
|
|
|
#define LIST_PANEL_UNIQUE_STR_LEN 4
|
|
|
|
void UI_list_panel_unique_str(struct Panel *panel, char *r_name);
|
|
|
|
|
|
|
|
void UI_panel_set_expand_from_list_data(const struct bContext *C, struct Panel *panel);
|
|
|
|
|
|
|
|
typedef void (*uiListPanelIDFromDataFunc)(void *data_link, char *r_idname);
|
|
|
|
bool UI_panel_list_matches_data(struct ARegion *region,
|
|
|
|
struct ListBase *data,
|
|
|
|
uiListPanelIDFromDataFunc panel_idname_func);
|
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Handlers
|
|
|
|
*
|
|
|
|
* Handlers that can be registered in regions, areas and windows for
|
|
|
|
* handling WM events. Mostly this is done automatic by modules such
|
|
|
|
* as screen/ if ED_KEYMAP_UI is set, or internally in popup functions. */
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_region_handlers_add(struct ListBase *handlers);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_popup_handlers_add(struct bContext *C,
|
|
|
|
struct ListBase *handlers,
|
|
|
|
uiPopupBlockHandle *popup,
|
|
|
|
const char flag);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_popup_handlers_remove(struct ListBase *handlers, uiPopupBlockHandle *popup);
|
|
|
|
void UI_popup_handlers_remove_all(struct bContext *C, struct ListBase *handlers);
|
UI: don't use operators anymore for handling user interface events, but rather
a special UI handler which makes the code clearer. This UI handler is attached
to the region along with other handlers, and also gets a callback when all
handlers for the region are removed to ensure things are properly cleaned up.
This should fix XXX's in the UI code related to events and context switching.
Most of the changes are in interface_handlers.c, which was renamed from
interface_ops.c, to convert operators to the UI handler. UI code notes:
* uiBeginBlock/uiEndBlock/uiFreeBlocks now takes a context argument, this is
required to properly cancel things like timers or tooltips when the region
gets removed.
* UI_add_region_handlers will add the region level UI handlers, to be used
when adding keymap handlers etc. This replaces the UI keymap.
* When the UI code starts a modal interaction (number sliding, text editing,
opening a menu, ..), it will add an UI handler at the window level which
will block events.
Windowmanager changes:
* Added an UI handler next to the existing keymap and operator modal handlers.
It has an event handling and remove callback, and like operator modal handlers
will remember the area and region if it is registered at the window level.
* Removed the MESSAGE event.
* Operator cancel and UI handler remove callbacks now get the
window/area/region restored in the context, like the operator modal and UI
handler event callbacks.
* Regions now receive MOUSEMOVE events for the mouse going outside of the
region. This was already happening for areas, but UI buttons are at the region
level so we need it there.
Issues:
* Tooltips and menus stay open when switching to another window, and button
highlight doesn't work without moving the mouse first when Blender starts up.
I tried using some events like Q_FIRSTTIME, WINTHAW, but those don't seem to
arrive..
* Timeline header buttons seem to be moving one pixel or so sometimes when
interacting with them.
* Seems not due to this commit, but UI and keymap handlers are leaking. It
seems that handlers are being added to regions in all screens, also in regions
of areas that are not visible, but these handlers are not removed. Probably
there should only be handlers in visible regions?
2008-12-10 04:36:33 +00:00
|
|
|
|
2.5: UI & Menus
* Cleaned up UI_interface.h a bit, and added some comments to
organize things a bit and indicate what should be used when.
* uiMenu* functions can now be used to create menus for headers
too, this is done with a uiDefMenuBut, which takes a pointer
to a uiMenuCreateFunc, that will then call uiMenu* functions.
* Renamed uiMenuBegin/End to uiPupMenuBegin/End, as these are
specific to making popup menus. Will convert the other
conformation popup menu functions to use this too so we can
remove some code.
* Extended uiMenu functions, now there is is also:
BooleanO, FloatO, BooleanR, EnumR, LevelEnumR, Separator.
* Converted image window headers to use uiMenu functions, simplifies
menu code further here. Did not remove the uiDefMenu functions as
they are used in sequencer/view3d in some places now (will fix).
* Also tried to simplify and fix bounds computation a bit better
for popup menus. It tried to find out in advance what the size
of the menu was but this is difficult with keymap strings in
there, now uiPopupBoundsBlock can figure this out afterwards and
ensure the popup is within the window bounds. Will convert some
other functions to use this too.
2009-01-30 12:18:08 +00:00
|
|
|
/* Module
|
|
|
|
*
|
|
|
|
* init and exit should be called before using this module. init_userdef must
|
|
|
|
* be used to reinitialize some internal state if user preferences change. */
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
|
|
|
|
void UI_init(void);
|
2018-06-08 12:16:37 +02:00
|
|
|
void UI_init_userdef(struct Main *bmain);
|
2011-09-21 15:15:30 +00:00
|
|
|
void UI_reinit_font(void);
|
Port of part of the Interface code to 2.50.
This is based on the current trunk version, so these files should not need
merges. There's two things (clipboard and intptr_t) that are missing in 2.50
and commented out with XXX 2.48, these can be enabled again once trunk is
merged into this branch.
Further this is not all interface code, there are many parts commented out:
* interface.c: nearly all button types, missing: links, chartab, keyevent.
* interface_draw.c: almost all code, with some small exceptions.
* interface_ops.c: this replaces ui_do_but and uiDoBlocks with two operators,
making it non-blocking.
* interface_regions: this is a part of interface.c, split off, contains code to
create regions for tooltips, menus, pupmenu (that one is crashing currently),
color chooser, basically regions with buttons which is fairly independent of
core interface code.
* interface_panel.c and interface_icons.c: not ported over, so no panels and
icons yet. Panels should probably become (free floating) regions?
* text.c: (formerly language.c) for drawing text and translation. this works
but is using bad globals still and could be cleaned up.
Header Files:
* ED_datafiles.h now has declarations for datatoc_ files, so those extern
declarations can be #included instead of repeated.
* The user interface code is in UI_interface.h and other UI_* files.
Core:
* The API for creating blocks, buttons, etc is nearly the same still. Blocks
are now created per region instead of per area.
* The code was made non-blocking, which means that any changes and redraws
should be possible while editing a button. That means though that we need
some sort of persistence even though the blender model is to recreate buttons
for each redraw. So when a new block is created, some matching happens to
find out which buttons correspond to buttons in the previously created block,
and for activated buttons some data is then copied over to the new button.
* Added UI_init/UI_init_userdef/UI_exit functions that should initialize code
in this module, instead of multiple function calls in the windowmanager.
* Removed most static/globals from interface.c.
* Removed UIafterfunc_ I don't think it's needed anymore, and not sure how it
would integrate here?
* Currently only full window redraws are used, this should become per region
and maybe per button later.
Operators:
* Events are currently handled through two operators: button activate and menu
handle. Operators may not be the best way to implement this, since there are
currently some issues with events being missed, but they can become a special
handler type instead, this should not be a big change.
* The button activate operator runs as long as a button is active, and will
handle all interaction with that button until the button is not activated
anymore. This means clicking, text editing, number dragging, opening menu
blocks, etc.
* Since this operator has to be non-blocking, the ui_do_but code needed to made
non-blocking. That means variables that were previously on the stack, now
need to be stored away in a struct such that they can be accessed again when
the operator receives more events.
* Additionally the place in the ui_do_but code indicated the state, now that
needs to be set explicit in order to handle the right events in the right
state. So an activated button can be in one of these states: init, highlight,
wait_flash, wait_release, wait_key_event, num_editing, text_editing,
text_selecting, block_open, exit.
* For each button type an ui_apply_but_* function has also been separated out
from ui_do_but. This makes it possible to continuously apply the button as
text is being typed for example, and there is an option in the code to enable
this. Since the code non-blocking and can deal with the button being deleted
even, it should be safe to do this.
* When editing text, dragging numbers, etc, the actual data (but->poin) is not
being edited, since that would mean data is being edited without correct
updates happening, while some other part of blender may be accessing that
data in the meantime. So data values, strings, vectors are written to a
temporary location and only flush in the apply function.
Regions:
* Menus, color chooser, tooltips etc all create screen level regions. Such menu
blocks give a handle to the button that creates it, which will contain the
results of the menu block once a MESSAGE event is received from that menu
block.
* For this type of menu block the coordinates used to be in window space. They
are still created that way and ui_positionblock still works with window
coordinates, but after that the block and buttons are brought back to region
coordinates since these are now contained in a region.
* The flush/overdraw frontbuffer drawing code was removed, the windowmanager
should have enough information with these screen level regions to have full
control over what gets drawn when and to then do correct compositing.
Testing:
* The header in the time space currently has some buttons to test the UI code.
2008-11-11 18:31:32 +00:00
|
|
|
void UI_exit(void);
|
|
|
|
|
2009-03-13 13:38:41 +00:00
|
|
|
/* Layout
|
|
|
|
*
|
|
|
|
* More automated layout of buttons. Has three levels:
|
|
|
|
* - Layout: contains a number templates, within a bounded width or height.
|
|
|
|
* - Template: predefined layouts for buttons with a number of slots, each
|
|
|
|
* slot can contain multiple items.
|
|
|
|
* - Item: item to put in a template slot, being either an RNA property,
|
UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
This means the layout engine now works at button level, and makes it
easier to write templates. Otherwise you had to store all info and
create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
These can contain regular buttons, and can be put in a Free layout,
which means you can specify manual coordinates, but still get nested
correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
in the last added layout specifier, i.e. one level up in the layout
hierarchy. This doesn't work well in always, so now when creating things
like rows or columns it always returns a layout which you have to add
the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
required width/height of all nested layouts, and then in the second
pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
buttons).
* Moved some more space variables into Style.
2009-05-15 11:19:59 +00:00
|
|
|
* operator, label or menu. Also regular buttons can be used when setting
|
|
|
|
* uiBlockCurLayout. */
|
2009-03-13 13:38:41 +00:00
|
|
|
|
|
|
|
/* layout */
|
2019-01-14 15:58:40 +11:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_LAYOUT_HORIZONTAL = 0,
|
|
|
|
UI_LAYOUT_VERTICAL = 1,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
2012-05-12 20:39:39 +00:00
|
|
|
|
2019-01-14 15:58:40 +11:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_LAYOUT_PANEL = 0,
|
|
|
|
UI_LAYOUT_HEADER = 1,
|
|
|
|
UI_LAYOUT_MENU = 2,
|
|
|
|
UI_LAYOUT_TOOLBAR = 3,
|
|
|
|
UI_LAYOUT_PIEMENU = 4,
|
|
|
|
UI_LAYOUT_VERT_BAR = 5,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
2012-05-12 20:39:39 +00:00
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
#define UI_UNIT_X ((void)0, U.widget_unit)
|
|
|
|
#define UI_UNIT_Y ((void)0, U.widget_unit)
|
2012-05-12 20:39:39 +00:00
|
|
|
|
2019-01-14 15:58:40 +11:00
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_LAYOUT_ALIGN_EXPAND = 0,
|
|
|
|
UI_LAYOUT_ALIGN_LEFT = 1,
|
|
|
|
UI_LAYOUT_ALIGN_CENTER = 2,
|
|
|
|
UI_LAYOUT_ALIGN_RIGHT = 3,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
|
|
|
|
|
|
|
enum {
|
2020-02-20 10:21:23 +11:00
|
|
|
/* UI_ITEM_O_RETURN_PROPS = 1 << 0, */ /* UNUSED */
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_ITEM_R_EXPAND = 1 << 1,
|
|
|
|
UI_ITEM_R_SLIDER = 1 << 2,
|
2019-05-21 14:39:09 +10:00
|
|
|
/**
|
|
|
|
* Use for booleans, causes the button to draw with an outline (emboss),
|
|
|
|
* instead of text with a checkbox.
|
|
|
|
* This is implied when toggle buttons have an icon
|
|
|
|
* unless #UI_ITEM_R_ICON_NEVER flag is set.
|
|
|
|
*/
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_ITEM_R_TOGGLE = 1 << 3,
|
2019-05-21 14:39:09 +10:00
|
|
|
/**
|
|
|
|
* Don't attempt to use an icon when the icon is set to #ICON_NONE.
|
|
|
|
*
|
|
|
|
* Use for boolean's, causes the buttons to always show as a checkbox
|
|
|
|
* even when there is an icon (which would normally show the button as a toggle).
|
|
|
|
*/
|
|
|
|
UI_ITEM_R_ICON_NEVER = 1 << 4,
|
|
|
|
UI_ITEM_R_ICON_ONLY = 1 << 5,
|
|
|
|
UI_ITEM_R_EVENT = 1 << 6,
|
|
|
|
UI_ITEM_R_FULL_EVENT = 1 << 7,
|
|
|
|
UI_ITEM_R_NO_BG = 1 << 8,
|
|
|
|
UI_ITEM_R_IMMEDIATE = 1 << 9,
|
|
|
|
UI_ITEM_O_DEPRESS = 1 << 10,
|
|
|
|
UI_ITEM_R_COMPACT = 1 << 11,
|
|
|
|
UI_ITEM_R_CHECKBOX_INVERT = 1 << 12,
|
UI: Better split layout support for checkboxes
Makes the following layout changes possible:
{F8473498} {F8473499} {F8473502}
The next commit will contain many layout changes to make good use of
these new possibilities. The result should be more consistent, easier to
read and should give a more organized impression. Additionally, it
should be possible to replace many sub-panels with compacter layouts.
Main changes:
* Checkboxes now respect the property split layouts
* Add support for row and column headers (i.e.
`uiLayout.column(heading="Foo")`, `uiLayout.row(heading="Bar")`). If the
first property added to this layout doesn't insert anything into the label
split column, the heading is inserted there. Otherwise, it's inserted as own
item.
* Add support for manually inserting decorators for an existing item
(`uiLayout.prop_decorator()`). That way layout creators can manually insert
this, which was the only way I saw to support property split layouts with a
checkbox before the actual property. {F8471883}
* Autogenerated layouts for operator properties look bad if there are only
checkboxes (which only use half the region width). So before creating the
layout, we iterate over visible properties and disable split layout if all
are booleans. I think this is fine, if needed we could also add layout hints
to operators.
* `uiTemplateOperatorPropertyButs()` now handles macros itself, the caller
used to be responsible for this. Code that didn't handle these so far never
used macros I think, so this change should be invisible.
* Remove manual property split layout from autogenerated operator properties
layout.
* Padding of checkboxes is tweaked to make their label visually more connected
to the checkboxes.
* Support split layout for menus (should work for `uiLayout.menu()`,
`.operator_menu_enum()`, `.prop_menu_enum()`, maybe more)
Maniphest Task: https://developer.blender.org/T65965
Differential Revision: https://developer.blender.org/D7427
Reviewed by: Brecht Van Lommel, William Reynish, Pablo Vazques
2020-04-17 16:40:25 +02:00
|
|
|
/** Don't add a real decorator item, just blank space. */
|
|
|
|
UI_ITEM_R_FORCE_BLANK_DECORATE = 1 << 13,
|
2020-04-27 15:24:25 +02:00
|
|
|
/* Even create the property split layout if there's no name to show there. */
|
|
|
|
UI_ITEM_R_SPLIT_EMPTY_NAME = 1 << 14,
|
2019-01-14 15:58:40 +11:00
|
|
|
};
|
2009-08-21 12:57:47 +00:00
|
|
|
|
2018-11-20 13:37:31 +01:00
|
|
|
#define UI_HEADER_OFFSET ((void)0, 0.4f * UI_UNIT_X)
|
UI: New Global Top-Bar (WIP)
== Main Features/Changes for Users
* Add horizontal bar at top of all non-temp windows, consisting out of two horizontal sub-bars.
* Upper sub-bar contains global menus (File, Render, etc.), tabs for workspaces and scene selector.
* Lower sub-bar contains object mode selector, screen-layout and render-layer selector. Later operator and/or tool settings will be placed here.
* Individual sections of the topbar are individually scrollable.
* Workspace tabs can be double- or ctrl-clicked for renaming and contain 'x' icon for deleting.
* Top-bar should scale nicely with DPI.
* The lower half of the top-bar can be hided by dragging the lower top-bar edge up. Better hiding options are planned (e.g. hide in fullscreen modes).
* Info editors at the top of the window and using the full window width with be replaced by the top-bar.
* In fullscreen modes, no more info editor is added on top, the top-bar replaces it.
== Technical Features/Changes
* Adds initial support for global areas
A global area is part of the window, not part of the regular screen-layout.
I've added a macro iterator to iterate over both, global and screen-layout level areas. When iterating over areas, from now on developers should always consider if they have to include global areas.
* Adds a TOPBAR editor type
The editor type is hidden in the UI editor type menu.
* Adds a variation of the ID template to display IDs as tab buttons (template_ID_tabs in BPY)
* Does various changes to RNA button creation code to improve their appearance in the horizontal top-bar.
* Adds support for dynamically sized regions. That is, regions that scale automatically to the layout bounds.
The code for this is currently a big hack (it's based on drawing the UI multiple times). This should definitely be improved.
* Adds a template for displaying operator properties optimized for the top-bar. This will probably change a lot still and is in fact disabled in code.
Since the final top-bar design depends a lot on other 2.8 designs (mainly tool-system and workspaces), we decided to not show the operator or tool settings in the top-bar for now. That means most of the lower sub-bar is empty for the time being.
NOTE: Top-bar or global area data is not written to files or SDNA. They are simply added to the window when opening Blender or reading a file. This allows us doing changes to the top-bar without having to care for compatibility.
== ToDo's
It's a bit hard to predict all the ToDo's here are the known main ones:
* Add options for the new active-tool system and for operator redo to the topbar.
* Automatically hide the top-bar in fullscreen modes.
* General visual polish.
* Top-bar drag & drop support (WIP in temp-tab_drag_drop).
* Improve dynamic regions (should also fix some layout glitches).
* Make internal terminology consistent.
* Enable topbar file writing once design is more advanced.
* Address TODO's and XXX's in code :)
Thanks @brecht for the review! And @sergey for the complaining ;)
Differential Revision: D2758
2018-04-20 17:14:03 +02:00
|
|
|
|
|
|
|
/* uiLayoutOperatorButs flags */
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_TEMPLATE_OP_PROPS_SHOW_TITLE = 1 << 0,
|
|
|
|
UI_TEMPLATE_OP_PROPS_SHOW_EMPTY = 1 << 1,
|
|
|
|
UI_TEMPLATE_OP_PROPS_COMPACT = 1 << 2,
|
|
|
|
UI_TEMPLATE_OP_PROPS_HIDE_ADVANCED = 1 << 3,
|
UI: Better split layout support for checkboxes
Makes the following layout changes possible:
{F8473498} {F8473499} {F8473502}
The next commit will contain many layout changes to make good use of
these new possibilities. The result should be more consistent, easier to
read and should give a more organized impression. Additionally, it
should be possible to replace many sub-panels with compacter layouts.
Main changes:
* Checkboxes now respect the property split layouts
* Add support for row and column headers (i.e.
`uiLayout.column(heading="Foo")`, `uiLayout.row(heading="Bar")`). If the
first property added to this layout doesn't insert anything into the label
split column, the heading is inserted there. Otherwise, it's inserted as own
item.
* Add support for manually inserting decorators for an existing item
(`uiLayout.prop_decorator()`). That way layout creators can manually insert
this, which was the only way I saw to support property split layouts with a
checkbox before the actual property. {F8471883}
* Autogenerated layouts for operator properties look bad if there are only
checkboxes (which only use half the region width). So before creating the
layout, we iterate over visible properties and disable split layout if all
are booleans. I think this is fine, if needed we could also add layout hints
to operators.
* `uiTemplateOperatorPropertyButs()` now handles macros itself, the caller
used to be responsible for this. Code that didn't handle these so far never
used macros I think, so this change should be invisible.
* Remove manual property split layout from autogenerated operator properties
layout.
* Padding of checkboxes is tweaked to make their label visually more connected
to the checkboxes.
* Support split layout for menus (should work for `uiLayout.menu()`,
`.operator_menu_enum()`, `.prop_menu_enum()`, maybe more)
Maniphest Task: https://developer.blender.org/T65965
Differential Revision: https://developer.blender.org/D7427
Reviewed by: Brecht Van Lommel, William Reynish, Pablo Vazques
2020-04-17 16:40:25 +02:00
|
|
|
/* Disable property split for the default layout (custom ui callbacks still have full control
|
|
|
|
* over the layout and can enable it). */
|
|
|
|
UI_TEMPLATE_OP_PROPS_NO_SPLIT_LAYOUT = 1 << 4,
|
UI: New Global Top-Bar (WIP)
== Main Features/Changes for Users
* Add horizontal bar at top of all non-temp windows, consisting out of two horizontal sub-bars.
* Upper sub-bar contains global menus (File, Render, etc.), tabs for workspaces and scene selector.
* Lower sub-bar contains object mode selector, screen-layout and render-layer selector. Later operator and/or tool settings will be placed here.
* Individual sections of the topbar are individually scrollable.
* Workspace tabs can be double- or ctrl-clicked for renaming and contain 'x' icon for deleting.
* Top-bar should scale nicely with DPI.
* The lower half of the top-bar can be hided by dragging the lower top-bar edge up. Better hiding options are planned (e.g. hide in fullscreen modes).
* Info editors at the top of the window and using the full window width with be replaced by the top-bar.
* In fullscreen modes, no more info editor is added on top, the top-bar replaces it.
== Technical Features/Changes
* Adds initial support for global areas
A global area is part of the window, not part of the regular screen-layout.
I've added a macro iterator to iterate over both, global and screen-layout level areas. When iterating over areas, from now on developers should always consider if they have to include global areas.
* Adds a TOPBAR editor type
The editor type is hidden in the UI editor type menu.
* Adds a variation of the ID template to display IDs as tab buttons (template_ID_tabs in BPY)
* Does various changes to RNA button creation code to improve their appearance in the horizontal top-bar.
* Adds support for dynamically sized regions. That is, regions that scale automatically to the layout bounds.
The code for this is currently a big hack (it's based on drawing the UI multiple times). This should definitely be improved.
* Adds a template for displaying operator properties optimized for the top-bar. This will probably change a lot still and is in fact disabled in code.
Since the final top-bar design depends a lot on other 2.8 designs (mainly tool-system and workspaces), we decided to not show the operator or tool settings in the top-bar for now. That means most of the lower sub-bar is empty for the time being.
NOTE: Top-bar or global area data is not written to files or SDNA. They are simply added to the window when opening Blender or reading a file. This allows us doing changes to the top-bar without having to care for compatibility.
== ToDo's
It's a bit hard to predict all the ToDo's here are the known main ones:
* Add options for the new active-tool system and for operator redo to the topbar.
* Automatically hide the top-bar in fullscreen modes.
* General visual polish.
* Top-bar drag & drop support (WIP in temp-tab_drag_drop).
* Improve dynamic regions (should also fix some layout glitches).
* Make internal terminology consistent.
* Enable topbar file writing once design is more advanced.
* Address TODO's and XXX's in code :)
Thanks @brecht for the review! And @sergey for the complaining ;)
Differential Revision: D2758
2018-04-20 17:14:03 +02:00
|
|
|
};
|
2010-12-15 05:42:23 +00:00
|
|
|
|
2013-12-24 17:20:37 +11:00
|
|
|
/* used for transp checkers */
|
|
|
|
#define UI_ALPHA_CHECKER_DARK 100
|
|
|
|
#define UI_ALPHA_CHECKER_LIGHT 160
|
|
|
|
|
2011-09-11 06:41:09 +00:00
|
|
|
/* flags to set which corners will become rounded:
|
|
|
|
*
|
|
|
|
* 1------2
|
|
|
|
* | |
|
|
|
|
* 8------4 */
|
|
|
|
|
|
|
|
enum {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_CNR_TOP_LEFT = 1 << 0,
|
|
|
|
UI_CNR_TOP_RIGHT = 1 << 1,
|
|
|
|
UI_CNR_BOTTOM_RIGHT = 1 << 2,
|
|
|
|
UI_CNR_BOTTOM_LEFT = 1 << 3,
|
|
|
|
/* just for convenience */
|
|
|
|
UI_CNR_NONE = 0,
|
|
|
|
UI_CNR_ALL = (UI_CNR_TOP_LEFT | UI_CNR_TOP_RIGHT | UI_CNR_BOTTOM_RIGHT | UI_CNR_BOTTOM_LEFT),
|
2011-09-11 06:41:09 +00:00
|
|
|
};
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
uiLayout *UI_block_layout(uiBlock *block,
|
|
|
|
int dir,
|
|
|
|
int type,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
int size,
|
|
|
|
int em,
|
|
|
|
int padding,
|
2020-03-15 17:32:25 +11:00
|
|
|
const struct uiStyle *style);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_block_layout_set_current(uiBlock *block, uiLayout *layout);
|
2019-03-25 12:19:55 +11:00
|
|
|
void UI_block_layout_resolve(uiBlock *block, int *r_x, int *r_y);
|
2009-03-13 13:38:41 +00:00
|
|
|
|
2020-03-06 16:56:42 +01:00
|
|
|
void UI_region_message_subscribe(struct ARegion *region, struct wmMsgBus *mbus);
|
2017-11-13 19:43:34 +11:00
|
|
|
|
2009-05-28 23:37:55 +00:00
|
|
|
uiBlock *uiLayoutGetBlock(uiLayout *layout);
|
2009-04-22 18:39:44 +00:00
|
|
|
|
2009-05-28 23:37:55 +00:00
|
|
|
void uiLayoutSetFunc(uiLayout *layout, uiMenuHandleFunc handlefunc, void *argv);
|
2010-11-17 09:45:45 +00:00
|
|
|
void uiLayoutSetContextPointer(uiLayout *layout, const char *name, struct PointerRNA *ptr);
|
2012-04-03 15:18:59 +00:00
|
|
|
void uiLayoutContextCopy(uiLayout *layout, struct bContextStore *context);
|
2014-11-09 21:20:40 +01:00
|
|
|
struct MenuType *UI_but_menutype_get(uiBut *but);
|
2018-04-22 17:16:39 +02:00
|
|
|
struct PanelType *UI_but_paneltype_get(uiBut *but);
|
2017-11-02 18:19:11 +11:00
|
|
|
void UI_menutype_draw(struct bContext *C, struct MenuType *mt, struct uiLayout *layout);
|
2018-05-25 12:19:04 +02:00
|
|
|
void UI_paneltype_draw(struct bContext *C, struct PanelType *pt, struct uiLayout *layout);
|
2017-11-02 18:19:11 +11:00
|
|
|
|
|
|
|
/* Only for convenience. */
|
|
|
|
void uiLayoutSetContextFromBut(uiLayout *layout, uiBut *but);
|
2009-05-28 23:13:42 +00:00
|
|
|
|
2009-08-21 12:57:47 +00:00
|
|
|
void uiLayoutSetOperatorContext(uiLayout *layout, int opcontext);
|
2013-04-04 02:05:11 +00:00
|
|
|
void uiLayoutSetActive(uiLayout *layout, bool active);
|
2019-03-27 21:39:44 +11:00
|
|
|
void uiLayoutSetActiveDefault(uiLayout *layout, bool active_default);
|
2019-03-20 22:40:38 +11:00
|
|
|
void uiLayoutSetActivateInit(uiLayout *layout, bool active);
|
2013-04-04 02:05:11 +00:00
|
|
|
void uiLayoutSetEnabled(uiLayout *layout, bool enabled);
|
|
|
|
void uiLayoutSetRedAlert(uiLayout *layout, bool redalert);
|
|
|
|
void uiLayoutSetAlignment(uiLayout *layout, char alignment);
|
2019-09-19 16:14:47 +02:00
|
|
|
void uiLayoutSetFixedSize(uiLayout *layout, bool fixed_size);
|
2013-04-04 02:05:11 +00:00
|
|
|
void uiLayoutSetKeepAspect(uiLayout *layout, bool keepaspect);
|
2009-06-03 00:04:48 +00:00
|
|
|
void uiLayoutSetScaleX(uiLayout *layout, float scale);
|
|
|
|
void uiLayoutSetScaleY(uiLayout *layout, float scale);
|
2018-09-26 17:44:35 +02:00
|
|
|
void uiLayoutSetUnitsX(uiLayout *layout, float unit);
|
|
|
|
void uiLayoutSetUnitsY(uiLayout *layout, float unit);
|
2018-05-13 12:57:31 +02:00
|
|
|
void uiLayoutSetEmboss(uiLayout *layout, char emboss);
|
2018-05-28 16:40:27 +02:00
|
|
|
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep);
|
2018-06-16 14:48:21 +02:00
|
|
|
void uiLayoutSetPropDecorate(uiLayout *layout, bool is_sep);
|
2018-12-20 11:59:31 +11:00
|
|
|
int uiLayoutGetLocalDir(const uiLayout *layout);
|
2009-05-28 23:37:55 +00:00
|
|
|
|
2009-06-09 10:30:11 +00:00
|
|
|
int uiLayoutGetOperatorContext(uiLayout *layout);
|
2013-04-04 02:05:11 +00:00
|
|
|
bool uiLayoutGetActive(uiLayout *layout);
|
2019-03-27 21:39:44 +11:00
|
|
|
bool uiLayoutGetActiveDefault(uiLayout *layout);
|
2019-03-20 22:40:38 +11:00
|
|
|
bool uiLayoutGetActivateInit(uiLayout *layout);
|
2013-04-04 02:05:11 +00:00
|
|
|
bool uiLayoutGetEnabled(uiLayout *layout);
|
|
|
|
bool uiLayoutGetRedAlert(uiLayout *layout);
|
2009-05-28 23:37:55 +00:00
|
|
|
int uiLayoutGetAlignment(uiLayout *layout);
|
2019-09-19 16:14:47 +02:00
|
|
|
bool uiLayoutGetFixedSize(uiLayout *layout);
|
2013-04-04 02:05:11 +00:00
|
|
|
bool uiLayoutGetKeepAspect(uiLayout *layout);
|
2009-08-16 13:01:40 +00:00
|
|
|
int uiLayoutGetWidth(uiLayout *layout);
|
2009-06-03 00:04:48 +00:00
|
|
|
float uiLayoutGetScaleX(uiLayout *layout);
|
|
|
|
float uiLayoutGetScaleY(uiLayout *layout);
|
2018-09-26 17:44:35 +02:00
|
|
|
float uiLayoutGetUnitsX(uiLayout *layout);
|
|
|
|
float uiLayoutGetUnitsY(uiLayout *layout);
|
2018-05-13 12:57:31 +02:00
|
|
|
int uiLayoutGetEmboss(uiLayout *layout);
|
2018-05-28 16:40:27 +02:00
|
|
|
bool uiLayoutGetPropSep(uiLayout *layout);
|
2018-06-16 14:48:21 +02:00
|
|
|
bool uiLayoutGetPropDecorate(uiLayout *layout);
|
2009-05-28 23:37:55 +00:00
|
|
|
|
2009-04-16 12:17:58 +00:00
|
|
|
/* layout specifiers */
|
2018-07-01 15:47:09 +02:00
|
|
|
uiLayout *uiLayoutRow(uiLayout *layout, bool align);
|
UI: Better split layout support for checkboxes
Makes the following layout changes possible:
{F8473498} {F8473499} {F8473502}
The next commit will contain many layout changes to make good use of
these new possibilities. The result should be more consistent, easier to
read and should give a more organized impression. Additionally, it
should be possible to replace many sub-panels with compacter layouts.
Main changes:
* Checkboxes now respect the property split layouts
* Add support for row and column headers (i.e.
`uiLayout.column(heading="Foo")`, `uiLayout.row(heading="Bar")`). If the
first property added to this layout doesn't insert anything into the label
split column, the heading is inserted there. Otherwise, it's inserted as own
item.
* Add support for manually inserting decorators for an existing item
(`uiLayout.prop_decorator()`). That way layout creators can manually insert
this, which was the only way I saw to support property split layouts with a
checkbox before the actual property. {F8471883}
* Autogenerated layouts for operator properties look bad if there are only
checkboxes (which only use half the region width). So before creating the
layout, we iterate over visible properties and disable split layout if all
are booleans. I think this is fine, if needed we could also add layout hints
to operators.
* `uiTemplateOperatorPropertyButs()` now handles macros itself, the caller
used to be responsible for this. Code that didn't handle these so far never
used macros I think, so this change should be invisible.
* Remove manual property split layout from autogenerated operator properties
layout.
* Padding of checkboxes is tweaked to make their label visually more connected
to the checkboxes.
* Support split layout for menus (should work for `uiLayout.menu()`,
`.operator_menu_enum()`, `.prop_menu_enum()`, maybe more)
Maniphest Task: https://developer.blender.org/T65965
Differential Revision: https://developer.blender.org/D7427
Reviewed by: Brecht Van Lommel, William Reynish, Pablo Vazques
2020-04-17 16:40:25 +02:00
|
|
|
uiLayout *uiLayoutRowWithHeading(uiLayout *layout, bool align, const char *heading);
|
2018-07-01 15:47:09 +02:00
|
|
|
uiLayout *uiLayoutColumn(uiLayout *layout, bool align);
|
UI: Better split layout support for checkboxes
Makes the following layout changes possible:
{F8473498} {F8473499} {F8473502}
The next commit will contain many layout changes to make good use of
these new possibilities. The result should be more consistent, easier to
read and should give a more organized impression. Additionally, it
should be possible to replace many sub-panels with compacter layouts.
Main changes:
* Checkboxes now respect the property split layouts
* Add support for row and column headers (i.e.
`uiLayout.column(heading="Foo")`, `uiLayout.row(heading="Bar")`). If the
first property added to this layout doesn't insert anything into the label
split column, the heading is inserted there. Otherwise, it's inserted as own
item.
* Add support for manually inserting decorators for an existing item
(`uiLayout.prop_decorator()`). That way layout creators can manually insert
this, which was the only way I saw to support property split layouts with a
checkbox before the actual property. {F8471883}
* Autogenerated layouts for operator properties look bad if there are only
checkboxes (which only use half the region width). So before creating the
layout, we iterate over visible properties and disable split layout if all
are booleans. I think this is fine, if needed we could also add layout hints
to operators.
* `uiTemplateOperatorPropertyButs()` now handles macros itself, the caller
used to be responsible for this. Code that didn't handle these so far never
used macros I think, so this change should be invisible.
* Remove manual property split layout from autogenerated operator properties
layout.
* Padding of checkboxes is tweaked to make their label visually more connected
to the checkboxes.
* Support split layout for menus (should work for `uiLayout.menu()`,
`.operator_menu_enum()`, `.prop_menu_enum()`, maybe more)
Maniphest Task: https://developer.blender.org/T65965
Differential Revision: https://developer.blender.org/D7427
Reviewed by: Brecht Van Lommel, William Reynish, Pablo Vazques
2020-04-17 16:40:25 +02:00
|
|
|
uiLayout *uiLayoutColumnWithHeading(uiLayout *layout, bool align, const char *heading);
|
2018-07-01 15:47:09 +02:00
|
|
|
uiLayout *uiLayoutColumnFlow(uiLayout *layout, int number, bool align);
|
2019-04-17 06:17:24 +02:00
|
|
|
uiLayout *uiLayoutGridFlow(uiLayout *layout,
|
|
|
|
bool row_major,
|
|
|
|
int columns_len,
|
|
|
|
bool even_columns,
|
|
|
|
bool even_rows,
|
|
|
|
bool align);
|
2009-04-16 12:17:58 +00:00
|
|
|
uiLayout *uiLayoutBox(uiLayout *layout);
|
2019-04-17 06:17:24 +02:00
|
|
|
uiLayout *uiLayoutListBox(uiLayout *layout,
|
|
|
|
struct uiList *ui_list,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
struct PointerRNA *actptr,
|
|
|
|
struct PropertyRNA *actprop);
|
2018-07-01 15:47:09 +02:00
|
|
|
uiLayout *uiLayoutAbsolute(uiLayout *layout, bool align);
|
|
|
|
uiLayout *uiLayoutSplit(uiLayout *layout, float percentage, bool align);
|
2009-10-21 20:58:10 +00:00
|
|
|
uiLayout *uiLayoutOverlap(uiLayout *layout);
|
2009-10-09 10:45:11 +00:00
|
|
|
uiBlock *uiLayoutAbsoluteBlock(uiLayout *layout);
|
Pie Menus C code backend.
This commit merges the code in the pie-menu branch.
As per decisions taken the last few days, there are no pie menus
included and there will be an official add-on including overrides of
some keys with pie menus. However, people will now be able to use the
new code in python.
Full Documentation is in http://wiki.blender.org/index.php/Dev:Ref/
Thanks:
Campbell Barton, Dalai Felinto and Ton Roosendaal for the code review
and design comments
Jonathan Williamson, Pawel Lyczkowski, Pablo Vazquez among others for
suggestions during the development.
Special Thanks to Sean Olson, for his support, suggestions, testing and
merciless bugging so that I would finish the pie menu code. Without him
we wouldn't be here. Also to the rest of the developers of the original
python add-on, Patrick Moore and Dan Eicher and finally to Matt Ebb, who
did the research and first implementation and whose code I used to get
started.
2014-08-11 10:39:59 +02:00
|
|
|
uiLayout *uiLayoutRadial(uiLayout *layout);
|
2009-05-19 17:13:33 +00:00
|
|
|
|
2009-04-16 12:17:58 +00:00
|
|
|
/* templates */
|
2014-01-27 18:38:53 +11:00
|
|
|
void uiTemplateHeader(uiLayout *layout, struct bContext *C);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateID(uiLayout *layout,
|
2020-06-02 14:09:01 -04:00
|
|
|
const struct bContext *C,
|
2019-04-17 06:17:24 +02:00
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
const char *newop,
|
|
|
|
const char *openop,
|
|
|
|
const char *unlinkop,
|
|
|
|
int filter,
|
2019-11-25 19:41:30 +01:00
|
|
|
const bool live_icon,
|
|
|
|
const char *text);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateIDBrowse(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
const char *newop,
|
|
|
|
const char *openop,
|
|
|
|
const char *unlinkop,
|
2019-11-25 19:41:30 +01:00
|
|
|
int filter,
|
|
|
|
const char *text);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateIDPreview(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
const char *newop,
|
|
|
|
const char *openop,
|
|
|
|
const char *unlinkop,
|
|
|
|
int rows,
|
|
|
|
int cols,
|
|
|
|
int filter,
|
|
|
|
const bool hide_buttons);
|
|
|
|
void uiTemplateIDTabs(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
const char *newop,
|
|
|
|
const char *menu,
|
|
|
|
int filter);
|
|
|
|
void uiTemplateAnyID(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
const char *proptypename,
|
|
|
|
const char *text);
|
|
|
|
void uiTemplateSearch(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
struct PointerRNA *searchptr,
|
|
|
|
const char *searchpropname,
|
|
|
|
const char *newop,
|
|
|
|
const char *unlinkop);
|
|
|
|
void uiTemplateSearchPreview(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
struct PointerRNA *searchptr,
|
|
|
|
const char *searchpropname,
|
|
|
|
const char *newop,
|
|
|
|
const char *unlinkop,
|
|
|
|
const int rows,
|
|
|
|
const int cols);
|
|
|
|
void uiTemplatePathBuilder(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
struct PointerRNA *root_ptr,
|
|
|
|
const char *text);
|
2020-06-05 10:41:03 -04:00
|
|
|
void uiTemplateModifiers(uiLayout *layout, struct bContext *C);
|
2020-06-19 12:40:48 -04:00
|
|
|
void uiTemplateConstraints(uiLayout *layout, struct bContext *C, bool use_bone_constraints);
|
|
|
|
|
2018-07-31 10:22:19 +02:00
|
|
|
uiLayout *uiTemplateGpencilModifier(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateGpencilColorPreview(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
int rows,
|
|
|
|
int cols,
|
|
|
|
float scale,
|
|
|
|
int filter);
|
2018-07-31 10:22:19 +02:00
|
|
|
|
|
|
|
uiLayout *uiTemplateShaderFx(uiLayout *layout, struct bContext *C, struct PointerRNA *ptr);
|
2018-04-25 07:52:40 +02:00
|
|
|
|
2018-05-02 10:59:20 +02:00
|
|
|
void uiTemplateOperatorRedoProperties(uiLayout *layout, const struct bContext *C);
|
2018-04-25 07:52:40 +02:00
|
|
|
|
2020-06-19 12:40:48 -04:00
|
|
|
void uiTemplateConstraintHeader(uiLayout *layout, struct PointerRNA *ptr);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplatePreview(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct ID *id,
|
|
|
|
bool show_buttons,
|
|
|
|
struct ID *parent,
|
|
|
|
struct MTex *slot,
|
|
|
|
const char *preview_id);
|
|
|
|
void uiTemplateColorRamp(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
bool expand);
|
2018-06-14 10:38:17 +02:00
|
|
|
void uiTemplateIcon(uiLayout *layout, int icon_value, float icon_scale);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateIconView(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
bool show_labels,
|
|
|
|
float icon_scale,
|
|
|
|
float icon_scale_popup);
|
2010-11-17 09:45:45 +00:00
|
|
|
void uiTemplateHistogram(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
|
|
|
|
void uiTemplateWaveform(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
|
|
|
|
void uiTemplateVectorscope(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateCurveMapping(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
int type,
|
|
|
|
bool levels,
|
|
|
|
bool brush,
|
|
|
|
bool neg_slope,
|
|
|
|
bool tone);
|
2019-11-20 16:12:32 -05:00
|
|
|
void uiTemplateCurveProfile(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateColorPicker(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
bool value_slider,
|
|
|
|
bool lock,
|
|
|
|
bool lock_luminosity,
|
|
|
|
bool cubic);
|
2018-07-01 15:47:09 +02:00
|
|
|
void uiTemplatePalette(uiLayout *layout, struct PointerRNA *ptr, const char *propname, bool color);
|
2018-07-18 13:03:09 +02:00
|
|
|
void uiTemplateCryptoPicker(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateLayers(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
PointerRNA *used_ptr,
|
|
|
|
const char *used_propname,
|
|
|
|
int active_layer);
|
|
|
|
void uiTemplateImage(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
struct PointerRNA *userptr,
|
|
|
|
bool compact,
|
|
|
|
bool multiview);
|
2018-07-01 15:47:09 +02:00
|
|
|
void uiTemplateImageSettings(uiLayout *layout, struct PointerRNA *imfptr, bool color_management);
|
2015-04-06 10:40:12 -03:00
|
|
|
void uiTemplateImageStereo3d(uiLayout *layout, struct PointerRNA *stereo3d_format_ptr);
|
|
|
|
void uiTemplateImageViews(uiLayout *layout, struct PointerRNA *imaptr);
|
|
|
|
void uiTemplateImageFormatViews(uiLayout *layout, PointerRNA *imfptr, PointerRNA *ptr);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateImageLayers(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct Image *ima,
|
|
|
|
struct ImageUser *iuser);
|
|
|
|
void uiTemplateImageInfo(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct Image *ima,
|
|
|
|
struct ImageUser *iuser);
|
2009-06-30 19:20:45 +00:00
|
|
|
void uiTemplateRunningJobs(uiLayout *layout, struct bContext *C);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_but_func_operator_search(uiBut *but);
|
2009-06-30 19:20:45 +00:00
|
|
|
void uiTemplateOperatorSearch(uiLayout *layout);
|
2020-03-24 11:34:18 +11:00
|
|
|
|
|
|
|
void UI_but_func_menu_search(uiBut *but);
|
|
|
|
void uiTemplateMenuSearch(uiLayout *layout);
|
|
|
|
|
UI: Better split layout support for checkboxes
Makes the following layout changes possible:
{F8473498} {F8473499} {F8473502}
The next commit will contain many layout changes to make good use of
these new possibilities. The result should be more consistent, easier to
read and should give a more organized impression. Additionally, it
should be possible to replace many sub-panels with compacter layouts.
Main changes:
* Checkboxes now respect the property split layouts
* Add support for row and column headers (i.e.
`uiLayout.column(heading="Foo")`, `uiLayout.row(heading="Bar")`). If the
first property added to this layout doesn't insert anything into the label
split column, the heading is inserted there. Otherwise, it's inserted as own
item.
* Add support for manually inserting decorators for an existing item
(`uiLayout.prop_decorator()`). That way layout creators can manually insert
this, which was the only way I saw to support property split layouts with a
checkbox before the actual property. {F8471883}
* Autogenerated layouts for operator properties look bad if there are only
checkboxes (which only use half the region width). So before creating the
layout, we iterate over visible properties and disable split layout if all
are booleans. I think this is fine, if needed we could also add layout hints
to operators.
* `uiTemplateOperatorPropertyButs()` now handles macros itself, the caller
used to be responsible for this. Code that didn't handle these so far never
used macros I think, so this change should be invisible.
* Remove manual property split layout from autogenerated operator properties
layout.
* Padding of checkboxes is tweaked to make their label visually more connected
to the checkboxes.
* Support split layout for menus (should work for `uiLayout.menu()`,
`.operator_menu_enum()`, `.prop_menu_enum()`, maybe more)
Maniphest Task: https://developer.blender.org/T65965
Differential Revision: https://developer.blender.org/D7427
Reviewed by: Brecht Van Lommel, William Reynish, Pablo Vazques
2020-04-17 16:40:25 +02:00
|
|
|
void uiTemplateOperatorPropertyButs(const struct bContext *C,
|
|
|
|
uiLayout *layout,
|
|
|
|
struct wmOperator *op,
|
|
|
|
eButLabelAlign label_align,
|
|
|
|
short flag);
|
2018-05-01 20:12:06 +02:00
|
|
|
void uiTemplateHeader3D_mode(uiLayout *layout, struct bContext *C);
|
2011-05-02 11:34:57 +00:00
|
|
|
void uiTemplateEditModeSelection(uiLayout *layout, struct bContext *C);
|
2010-06-03 07:27:55 +00:00
|
|
|
void uiTemplateReportsBanner(uiLayout *layout, struct bContext *C);
|
2018-06-26 17:19:25 +02:00
|
|
|
void uiTemplateInputStatus(uiLayout *layout, struct bContext *C);
|
2011-10-04 13:24:48 +00:00
|
|
|
void uiTemplateKeymapItemProperties(uiLayout *layout, struct PointerRNA *ptr);
|
2019-10-28 02:51:26 +11:00
|
|
|
|
|
|
|
bool uiTemplateEventFromKeymapItem(struct uiLayout *layout,
|
|
|
|
const char *text,
|
|
|
|
const struct wmKeyMapItem *kmi,
|
|
|
|
bool text_fallback);
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateComponentMenu(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
const char *name);
|
2013-03-18 16:34:57 +00:00
|
|
|
void uiTemplateNodeSocket(uiLayout *layout, struct bContext *C, float *color);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateCacheFile(uiLayout *layout,
|
2020-06-02 14:09:01 -04:00
|
|
|
const struct bContext *C,
|
2019-04-17 06:17:24 +02:00
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname);
|
2009-03-13 13:38:41 +00:00
|
|
|
|
2013-02-18 14:03:26 +00:00
|
|
|
/* Default UIList class name, keep in sync with its declaration in bl_ui/__init__.py */
|
|
|
|
#define UI_UL_DEFAULT_CLASS_NAME "UI_UL_list"
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateList(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
const char *listtype_name,
|
|
|
|
const char *list_id,
|
|
|
|
struct PointerRNA *dataptr,
|
|
|
|
const char *propname,
|
|
|
|
struct PointerRNA *active_dataptr,
|
|
|
|
const char *active_propname,
|
|
|
|
const char *item_dyntip_propname,
|
|
|
|
int rows,
|
|
|
|
int maxrows,
|
|
|
|
int layout_type,
|
|
|
|
int columns,
|
|
|
|
bool sort_reverse,
|
|
|
|
bool sort_lock);
|
|
|
|
void uiTemplateNodeLink(uiLayout *layout,
|
2020-04-16 15:09:49 +02:00
|
|
|
struct bContext *C,
|
2019-04-17 06:17:24 +02:00
|
|
|
struct bNodeTree *ntree,
|
|
|
|
struct bNode *node,
|
|
|
|
struct bNodeSocket *input);
|
|
|
|
void uiTemplateNodeView(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct bNodeTree *ntree,
|
|
|
|
struct bNode *node,
|
|
|
|
struct bNodeSocket *input);
|
2011-11-08 13:07:16 +00:00
|
|
|
void uiTemplateTextureUser(uiLayout *layout, struct bContext *C);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateTextureShow(uiLayout *layout,
|
2020-06-02 14:09:01 -04:00
|
|
|
const struct bContext *C,
|
2019-04-17 06:17:24 +02:00
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop);
|
|
|
|
|
|
|
|
void uiTemplateMovieClip(struct uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
bool compact);
|
2011-11-07 12:55:18 +00:00
|
|
|
void uiTemplateTrack(struct uiLayout *layout, struct PointerRNA *ptr, const char *propname);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiTemplateMarker(struct uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
PointerRNA *userptr,
|
|
|
|
PointerRNA *trackptr,
|
|
|
|
bool compact);
|
|
|
|
void uiTemplateMovieclipInformation(struct uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
struct PointerRNA *userptr);
|
|
|
|
|
|
|
|
void uiTemplateColorspaceSettings(struct uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname);
|
|
|
|
void uiTemplateColormanagedViewSettings(struct uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname);
|
Color Management, Stage 2: Switch color pipeline to use OpenColorIO
Replace old color pipeline which was supporting linear/sRGB color spaces
only with OpenColorIO-based pipeline.
This introduces two configurable color spaces:
- Input color space for images and movie clips. This space is used to convert
images/movies from color space in which file is saved to Blender's linear
space (for float images, byte images are not internally converted, only input
space is stored for such images and used later).
This setting could be found in image/clip data block settings.
- Display color space which defines space in which particular display is working.
This settings could be found in scene's Color Management panel.
When render result is being displayed on the screen, apart from converting image
to display space, some additional conversions could happen.
This conversions are:
- View, which defines tone curve applying before display transformation.
These are different ways to view the image on the same display device.
For example it could be used to emulate film view on sRGB display.
- Exposure affects on image exposure before tone map is applied.
- Gamma is post-display gamma correction, could be used to match particular
display gamma.
- RGB curves are user-defined curves which are applying before display
transformation, could be used for different purposes.
All this settings by default are only applying on render result and does not
affect on other images. If some particular image needs to be affected by this
transformation, "View as Render" setting of image data block should be set to
truth. Movie clips are always affected by all display transformations.
This commit also introduces configurable color space in which sequencer is
working. This setting could be found in scene's Color Management panel and
it should be used if such stuff as grading needs to be done in color space
different from sRGB (i.e. when Film view on sRGB display is use, using VD16
space as sequencer's internal space would make grading working in space
which is close to the space using for display).
Some technical notes:
- Image buffer's float buffer is now always in linear space, even if it was
created from 16bit byte images.
- Space of byte buffer is stored in image buffer's rect_colorspace property.
- Profile of image buffer was removed since it's not longer meaningful.
- OpenGL and GLSL is supposed to always work in sRGB space. It is possible
to support other spaces, but it's quite large project which isn't so
much important.
- Legacy Color Management option disabled is emulated by using None display.
It could have some regressions, but there's no clear way to avoid them.
- If OpenColorIO is disabled on build time, it should make blender behaving
in the same way as previous release with color management enabled.
More details could be found at this page (more details would be added soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Color_Management
--
Thanks to Xavier Thomas, Lukas Toene for initial work on OpenColorIO
integration and to Brecht van Lommel for some further development and code/
usecase review!
2012-09-15 10:05:07 +00:00
|
|
|
|
2018-09-18 17:44:14 +02:00
|
|
|
int uiTemplateRecentFiles(struct uiLayout *layout, int rows);
|
2019-09-06 01:22:35 +02:00
|
|
|
void uiTemplateFileSelectPath(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct FileSelectParams *params);
|
2018-09-18 17:44:14 +02:00
|
|
|
|
2009-03-13 13:38:41 +00:00
|
|
|
/* items */
|
2010-11-17 09:45:45 +00:00
|
|
|
void uiItemO(uiLayout *layout, const char *name, int icon, const char *opname);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiItemEnumO_ptr(uiLayout *layout,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *propname,
|
|
|
|
int value);
|
|
|
|
void uiItemEnumO(uiLayout *layout,
|
|
|
|
const char *opname,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *propname,
|
|
|
|
int value);
|
|
|
|
void uiItemEnumO_value(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
int value);
|
|
|
|
void uiItemEnumO_string(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
const char *value);
|
2010-11-17 09:45:45 +00:00
|
|
|
void uiItemsEnumO(uiLayout *layout, const char *opname, const char *propname);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiItemBooleanO(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
int value);
|
|
|
|
void uiItemIntO(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
int value);
|
|
|
|
void uiItemFloatO(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
float value);
|
|
|
|
void uiItemStringO(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
const char *value);
|
|
|
|
|
|
|
|
void uiItemFullO_ptr(uiLayout *layout,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
struct IDProperty *properties,
|
|
|
|
int context,
|
|
|
|
int flag,
|
|
|
|
PointerRNA *r_opptr);
|
|
|
|
void uiItemFullO(uiLayout *layout,
|
|
|
|
const char *idname,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
struct IDProperty *properties,
|
|
|
|
int context,
|
|
|
|
int flag,
|
|
|
|
PointerRNA *r_opptr);
|
|
|
|
void uiItemFullOMenuHold_ptr(uiLayout *layout,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
struct IDProperty *properties,
|
|
|
|
int context,
|
|
|
|
int flag,
|
|
|
|
const char *menu_id, /* extra menu arg. */
|
|
|
|
PointerRNA *r_opptr);
|
|
|
|
|
|
|
|
void uiItemR(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
int flag,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
|
|
|
void uiItemFullR(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
int index,
|
|
|
|
int value,
|
|
|
|
int flag,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
|
|
|
void uiItemFullR_with_popover(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
int index,
|
|
|
|
int value,
|
|
|
|
int flag,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *panel_type);
|
|
|
|
void uiItemFullR_with_menu(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
int index,
|
|
|
|
int value,
|
|
|
|
int flag,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
const char *menu_type);
|
|
|
|
void uiItemEnumR_prop(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
PropertyRNA *prop,
|
|
|
|
int value);
|
|
|
|
void uiItemEnumR(uiLayout *layout,
|
|
|
|
const char *name,
|
|
|
|
int icon,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
int value);
|
|
|
|
void uiItemEnumR_string_prop(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
PropertyRNA *prop,
|
|
|
|
const char *value,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
|
|
|
void uiItemEnumR_string(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
const char *value,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
2010-11-17 09:45:45 +00:00
|
|
|
void uiItemsEnumR(uiLayout *layout, struct PointerRNA *ptr, const char *propname);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiItemPointerR_prop(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
PropertyRNA *prop,
|
|
|
|
struct PointerRNA *searchptr,
|
|
|
|
PropertyRNA *searchprop,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
|
|
|
void uiItemPointerR(uiLayout *layout,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
const char *propname,
|
|
|
|
struct PointerRNA *searchptr,
|
|
|
|
const char *searchpropname,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
|
|
|
void uiItemsFullEnumO(uiLayout *layout,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
struct IDProperty *properties,
|
|
|
|
int context,
|
|
|
|
int flag);
|
|
|
|
void uiItemsFullEnumO_items(uiLayout *layout,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
PointerRNA ptr,
|
|
|
|
PropertyRNA *prop,
|
|
|
|
struct IDProperty *properties,
|
|
|
|
int context,
|
|
|
|
int flag,
|
|
|
|
const EnumPropertyItem *item_array,
|
|
|
|
int totitem);
|
2010-11-17 09:45:45 +00:00
|
|
|
|
2020-04-27 16:43:36 +02:00
|
|
|
typedef struct uiPropertySplitWrapper {
|
|
|
|
uiLayout *label_column;
|
|
|
|
uiLayout *property_row;
|
|
|
|
uiLayout *decorate_column;
|
|
|
|
} uiPropertySplitWrapper;
|
|
|
|
|
|
|
|
uiPropertySplitWrapper uiItemPropertySplitWrapperCreate(uiLayout *parent_layout);
|
|
|
|
|
2010-11-17 09:45:45 +00:00
|
|
|
void uiItemL(uiLayout *layout, const char *name, int icon); /* label */
|
2020-02-28 13:51:40 +01:00
|
|
|
void uiItemL_ex(
|
|
|
|
uiLayout *layout, const char *name, int icon, const bool highlight, const bool redalert);
|
2019-11-25 19:41:30 +01:00
|
|
|
uiLayout *uiItemL_respect_property_split(uiLayout *layout, const char *text, int icon);
|
2019-01-15 23:24:20 +11:00
|
|
|
/* label icon for dragging */
|
|
|
|
void uiItemLDrag(uiLayout *layout, struct PointerRNA *ptr, const char *name, int icon);
|
|
|
|
/* menu */
|
2019-05-27 15:30:48 +10:00
|
|
|
void uiItemM_ptr(uiLayout *layout, struct MenuType *mt, const char *name, int icon);
|
2019-01-15 23:24:20 +11:00
|
|
|
void uiItemM(uiLayout *layout, const char *menuname, const char *name, int icon);
|
|
|
|
/* menu contents */
|
|
|
|
void uiItemMContents(uiLayout *layout, const char *menuname);
|
UI: Better split layout support for checkboxes
Makes the following layout changes possible:
{F8473498} {F8473499} {F8473502}
The next commit will contain many layout changes to make good use of
these new possibilities. The result should be more consistent, easier to
read and should give a more organized impression. Additionally, it
should be possible to replace many sub-panels with compacter layouts.
Main changes:
* Checkboxes now respect the property split layouts
* Add support for row and column headers (i.e.
`uiLayout.column(heading="Foo")`, `uiLayout.row(heading="Bar")`). If the
first property added to this layout doesn't insert anything into the label
split column, the heading is inserted there. Otherwise, it's inserted as own
item.
* Add support for manually inserting decorators for an existing item
(`uiLayout.prop_decorator()`). That way layout creators can manually insert
this, which was the only way I saw to support property split layouts with a
checkbox before the actual property. {F8471883}
* Autogenerated layouts for operator properties look bad if there are only
checkboxes (which only use half the region width). So before creating the
layout, we iterate over visible properties and disable split layout if all
are booleans. I think this is fine, if needed we could also add layout hints
to operators.
* `uiTemplateOperatorPropertyButs()` now handles macros itself, the caller
used to be responsible for this. Code that didn't handle these so far never
used macros I think, so this change should be invisible.
* Remove manual property split layout from autogenerated operator properties
layout.
* Padding of checkboxes is tweaked to make their label visually more connected
to the checkboxes.
* Support split layout for menus (should work for `uiLayout.menu()`,
`.operator_menu_enum()`, `.prop_menu_enum()`, maybe more)
Maniphest Task: https://developer.blender.org/T65965
Differential Revision: https://developer.blender.org/D7427
Reviewed by: Brecht Van Lommel, William Reynish, Pablo Vazques
2020-04-17 16:40:25 +02:00
|
|
|
/* Decorators */
|
|
|
|
void uiItemDecoratorR_prop(uiLayout *layout, PointerRNA *ptr, PropertyRNA *prop, int index);
|
|
|
|
void uiItemDecoratorR(uiLayout *layout, PointerRNA *ptr, const char *propname, int index);
|
2019-01-15 23:24:20 +11:00
|
|
|
/* value */
|
|
|
|
void uiItemV(uiLayout *layout, const char *name, int icon, int argval);
|
|
|
|
/* separator */
|
|
|
|
void uiItemS(uiLayout *layout);
|
2018-11-02 16:32:31 +01:00
|
|
|
void uiItemS_ex(uiLayout *layout, float factor);
|
2019-01-15 23:24:20 +11:00
|
|
|
/* Special separator. */
|
|
|
|
void uiItemSpacer(uiLayout *layout);
|
2009-04-22 18:39:44 +00:00
|
|
|
|
2018-04-22 17:16:39 +02:00
|
|
|
void uiItemPopoverPanel_ptr(
|
2019-04-17 06:17:24 +02:00
|
|
|
uiLayout *layout, struct bContext *C, struct PanelType *pt, const char *name, int icon);
|
2018-04-22 17:16:39 +02:00
|
|
|
void uiItemPopoverPanel(
|
2019-04-17 06:17:24 +02:00
|
|
|
uiLayout *layout, struct bContext *C, const char *panelname, const char *name, int icon);
|
|
|
|
void uiItemPopoverPanelFromGroup(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
int space_id,
|
|
|
|
int region_id,
|
|
|
|
const char *context,
|
|
|
|
const char *category);
|
2018-04-22 17:16:39 +02:00
|
|
|
|
2010-11-17 09:45:45 +00:00
|
|
|
void uiItemMenuF(uiLayout *layout, const char *name, int icon, uiMenuCreateFunc func, void *arg);
|
2018-10-30 10:46:29 +11:00
|
|
|
void uiItemMenuFN(uiLayout *layout, const char *name, int icon, uiMenuCreateFunc func, void *argN);
|
2019-04-17 06:17:24 +02:00
|
|
|
void uiItemMenuEnumO_ptr(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct wmOperatorType *ot,
|
|
|
|
const char *propname,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
|
|
|
void uiItemMenuEnumO(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
const char *opname,
|
|
|
|
const char *propname,
|
|
|
|
const char *name,
|
|
|
|
int icon);
|
|
|
|
void uiItemMenuEnumR_prop(
|
|
|
|
uiLayout *layout, struct PointerRNA *ptr, PropertyRNA *prop, const char *name, int icon);
|
|
|
|
void uiItemMenuEnumR(
|
|
|
|
uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *name, int icon);
|
|
|
|
void uiItemTabsEnumR_prop(uiLayout *layout,
|
|
|
|
struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
PropertyRNA *prop,
|
|
|
|
bool icon_only);
|
2009-03-13 13:38:41 +00:00
|
|
|
|
2009-12-17 10:47:55 +00:00
|
|
|
/* UI Operators */
|
2014-07-21 12:02:05 +02:00
|
|
|
typedef struct uiDragColorHandle {
|
2019-04-17 06:17:24 +02:00
|
|
|
float color[3];
|
|
|
|
bool gamma_corrected;
|
2014-07-21 12:02:05 +02:00
|
|
|
} uiDragColorHandle;
|
|
|
|
|
2016-02-29 17:47:36 +01:00
|
|
|
void ED_operatortypes_ui(void);
|
2016-02-29 17:40:19 +01:00
|
|
|
void ED_keymap_ui(struct wmKeyConfig *keyconf);
|
|
|
|
|
2014-07-21 12:02:05 +02:00
|
|
|
void UI_drop_color_copy(struct wmDrag *drag, struct wmDropBox *drop);
|
2019-04-17 06:17:24 +02:00
|
|
|
bool UI_drop_color_poll(struct bContext *C,
|
|
|
|
struct wmDrag *drag,
|
|
|
|
const struct wmEvent *event,
|
2020-03-25 17:58:58 +11:00
|
|
|
const char **r_tooltip);
|
2019-04-17 06:17:24 +02:00
|
|
|
|
|
|
|
bool UI_context_copy_to_selected_list(struct bContext *C,
|
|
|
|
struct PointerRNA *ptr,
|
|
|
|
struct PropertyRNA *prop,
|
|
|
|
struct ListBase *r_lb,
|
|
|
|
bool *r_use_path_from_id,
|
|
|
|
char **r_path);
|
2015-05-11 15:32:43 +10:00
|
|
|
|
2009-07-28 18:51:06 +00:00
|
|
|
/* Helpers for Operators */
|
2014-11-09 21:20:40 +01:00
|
|
|
uiBut *UI_context_active_but_get(const struct bContext *C);
|
2020-05-12 20:30:15 +02:00
|
|
|
uiBut *UI_context_active_but_get_respect_menu(const struct bContext *C);
|
2019-04-17 06:17:24 +02:00
|
|
|
uiBut *UI_context_active_but_prop_get(const struct bContext *C,
|
|
|
|
struct PointerRNA *r_ptr,
|
|
|
|
struct PropertyRNA **r_prop,
|
|
|
|
int *r_index);
|
2014-11-09 21:20:40 +01:00
|
|
|
void UI_context_active_but_prop_handle(struct bContext *C);
|
2020-05-20 22:04:59 +10:00
|
|
|
void UI_context_active_but_clear(struct bContext *C, struct wmWindow *win, struct ARegion *region);
|
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
struct wmOperator *UI_context_active_operator_get(const struct bContext *C);
|
|
|
|
void UI_context_update_anim_flag(const struct bContext *C);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_context_active_but_prop_get_filebrowser(const struct bContext *C,
|
|
|
|
struct PointerRNA *r_ptr,
|
|
|
|
struct PropertyRNA **r_prop,
|
2020-06-11 17:24:00 +10:00
|
|
|
bool *r_is_undo,
|
|
|
|
bool *r_is_userdef);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_context_active_but_prop_get_templateID(struct bContext *C,
|
|
|
|
struct PointerRNA *r_ptr,
|
|
|
|
struct PropertyRNA **r_prop);
|
2018-08-23 19:58:54 +02:00
|
|
|
struct ID *UI_context_active_but_get_tab_ID(struct bContext *C);
|
2009-04-03 23:30:32 +00:00
|
|
|
|
2020-03-06 16:56:42 +01:00
|
|
|
uiBut *UI_region_active_but_get(struct ARegion *region);
|
|
|
|
uiBut *UI_region_but_find_rect_over(const struct ARegion *region, const struct rcti *isect);
|
2020-03-13 01:19:22 +11:00
|
|
|
uiBlock *UI_region_block_find_mouse_over(const struct ARegion *region,
|
|
|
|
const int xy[2],
|
|
|
|
bool only_clip);
|
2018-01-25 16:17:25 +11:00
|
|
|
|
2019-01-04 09:58:03 +11:00
|
|
|
/* uiFontStyle.align */
|
|
|
|
typedef enum eFontStyle_Align {
|
2019-04-17 06:17:24 +02:00
|
|
|
UI_STYLE_TEXT_LEFT = 0,
|
|
|
|
UI_STYLE_TEXT_CENTER = 1,
|
|
|
|
UI_STYLE_TEXT_RIGHT = 2,
|
2019-01-04 09:58:03 +11:00
|
|
|
} eFontStyle_Align;
|
|
|
|
|
|
|
|
struct uiFontStyleDraw_Params {
|
2019-04-17 06:17:24 +02:00
|
|
|
eFontStyle_Align align;
|
|
|
|
uint word_wrap : 1;
|
2019-01-04 09:58:03 +11:00
|
|
|
};
|
|
|
|
|
2009-04-09 18:11:18 +00:00
|
|
|
/* Styled text draw */
|
2015-01-20 14:25:39 +11:00
|
|
|
void UI_fontstyle_set(const struct uiFontStyle *fs);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_fontstyle_draw_ex(const struct uiFontStyle *fs,
|
|
|
|
const struct rcti *rect,
|
|
|
|
const char *str,
|
|
|
|
const uchar col[4],
|
|
|
|
const struct uiFontStyleDraw_Params *fs_params,
|
|
|
|
size_t len,
|
2020-04-14 18:41:23 +10:00
|
|
|
int *r_xofs,
|
2020-04-14 18:46:13 +10:00
|
|
|
int *r_yofs,
|
|
|
|
struct ResultBLF *r_info);
|
2019-04-17 06:17:24 +02:00
|
|
|
void UI_fontstyle_draw(const struct uiFontStyle *fs,
|
|
|
|
const struct rcti *rect,
|
|
|
|
const char *str,
|
|
|
|
const uchar col[4],
|
|
|
|
const struct uiFontStyleDraw_Params *fs_params);
|
|
|
|
void UI_fontstyle_draw_rotated(const struct uiFontStyle *fs,
|
|
|
|
const struct rcti *rect,
|
|
|
|
const char *str,
|
|
|
|
const uchar col[4]);
|
2018-07-09 06:40:47 +02:00
|
|
|
void UI_fontstyle_draw_simple(
|
2019-04-17 06:17:24 +02:00
|
|
|
const struct uiFontStyle *fs, float x, float y, const char *str, const uchar col[4]);
|
|
|
|
void UI_fontstyle_draw_simple_backdrop(const struct uiFontStyle *fs,
|
|
|
|
float x,
|
|
|
|
float y,
|
|
|
|
const char *str,
|
|
|
|
const float col_fg[4],
|
|
|
|
const float col_bg[4]);
|
2009-04-09 18:11:18 +00:00
|
|
|
|
2015-01-20 14:25:39 +11:00
|
|
|
int UI_fontstyle_string_width(const struct uiFontStyle *fs, const char *str);
|
2015-01-20 15:48:40 +11:00
|
|
|
int UI_fontstyle_height_max(const struct uiFontStyle *fs);
|
|
|
|
|
2017-02-14 13:00:22 +01:00
|
|
|
void UI_draw_icon_tri(float x, float y, char dir, const float[4]);
|
Holiday coding log :)
Nice formatted version (pictures soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.66/Usability
Short list of main changes:
- Transparent region option (over main region), added code to blend in/out such panels.
- Min size window now 640 x 480
- Fixed DPI for ui - lots of cleanup and changes everywhere. Icon image need correct size still, layer-in-use icon needs remake.
- Macbook retina support, use command line --no-native-pixels to disable it
- Timeline Marker label was drawing wrong
- Trackpad and magic mouse: supports zoom (hold ctrl)
- Fix for splash position: removed ghost function and made window size update after creation immediate
- Fast undo buffer save now adds UI as well. Could be checked for regular file save even...
Quit.blend and temp file saving use this now.
- Dixed filename in window on reading quit.blend or temp saves, and they now add a warning in window title: "(Recovered)"
- New Userpref option "Keep Session" - this always saves quit.blend, and loads on start.
This allows keeping UI and data without actual saves, until you actually save.
When you load startup.blend and quit, it recognises the quit.blend as a startup (no file name in header)
- Added 3D view copy/paste buffers (selected objects). Shortcuts ctrl-c, ctrl-v (OSX, cmd-c, cmd-v).
Coded partial file saving for it. Could be used for other purposes. Todo: use OS clipboards.
- User preferences (themes, keymaps, user settings) now can be saved as a separate file.
Old option is called "Save Startup File" the new one "Save User Settings".
To visualise this difference, the 'save startup file' button has been removed from user preferences window. That option is available as CTRL+U and in File menu still.
- OSX: fixed bug that stopped giving mouse events outside window.
This also fixes "Continuous Grab" for OSX. (error since 2009)
2012-12-12 18:58:11 +00:00
|
|
|
|
2020-03-15 17:32:25 +11:00
|
|
|
const struct uiStyle *UI_style_get(void); /* use for fonts etc */
|
|
|
|
const struct uiStyle *UI_style_get_dpi(void); /* DPI scaled settings for drawing */
|
Holiday coding log :)
Nice formatted version (pictures soon):
http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.66/Usability
Short list of main changes:
- Transparent region option (over main region), added code to blend in/out such panels.
- Min size window now 640 x 480
- Fixed DPI for ui - lots of cleanup and changes everywhere. Icon image need correct size still, layer-in-use icon needs remake.
- Macbook retina support, use command line --no-native-pixels to disable it
- Timeline Marker label was drawing wrong
- Trackpad and magic mouse: supports zoom (hold ctrl)
- Fix for splash position: removed ghost function and made window size update after creation immediate
- Fast undo buffer save now adds UI as well. Could be checked for regular file save even...
Quit.blend and temp file saving use this now.
- Dixed filename in window on reading quit.blend or temp saves, and they now add a warning in window title: "(Recovered)"
- New Userpref option "Keep Session" - this always saves quit.blend, and loads on start.
This allows keeping UI and data without actual saves, until you actually save.
When you load startup.blend and quit, it recognises the quit.blend as a startup (no file name in header)
- Added 3D view copy/paste buffers (selected objects). Shortcuts ctrl-c, ctrl-v (OSX, cmd-c, cmd-v).
Coded partial file saving for it. Could be used for other purposes. Todo: use OS clipboards.
- User preferences (themes, keymaps, user settings) now can be saved as a separate file.
Old option is called "Save Startup File" the new one "Save User Settings".
To visualise this difference, the 'save startup file' button has been removed from user preferences window. That option is available as CTRL+U and in File menu still.
- OSX: fixed bug that stopped giving mouse events outside window.
This also fixes "Continuous Grab" for OSX. (error since 2009)
2012-12-12 18:58:11 +00:00
|
|
|
|
2011-02-13 14:16:36 +00:00
|
|
|
/* linker workaround ack! */
|
|
|
|
void UI_template_fix_linking(void);
|
2009-04-09 18:11:18 +00:00
|
|
|
|
2011-10-23 04:13:56 +00:00
|
|
|
/* UI_OT_editsource helpers */
|
2013-04-04 02:05:11 +00:00
|
|
|
bool UI_editsource_enable_check(void);
|
2011-10-23 04:13:56 +00:00
|
|
|
void UI_editsource_active_but_test(uiBut *but);
|
|
|
|
|
2014-02-08 09:03:25 +11:00
|
|
|
/* UI_butstore_ helpers */
|
|
|
|
typedef struct uiButStore uiButStore;
|
|
|
|
typedef struct uiButStoreElem uiButStoreElem;
|
|
|
|
|
|
|
|
uiButStore *UI_butstore_create(uiBlock *block);
|
|
|
|
void UI_butstore_clear(uiBlock *block);
|
|
|
|
void UI_butstore_update(uiBlock *block);
|
|
|
|
void UI_butstore_free(uiBlock *block, uiButStore *bs);
|
|
|
|
bool UI_butstore_is_valid(uiButStore *bs);
|
|
|
|
bool UI_butstore_is_registered(uiBlock *block, uiBut *but);
|
|
|
|
void UI_butstore_register(uiButStore *bs_handle, uiBut **but_p);
|
2014-12-01 23:30:54 +01:00
|
|
|
bool UI_butstore_register_update(uiBlock *block, uiBut *but_dst, const uiBut *but_src);
|
2014-02-08 09:03:25 +11:00
|
|
|
void UI_butstore_unregister(uiButStore *bs_handle, uiBut **but_p);
|
|
|
|
|
2017-12-20 14:50:39 +11:00
|
|
|
/* ui_interface_region_tooltip.c */
|
2019-04-17 06:17:24 +02:00
|
|
|
struct ARegion *UI_tooltip_create_from_button(struct bContext *C,
|
|
|
|
struct ARegion *butregion,
|
|
|
|
uiBut *but,
|
|
|
|
bool is_label);
|
2018-07-15 14:24:10 +02:00
|
|
|
struct ARegion *UI_tooltip_create_from_gizmo(struct bContext *C, struct wmGizmo *gz);
|
2020-04-03 14:23:21 +02:00
|
|
|
void UI_tooltip_free(struct bContext *C, struct bScreen *screen, struct ARegion *region);
|
2017-12-20 14:50:39 +11:00
|
|
|
|
|
|
|
/* How long before a tool-tip shows. */
|
|
|
|
#define UI_TOOLTIP_DELAY 0.5
|
2018-09-06 14:19:15 +10:00
|
|
|
#define UI_TOOLTIP_DELAY_LABEL 0.2
|
2014-02-08 09:03:25 +11:00
|
|
|
|
2014-01-08 17:04:10 +01:00
|
|
|
/* Float precision helpers */
|
2017-07-21 10:10:36 +02:00
|
|
|
#define UI_PRECISION_FLOAT_MAX 6
|
2015-09-17 21:50:40 +10:00
|
|
|
/* For float buttons the 'step' (or a1), is scaled */
|
|
|
|
#define UI_PRECISION_FLOAT_SCALE 0.01f
|
2014-01-08 17:04:10 +01:00
|
|
|
|
2015-01-20 14:25:39 +11:00
|
|
|
/* Typical UI text */
|
|
|
|
#define UI_FSTYLE_WIDGET (const uiFontStyle *)&(UI_style_get()->widget)
|
|
|
|
|
2014-11-09 21:20:40 +01:00
|
|
|
int UI_calc_float_precision(int prec, double value);
|
2014-01-08 17:04:10 +01:00
|
|
|
|
2018-04-06 14:25:55 +02:00
|
|
|
/* widget batched drawing */
|
|
|
|
void UI_widgetbase_draw_cache_begin(void);
|
|
|
|
void UI_widgetbase_draw_cache_flush(void);
|
|
|
|
void UI_widgetbase_draw_cache_end(void);
|
|
|
|
|
2019-03-02 00:52:00 +11:00
|
|
|
/* Use for resetting the theme. */
|
|
|
|
void UI_theme_init_default(void);
|
|
|
|
void UI_style_init_default(void);
|
|
|
|
|
2019-10-01 01:59:31 +10:00
|
|
|
void UI_interface_tag_script_reload(void);
|
|
|
|
|
2018-04-25 21:01:36 +02:00
|
|
|
/* Special drawing for toolbar, mainly workarounds for inflexible icon sizing. */
|
2018-06-06 09:27:23 +02:00
|
|
|
#define USE_UI_TOOLBAR_HACK
|
2018-04-25 21:01:36 +02:00
|
|
|
|
2018-05-19 19:16:47 +02:00
|
|
|
/* Support click-drag motion which presses the button and closes a popover (like a menu). */
|
2018-06-06 09:27:23 +02:00
|
|
|
#define USE_UI_POPOVER_ONCE
|
2018-05-19 19:16:47 +02:00
|
|
|
|
2020-02-17 15:06:56 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2019-04-17 06:17:24 +02:00
|
|
|
#endif /* __UI_INTERFACE_H__ */
|