| 
									
										
										
										
											2011-02-23 10:52:22 +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
										 |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											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. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
											  
											
												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
										 |  |  |  * Contributor(s): Blender Foundation | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  | /** \file blender/editors/interface/interface_draw.c
 | 
					
						
							|  |  |  |  *  \ingroup edinterface | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | #include <math.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_color_types.h"
 | 
					
						
							|  |  |  | #include "DNA_screen_types.h"
 | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | #include "DNA_movieclip_types.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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2010-10-25 18:12:28 +00:00
										 |  |  | #include "BLI_rect.h"
 | 
					
						
							| 
									
										
										
										
											2011-09-26 16:53:04 +00:00
										 |  |  | #include "BLI_string.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-07 15:36:26 +11:00
										 |  |  | #include "BKE_colorband.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
										 |  |  | #include "BKE_colortools.h"
 | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | #include "BKE_node.h"
 | 
					
						
							| 
									
										
											  
											
												Planar tracking support for motion tracking
===========================================
Major list of changes done in tomato branch:
- Add a planar tracking implementation to libmv
  This adds a new planar tracking implementation to libmv. The
  tracker is based on Ceres[1], the new nonlinear minimizer that
  myself and Sameer released from Google as open source. Since
  the motion model is more involved, the interface is
  different than the RegionTracker interface used previously
  in Blender.
  The start of a C API in libmv-capi.{cpp,h} is also included.
- Migrate from pat_{min,max} for markers to 4 corners representation
  Convert markers in the movie clip editor / 2D tracker from using
  pat_min and pat_max notation to using the a more general, 4-corner
  representation.
  There is still considerable porting work to do; in particular
  sliding from preview widget does not work correct for rotated
  markers.
  All other areas should be ported to new representation:
  * Added support of sliding individual corners. LMB slide + Ctrl
    would scale the whole pattern
  * S would scale the whole marker, S-S would scale pattern only
  * Added support of marker's rotation which is currently rotates
    only patterns around their centers or all markers around median,
    Rotation or other non-translation/scaling transformation of search
    area doesn't make sense.
  * Track Preview widget would display transformed pattern which
    libmv actually operates with.
- "Efficient Second-order Minimization" for the planar tracker
  This implements the "Efficient Second-order Minimization"
  scheme, as supported by the existing translation tracker.
  This increases the amount of per-iteration work, but
  decreases the number of iterations required to converge and
  also increases the size of the basin of attraction for the
  optimization.
- Remove the use of the legacy RegionTracker API from Blender,
  and replaces it with the new TrackRegion API. This also
  adds several features to the planar tracker in libmv:
  * Do a brute-force initialization of tracking similar to "Hybrid"
    mode in the stable release, but using all floats. This is slower
    but more accurate. It is still necessary to evaluate if the
    performance loss is worth it. In particular, this change is
    necessary to support high bit depth imagery.
  * Add support for masks over the search window. This is a step
    towards supporting user-defined tracker masks. The tracker masks
    will make it easy for users to make a mask for e.g. a ball.
    Not exposed into interface yet/
  * Add Pearson product moment correlation coefficient checking (aka
    "Correlation" in the UI. This causes tracking failure if the
    tracked patch is not linearly related to the template.
  * Add support for warping a few points in addition to the supplied
    points. This is useful because the tracking code deliberately
    does not expose the underlying warp representation. Instead,
    warps are specified in an aparametric way via the correspondences.
- Replace the old style tracker configuration panel with the
  new planar tracking panel. From a users perspective, this means:
  * The old "tracking algorithm" picker is gone. There is only 1
    algorithm now. We may revisit this later, but I would much
    prefer to have only 1 algorithm. So far no optimization work
    has been done so the speed is not there yet.
  * There is now a dropdown to select the motion model. Choices:
        * Translation
        * Translation, rotation
        * Translation, scale
        * Translation, rotation, scale
        * Affine
        * Perspective
  * The old "Hybrid" mode is gone; instead there is a toggle to
    enable or disable translation-only tracker initialization. This
    is the equivalent of the hyrbid mode before, but rewritten to work
    with the new planar tracking modes.
  * The pyramid levels setting is gone. At a future date, the planar
    tracker will decide to use pyramids or not automatically. The
    pyramid setting was ultimately a mistake; with the brute force
    initialization it is unnecessary.
- Add light-normalized tracking
  Added the ability to normalize patterns by their average value while
  tracking, to make them invariant to global illumination changes.
Additional details could be found at wiki page [2]
  [1] http://code.google.com/p/ceres-solver
  [2] http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Motion_Tracker
											
										 
											2012-06-10 15:28:19 +00:00
										 |  |  | #include "BKE_tracking.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 19:18:31 +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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-23 13:58:55 +00:00
										 |  |  | #include "IMB_imbuf.h"
 | 
					
						
							|  |  |  | #include "IMB_imbuf_types.h"
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | #include "IMB_colormanagement.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-23 13:58:55 +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
										 |  |  | #include "BIF_glutil.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | #include "BLF_api.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | #include "GPU_batch.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-15 10:34:31 +02:00
										 |  |  | #include "GPU_batch_presets.h"
 | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | #include "GPU_immediate.h"
 | 
					
						
							| 
									
										
										
										
											2017-04-05 18:30:14 +10:00
										 |  |  | #include "GPU_immediate_util.h"
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | #include "GPU_matrix.h"
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | #include "GPU_state.h"
 | 
					
						
							| 
									
										
										
										
											2015-11-27 21:08:48 +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
										 |  |  | #include "UI_interface.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-15 12:18:50 +00:00
										 |  |  | /* own include */ | 
					
						
							| 
									
										
										
										
											2008-12-26 13:11:04 +00:00
										 |  |  | #include "interface_intern.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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | static int roundboxtype = UI_CNR_ALL; | 
					
						
							| 
									
										
											  
											
												
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_draw_roundbox_corner_set(int type) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							|  |  |  | 	/* Not sure the roundbox function is the best place to change this
 | 
					
						
							| 
									
										
										
										
											2015-02-26 14:11:39 -05:00
										 |  |  | 	 * if this is undone, it's not that big a deal, only makes curves edges | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	 * square for the  */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	roundboxtype = type; | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | #if 0 /* unused */
 | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | int UI_draw_roundbox_corner_get(void) | 
					
						
							| 
									
										
										
										
											2009-03-08 17:12:59 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												2.5
Summary of ain features:
- Themes and Styles are now editable.
- CTRL+U "Save user defaults" now goes to new .B25.blend, so you
  can use 2.4x and 2.5x next to each other. If B25 doesn't exist, it
  reads the regular .B.blend
- Press Tkey in 3d window for (unfinished) toolbar WIP. It now only
  shows the last operator, if appropriate.
  Nkey properties moved to the other side.
A lot of work was done on removing old themes for good and properly
getting it work with the 2.5 region system. Here's some notes;
- Buttons now all have a complete set of colors, based on button classifications
  (See outliner -> user prefs -> Interface
- Theme colors have been extended with basic colors for region types. 
  Currently colors are defined for Window, Header, List/Channels and
  for Button/Tool views. 
  The screen manager handles this btw, so a TH_BACK will always pick the
  right backdrop color.
- Menu backdrops are in in Button theme colors. Floating Panels will be in
  the per-space type Themes.
- Styles were added in RNA too, but only for the font settings now.
  Only Panel font, widget font and widget-label work now. The 'group label'
  will be for templates mostly.
  Style settings will be expanded with spacing defaults, label conventions, 
  etc.
- Label text colors are stored in per-space Theme too, to make sure they fit.
  Same goes for Panel title color.
Note that 'shadow' for fonts can conflict with text colors; shadow color is
currently stored in Style... shadow code needs a bit of work still.
											
										 
											2009-04-27 13:44:11 +00:00
										 |  |  | 	return roundboxtype; | 
					
						
							| 
									
										
										
										
											2009-03-08 17:12:59 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-03-08 17:12:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | void UI_draw_roundbox_3ubAlpha(bool filled, float minx, float miny, float maxx, float maxy, float rad, const unsigned char col[3], unsigned char alpha) | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | { | 
					
						
							|  |  |  | 	float colv[4]; | 
					
						
							|  |  |  | 	colv[0] = ((float)col[0]) / 255; | 
					
						
							|  |  |  | 	colv[1] = ((float)col[1]) / 255; | 
					
						
							|  |  |  | 	colv[2] = ((float)col[2]) / 255; | 
					
						
							|  |  |  | 	colv[3] = ((float)alpha) / 255; | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_4fv(filled, minx, miny, maxx, maxy, rad, colv); | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | void UI_draw_roundbox_3fvAlpha(bool filled, float minx, float miny, float maxx, float maxy, float rad, const float col[3], float alpha) | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | { | 
					
						
							|  |  |  | 	float colv[4]; | 
					
						
							|  |  |  | 	colv[0] = col[0]; | 
					
						
							|  |  |  | 	colv[1] = col[1]; | 
					
						
							|  |  |  | 	colv[2] = col[2]; | 
					
						
							|  |  |  | 	colv[3] = alpha; | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_4fv(filled, minx, miny, maxx, maxy, rad, colv); | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | void UI_draw_roundbox_aa(bool filled, float minx, float miny, float maxx, float maxy, float rad, const float color[4]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiWidgetBaseParameters widget_params = { | 
					
						
							|  |  |  | 		.recti.xmin = minx, .recti.ymin = miny, | 
					
						
							|  |  |  | 		.recti.xmax = maxx, .recti.ymax = maxy, | 
					
						
							|  |  |  | 		.radi = rad, | 
					
						
							|  |  |  | 		.round_corners[0] = (roundboxtype & UI_CNR_BOTTOM_LEFT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[1] = (roundboxtype & UI_CNR_BOTTOM_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[2] = (roundboxtype & UI_CNR_TOP_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[3] = (roundboxtype & UI_CNR_TOP_LEFT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.color_inner1[0] = color[0], .color_inner2[0] = color[0], | 
					
						
							|  |  |  | 		.color_inner1[1] = color[1], .color_inner2[1] = color[1], | 
					
						
							|  |  |  | 		.color_inner1[2] = color[2], .color_inner2[2] = color[2], | 
					
						
							|  |  |  | 		.color_inner1[3] = color[3], .color_inner2[3] = color[3], | 
					
						
							| 
									
										
										
										
											2018-05-03 09:56:20 +02:00
										 |  |  | 		.alpha_discard = 1.0f, | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (filled) { | 
					
						
							|  |  |  | 		/* plain antialiased filled box */ | 
					
						
							|  |  |  | 		widget_params.color_inner1[3] *= 0.125f; | 
					
						
							|  |  |  | 		widget_params.color_inner2[3] *= 0.125f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* WATCH: This is assuming the ModelViewProjectionMatrix is area pixel space.
 | 
					
						
							|  |  |  | 		 * If it has been scaled, then it's no longer valid. */ | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		GPUBatch *batch = ui_batch_roundbox_get(filled, true); | 
					
						
							|  |  |  | 		GPU_batch_program_set_builtin(batch, GPU_SHADER_2D_WIDGET_BASE); | 
					
						
							|  |  |  | 		GPU_batch_uniform_4fv_array(batch, "parameters", 11, (float *)&widget_params); | 
					
						
							|  |  |  | 		GPU_batch_draw(batch); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* plain antialiased unfilled box */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_line_smooth(true); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		GPUBatch *batch = ui_batch_roundbox_get(filled, false); | 
					
						
							|  |  |  | 		GPU_batch_program_set_builtin(batch, GPU_SHADER_2D_WIDGET_BASE); | 
					
						
							|  |  |  | 		GPU_batch_uniform_4fv_array(batch, "parameters", 11, (float *)&widget_params); | 
					
						
							|  |  |  | 		GPU_batch_draw(batch); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_line_smooth(false); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | void UI_draw_roundbox_4fv(bool filled, float minx, float miny, float maxx, float maxy, float rad, const float col[4]) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2018-07-01 19:57:31 +02:00
										 |  |  | 	float vec[7][2] = { | 
					
						
							|  |  |  | 		{0.195, 0.02}, {0.383, 0.067}, {0.55, 0.169}, {0.707, 0.293}, | 
					
						
							|  |  |  | 		{0.831, 0.45}, {0.924, 0.617}, {0.98, 0.805}, | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	int a; | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04: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
										 |  |  | 	/* mult */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2012-09-16 23:40:03 +00:00
										 |  |  | 		mul_v2_fl(vec[a], rad); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 13:19:10 +02:00
										 |  |  | 	uint vert_len = 0; | 
					
						
							|  |  |  | 	vert_len += (roundboxtype & UI_CNR_BOTTOM_RIGHT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_len += (roundboxtype & UI_CNR_TOP_RIGHT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_len += (roundboxtype & UI_CNR_TOP_LEFT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_len += (roundboxtype & UI_CNR_BOTTOM_LEFT) ? 9 : 1; | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 	immUniformColor4fv(col); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(filled ? GPU_PRIM_TRI_FAN : GPU_PRIM_LINE_LOOP, vert_len); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	/* start with corner right-bottom */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_RIGHT) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, maxx - rad, miny); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 			immVertex2f(pos, maxx - rad + vec[a][0], miny + vec[a][1]); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, maxx, miny + rad); | 
					
						
							| 
									
										
											  
											
												
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-03-09 03:46:30 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, maxx, miny); | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02: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
										 |  |  | 	/* corner right-top */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_TOP_RIGHT) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, maxx, maxy - rad); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 			immVertex2f(pos, maxx - vec[a][1], maxy - rad + vec[a][0]); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, maxx - rad, maxy); | 
					
						
							| 
									
										
											  
											
												
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-03-09 03:46:30 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, maxx, maxy); | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02: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
										 |  |  | 	/* corner left-top */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_TOP_LEFT) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, minx + rad, maxy); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 			immVertex2f(pos, minx + rad - vec[a][0], maxy - vec[a][1]); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, minx, maxy - rad); | 
					
						
							| 
									
										
											  
											
												
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-03-09 03:46:30 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, minx, maxy); | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02: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
										 |  |  | 	/* corner left-bottom */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_LEFT) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, minx, miny + rad); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 			immVertex2f(pos, minx + vec[a][1], miny + rad - vec[a][0]); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, minx + rad, miny); | 
					
						
							| 
									
										
											  
											
												
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-03-09 03:46:30 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		immVertex2f(pos, minx, miny); | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 	immEnd(); | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uiWidgetBaseParameters widget_params = { | 
					
						
							|  |  |  | 		.recti.xmin = minx, .recti.ymin = miny, | 
					
						
							|  |  |  | 		.recti.xmax = maxx, .recti.ymax = maxy, | 
					
						
							|  |  |  | 		.radi = rad, | 
					
						
							|  |  |  | 		.round_corners[0] = (roundboxtype & UI_CNR_BOTTOM_LEFT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[1] = (roundboxtype & UI_CNR_BOTTOM_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[2] = (roundboxtype & UI_CNR_TOP_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[3] = (roundboxtype & UI_CNR_TOP_LEFT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.color_inner1[0] = col[0], .color_inner2[0] = col[0], | 
					
						
							|  |  |  | 		.color_inner1[1] = col[1], .color_inner2[1] = col[1], | 
					
						
							|  |  |  | 		.color_inner1[2] = col[2], .color_inner2[2] = col[2], | 
					
						
							|  |  |  | 		.color_inner1[3] = col[3], .color_inner2[3] = col[3], | 
					
						
							| 
									
										
										
										
											2018-05-03 09:56:20 +02:00
										 |  |  | 		.alpha_discard = 1.0f, | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUBatch *batch = ui_batch_roundbox_get(filled, false); | 
					
						
							|  |  |  | 	GPU_batch_program_set_builtin(batch, GPU_SHADER_2D_WIDGET_BASE); | 
					
						
							|  |  |  | 	GPU_batch_uniform_4fv_array(batch, "parameters", 11, (float *)&widget_params); | 
					
						
							|  |  |  | 	GPU_batch_draw(batch); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | static void round_box_shade_col(unsigned attrib, const float col1[3], float const col2[3], const float fac) | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 	float col[4] = { | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		fac * col1[0] + (1.0f - fac) * col2[0], | 
					
						
							|  |  |  | 		fac * col1[1] + (1.0f - fac) * col2[1], | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		fac * col1[2] + (1.0f - fac) * col2[2], | 
					
						
							|  |  |  | 		1.0f | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 	immAttrib4fv(attrib, col); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* linear horizontal shade within button or in outline */ | 
					
						
							| 
									
										
										
										
											2009-04-06 15:44:30 +00:00
										 |  |  | /* view2d scrollers use it */ | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | void UI_draw_roundbox_shade_x( | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  |         bool filled, float minx, float miny, float maxx, float maxy, | 
					
						
							| 
									
										
										
										
											2017-02-06 15:19:45 +01:00
										 |  |  |         float rad, float shadetop, float shadedown, const float col[4]) | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2018-07-01 19:57:31 +02:00
										 |  |  | 	float vec[7][2] = { | 
					
						
							|  |  |  | 		{0.195, 0.02}, {0.383, 0.067}, {0.55, 0.169}, {0.707, 0.293}, | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 		{0.831, 0.45}, {0.924, 0.617}, {0.98, 0.805}, | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	const float div = maxy - miny; | 
					
						
							|  |  |  | 	const float idiv = 1.0f / div; | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 	float coltop[3], coldown[3]; | 
					
						
							|  |  |  | 	int vert_count = 0; | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	int a; | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 	uint color = GPU_vertformat_attr_add(format, "color", GPU_COMP_F32, 4, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_SMOOTH_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	/* mult */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2012-09-16 23:40:03 +00:00
										 |  |  | 		mul_v2_fl(vec[a], rad); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 	/* 'shade' defines strength of shading */ | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 	coltop[0]  = min_ff(1.0f, col[0] + shadetop); | 
					
						
							|  |  |  | 	coltop[1]  = min_ff(1.0f, col[1] + shadetop); | 
					
						
							|  |  |  | 	coltop[2]  = min_ff(1.0f, col[2] + shadetop); | 
					
						
							|  |  |  | 	coldown[0] = max_ff(0.0f, col[0] + shadedown); | 
					
						
							|  |  |  | 	coldown[1] = max_ff(0.0f, col[1] + shadedown); | 
					
						
							|  |  |  | 	coldown[2] = max_ff(0.0f, col[2] + shadedown); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_BOTTOM_RIGHT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_TOP_RIGHT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_TOP_LEFT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_BOTTOM_LEFT) ? 9 : 1; | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(filled ? GPU_PRIM_TRI_FAN : GPU_PRIM_LINE_LOOP, vert_count); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* start with corner right-bottom */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_RIGHT) { | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx - rad, miny); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, coltop, coldown, vec[a][1] * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, maxx - rad + vec[a][0], miny + vec[a][1]); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, rad * idiv); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, miny + rad); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, miny); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	/* corner right-top */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_TOP_RIGHT) { | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, (div - rad) * idiv); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, maxy - rad); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, coltop, coldown, (div - rad + vec[a][1]) * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, maxx - vec[a][1], maxy - rad + vec[a][0]); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx - rad, maxy); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, maxy); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	/* corner left-top */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_TOP_LEFT) { | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx + rad, maxy); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, coltop, coldown, (div - vec[a][1]) * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, minx + rad - vec[a][0], maxy - vec[a][1]); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, (div - rad) * idiv); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, maxy - rad); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, maxy); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	/* corner left-bottom */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_LEFT) { | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, rad * idiv); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, miny + rad); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, coltop, coldown, (rad - vec[a][1]) * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, minx + vec[a][1], miny + rad - vec[a][0]); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx + rad, miny); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, coltop, coldown, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, miny); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uiWidgetBaseParameters widget_params = { | 
					
						
							|  |  |  | 		.recti.xmin = minx, .recti.ymin = miny, | 
					
						
							|  |  |  | 		.recti.xmax = maxx, .recti.ymax = maxy, | 
					
						
							|  |  |  | 		.radi = rad, | 
					
						
							|  |  |  | 		.round_corners[0] = (roundboxtype & UI_CNR_BOTTOM_LEFT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[1] = (roundboxtype & UI_CNR_BOTTOM_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[2] = (roundboxtype & UI_CNR_TOP_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[3] = (roundboxtype & UI_CNR_TOP_LEFT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.color_inner1[0] = min_ff(1.0f, col[0] + shadetop), | 
					
						
							|  |  |  | 		.color_inner2[0] = max_ff(0.0f, col[0] + shadedown), | 
					
						
							|  |  |  | 		.color_inner1[1] = min_ff(1.0f, col[1] + shadetop), | 
					
						
							|  |  |  | 		.color_inner2[1] = max_ff(0.0f, col[1] + shadedown), | 
					
						
							|  |  |  | 		.color_inner1[2] = min_ff(1.0f, col[2] + shadetop), | 
					
						
							|  |  |  | 		.color_inner2[2] = max_ff(0.0f, col[2] + shadedown), | 
					
						
							|  |  |  | 		.color_inner1[3] = 1.0f, | 
					
						
							|  |  |  | 		.color_inner2[3] = 1.0f, | 
					
						
							| 
									
										
										
										
											2018-05-03 09:56:20 +02:00
										 |  |  | 		.alpha_discard = 1.0f, | 
					
						
							| 
									
										
										
										
											2018-04-05 18:51:08 +02:00
										 |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUBatch *batch = ui_batch_roundbox_get(filled, false); | 
					
						
							|  |  |  | 	GPU_batch_program_set_builtin(batch, GPU_SHADER_2D_WIDGET_BASE); | 
					
						
							|  |  |  | 	GPU_batch_uniform_4fv_array(batch, "parameters", 11, (float *)&widget_params); | 
					
						
							|  |  |  | 	GPU_batch_draw(batch); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | #if 0 /* unused */
 | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | /* linear vertical shade within button or in outline */ | 
					
						
							| 
									
										
										
										
											2009-04-06 15:44:30 +00:00
										 |  |  | /* view2d scrollers use it */ | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | void UI_draw_roundbox_shade_y( | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  |         bool filled, float minx, float miny, float maxx, float maxy, | 
					
						
							| 
									
										
										
										
											2017-02-06 15:19:45 +01:00
										 |  |  |         float rad, float shadeleft, float shaderight, const float col[4]) | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-01 19:57:31 +02:00
										 |  |  | 	float vec[7][2] = { | 
					
						
							|  |  |  | 		{0.195, 0.02}, {0.383, 0.067}, {0.55, 0.169}, {0.707, 0.293}, | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 		{0.831, 0.45}, {0.924, 0.617}, {0.98, 0.805}, | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	const float div = maxx - minx; | 
					
						
							|  |  |  | 	const float idiv = 1.0f / div; | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 	float colLeft[3], colRight[3]; | 
					
						
							|  |  |  | 	int vert_count = 0; | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	int a; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	/* mult */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2012-09-16 23:40:03 +00:00
										 |  |  | 		mul_v2_fl(vec[a], rad); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 	uint color = GPU_vertformat_attr_add(format, "color", GPU_COMP_F32, 4, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_SMOOTH_COLOR); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 	/* 'shade' defines strength of shading */ | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 	colLeft[0]  = min_ff(1.0f, col[0] + shadeleft); | 
					
						
							|  |  |  | 	colLeft[1]  = min_ff(1.0f, col[1] + shadeleft); | 
					
						
							|  |  |  | 	colLeft[2]  = min_ff(1.0f, col[2] + shadeleft); | 
					
						
							|  |  |  | 	colRight[0] = max_ff(0.0f, col[0] + shaderight); | 
					
						
							|  |  |  | 	colRight[1] = max_ff(0.0f, col[1] + shaderight); | 
					
						
							|  |  |  | 	colRight[2] = max_ff(0.0f, col[2] + shaderight); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_BOTTOM_RIGHT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_TOP_RIGHT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_TOP_LEFT) ? 9 : 1; | 
					
						
							|  |  |  | 	vert_count += (roundboxtype & UI_CNR_BOTTOM_LEFT) ? 9 : 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(filled ? GPU_PRIM_TRI_FAN : GPU_PRIM_LINE_LOOP, vert_count); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* start with corner right-bottom */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_RIGHT) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx - rad, miny); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, colLeft, colRight, vec[a][0] * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, maxx - rad + vec[a][0], miny + vec[a][1]); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, rad * idiv); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, miny + rad); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, miny); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	/* corner right-top */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_TOP_RIGHT) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, maxy - rad); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, colLeft, colRight, (div - rad - vec[a][0]) * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, maxx - vec[a][1], maxy - rad + vec[a][0]); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, (div - rad) * idiv); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx - rad, maxy); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 0.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, maxy); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	/* corner left-top */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_TOP_LEFT) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, (div - rad) * idiv); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx + rad, maxy); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, colLeft, colRight, (div - rad + vec[a][0]) * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, minx + rad - vec[a][0], maxy - vec[a][1]); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, maxy - rad); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, maxy); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	/* corner left-bottom */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_LEFT) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, miny + rad); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < 7; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 			round_box_shade_col(color, colLeft, colRight, (vec[a][0]) * idiv); | 
					
						
							|  |  |  | 			immVertex2f(pos, minx + vec[a][1], miny + rad - vec[a][0]); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx + rad, miny); | 
					
						
							| 
									
										
										
										
											2008-12-14 08:32:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 		round_box_shade_col(color, colLeft, colRight, 1.0); | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, miny); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-06 14:06:13 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | #endif /* unused */
 | 
					
						
							| 
									
										
										
										
											2008-11-19 03:15:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											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]) | 
					
						
							| 
									
										
										
										
											2014-12-07 00:58:17 +01:00
										 |  |  | { | 
					
						
							|  |  |  | 	int ofs_y = 4 * U.pixelsize; | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_I32, 2, GPU_FETCH_INT_TO_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 	immUniformColor4fv(color); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immRecti(pos, pos_x, pos_y - ofs_y, pos_x + len, pos_y - ofs_y + (height * U.pixelsize)); | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2014-12-07 00:58:17 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-23 13:58:55 +00:00
										 |  |  | /* ************** SPECIAL BUTTON DRAWING FUNCTIONS ************* */ | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-17 17:08:20 +01:00
										 |  |  | /* based on UI_draw_roundbox_gl_mode, check on making a version which allows us to skip some sides */ | 
					
						
							|  |  |  | void ui_draw_but_TAB_outline(const rcti *rect, float rad, unsigned char highlight[3], unsigned char highlight_fade[3]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 	uint col = GPU_vertformat_attr_add(format, "color", GPU_COMP_U8, 3, GPU_FETCH_INT_TO_FLOAT_UNIT); | 
					
						
							| 
									
										
										
										
											2017-03-17 17:08:20 +01:00
										 |  |  | 	/* add a 1px offset, looks nicer */ | 
					
						
							|  |  |  | 	const int minx = rect->xmin + U.pixelsize, maxx = rect->xmax - U.pixelsize; | 
					
						
							|  |  |  | 	const int miny = rect->ymin + U.pixelsize, maxy = rect->ymax - U.pixelsize; | 
					
						
							|  |  |  | 	int a; | 
					
						
							|  |  |  | 	float vec[4][2] = { | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 		{0.195, 0.02}, | 
					
						
							|  |  |  | 		{0.55, 0.169}, | 
					
						
							|  |  |  | 		{0.831, 0.45}, | 
					
						
							|  |  |  | 		{0.98, 0.805}, | 
					
						
							| 
									
										
										
										
											2017-03-17 17:08:20 +01:00
										 |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* mult */ | 
					
						
							|  |  |  | 	for (a = 0; a < 4; a++) { | 
					
						
							|  |  |  | 		mul_v2_fl(vec[a], rad); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_SMOOTH_COLOR); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBeginAtMost(GPU_PRIM_LINE_STRIP, 25); | 
					
						
							| 
									
										
										
										
											2017-03-17 17:08:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immAttrib3ubv(col, highlight); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* start with corner left-top */ | 
					
						
							|  |  |  | 	if (roundboxtype & UI_CNR_TOP_LEFT) { | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, maxy - rad); | 
					
						
							|  |  |  | 		for (a = 0; a < 4; a++) { | 
					
						
							|  |  |  | 			immVertex2f(pos, minx + vec[a][1], maxy - rad + vec[a][0]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		immVertex2f(pos, minx + rad, maxy); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, maxy); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* corner right-top */ | 
					
						
							|  |  |  | 	if (roundboxtype & UI_CNR_TOP_RIGHT) { | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx - rad, maxy); | 
					
						
							|  |  |  | 		for (a = 0; a < 4; a++) { | 
					
						
							|  |  |  | 			immVertex2f(pos, maxx - rad + vec[a][0], maxy - vec[a][1]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, maxy - rad); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, maxy); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immAttrib3ubv(col, highlight_fade); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* corner right-bottom */ | 
					
						
							|  |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_RIGHT) { | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, miny + rad); | 
					
						
							|  |  |  | 		for (a = 0; a < 4; a++) { | 
					
						
							|  |  |  | 			immVertex2f(pos, maxx - vec[a][1], miny + rad - vec[a][0]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx - rad, miny); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		immVertex2f(pos, maxx, miny); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* corner left-bottom */ | 
					
						
							|  |  |  | 	if (roundboxtype & UI_CNR_BOTTOM_LEFT) { | 
					
						
							|  |  |  | 		immVertex2f(pos, minx + rad, miny); | 
					
						
							|  |  |  | 		for (a = 0; a < 4; a++) { | 
					
						
							|  |  |  | 			immVertex2f(pos, minx + rad - vec[a][0], miny + vec[a][1]); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, miny + rad); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		immVertex2f(pos, minx, miny); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immAttrib3ubv(col, highlight); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* back to corner left-top */ | 
					
						
							|  |  |  | 	immVertex2f(pos, minx, roundboxtype & UI_CNR_TOP_LEFT ? maxy - rad : maxy); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-07 15:47:57 +11:00
										 |  |  | void ui_draw_but_IMAGE(ARegion *UNUSED(ar), uiBut *but, uiWidgetColors *UNUSED(wcol), const rcti *rect) | 
					
						
							| 
									
										
										
										
											2009-11-23 13:58:55 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-06-05 07:55:18 +00:00
										 |  |  | #ifdef WITH_HEADLESS
 | 
					
						
							|  |  |  | 	(void)rect; | 
					
						
							| 
									
										
										
										
											2011-09-30 07:47:45 +00:00
										 |  |  | 	(void)but; | 
					
						
							| 
									
										
										
										
											2011-06-05 07:55:18 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	ImBuf *ibuf = (ImBuf *)but->poin; | 
					
						
							| 
									
										
										
										
											2009-11-23 13:58:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!ibuf) return; | 
					
						
							| 
									
										
										
										
											2017-02-24 01:21:02 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	float facx = 1.0f; | 
					
						
							|  |  |  | 	float facy = 1.0f; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:50:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	int w = BLI_rcti_size_x(rect); | 
					
						
							|  |  |  | 	int h = BLI_rcti_size_y(rect); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | 	/* scissor doesn't seem to be doing the right thing...? */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2012-07-07 22:51:57 +00:00
										 |  |  | 	/* prevent drawing outside widget area */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	int scissor[4]; | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 	GPU_scissor_get_i(scissor); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_scissor(rect->xmin, rect->ymin, w, h); | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	if (w != ibuf->x || h != ibuf->y) { | 
					
						
							| 
									
										
										
										
											2017-02-24 01:21:02 +01:00
										 |  |  | 		facx = (float)w / (float)ibuf->x; | 
					
						
							|  |  |  | 		facy = (float)h / (float)ibuf->y; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-24 01:21:02 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-11 16:30:00 +02:00
										 |  |  | 	IMMDrawPixelsTexState state = immDrawPixelsTexSetup(GPU_SHADER_2D_IMAGE_COLOR); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	immDrawPixelsTex( | 
					
						
							|  |  |  | 	        &state, (float)rect->xmin, (float)rect->ymin, ibuf->x, ibuf->y, GL_RGBA, GL_UNSIGNED_BYTE, GL_NEAREST, ibuf->rect, | 
					
						
							|  |  |  | 	        facx, facy, NULL); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2009-11-23 13:58:55 +00:00
										 |  |  | 	// restore scissortest
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_scissor(scissor[0], scissor[1], scissor[2], scissor[3]); | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-05 07:55:18 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2009-11-23 13:58:55 +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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Draw title and text safe areas. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-04-26 12:17:46 +02:00
										 |  |  |  * \Note This functionn is to be used with the 2D dashed shader enabled. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  |  * \param pos is a PRIM_FLOAT, 2, GPU_FETCH_FLOAT vertex attrib | 
					
						
							|  |  |  |  * \param line_origin is a PRIM_FLOAT, 2, GPU_FETCH_FLOAT vertex attrib | 
					
						
							| 
									
										
										
										
											2017-04-26 12:17:46 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2016-10-13 23:28:11 +00:00
										 |  |  |  * The next 4 parameters are the offsets for the view, not the zones. | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  |  */ | 
					
						
							|  |  |  | void UI_draw_safe_areas( | 
					
						
							| 
									
										
										
											
												Reworked version of dashed line shader.
Using geometry shader allows us to get rid of the 'line origin' extra
vertex attribute, which means dashed shader no longer requires fiddling
with those vertex attributes definition, and, most importantly, does not
require anymore special drawing code!
As you can see, this makes code much simpler, and much less verbose,
especially in complex cases.
In addition, changed how dashes are handled, to have two 'modes', a
simple one with single color (using default "color" uniform name), and a
more advanced one allowing more complex and multi-color patterns.
Note that since GLSL 1.2 does not support geometry shaders, a hack was
added for now (which gives solid lines, but at least does not make
Blender crash).
											
										 
											2017-05-01 16:21:53 +02:00
										 |  |  |         uint pos, float x1, float x2, float y1, float y2, | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  |         const float title_aspect[2], const float action_aspect[2]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	const float size_x_half = (x2 - x1) * 0.5f; | 
					
						
							|  |  |  | 	const float size_y_half = (y2 - y1) * 0.5f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const float *safe_areas[] = {title_aspect, action_aspect}; | 
					
						
							| 
									
										
										
										
											2016-12-14 02:43:26 -05:00
										 |  |  | 	const int safe_len = ARRAY_SIZE(safe_areas); | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int i = 0; i < safe_len; i++) { | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  | 		if (safe_areas[i][0] || safe_areas[i][1]) { | 
					
						
							| 
									
										
										
										
											2016-12-14 02:43:26 -05:00
										 |  |  | 			float margin_x = safe_areas[i][0] * size_x_half; | 
					
						
							|  |  |  | 			float margin_y = safe_areas[i][1] * size_y_half; | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-14 02:43:26 -05:00
										 |  |  | 			float minx = x1 + margin_x; | 
					
						
							|  |  |  | 			float miny = y1 + margin_y; | 
					
						
							|  |  |  | 			float maxx = x2 - margin_x; | 
					
						
							|  |  |  | 			float maxy = y2 - margin_y; | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-26 15:21:01 +10:00
										 |  |  | 			imm_draw_box_wire_2d(pos, minx, miny, maxx, maxy); | 
					
						
							| 
									
										
										
										
											2015-01-19 16:30:35 +11:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-15 11:48:20 +00:00
										 |  |  | static void draw_scope_end(const rctf *rect, GLint *scissor) | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* restore scissortest */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_scissor(scissor[0], scissor[1], scissor[2], scissor[3]); | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | 	/* outline */ | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 	UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 	float color[4] = {0.0f, 0.0f, 0.0f, 0.5f}; | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_4fv(false, rect->xmin - 1, rect->ymin, rect->xmax + 1, rect->ymax + 1, 3.0f, color); | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-05 03:13:47 +10:00
										 |  |  | static void histogram_draw_one( | 
					
						
							|  |  |  |         float r, float g, float b, float alpha, | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  |         float x, float y, float w, float h, const float *data, int res, const bool is_line, | 
					
						
							|  |  |  |         unsigned int pos_attrib) | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 	float color[4] = {r, g, b, alpha}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 	/* that can happen */ | 
					
						
							|  |  |  | 	if (res == 0) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(true); | 
					
						
							| 
									
										
										
										
											2018-02-14 01:01:29 +01:00
										 |  |  | 	glBlendFuncSeparate(GL_SRC_ALPHA, GL_ONE, GL_ONE, GL_ONE); | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immUniformColor4fv(color); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-22 02:44:33 -05:00
										 |  |  | 	if (is_line) { | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 		/* curve outline */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_line_width(1.5); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINE_STRIP, res); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		for (int i = 0; i < res; i++) { | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 			float x2 = x + i * (w / (float)res); | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 			immVertex2f(pos_attrib, x2, y + (data[i] * h)); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		/* under the curve */ | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_TRI_STRIP, res * 2); | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 		immVertex2f(pos_attrib, x, y); | 
					
						
							|  |  |  | 		immVertex2f(pos_attrib, x, y + (data[0] * h)); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		for (int i = 1; i < res; i++) { | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 			float x2 = x + i * (w / (float)res); | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 			immVertex2f(pos_attrib, x2, y + (data[i] * h)); | 
					
						
							|  |  |  | 			immVertex2f(pos_attrib, x2, y); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* curve outline */ | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 		immUniformColor4f(0.0f, 0.0f, 0.0f, 0.25f); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINE_STRIP, res); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		for (int i = 0; i < res; i++) { | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 			float x2 = x + i * (w / (float)res); | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 			immVertex2f(pos_attrib, x2, y + (data[i] * h)); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:09:25 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-01-22 02:44:33 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(false); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-26 09:06:23 +00:00
										 |  |  | #define HISTOGRAM_TOT_GRID_LINES 4
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | void ui_draw_but_HISTOGRAM(ARegion *UNUSED(ar), uiBut *but, uiWidgetColors *UNUSED(wcol), const rcti *recti) | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Histogram *hist = (Histogram *)but->poin; | 
					
						
							|  |  |  | 	int res = hist->x_resolution; | 
					
						
							| 
									
										
										
										
											2014-01-28 03:52:21 +11:00
										 |  |  | 	const bool is_line = (hist->flag & HISTO_FLAG_LINE) != 0; | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	rctf rect = { | 
					
						
							|  |  |  | 		.xmin = (float)recti->xmin + 1, | 
					
						
							|  |  |  | 		.xmax = (float)recti->xmax - 1, | 
					
						
							|  |  |  | 		.ymin = (float)recti->ymin + 1, | 
					
						
							|  |  |  | 		.ymax = (float)recti->ymax - 1 | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float w = BLI_rctf_size_x(&rect); | 
					
						
							|  |  |  | 	float h = BLI_rctf_size_y(&rect) * hist->ymax; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							|  |  |  | 	GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2015-09-20 20:17:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 	float color[4]; | 
					
						
							|  |  |  | 	UI_GetThemeColor4fv(TH_PREVIEW_BACK, color); | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 	UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_4fv(true, rect.xmin - 1, rect.ymin - 1, rect.xmax + 1, rect.ymax + 1, 3.0f, color); | 
					
						
							| 
									
										
										
										
											2011-09-02 19:25:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* need scissor test, histogram can draw outside of boundary */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	int scissor[4]; | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 	GPU_scissor_get_i(scissor); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	GPU_scissor( | 
					
						
							|  |  |  | 	        (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymin - 1), | 
					
						
							|  |  |  | 	        (rect.xmax + 1) - (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymax + 1) - (rect.ymin - 1)); | 
					
						
							| 
									
										
										
										
											2011-09-02 19:25:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniformColor4f(1.0f, 1.0f, 1.0f, 0.08f); | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | 	/* draw grid lines here */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int i = 1; i <= HISTOGRAM_TOT_GRID_LINES; i++) { | 
					
						
							| 
									
										
										
										
											2012-07-26 09:06:23 +00:00
										 |  |  | 		const float fac = (float)i / (float)HISTOGRAM_TOT_GRID_LINES; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* so we can tell the 1.0 color point */ | 
					
						
							|  |  |  | 		if (i == HISTOGRAM_TOT_GRID_LINES) { | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 			immUniformColor4f(1.0f, 1.0f, 1.0f, 0.5f); | 
					
						
							| 
									
										
										
										
											2012-07-26 09:06:23 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 4); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin, rect.ymin + fac * h); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmax, rect.ymin + fac * h); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin + fac * w, rect.ymin); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin + fac * w, rect.ymax); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-10 12:33:27 +00:00
										 |  |  | 	if (hist->mode == HISTO_MODE_LUMA) { | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 		histogram_draw_one(1.0, 1.0, 1.0, 0.75, rect.xmin, rect.ymin, w, h, hist->data_luma, res, is_line, pos); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:33:27 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if (hist->mode == HISTO_MODE_ALPHA) { | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 		histogram_draw_one(1.0, 1.0, 1.0, 0.75, rect.xmin, rect.ymin, w, h, hist->data_a, res, is_line, pos); | 
					
						
							| 
									
										
										
										
											2012-06-10 12:33:27 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		if (hist->mode == HISTO_MODE_RGB || hist->mode == HISTO_MODE_R) | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 			histogram_draw_one(1.0, 0.0, 0.0, 0.75, rect.xmin, rect.ymin, w, h, hist->data_r, res, is_line, pos); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 		if (hist->mode == HISTO_MODE_RGB || hist->mode == HISTO_MODE_G) | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 			histogram_draw_one(0.0, 1.0, 0.0, 0.75, rect.xmin, rect.ymin, w, h, hist->data_g, res, is_line, pos); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 		if (hist->mode == HISTO_MODE_RGB || hist->mode == HISTO_MODE_B) | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 			histogram_draw_one(0.0, 0.0, 1.0, 0.75, rect.xmin, rect.ymin, w, h, hist->data_b, res, is_line, pos); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-06 16:54:26 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:50:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 	/* outline */ | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | 	draw_scope_end(&rect, scissor); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-07-26 09:06:23 +00:00
										 |  |  | #undef HISTOGRAM_TOT_GRID_LINES
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | static void waveform_draw_one(float *waveform, int nbr, const float col[3]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat format = {0}; | 
					
						
							|  |  |  | 	uint pos_id = GPU_vertformat_attr_add(&format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertBuf *vbo = GPU_vertbuf_create_with_format(&format); | 
					
						
							|  |  |  | 	GPU_vertbuf_data_alloc(vbo, nbr); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPU_vertbuf_attr_fill(vbo, pos_id, waveform); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	/* TODO store the GPUBatch inside the scope */ | 
					
						
							|  |  |  | 	GPUBatch *batch = GPU_batch_create_ex(GPU_PRIM_POINTS, vbo, NULL, GPU_BATCH_OWNS_VBO); | 
					
						
							|  |  |  | 	GPU_batch_program_set_builtin(batch, GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 	GPU_batch_uniform_4f(batch, "color", col[0], col[1], col[2], 1.0f); | 
					
						
							|  |  |  | 	GPU_batch_draw(batch); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPU_batch_discard(batch); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | void ui_draw_but_WAVEFORM(ARegion *UNUSED(ar), uiBut *but, uiWidgetColors *UNUSED(wcol), const rcti *recti) | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Scopes *scopes = (Scopes *)but->poin; | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	int scissor[4]; | 
					
						
							| 
									
										
										
										
											2014-06-26 16:09:59 +10:00
										 |  |  | 	float colors[3][3]; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	float colorsycc[3][3] = {{1, 0, 1}, {1, 1, 0}, {0, 1, 1}}; | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	float colors_alpha[3][3], colorsycc_alpha[3][3]; /* colors  pre multiplied by alpha for speed up */ | 
					
						
							|  |  |  | 	float min, max; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (scopes == NULL) return; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	rctf rect = { | 
					
						
							|  |  |  | 		.xmin = (float)recti->xmin + 1, | 
					
						
							|  |  |  | 		.xmax = (float)recti->xmax - 1, | 
					
						
							|  |  |  | 		.ymin = (float)recti->ymin + 1, | 
					
						
							|  |  |  | 		.ymax = (float)recti->ymax - 1 | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (scopes->wavefrm_yfac < 0.5f) | 
					
						
							|  |  |  | 		scopes->wavefrm_yfac = 0.98f; | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float w = BLI_rctf_size_x(&rect) - 7; | 
					
						
							|  |  |  | 	float h = BLI_rctf_size_y(&rect) * scopes->wavefrm_yfac; | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	float yofs = rect.ymin + (BLI_rctf_size_y(&rect) - h) * 0.5f; | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float w3 = w / 3.0f; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* log scale for alpha */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float alpha = scopes->wavefrm_alpha * scopes->wavefrm_alpha; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-26 16:09:59 +10:00
										 |  |  | 	unit_m3(colors); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int c = 0; c < 3; c++) { | 
					
						
							|  |  |  | 		for (int i = 0; i < 3; i++) { | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 			colors_alpha[c][i] = colors[c][i] * alpha; | 
					
						
							|  |  |  | 			colorsycc_alpha[c][i] = colorsycc[c][i] * alpha; | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-07 14:03:32 +02:00
										 |  |  | 	/* Flush text cache before changing scissors. */ | 
					
						
							|  |  |  | 	BLF_batch_draw_flush(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							|  |  |  | 	GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2015-09-20 20:17:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 	float color[4]; | 
					
						
							|  |  |  | 	UI_GetThemeColor4fv(TH_PREVIEW_BACK, color); | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 	UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_4fv(true, rect.xmin - 1, rect.ymin - 1, rect.xmax + 1, rect.ymax + 1, 3.0f, color); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | 	/* need scissor test, waveform can draw outside of boundary */ | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 	GPU_scissor_get_i(scissor); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	GPU_scissor( | 
					
						
							|  |  |  | 	        (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymin - 1), | 
					
						
							|  |  |  | 	        (rect.xmax + 1) - (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymax + 1) - (rect.ymin - 1)); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	/* draw scale numbers first before binding any shader */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int i = 0; i < 6; i++) { | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 		char str[4]; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		BLI_snprintf(str, sizeof(str), "%-3d", i * 20); | 
					
						
							|  |  |  | 		str[3] = '\0'; | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 		BLF_color4f(BLF_default(), 1.0f, 1.0f, 1.0f, 0.08f); | 
					
						
							|  |  |  | 		BLF_draw_default(rect.xmin + 1, yofs - 5 + (i * 0.2f) * h, 0, str, sizeof(str) - 1); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-07 14:03:32 +02:00
										 |  |  | 	/* Flush text cache before drawing things on top. */ | 
					
						
							|  |  |  | 	BLF_batch_draw_flush(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							|  |  |  | 	GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniformColor4f(1.0f, 1.0f, 1.0f, 0.08f); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	/* draw grid lines here */ | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINES, 12); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	for (int i = 0; i < 6; i++) { | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 		immVertex2f(pos, rect.xmin + 22, yofs + (i * 0.2f) * h); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmax + 1, yofs + (i * 0.2f) * h); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* 3 vertical separation */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (scopes->wavefrm_mode != SCOPES_WAVEFRM_LUMA) { | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 4); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		for (int i = 1; i < 3; i++) { | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 			immVertex2f(pos, rect.xmin + i * w3, rect.ymin); | 
					
						
							|  |  |  | 			immVertex2f(pos, rect.xmin + i * w3, rect.ymax); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* separate min max zone on the right */ | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 	immVertex2f(pos, rect.xmin + w, rect.ymin); | 
					
						
							|  |  |  | 	immVertex2f(pos, rect.xmin + w, rect.ymax); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* 16-235-240 level in case of ITU-R BT601/709 */ | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniformColor4f(1.0f, 0.4f, 0.0f, 0.2f); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ELEM(scopes->wavefrm_mode, SCOPES_WAVEFRM_YCC_601, SCOPES_WAVEFRM_YCC_709)) { | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 8); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin + 22, yofs + h * 16.0f / 255.0f); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmax + 1, yofs + h * 16.0f / 255.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin + 22, yofs + h * 235.0f / 255.0f); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin + w3, yofs + h * 235.0f / 255.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin + 3 * w3, yofs + h * 235.0f / 255.0f); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmax + 1, yofs + h * 235.0f / 255.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmin + w3, yofs + h * 240.0f / 255.0f); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmax + 1, yofs + h * 240.0f / 255.0f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | 	/* 7.5 IRE black point level for NTSC */ | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 	if (scopes->wavefrm_mode == SCOPES_WAVEFRM_LUMA) { | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 		immVertex2f(pos, rect.xmin, yofs + h * 0.075f); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect.xmax + 1, yofs + h * 0.075f); | 
					
						
							|  |  |  | 		immEnd(); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-10 01:46:44 +00:00
										 |  |  | 	if (scopes->ok && scopes->waveform_1 != NULL) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		glBlendFunc(GL_ONE, GL_ONE); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_point_size(1.0); | 
					
						
							| 
									
										
										
										
											2016-01-15 22:59:42 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 		/* LUMA (1 channel) */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (scopes->wavefrm_mode == SCOPES_WAVEFRM_LUMA) { | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 			float col[3] = {alpha, alpha, alpha}; | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_push(); | 
					
						
							|  |  |  | 			GPU_matrix_translate_2f(rect.xmin, yofs); | 
					
						
							|  |  |  | 			GPU_matrix_scale_2f(w, h); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			waveform_draw_one(scopes->waveform_1, scopes->waveform_tot, col); | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_pop(); | 
					
						
							| 
									
										
										
										
											2010-05-10 01:46:44 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* min max */ | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 			immUniformColor3f(0.5f, 0.5f, 0.5f); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			min = yofs + scopes->minmax[0][0] * h; | 
					
						
							|  |  |  | 			max = yofs + scopes->minmax[0][1] * h; | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | 			CLAMP(min, rect.ymin, rect.ymax); | 
					
						
							|  |  |  | 			CLAMP(max, rect.ymin, rect.ymax); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 			immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 			immVertex2f(pos, rect.xmax - 3, min); | 
					
						
							|  |  |  | 			immVertex2f(pos, rect.xmax - 3, max); | 
					
						
							|  |  |  | 			immEnd(); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 		/* RGB (3 channel) */ | 
					
						
							|  |  |  | 		else if (scopes->wavefrm_mode == SCOPES_WAVEFRM_RGB) { | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_push(); | 
					
						
							|  |  |  | 			GPU_matrix_translate_2f(rect.xmin, yofs); | 
					
						
							|  |  |  | 			GPU_matrix_scale_2f(w, h); | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 			waveform_draw_one(scopes->waveform_1, scopes->waveform_tot, colors_alpha[0]); | 
					
						
							|  |  |  | 			waveform_draw_one(scopes->waveform_2, scopes->waveform_tot, colors_alpha[1]); | 
					
						
							|  |  |  | 			waveform_draw_one(scopes->waveform_3, scopes->waveform_tot, colors_alpha[2]); | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_pop(); | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		/* PARADE / YCC (3 channels) */ | 
					
						
							| 
									
										
										
										
											2014-07-20 01:30:29 +10:00
										 |  |  | 		else if (ELEM(scopes->wavefrm_mode, | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 		              SCOPES_WAVEFRM_RGB_PARADE, | 
					
						
							| 
									
										
										
										
											2014-07-20 01:30:29 +10:00
										 |  |  | 		              SCOPES_WAVEFRM_YCC_601, | 
					
						
							|  |  |  | 		              SCOPES_WAVEFRM_YCC_709, | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 		              SCOPES_WAVEFRM_YCC_JPEG | 
					
						
							|  |  |  | 		              )) | 
					
						
							| 
									
										
										
										
											2012-05-17 07:59:25 +00:00
										 |  |  | 		{ | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 			int rgb = (scopes->wavefrm_mode == SCOPES_WAVEFRM_RGB_PARADE); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_push(); | 
					
						
							|  |  |  | 			GPU_matrix_translate_2f(rect.xmin, yofs); | 
					
						
							|  |  |  | 			GPU_matrix_scale_2f(w3, h); | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 			waveform_draw_one(scopes->waveform_1, scopes->waveform_tot, (rgb) ? colors_alpha[0] : colorsycc_alpha[0]); | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_translate_2f(1.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 			waveform_draw_one(scopes->waveform_2, scopes->waveform_tot, (rgb) ? colors_alpha[1] : colorsycc_alpha[1]); | 
					
						
							| 
									
										
										
										
											2010-05-10 01:46:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_translate_2f(1.0f, 0.0f); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 			waveform_draw_one(scopes->waveform_3, scopes->waveform_tot, (rgb) ? colors_alpha[2] : colorsycc_alpha[2]); | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_pop(); | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 		/* min max */ | 
					
						
							|  |  |  | 		if (scopes->wavefrm_mode != SCOPES_WAVEFRM_LUMA ) { | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 			for (int c = 0; c < 3; c++) { | 
					
						
							| 
									
										
										
										
											2016-07-18 15:28:56 +02:00
										 |  |  | 				if (ELEM(scopes->wavefrm_mode, SCOPES_WAVEFRM_RGB_PARADE, SCOPES_WAVEFRM_RGB)) | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 					immUniformColor3f(colors[c][0] * 0.75f, colors[c][1] * 0.75f, colors[c][2] * 0.75f); | 
					
						
							| 
									
										
										
										
											2010-05-10 01:46:44 +00:00
										 |  |  | 				else | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 					immUniformColor3f(colorsycc[c][0] * 0.75f, colorsycc[c][1] * 0.75f, colorsycc[c][2] * 0.75f); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				min = yofs + scopes->minmax[c][0] * h; | 
					
						
							|  |  |  | 				max = yofs + scopes->minmax[c][1] * h; | 
					
						
							| 
									
										
										
										
											2010-05-10 01:46:44 +00:00
										 |  |  | 				CLAMP(min, rect.ymin, rect.ymax); | 
					
						
							|  |  |  | 				CLAMP(max, rect.ymin, rect.ymax); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 				immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 				immVertex2f(pos, rect.xmin + w + 2 + c * 2, min); | 
					
						
							|  |  |  | 				immVertex2f(pos, rect.xmin + w + 2 + c * 2, max); | 
					
						
							|  |  |  | 				immEnd(); | 
					
						
							| 
									
										
										
										
											2010-05-10 01:46:44 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 	/* outline */ | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | 	draw_scope_end(&rect, scissor); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 14:16:36 +00:00
										 |  |  | static float polar_to_x(float center, float diam, float ampli, float angle) | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-20 22:05:05 +10:00
										 |  |  | 	return center + diam * ampli * cosf(angle); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 14:16:36 +00:00
										 |  |  | static float polar_to_y(float center, float diam, float ampli, float angle) | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-20 22:05:05 +10:00
										 |  |  | 	return center + diam * ampli * sinf(angle); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | static void vectorscope_draw_target(unsigned int pos, float centerx, float centery, float diam, const float colf[3]) | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	float y, u, v; | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	float tangle = 0.0f, tampli; | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	float dangle, dampli, dangle2, dampli2; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-29 18:00:45 -04:00
										 |  |  | 	rgb_to_yuv(colf[0], colf[1], colf[2], &y, &u, &v, BLI_YUV_ITU_BT709); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (u > 0 && v >= 0) tangle = atanf(v / u); | 
					
						
							|  |  |  | 	else if (u > 0 && v < 0) tangle = atanf(v / u) + 2.0f * (float)M_PI; | 
					
						
							|  |  |  | 	else if (u < 0) tangle = atanf(v / u) + (float)M_PI; | 
					
						
							| 
									
										
										
										
											2015-01-31 17:23:30 +11:00
										 |  |  | 	else if (u == 0 && v > 0.0f) tangle = M_PI_2; | 
					
						
							|  |  |  | 	else if (u == 0 && v < 0.0f) tangle = -M_PI_2; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	tampli = sqrtf(u * u + v * v); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* small target vary by 2.5 degree and 2.5 IRE unit */ | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immUniformColor4f(1.0f, 1.0f, 1.0f, 0.12f); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	dangle = DEG2RADF(2.5f); | 
					
						
							|  |  |  | 	dampli = 2.5f / 200.0f; | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_LOOP, 4); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli, tangle + dangle), polar_to_y(centery, diam, tampli + dampli, tangle + dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli, tangle + dangle), polar_to_y(centery, diam, tampli - dampli, tangle + dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli, tangle - dangle), polar_to_y(centery, diam, tampli - dampli, tangle - dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli, tangle - dangle), polar_to_y(centery, diam, tampli + dampli, tangle - dangle)); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* big target vary by 10 degree and 20% amplitude */ | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immUniformColor4f(1.0f, 1.0f, 1.0f, 0.12f); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	dangle = DEG2RADF(10.0f); | 
					
						
							|  |  |  | 	dampli = 0.2f * tampli; | 
					
						
							|  |  |  | 	dangle2 = DEG2RADF(5.0f); | 
					
						
							|  |  |  | 	dampli2 = 0.5f * dampli; | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_STRIP, 3); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli - dampli2, tangle + dangle), polar_to_y(centery, diam, tampli + dampli - dampli2, tangle + dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli, tangle + dangle), polar_to_y(centery, diam, tampli + dampli, tangle + dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli, tangle + dangle - dangle2), polar_to_y(centery, diam, tampli + dampli, tangle + dangle - dangle2)); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_STRIP, 3); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli + dampli2, tangle + dangle), polar_to_y(centery, diam, tampli - dampli + dampli2, tangle + dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli, tangle + dangle), polar_to_y(centery, diam, tampli - dampli, tangle + dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli, tangle + dangle - dangle2), polar_to_y(centery, diam, tampli - dampli, tangle + dangle - dangle2)); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_STRIP, 3); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli + dampli2, tangle - dangle), polar_to_y(centery, diam, tampli - dampli + dampli2, tangle - dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli, tangle - dangle), polar_to_y(centery, diam, tampli - dampli, tangle - dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli - dampli, tangle - dangle + dangle2), polar_to_y(centery, diam, tampli - dampli, tangle - dangle + dangle2)); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_STRIP, 3); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli - dampli2, tangle - dangle), polar_to_y(centery, diam, tampli + dampli - dampli2, tangle - dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli, tangle - dangle), polar_to_y(centery, diam, tampli + dampli, tangle - dangle)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, tampli + dampli, tangle - dangle + dangle2), polar_to_y(centery, diam, tampli + dampli, tangle - dangle + dangle2)); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | void ui_draw_but_VECTORSCOPE(ARegion *UNUSED(ar), uiBut *but, uiWidgetColors *UNUSED(wcol), const rcti *recti) | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	const float skin_rad = DEG2RADF(123.0f); /* angle in radians of the skin tone line */ | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	Scopes *scopes = (Scopes *)but->poin; | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-17 09:58:26 +00:00
										 |  |  | 	const float colors[6][3] = { | 
					
						
							|  |  |  | 	    {0.75, 0.0, 0.0},  {0.75, 0.75, 0.0}, {0.0, 0.75, 0.0}, | 
					
						
							|  |  |  | 	    {0.0, 0.75, 0.75}, {0.0, 0.0, 0.75},  {0.75, 0.0, 0.75}}; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	rctf rect = { | 
					
						
							|  |  |  | 		.xmin = (float)recti->xmin + 1, | 
					
						
							|  |  |  | 		.xmax = (float)recti->xmax - 1, | 
					
						
							|  |  |  | 		.ymin = (float)recti->ymin + 1, | 
					
						
							|  |  |  | 		.ymax = (float)recti->ymax - 1 | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float w = BLI_rctf_size_x(&rect); | 
					
						
							|  |  |  | 	float h = BLI_rctf_size_y(&rect); | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	float centerx = rect.xmin + w * 0.5f; | 
					
						
							|  |  |  | 	float centery = rect.ymin + h * 0.5f; | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float diam = (w < h) ? w : h; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float alpha = scopes->vecscope_alpha * scopes->vecscope_alpha * scopes->vecscope_alpha; | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							|  |  |  | 	GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2015-09-20 20:17:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 	float color[4]; | 
					
						
							|  |  |  | 	UI_GetThemeColor4fv(TH_PREVIEW_BACK, color); | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 	UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_4fv(true, rect.xmin - 1, rect.ymin - 1, rect.xmax + 1, rect.ymax + 1, 3.0f, color); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* need scissor test, hvectorscope can draw outside of boundary */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	int scissor[4]; | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 	GPU_scissor_get_i(scissor); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	GPU_scissor( | 
					
						
							|  |  |  | 	        (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymin - 1), | 
					
						
							|  |  |  | 	        (rect.xmax + 1) - (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymax + 1) - (rect.ymin - 1)); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniformColor4f(1.0f, 1.0f, 1.0f, 0.08f); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* draw grid elements */ | 
					
						
							|  |  |  | 	/* cross */ | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINES, 4); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immVertex2f(pos, centerx - (diam * 0.5f) - 5, centery); | 
					
						
							|  |  |  | 	immVertex2f(pos, centerx + (diam * 0.5f) + 5, centery); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immVertex2f(pos, centerx, centery - (diam * 0.5f) - 5); | 
					
						
							|  |  |  | 	immVertex2f(pos, centerx, centery + (diam * 0.5f) + 5); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* circles */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int j = 0; j < 5; j++) { | 
					
						
							| 
									
										
										
										
											2016-01-16 01:17:51 -05:00
										 |  |  | 		const int increment = 15; | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINE_LOOP, (int)(360 / increment)); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		for (int i = 0; i <= 360 - increment; i += increment) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			const float a = DEG2RADF((float)i); | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 			const float r = (j + 1) * 0.1f; | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 			immVertex2f(pos, polar_to_x(centerx, diam, r, a), polar_to_y(centery, diam, r, a)); | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* skin tone line */ | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 	immUniformColor4f(1.0f, 0.4f, 0.0f, 0.2f); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, 0.5f, skin_rad), polar_to_y(centery, diam, 0.5f, skin_rad)); | 
					
						
							|  |  |  | 	immVertex2f(pos, polar_to_x(centerx, diam, 0.1f, skin_rad), polar_to_y(centery, diam, 0.1f, skin_rad)); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 	/* saturation points */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int i = 0; i < 6; i++) | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 		vectorscope_draw_target(pos, centerx, centery, diam, colors[i]); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-10 01:46:44 +00:00
										 |  |  | 	if (scopes->ok && scopes->vecscope != NULL) { | 
					
						
							|  |  |  | 		/* pixel point cloud */ | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 		float col[3] = {alpha, alpha, alpha}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		glBlendFunc(GL_ONE, GL_ONE); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_point_size(1.0); | 
					
						
							| 
									
										
										
										
											2010-04-04 02:37:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 		GPU_matrix_push(); | 
					
						
							|  |  |  | 		GPU_matrix_translate_2f(centerx, centery); | 
					
						
							|  |  |  | 		GPU_matrix_scale_1f(diam); | 
					
						
							| 
									
										
										
										
											2010-04-06 02:05:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 		waveform_draw_one(scopes->vecscope, scopes->waveform_tot, col); | 
					
						
							| 
									
										
										
										
											2010-05-06 19:54:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 		GPU_matrix_pop(); | 
					
						
							| 
									
										
										
										
											2010-05-06 19:54:43 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-04-04 02:37:22 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 00:24:44 +01:00
										 |  |  | 	immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 	/* outline */ | 
					
						
							| 
									
										
										
										
											2010-04-09 00:44:35 +00:00
										 |  |  | 	draw_scope_end(&rect, scissor); | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2010-01-19 01:32:06 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | static void ui_draw_colorband_handle_tri_hlight(unsigned int pos, float x1, float y1, float halfwidth, float height) | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(true); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_STRIP, 3); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immVertex2f(pos, x1 + halfwidth, y1); | 
					
						
							|  |  |  | 	immVertex2f(pos, x1, y1 + height); | 
					
						
							|  |  |  | 	immVertex2f(pos, x1 - halfwidth, y1); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(false); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | static void ui_draw_colorband_handle_tri(unsigned int pos, float x1, float y1, float halfwidth, float height, bool fill) | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-01-16 01:17:51 -05:00
										 |  |  | 	glEnable(fill ? GL_POLYGON_SMOOTH : GL_LINE_SMOOTH); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(fill ? GPU_PRIM_TRIS : GPU_PRIM_LINE_LOOP, 3); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immVertex2f(pos, x1 + halfwidth, y1); | 
					
						
							|  |  |  | 	immVertex2f(pos, x1, y1 + height); | 
					
						
							|  |  |  | 	immVertex2f(pos, x1 - halfwidth, y1); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 01:17:51 -05:00
										 |  |  | 	glDisable(fill ? GL_POLYGON_SMOOTH : GL_LINE_SMOOTH); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | static void ui_draw_colorband_handle_box(unsigned int pos, float x1, float y1, float x2, float y2, bool fill) | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(fill ? GPU_PRIM_TRI_FAN : GPU_PRIM_LINE_LOOP, 4); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immVertex2f(pos, x1, y1); | 
					
						
							|  |  |  | 	immVertex2f(pos, x1, y2); | 
					
						
							|  |  |  | 	immVertex2f(pos, x2, y2); | 
					
						
							|  |  |  | 	immVertex2f(pos, x2, y1); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_draw_colorband_handle( | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  |         uint shdr_pos, const rcti *rect, float x, | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  |         const float rgb[3], struct ColorManagedDisplay *display, | 
					
						
							|  |  |  |         bool active) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	const float sizey = BLI_rcti_size_y(rect); | 
					
						
							|  |  |  | 	const float min_width = 3.0f; | 
					
						
							|  |  |  | 	float colf[3] = {UNPACK3(rgb)}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float half_width = floorf(sizey / 3.5f); | 
					
						
							|  |  |  | 	float height = half_width * 1.4f; | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float y1 = rect->ymin + (sizey * 0.16f); | 
					
						
							|  |  |  | 	float y2 = rect->ymax; | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* align to pixels */ | 
					
						
							|  |  |  | 	x  = floorf(x  + 0.5f); | 
					
						
							|  |  |  | 	y1 = floorf(y1 + 0.5f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (active || half_width < min_width) { | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 		immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-07-13 16:44:02 +02:00
										 |  |  | 		immBindBuiltinProgram(GPU_SHADER_2D_LINE_DASHED_UNIFORM_COLOR); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		float viewport_size[4]; | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 		GPU_viewport_size_get_f(viewport_size); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 		immUniform2f("viewport_size", viewport_size[2] / UI_DPI_FAC, viewport_size[3] / UI_DPI_FAC); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 08:42:16 +02:00
										 |  |  | 		immUniform1i("colors_len", 2);  /* "advanced" mode */ | 
					
						
							| 
									
										
										
											
												Reworked version of dashed line shader.
Using geometry shader allows us to get rid of the 'line origin' extra
vertex attribute, which means dashed shader no longer requires fiddling
with those vertex attributes definition, and, most importantly, does not
require anymore special drawing code!
As you can see, this makes code much simpler, and much less verbose,
especially in complex cases.
In addition, changed how dashes are handled, to have two 'modes', a
simple one with single color (using default "color" uniform name), and a
more advanced one allowing more complex and multi-color patterns.
Note that since GLSL 1.2 does not support geometry shaders, a hack was
added for now (which gives solid lines, but at least does not make
Blender crash).
											
										 
											2017-05-01 16:21:53 +02:00
										 |  |  | 		immUniformArray4fv("colors", (float *)(float[][4]){{0.8f, 0.8f, 0.8f, 1.0f}, {0.0f, 0.0f, 0.0f, 1.0f}}, 2); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 		immUniform1f("dash_width", active ? 4.0f : 2.0f); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
											
												Reworked version of dashed line shader.
Using geometry shader allows us to get rid of the 'line origin' extra
vertex attribute, which means dashed shader no longer requires fiddling
with those vertex attributes definition, and, most importantly, does not
require anymore special drawing code!
As you can see, this makes code much simpler, and much less verbose,
especially in complex cases.
In addition, changed how dashes are handled, to have two 'modes', a
simple one with single color (using default "color" uniform name), and a
more advanced one allowing more complex and multi-color patterns.
Note that since GLSL 1.2 does not support geometry shaders, a hack was
added for now (which gives solid lines, but at least does not make
Blender crash).
											
										 
											2017-05-01 16:21:53 +02:00
										 |  |  | 		immVertex2f(shdr_pos, x, y1); | 
					
						
							|  |  |  | 		immVertex2f(shdr_pos, x, y2); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* hide handles when zoomed out too far */ | 
					
						
							|  |  |  | 		if (half_width < min_width) { | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* shift handle down */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	y1 -= half_width; | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immUniformColor3ub(0, 0, 0); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 	ui_draw_colorband_handle_box(shdr_pos, x - half_width, y1 - 1, x + half_width, y1 + height, false); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* draw all triangles blended */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 	ui_draw_colorband_handle_tri(shdr_pos, x, y1 + height, half_width, half_width, true); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (active) | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 		immUniformColor3ub(196, 196, 196); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 		immUniformColor3ub(96, 96, 96); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 	ui_draw_colorband_handle_tri(shdr_pos, x, y1 + height, half_width, half_width, true); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (active) | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 		immUniformColor3ub(255, 255, 255); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 		immUniformColor3ub(128, 128, 128); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 	ui_draw_colorband_handle_tri_hlight(shdr_pos, x, y1 + height - 1, (half_width - 1), (half_width - 1)); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immUniformColor3ub(0, 0, 0); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 	ui_draw_colorband_handle_tri_hlight(shdr_pos, x, y1 + height, half_width, half_width); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immUniformColor3ub(128, 128, 128); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 	ui_draw_colorband_handle_box(shdr_pos, x - (half_width - 1), y1, x + (half_width - 1), y1 + height, true); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (display) { | 
					
						
							|  |  |  | 		IMB_colormanagement_scene_linear_to_display_v3(colf, display); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immUniformColor3fv(colf); | 
					
						
							| 
									
										
										
										
											2017-04-29 12:57:14 +02:00
										 |  |  | 	ui_draw_colorband_handle_box(shdr_pos, x - (half_width - 2), y1 + 1, x + (half_width - 2), y1 + height - 2, true); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-07 15:47:57 +11:00
										 |  |  | void ui_draw_but_COLORBAND(uiBut *but, uiWidgetColors *UNUSED(wcol), const rcti *rect) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	struct ColorManagedDisplay *display = NULL; | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 	uint pos_id, col_id; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	ColorBand *coba = (ColorBand *)(but->editcoba ? but->editcoba : but->poin); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (coba == NULL) return; | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (but->block->color_profile) | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 		display = ui_block_cm_display_get(but->block); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float x1 = rect->xmin; | 
					
						
							|  |  |  | 	float sizex = rect->xmax - x1; | 
					
						
							|  |  |  | 	float sizey = BLI_rcti_size_y(rect); | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	float sizey_solid = sizey * 0.25f; | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float y1 = rect->ymin; | 
					
						
							| 
									
										
										
										
											2011-06-06 09:12:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	pos_id = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_CHECKER); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Drawing the checkerboard. */ | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniform4f("color1", UI_ALPHA_CHECKER_DARK / 255.0f, UI_ALPHA_CHECKER_DARK / 255.0f, UI_ALPHA_CHECKER_DARK / 255.0f, 1.0f); | 
					
						
							|  |  |  | 	immUniform4f("color2", UI_ALPHA_CHECKER_LIGHT / 255.0f, UI_ALPHA_CHECKER_LIGHT / 255.0f, UI_ALPHA_CHECKER_LIGHT / 255.0f, 1.0f); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immUniform1i("size", 8); | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 	immRectf(pos_id, x1, y1, x1 + sizex, rect->ymax); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* New format */ | 
					
						
							|  |  |  | 	format = immVertexFormat(); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	pos_id = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 	col_id = GPU_vertformat_attr_add(format, "color", GPU_COMP_F32, 4, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_SMOOTH_COLOR); | 
					
						
							| 
									
										
										
										
											2011-06-06 09:12:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	/* layer: color ramp */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	CBData *cbd = coba->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	float v1[2], v2[2]; | 
					
						
							|  |  |  | 	float colf[4] = {0, 0, 0, 0}; /* initialize in case the colorband isn't valid */ | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	v1[1] = y1 + sizey_solid; | 
					
						
							|  |  |  | 	v2[1] = rect->ymax; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_TRI_STRIP, (sizex + 1) * 2); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int a = 0; a <= sizex; a++) { | 
					
						
							|  |  |  | 		float pos = ((float)a) / sizex; | 
					
						
							| 
									
										
										
										
											2017-12-07 15:52:59 +11:00
										 |  |  | 		BKE_colorband_evaluate(coba, pos, colf); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		if (display) | 
					
						
							|  |  |  | 			IMB_colormanagement_scene_linear_to_display_v3(colf, display); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		v1[0] = v2[0] = x1 + a; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 		immAttrib4fv(col_id, colf); | 
					
						
							|  |  |  | 		immVertex2fv(pos_id, v1); | 
					
						
							|  |  |  | 		immVertex2fv(pos_id, v2); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* layer: color ramp without alpha for reference when manipulating ramp properties */ | 
					
						
							|  |  |  | 	v1[1] = y1; | 
					
						
							|  |  |  | 	v2[1] = y1 + sizey_solid; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_TRI_STRIP, (sizex + 1) * 2); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int a = 0; a <= sizex; a++) { | 
					
						
							|  |  |  | 		float pos = ((float)a) / sizex; | 
					
						
							| 
									
										
										
										
											2017-12-07 15:52:59 +11:00
										 |  |  | 		BKE_colorband_evaluate(coba, pos, colf); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 		if (display) | 
					
						
							|  |  |  | 			IMB_colormanagement_scene_linear_to_display_v3(colf, display); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		v1[0] = v2[0] = x1 + a; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 		immAttrib4f(col_id, colf[0], colf[1], colf[2], 1.0f); | 
					
						
							|  |  |  | 		immVertex2fv(pos_id, v1); | 
					
						
							|  |  |  | 		immVertex2fv(pos_id, v2); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	/* New format */ | 
					
						
							|  |  |  | 	format = immVertexFormat(); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	pos_id = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	/* layer: box outline */ | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniformColor4f(0.0f, 0.0f, 0.0f, 1.0f); | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 	imm_draw_box_wire_2d(pos_id, x1, y1, x1 + sizex, rect->ymax); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	/* layer: box outline */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniformColor4f(0.0f, 0.0f, 0.0f, 0.5f); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 	immVertex2f(pos_id, x1, y1); | 
					
						
							|  |  |  | 	immVertex2f(pos_id, x1 + sizex, y1); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	immUniformColor4f(1.0f, 1.0f, 1.0f, 0.25f); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 	immVertex2f(pos_id, x1, y1 - 1); | 
					
						
							|  |  |  | 	immVertex2f(pos_id, x1 + sizex, y1 - 1); | 
					
						
							| 
									
										
										
										
											2017-02-23 02:52:36 -03:00
										 |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	/* layer: draw handles */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int a = 0; a < coba->tot; a++, cbd++) { | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 		if (a != coba->cur) { | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 			float pos = x1 + cbd->pos * (sizex - 1) + 1; | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 			ui_draw_colorband_handle(pos_id, rect, pos, &cbd->r, display, false); | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-08-11 02:31:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-03-29 15:26:29 +11:00
										 |  |  | 	/* layer: active handle */ | 
					
						
							| 
									
										
										
										
											2014-08-29 16:56:19 +10:00
										 |  |  | 	if (coba->tot != 0) { | 
					
						
							|  |  |  | 		cbd = &coba->data[coba->cur]; | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		float pos = x1 + cbd->pos * (sizex - 1) + 1; | 
					
						
							| 
									
										
										
										
											2018-07-08 12:48:04 +02:00
										 |  |  | 		ui_draw_colorband_handle(pos_id, rect, pos, &cbd->r, display, true); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | void ui_draw_but_UNITVEC(uiBut *but, uiWidgetColors *wcol, const rcti *rect) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	/* sphere color */ | 
					
						
							| 
									
										
										
										
											2015-11-27 21:32:14 +01:00
										 |  |  | 	float diffuse[3] = {1.0f, 1.0f, 1.0f}; | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	float light[3]; | 
					
						
							| 
									
										
										
										
											2015-11-27 21:08:48 +01:00
										 |  |  | 	float size; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02: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
										 |  |  | 	/* backdrop */ | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 	UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_3ubAlpha(true, rect->xmin, rect->ymin, rect->xmax, rect->ymax, 5.0f, (unsigned char *)wcol->inner, 255); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-16 23:40:03 +00:00
										 |  |  | 	glCullFace(GL_BACK); | 
					
						
							|  |  |  | 	glEnable(GL_CULL_FACE); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-11-27 21:08:48 +01:00
										 |  |  | 	/* setup lights */ | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	ui_but_v3_get(but, light); | 
					
						
							| 
									
										
										
										
											2015-11-27 21:08:48 +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
										 |  |  | 	/* transform to button */ | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 	GPU_matrix_push(); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-15 11:48:20 +00:00
										 |  |  | 	if (BLI_rcti_size_x(rect) < BLI_rcti_size_y(rect)) | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 		size = 0.5f * BLI_rcti_size_x(rect); | 
					
						
							| 
									
										
										
										
											2009-06-01 14:08:19 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 		size = 0.5f * BLI_rcti_size_y(rect); | 
					
						
							| 
									
										
										
										
											2015-06-22 20:35:10 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 	GPU_matrix_translate_2f(rect->xmin + 0.5f * BLI_rcti_size_x(rect), rect->ymin + 0.5f * BLI_rcti_size_y(rect)); | 
					
						
							|  |  |  | 	GPU_matrix_scale_1f(size); | 
					
						
							| 
									
										
										
										
											2013-03-09 03:46:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUBatch *sphere = GPU_batch_preset_sphere(2); | 
					
						
							|  |  |  | 	GPU_batch_program_set_builtin(sphere, GPU_SHADER_SIMPLE_LIGHTING); | 
					
						
							|  |  |  | 	GPU_batch_uniform_4f(sphere, "color", diffuse[0], diffuse[1], diffuse[2], 1.0f); | 
					
						
							|  |  |  | 	GPU_batch_uniform_3fv(sphere, "light", light); | 
					
						
							|  |  |  | 	GPU_batch_draw(sphere); | 
					
						
							| 
									
										
										
										
											2013-04-03 01:35: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
										 |  |  | 	/* restore */ | 
					
						
							|  |  |  | 	glDisable(GL_CULL_FACE); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-20 14:32:15 +00:00
										 |  |  | 	/* AA circle */ | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 	immUniformColor3ubv((unsigned char *)wcol->inner); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							|  |  |  | 	GPU_line_smooth(true); | 
					
						
							| 
									
										
										
										
											2017-09-14 00:39:28 +10:00
										 |  |  | 	imm_draw_circle_wire_2d(pos, 0.0f, 0.0f, 1.0f, 32); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							|  |  |  | 	GPU_line_smooth(false); | 
					
						
							| 
									
										
										
										
											2009-05-20 14:32:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* matrix after circle */ | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 	GPU_matrix_pop(); | 
					
						
							| 
									
										
										
										
											2016-09-20 11:56:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-07 13:04:08 +01:00
										 |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | static void ui_draw_but_curve_grid(unsigned int pos, const rcti *rect, float zoomx, float zoomy, float offsx, float offsy, float step) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float dx = step * zoomx; | 
					
						
							|  |  |  | 	float fx = rect->xmin + zoomx * (-offsx); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (fx > rect->xmin) fx -= dx * (floorf(fx - rect->xmin)); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float dy = step * zoomy; | 
					
						
							|  |  |  | 	float fy = rect->ymin + zoomy * (-offsy); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (fy > rect->ymin) fy -= dy * (floorf(fy - rect->ymin)); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	float line_count = ( | 
					
						
							|  |  |  | 	        floorf((rect->xmax - fx) / dx) + 1.0f + | 
					
						
							|  |  |  | 	        floorf((rect->ymax - fy) / dy) + 1.0f); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINES, (int)line_count * 2); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	while (fx < rect->xmax) { | 
					
						
							|  |  |  | 		immVertex2f(pos, fx, rect->ymin); | 
					
						
							|  |  |  | 		immVertex2f(pos, fx, rect->ymax); | 
					
						
							|  |  |  | 		fx += dx; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	while (fy < rect->ymax) { | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immVertex2f(pos, rect->xmin, fy); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect->xmax, fy); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		fy += dy; | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02: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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-04 11:50:11 +00:00
										 |  |  | static void gl_shaded_color(unsigned char *col, int shade) | 
					
						
							| 
									
										
											  
											
												2.5
Summary of ain features:
- Themes and Styles are now editable.
- CTRL+U "Save user defaults" now goes to new .B25.blend, so you
  can use 2.4x and 2.5x next to each other. If B25 doesn't exist, it
  reads the regular .B.blend
- Press Tkey in 3d window for (unfinished) toolbar WIP. It now only
  shows the last operator, if appropriate.
  Nkey properties moved to the other side.
A lot of work was done on removing old themes for good and properly
getting it work with the 2.5 region system. Here's some notes;
- Buttons now all have a complete set of colors, based on button classifications
  (See outliner -> user prefs -> Interface
- Theme colors have been extended with basic colors for region types. 
  Currently colors are defined for Window, Header, List/Channels and
  for Button/Tool views. 
  The screen manager handles this btw, so a TH_BACK will always pick the
  right backdrop color.
- Menu backdrops are in in Button theme colors. Floating Panels will be in
  the per-space type Themes.
- Styles were added in RNA too, but only for the font settings now.
  Only Panel font, widget font and widget-label work now. The 'group label'
  will be for templates mostly.
  Style settings will be expanded with spacing defaults, label conventions, 
  etc.
- Label text colors are stored in per-space Theme too, to make sure they fit.
  Same goes for Panel title color.
Note that 'shadow' for fonts can conflict with text colors; shadow color is
currently stored in Style... shadow code needs a bit of work still.
											
										 
											2009-04-27 13:44:11 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	immUniformColor3ub( | 
					
						
							|  |  |  | 	        col[0] - shade > 0 ? col[0] - shade : 0, | 
					
						
							|  |  |  | 	        col[1] - shade > 0 ? col[1] - shade : 0, | 
					
						
							|  |  |  | 	        col[2] - shade > 0 ? col[2] - shade : 0); | 
					
						
							| 
									
										
											  
											
												2.5
Summary of ain features:
- Themes and Styles are now editable.
- CTRL+U "Save user defaults" now goes to new .B25.blend, so you
  can use 2.4x and 2.5x next to each other. If B25 doesn't exist, it
  reads the regular .B.blend
- Press Tkey in 3d window for (unfinished) toolbar WIP. It now only
  shows the last operator, if appropriate.
  Nkey properties moved to the other side.
A lot of work was done on removing old themes for good and properly
getting it work with the 2.5 region system. Here's some notes;
- Buttons now all have a complete set of colors, based on button classifications
  (See outliner -> user prefs -> Interface
- Theme colors have been extended with basic colors for region types. 
  Currently colors are defined for Window, Header, List/Channels and
  for Button/Tool views. 
  The screen manager handles this btw, so a TH_BACK will always pick the
  right backdrop color.
- Menu backdrops are in in Button theme colors. Floating Panels will be in
  the per-space type Themes.
- Styles were added in RNA too, but only for the font settings now.
  Only Panel font, widget font and widget-label work now. The 'group label'
  will be for templates mostly.
  Style settings will be expanded with spacing defaults, label conventions, 
  etc.
- Label text colors are stored in per-space Theme too, to make sure they fit.
  Same goes for Panel title color.
Note that 'shadow' for fonts can conflict with text colors; shadow color is
currently stored in Style... shadow code needs a bit of work still.
											
										 
											2009-04-27 13:44:11 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-07 15:47:57 +11:00
										 |  |  | void ui_draw_but_CURVE(ARegion *ar, uiBut *but, uiWidgetColors *wcol, const rcti *rect) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							|  |  |  | 	CurveMapping *cumap; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-21 15:14:29 +00:00
										 |  |  | 	if (but->editcumap) { | 
					
						
							|  |  |  | 		cumap = but->editcumap; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		cumap = (CurveMapping *)but->poin; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	CurveMap *cuma = &cumap->cm[cumap->cur]; | 
					
						
							| 
									
										
										
										
											2012-06-21 14:37:56 +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
										 |  |  | 	/* need scissor test, curve can draw outside of boundary */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	int scissor[4]; | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 	GPU_scissor_get_i(scissor); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	rcti scissor_new = { | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | 		.xmin = rect->xmin, | 
					
						
							|  |  |  | 		.ymin = rect->ymin, | 
					
						
							|  |  |  | 		.xmax = rect->xmax, | 
					
						
							|  |  |  | 		.ymax = rect->ymax | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | 	rcti scissor_region = {0, ar->winx, 0, ar->winy}; | 
					
						
							|  |  |  | 	BLI_rcti_isect(&scissor_new, &scissor_region, &scissor_new); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	GPU_scissor( | 
					
						
							|  |  |  | 	        scissor_new.xmin, | 
					
						
							|  |  |  | 	        scissor_new.ymin, | 
					
						
							|  |  |  | 	        BLI_rcti_size_x(&scissor_new), | 
					
						
							|  |  |  | 	        BLI_rcti_size_y(&scissor_new)); | 
					
						
							| 
									
										
										
										
											2012-08-21 19:35:06 +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
										 |  |  | 	/* calculate offset and zoom */ | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float zoomx = (BLI_rcti_size_x(rect) - 2.0f) / BLI_rctf_size_x(&cumap->curr); | 
					
						
							|  |  |  | 	float zoomy = (BLI_rcti_size_y(rect) - 2.0f) / BLI_rctf_size_y(&cumap->curr); | 
					
						
							|  |  |  | 	float offsx = cumap->curr.xmin - (1.0f / zoomx); | 
					
						
							|  |  |  | 	float offsy = cumap->curr.ymin - (1.0f / zoomy); | 
					
						
							| 
									
										
										
										
											2016-02-16 23:45:12 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	/* Do this first to not mess imm context */ | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 	if (but->a1 == UI_GRAD_H) { | 
					
						
							|  |  |  | 		/* magic trigger for curve backgrounds */ | 
					
						
							|  |  |  | 		float col[3] = {0.0f, 0.0f, 0.0f}; /* dummy arg */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		rcti grid = { | 
					
						
							|  |  |  | 			.xmin = rect->xmin + zoomx * (-offsx), | 
					
						
							|  |  |  | 			.xmax = grid.xmin + zoomx, | 
					
						
							|  |  |  | 			.ymin = rect->ymin + zoomy * (-offsy), | 
					
						
							|  |  |  | 			.ymax = grid.ymin + zoomy | 
					
						
							|  |  |  | 		}; | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		ui_draw_gradient(&grid, col, UI_GRAD_H, 1.0f); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_width(1.0f); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	/* backdrop */ | 
					
						
							|  |  |  | 	if (but->a1 == UI_GRAD_H) { | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 		/* grid, hsv uses different grid */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_blend(true); | 
					
						
							|  |  |  | 		GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immUniformColor4ub(0, 0, 0, 48); | 
					
						
							|  |  |  | 		ui_draw_but_curve_grid(pos, rect, zoomx, zoomy, offsx, offsy, 0.1666666f); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_blend(false); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 		if (cumap->flag & CUMA_DO_CLIP) { | 
					
						
							|  |  |  | 			gl_shaded_color((unsigned char *)wcol->inner, -20); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			immRectf(pos, rect->xmin, rect->ymin, rect->xmax, rect->ymax); | 
					
						
							|  |  |  | 			immUniformColor3ubv((unsigned char *)wcol->inner); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 			immRectf(pos, | 
					
						
							|  |  |  | 			         rect->xmin + zoomx * (cumap->clipr.xmin - offsx), | 
					
						
							|  |  |  | 			         rect->ymin + zoomy * (cumap->clipr.ymin - offsy), | 
					
						
							|  |  |  | 			         rect->xmin + zoomx * (cumap->clipr.xmax - offsx), | 
					
						
							|  |  |  | 			         rect->ymin + zoomy * (cumap->clipr.ymax - offsy)); | 
					
						
							| 
									
										
										
										
											2010-01-21 00:00:45 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			immUniformColor3ubv((unsigned char *)wcol->inner); | 
					
						
							|  |  |  | 			immRectf(pos, rect->xmin, rect->ymin, rect->xmax, rect->ymax); | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* grid, every 0.25 step */ | 
					
						
							|  |  |  | 		gl_shaded_color((unsigned char *)wcol->inner, -16); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		ui_draw_but_curve_grid(pos, rect, zoomx, zoomy, offsx, offsy, 0.25f); | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 		/* grid, every 1.0 step */ | 
					
						
							|  |  |  | 		gl_shaded_color((unsigned char *)wcol->inner, -24); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		ui_draw_but_curve_grid(pos, rect, zoomx, zoomy, offsx, offsy, 1.0f); | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +00:00
										 |  |  | 		/* axes */ | 
					
						
							|  |  |  | 		gl_shaded_color((unsigned char *)wcol->inner, -50); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 4); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immVertex2f(pos, rect->xmin, rect->ymin + zoomy * (-offsy)); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect->xmax, rect->ymin + zoomy * (-offsy)); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect->xmin + zoomx * (-offsx), rect->ymin); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect->xmin + zoomx * (-offsx), rect->ymax); | 
					
						
							|  |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2010-01-21 00:00:45 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-21 15:03:30 +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
										 |  |  | 	/* cfra option */ | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | 	/* XXX 2.48 */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (cumap->flag & CUMA_DRAW_CFRA) { | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 		immUniformColor3ub(0x60, 0xc0, 0x40); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 2); | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 		immVertex2f(pos, rect->xmin + zoomx * (cumap->sample[0] - offsx), rect->ymin); | 
					
						
							|  |  |  | 		immVertex2f(pos, rect->xmin + zoomx * (cumap->sample[0] - offsx), rect->ymax); | 
					
						
							|  |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +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
										 |  |  | 	/* sample option */ | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (cumap->flag & CUMA_DRAW_SAMPLE) { | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 		immBegin(GPU_PRIM_LINES, 2); /* will draw one of the following 3 lines */ | 
					
						
							| 
									
										
										
										
											2012-06-21 14:37:56 +00:00
										 |  |  | 		if (but->a1 == UI_GRAD_H) { | 
					
						
							|  |  |  | 			float tsample[3]; | 
					
						
							|  |  |  | 			float hsv[3]; | 
					
						
							|  |  |  | 			linearrgb_to_srgb_v3_v3(tsample, cumap->sample); | 
					
						
							|  |  |  | 			rgb_to_hsv_v(tsample, hsv); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			immUniformColor3ub(240, 240, 240); | 
					
						
							| 
									
										
										
										
											2012-06-21 14:37:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			immVertex2f(pos, rect->xmin + zoomx * (hsv[0] - offsx), rect->ymin); | 
					
						
							|  |  |  | 			immVertex2f(pos, rect->xmin + zoomx * (hsv[0] - offsx), rect->ymax); | 
					
						
							| 
									
										
										
										
											2012-06-21 14:37:56 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else if (cumap->cur == 3) { | 
					
						
							| 
									
										
										
										
											2015-03-17 15:20:33 +01:00
										 |  |  | 			float lum = IMB_colormanagement_get_luminance(cumap->sample); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			immUniformColor3ub(240, 240, 240); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			immVertex2f(pos, rect->xmin + zoomx * (lum - offsx), rect->ymin); | 
					
						
							|  |  |  | 			immVertex2f(pos, rect->xmin + zoomx * (lum - offsx), rect->ymax); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			if (cumap->cur == 0) | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 				immUniformColor3ub(240, 100, 100); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			else if (cumap->cur == 1) | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 				immUniformColor3ub(100, 240, 100); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 				immUniformColor3ub(100, 100, 240); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			immVertex2f(pos, rect->xmin + zoomx * (cumap->sample[cumap->cur] - offsx), rect->ymin); | 
					
						
							|  |  |  | 			immVertex2f(pos, rect->xmin + zoomx * (cumap->sample[cumap->cur] - offsx), rect->ymax); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immEnd(); | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +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
										 |  |  | 	/* the curve */ | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immUniformColor3ubv((unsigned char *)wcol->item); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(true); | 
					
						
							|  |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_STRIP, (CM_TABLE + 1) + 2); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (cuma->table == NULL) | 
					
						
							| 
									
										
										
										
											2014-01-04 17:16:19 +11:00
										 |  |  | 		curvemapping_changed(cumap, false); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	CurveMapPoint *cmp = cuma->table; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	/* first point */ | 
					
						
							| 
									
										
										
										
											2012-08-21 15:14:29 +00:00
										 |  |  | 	if ((cuma->flag & CUMA_EXTEND_EXTRAPOLATE) == 0) { | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immVertex2f(pos, rect->xmin, rect->ymin + zoomy * (cmp[0].y - offsy)); | 
					
						
							| 
									
										
										
										
											2012-08-21 15:14:29 +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
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		float fx = rect->xmin + zoomx * (cmp[0].x - offsx + cuma->ext_in[0]); | 
					
						
							|  |  |  | 		float fy = rect->ymin + zoomy * (cmp[0].y - offsy + cuma->ext_in[1]); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immVertex2f(pos, fx, fy); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int a = 0; a <= CM_TABLE; a++) { | 
					
						
							|  |  |  | 		float fx = rect->xmin + zoomx * (cmp[a].x - offsx); | 
					
						
							|  |  |  | 		float fy = rect->ymin + zoomy * (cmp[a].y - offsy); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immVertex2f(pos, fx, fy); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							|  |  |  | 	/* last point */ | 
					
						
							| 
									
										
										
										
											2012-08-21 15:14:29 +00:00
										 |  |  | 	if ((cuma->flag & CUMA_EXTEND_EXTRAPOLATE) == 0) { | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immVertex2f(pos, rect->xmax, rect->ymin + zoomy * (cmp[CM_TABLE].y - offsy)); | 
					
						
							| 
									
										
										
										
											2012-08-21 15:14:29 +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
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		float fx = rect->xmin + zoomx * (cmp[CM_TABLE].x - offsx - cuma->ext_out[0]); | 
					
						
							|  |  |  | 		float fy = rect->ymin + zoomy * (cmp[CM_TABLE].y - offsy - cuma->ext_out[1]); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immVertex2f(pos, fx, fy); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(false); | 
					
						
							|  |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
											  
											
												
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 points, use aspect to make them visible on edges */ | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	format = immVertexFormat(); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 	uint col = GPU_vertformat_attr_add(format, "color", GPU_COMP_F32, 4, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_FLAT_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	cmp = cuma->curve; | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_point_size(3.0f); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_POINTS, cuma->totpoint); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int a = 0; a < cuma->totpoint; a++) { | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		float color[4]; | 
					
						
							| 
									
										
										
										
											2012-08-21 08:47:36 +00:00
										 |  |  | 		if (cmp[a].flag & CUMA_SELECT) | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			UI_GetThemeColor4fv(TH_TEXT_HI, color); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 			UI_GetThemeColor4fv(TH_TEXT, color); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		float fx = rect->xmin + zoomx * (cmp[a].x - offsx); | 
					
						
							|  |  |  | 		float fy = rect->ymin + zoomy * (cmp[a].y - offsy); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 		immAttrib4fv(col, color); | 
					
						
							|  |  |  | 		immVertex2f(pos, fx, fy); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immEnd(); | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02: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
										 |  |  | 	/* restore scissortest */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_scissor(scissor[0], scissor[1], scissor[2], scissor[3]); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* outline */ | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	format = immVertexFormat(); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immUniformColor3ubv((unsigned char *)wcol->outline); | 
					
						
							| 
									
										
										
										
											2017-09-26 15:21:01 +10:00
										 |  |  | 	imm_draw_box_wire_2d(pos, rect->xmin, rect->ymin, rect->xmax, rect->ymax); | 
					
						
							| 
									
										
										
										
											2017-02-08 12:01:03 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | void ui_draw_but_TRACKPREVIEW(ARegion *UNUSED(ar), uiBut *but, uiWidgetColors *UNUSED(wcol), const rcti *recti) | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2014-04-11 11:25:41 +10:00
										 |  |  | 	bool ok = false; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	MovieClipScopes *scopes = (MovieClipScopes *)but->poin; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	rctf rect = { | 
					
						
							|  |  |  | 		.xmin = (float)recti->xmin + 1, | 
					
						
							|  |  |  | 		.xmax = (float)recti->xmax - 1, | 
					
						
							|  |  |  | 		.ymin = (float)recti->ymin + 1, | 
					
						
							|  |  |  | 		.ymax = (float)recti->ymax - 1 | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	int width  = BLI_rctf_size_x(&rect) + 1; | 
					
						
							|  |  |  | 	int height = BLI_rctf_size_y(&rect); | 
					
						
							| 
									
										
											  
											
												Planar tracking support for motion tracking
===========================================
Major list of changes done in tomato branch:
- Add a planar tracking implementation to libmv
  This adds a new planar tracking implementation to libmv. The
  tracker is based on Ceres[1], the new nonlinear minimizer that
  myself and Sameer released from Google as open source. Since
  the motion model is more involved, the interface is
  different than the RegionTracker interface used previously
  in Blender.
  The start of a C API in libmv-capi.{cpp,h} is also included.
- Migrate from pat_{min,max} for markers to 4 corners representation
  Convert markers in the movie clip editor / 2D tracker from using
  pat_min and pat_max notation to using the a more general, 4-corner
  representation.
  There is still considerable porting work to do; in particular
  sliding from preview widget does not work correct for rotated
  markers.
  All other areas should be ported to new representation:
  * Added support of sliding individual corners. LMB slide + Ctrl
    would scale the whole pattern
  * S would scale the whole marker, S-S would scale pattern only
  * Added support of marker's rotation which is currently rotates
    only patterns around their centers or all markers around median,
    Rotation or other non-translation/scaling transformation of search
    area doesn't make sense.
  * Track Preview widget would display transformed pattern which
    libmv actually operates with.
- "Efficient Second-order Minimization" for the planar tracker
  This implements the "Efficient Second-order Minimization"
  scheme, as supported by the existing translation tracker.
  This increases the amount of per-iteration work, but
  decreases the number of iterations required to converge and
  also increases the size of the basin of attraction for the
  optimization.
- Remove the use of the legacy RegionTracker API from Blender,
  and replaces it with the new TrackRegion API. This also
  adds several features to the planar tracker in libmv:
  * Do a brute-force initialization of tracking similar to "Hybrid"
    mode in the stable release, but using all floats. This is slower
    but more accurate. It is still necessary to evaluate if the
    performance loss is worth it. In particular, this change is
    necessary to support high bit depth imagery.
  * Add support for masks over the search window. This is a step
    towards supporting user-defined tracker masks. The tracker masks
    will make it easy for users to make a mask for e.g. a ball.
    Not exposed into interface yet/
  * Add Pearson product moment correlation coefficient checking (aka
    "Correlation" in the UI. This causes tracking failure if the
    tracked patch is not linearly related to the template.
  * Add support for warping a few points in addition to the supplied
    points. This is useful because the tracking code deliberately
    does not expose the underlying warp representation. Instead,
    warps are specified in an aparametric way via the correspondences.
- Replace the old style tracker configuration panel with the
  new planar tracking panel. From a users perspective, this means:
  * The old "tracking algorithm" picker is gone. There is only 1
    algorithm now. We may revisit this later, but I would much
    prefer to have only 1 algorithm. So far no optimization work
    has been done so the speed is not there yet.
  * There is now a dropdown to select the motion model. Choices:
        * Translation
        * Translation, rotation
        * Translation, scale
        * Translation, rotation, scale
        * Affine
        * Perspective
  * The old "Hybrid" mode is gone; instead there is a toggle to
    enable or disable translation-only tracker initialization. This
    is the equivalent of the hyrbid mode before, but rewritten to work
    with the new planar tracking modes.
  * The pyramid levels setting is gone. At a future date, the planar
    tracker will decide to use pyramids or not automatically. The
    pyramid setting was ultimately a mistake; with the brute force
    initialization it is unnecessary.
- Add light-normalized tracking
  Added the ability to normalize patterns by their average value while
  tracking, to make them invariant to global illumination changes.
Additional details could be found at wiki page [2]
  [1] http://code.google.com/p/ceres-solver
  [2] http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Motion_Tracker
											
										 
											2012-06-10 15:28:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							|  |  |  | 	GPU_blend_set_func_separate(GPU_SRC_ALPHA, GPU_ONE_MINUS_SRC_ALPHA, GPU_ONE, GPU_ONE_MINUS_SRC_ALPHA); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* need scissor test, preview image can draw outside of boundary */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	int scissor[4]; | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 	GPU_scissor_get_i(scissor); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	GPU_scissor( | 
					
						
							|  |  |  | 	        (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymin - 1), | 
					
						
							|  |  |  | 	        (rect.xmax + 1) - (rect.xmin - 1), | 
					
						
							|  |  |  | 	        (rect.ymax + 1) - (rect.ymin - 1)); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (scopes->track_disabled) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		float color[4] = {0.7f, 0.3f, 0.3f, 0.3f}; | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 		UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 		UI_draw_roundbox_4fv(true, rect.xmin - 1, rect.ymin, rect.xmax + 1, rect.ymax + 1, 3.0f, color); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		ok = true; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												Planar tracking support for motion tracking
===========================================
Major list of changes done in tomato branch:
- Add a planar tracking implementation to libmv
  This adds a new planar tracking implementation to libmv. The
  tracker is based on Ceres[1], the new nonlinear minimizer that
  myself and Sameer released from Google as open source. Since
  the motion model is more involved, the interface is
  different than the RegionTracker interface used previously
  in Blender.
  The start of a C API in libmv-capi.{cpp,h} is also included.
- Migrate from pat_{min,max} for markers to 4 corners representation
  Convert markers in the movie clip editor / 2D tracker from using
  pat_min and pat_max notation to using the a more general, 4-corner
  representation.
  There is still considerable porting work to do; in particular
  sliding from preview widget does not work correct for rotated
  markers.
  All other areas should be ported to new representation:
  * Added support of sliding individual corners. LMB slide + Ctrl
    would scale the whole pattern
  * S would scale the whole marker, S-S would scale pattern only
  * Added support of marker's rotation which is currently rotates
    only patterns around their centers or all markers around median,
    Rotation or other non-translation/scaling transformation of search
    area doesn't make sense.
  * Track Preview widget would display transformed pattern which
    libmv actually operates with.
- "Efficient Second-order Minimization" for the planar tracker
  This implements the "Efficient Second-order Minimization"
  scheme, as supported by the existing translation tracker.
  This increases the amount of per-iteration work, but
  decreases the number of iterations required to converge and
  also increases the size of the basin of attraction for the
  optimization.
- Remove the use of the legacy RegionTracker API from Blender,
  and replaces it with the new TrackRegion API. This also
  adds several features to the planar tracker in libmv:
  * Do a brute-force initialization of tracking similar to "Hybrid"
    mode in the stable release, but using all floats. This is slower
    but more accurate. It is still necessary to evaluate if the
    performance loss is worth it. In particular, this change is
    necessary to support high bit depth imagery.
  * Add support for masks over the search window. This is a step
    towards supporting user-defined tracker masks. The tracker masks
    will make it easy for users to make a mask for e.g. a ball.
    Not exposed into interface yet/
  * Add Pearson product moment correlation coefficient checking (aka
    "Correlation" in the UI. This causes tracking failure if the
    tracked patch is not linearly related to the template.
  * Add support for warping a few points in addition to the supplied
    points. This is useful because the tracking code deliberately
    does not expose the underlying warp representation. Instead,
    warps are specified in an aparametric way via the correspondences.
- Replace the old style tracker configuration panel with the
  new planar tracking panel. From a users perspective, this means:
  * The old "tracking algorithm" picker is gone. There is only 1
    algorithm now. We may revisit this later, but I would much
    prefer to have only 1 algorithm. So far no optimization work
    has been done so the speed is not there yet.
  * There is now a dropdown to select the motion model. Choices:
        * Translation
        * Translation, rotation
        * Translation, scale
        * Translation, rotation, scale
        * Affine
        * Perspective
  * The old "Hybrid" mode is gone; instead there is a toggle to
    enable or disable translation-only tracker initialization. This
    is the equivalent of the hyrbid mode before, but rewritten to work
    with the new planar tracking modes.
  * The pyramid levels setting is gone. At a future date, the planar
    tracker will decide to use pyramids or not automatically. The
    pyramid setting was ultimately a mistake; with the brute force
    initialization it is unnecessary.
- Add light-normalized tracking
  Added the ability to normalize patterns by their average value while
  tracking, to make them invariant to global illumination changes.
Additional details could be found at wiki page [2]
  [1] http://code.google.com/p/ceres-solver
  [2] http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Motion_Tracker
											
										 
											2012-06-10 15:28:19 +00:00
										 |  |  | 	else if ((scopes->track_search) && | 
					
						
							|  |  |  | 	         ((!scopes->track_preview) || | 
					
						
							| 
									
										
										
										
											2012-06-10 19:59:02 +00:00
										 |  |  | 	          (scopes->track_preview->x != width || scopes->track_preview->y != height))) | 
					
						
							| 
									
										
											  
											
												Planar tracking support for motion tracking
===========================================
Major list of changes done in tomato branch:
- Add a planar tracking implementation to libmv
  This adds a new planar tracking implementation to libmv. The
  tracker is based on Ceres[1], the new nonlinear minimizer that
  myself and Sameer released from Google as open source. Since
  the motion model is more involved, the interface is
  different than the RegionTracker interface used previously
  in Blender.
  The start of a C API in libmv-capi.{cpp,h} is also included.
- Migrate from pat_{min,max} for markers to 4 corners representation
  Convert markers in the movie clip editor / 2D tracker from using
  pat_min and pat_max notation to using the a more general, 4-corner
  representation.
  There is still considerable porting work to do; in particular
  sliding from preview widget does not work correct for rotated
  markers.
  All other areas should be ported to new representation:
  * Added support of sliding individual corners. LMB slide + Ctrl
    would scale the whole pattern
  * S would scale the whole marker, S-S would scale pattern only
  * Added support of marker's rotation which is currently rotates
    only patterns around their centers or all markers around median,
    Rotation or other non-translation/scaling transformation of search
    area doesn't make sense.
  * Track Preview widget would display transformed pattern which
    libmv actually operates with.
- "Efficient Second-order Minimization" for the planar tracker
  This implements the "Efficient Second-order Minimization"
  scheme, as supported by the existing translation tracker.
  This increases the amount of per-iteration work, but
  decreases the number of iterations required to converge and
  also increases the size of the basin of attraction for the
  optimization.
- Remove the use of the legacy RegionTracker API from Blender,
  and replaces it with the new TrackRegion API. This also
  adds several features to the planar tracker in libmv:
  * Do a brute-force initialization of tracking similar to "Hybrid"
    mode in the stable release, but using all floats. This is slower
    but more accurate. It is still necessary to evaluate if the
    performance loss is worth it. In particular, this change is
    necessary to support high bit depth imagery.
  * Add support for masks over the search window. This is a step
    towards supporting user-defined tracker masks. The tracker masks
    will make it easy for users to make a mask for e.g. a ball.
    Not exposed into interface yet/
  * Add Pearson product moment correlation coefficient checking (aka
    "Correlation" in the UI. This causes tracking failure if the
    tracked patch is not linearly related to the template.
  * Add support for warping a few points in addition to the supplied
    points. This is useful because the tracking code deliberately
    does not expose the underlying warp representation. Instead,
    warps are specified in an aparametric way via the correspondences.
- Replace the old style tracker configuration panel with the
  new planar tracking panel. From a users perspective, this means:
  * The old "tracking algorithm" picker is gone. There is only 1
    algorithm now. We may revisit this later, but I would much
    prefer to have only 1 algorithm. So far no optimization work
    has been done so the speed is not there yet.
  * There is now a dropdown to select the motion model. Choices:
        * Translation
        * Translation, rotation
        * Translation, scale
        * Translation, rotation, scale
        * Affine
        * Perspective
  * The old "Hybrid" mode is gone; instead there is a toggle to
    enable or disable translation-only tracker initialization. This
    is the equivalent of the hyrbid mode before, but rewritten to work
    with the new planar tracking modes.
  * The pyramid levels setting is gone. At a future date, the planar
    tracker will decide to use pyramids or not automatically. The
    pyramid setting was ultimately a mistake; with the brute force
    initialization it is unnecessary.
- Add light-normalized tracking
  Added the ability to normalize patterns by their average value while
  tracking, to make them invariant to global illumination changes.
Additional details could be found at wiki page [2]
  [1] http://code.google.com/p/ceres-solver
  [2] http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Motion_Tracker
											
										 
											2012-06-10 15:28:19 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		if (scopes->track_preview) | 
					
						
							|  |  |  | 			IMB_freeImBuf(scopes->track_preview); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-01 19:57:31 +02:00
										 |  |  | 		ImBuf *tmpibuf = BKE_tracking_sample_pattern( | 
					
						
							|  |  |  | 		        scopes->frame_width, scopes->frame_height, | 
					
						
							|  |  |  | 		        scopes->track_search, scopes->track, | 
					
						
							|  |  |  | 		        &scopes->undist_marker, true, scopes->use_track_mask, | 
					
						
							|  |  |  | 		        width, height, scopes->track_pos); | 
					
						
							| 
									
										
										
										
											2012-11-07 11:18:42 +00:00
										 |  |  | 		if (tmpibuf) { | 
					
						
							|  |  |  | 			if (tmpibuf->rect_float) | 
					
						
							|  |  |  | 				IMB_rect_from_float(tmpibuf); | 
					
						
							| 
									
										
											  
											
												Planar tracking support for motion tracking
===========================================
Major list of changes done in tomato branch:
- Add a planar tracking implementation to libmv
  This adds a new planar tracking implementation to libmv. The
  tracker is based on Ceres[1], the new nonlinear minimizer that
  myself and Sameer released from Google as open source. Since
  the motion model is more involved, the interface is
  different than the RegionTracker interface used previously
  in Blender.
  The start of a C API in libmv-capi.{cpp,h} is also included.
- Migrate from pat_{min,max} for markers to 4 corners representation
  Convert markers in the movie clip editor / 2D tracker from using
  pat_min and pat_max notation to using the a more general, 4-corner
  representation.
  There is still considerable porting work to do; in particular
  sliding from preview widget does not work correct for rotated
  markers.
  All other areas should be ported to new representation:
  * Added support of sliding individual corners. LMB slide + Ctrl
    would scale the whole pattern
  * S would scale the whole marker, S-S would scale pattern only
  * Added support of marker's rotation which is currently rotates
    only patterns around their centers or all markers around median,
    Rotation or other non-translation/scaling transformation of search
    area doesn't make sense.
  * Track Preview widget would display transformed pattern which
    libmv actually operates with.
- "Efficient Second-order Minimization" for the planar tracker
  This implements the "Efficient Second-order Minimization"
  scheme, as supported by the existing translation tracker.
  This increases the amount of per-iteration work, but
  decreases the number of iterations required to converge and
  also increases the size of the basin of attraction for the
  optimization.
- Remove the use of the legacy RegionTracker API from Blender,
  and replaces it with the new TrackRegion API. This also
  adds several features to the planar tracker in libmv:
  * Do a brute-force initialization of tracking similar to "Hybrid"
    mode in the stable release, but using all floats. This is slower
    but more accurate. It is still necessary to evaluate if the
    performance loss is worth it. In particular, this change is
    necessary to support high bit depth imagery.
  * Add support for masks over the search window. This is a step
    towards supporting user-defined tracker masks. The tracker masks
    will make it easy for users to make a mask for e.g. a ball.
    Not exposed into interface yet/
  * Add Pearson product moment correlation coefficient checking (aka
    "Correlation" in the UI. This causes tracking failure if the
    tracked patch is not linearly related to the template.
  * Add support for warping a few points in addition to the supplied
    points. This is useful because the tracking code deliberately
    does not expose the underlying warp representation. Instead,
    warps are specified in an aparametric way via the correspondences.
- Replace the old style tracker configuration panel with the
  new planar tracking panel. From a users perspective, this means:
  * The old "tracking algorithm" picker is gone. There is only 1
    algorithm now. We may revisit this later, but I would much
    prefer to have only 1 algorithm. So far no optimization work
    has been done so the speed is not there yet.
  * There is now a dropdown to select the motion model. Choices:
        * Translation
        * Translation, rotation
        * Translation, scale
        * Translation, rotation, scale
        * Affine
        * Perspective
  * The old "Hybrid" mode is gone; instead there is a toggle to
    enable or disable translation-only tracker initialization. This
    is the equivalent of the hyrbid mode before, but rewritten to work
    with the new planar tracking modes.
  * The pyramid levels setting is gone. At a future date, the planar
    tracker will decide to use pyramids or not automatically. The
    pyramid setting was ultimately a mistake; with the brute force
    initialization it is unnecessary.
- Add light-normalized tracking
  Added the ability to normalize patterns by their average value while
  tracking, to make them invariant to global illumination changes.
Additional details could be found at wiki page [2]
  [1] http://code.google.com/p/ceres-solver
  [2] http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Motion_Tracker
											
										 
											2012-06-10 15:28:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-07 11:18:42 +00:00
										 |  |  | 			if (tmpibuf->rect) | 
					
						
							|  |  |  | 				scopes->track_preview = tmpibuf; | 
					
						
							|  |  |  | 			else | 
					
						
							|  |  |  | 				IMB_freeImBuf(tmpibuf); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
											  
											
												Planar tracking support for motion tracking
===========================================
Major list of changes done in tomato branch:
- Add a planar tracking implementation to libmv
  This adds a new planar tracking implementation to libmv. The
  tracker is based on Ceres[1], the new nonlinear minimizer that
  myself and Sameer released from Google as open source. Since
  the motion model is more involved, the interface is
  different than the RegionTracker interface used previously
  in Blender.
  The start of a C API in libmv-capi.{cpp,h} is also included.
- Migrate from pat_{min,max} for markers to 4 corners representation
  Convert markers in the movie clip editor / 2D tracker from using
  pat_min and pat_max notation to using the a more general, 4-corner
  representation.
  There is still considerable porting work to do; in particular
  sliding from preview widget does not work correct for rotated
  markers.
  All other areas should be ported to new representation:
  * Added support of sliding individual corners. LMB slide + Ctrl
    would scale the whole pattern
  * S would scale the whole marker, S-S would scale pattern only
  * Added support of marker's rotation which is currently rotates
    only patterns around their centers or all markers around median,
    Rotation or other non-translation/scaling transformation of search
    area doesn't make sense.
  * Track Preview widget would display transformed pattern which
    libmv actually operates with.
- "Efficient Second-order Minimization" for the planar tracker
  This implements the "Efficient Second-order Minimization"
  scheme, as supported by the existing translation tracker.
  This increases the amount of per-iteration work, but
  decreases the number of iterations required to converge and
  also increases the size of the basin of attraction for the
  optimization.
- Remove the use of the legacy RegionTracker API from Blender,
  and replaces it with the new TrackRegion API. This also
  adds several features to the planar tracker in libmv:
  * Do a brute-force initialization of tracking similar to "Hybrid"
    mode in the stable release, but using all floats. This is slower
    but more accurate. It is still necessary to evaluate if the
    performance loss is worth it. In particular, this change is
    necessary to support high bit depth imagery.
  * Add support for masks over the search window. This is a step
    towards supporting user-defined tracker masks. The tracker masks
    will make it easy for users to make a mask for e.g. a ball.
    Not exposed into interface yet/
  * Add Pearson product moment correlation coefficient checking (aka
    "Correlation" in the UI. This causes tracking failure if the
    tracked patch is not linearly related to the template.
  * Add support for warping a few points in addition to the supplied
    points. This is useful because the tracking code deliberately
    does not expose the underlying warp representation. Instead,
    warps are specified in an aparametric way via the correspondences.
- Replace the old style tracker configuration panel with the
  new planar tracking panel. From a users perspective, this means:
  * The old "tracking algorithm" picker is gone. There is only 1
    algorithm now. We may revisit this later, but I would much
    prefer to have only 1 algorithm. So far no optimization work
    has been done so the speed is not there yet.
  * There is now a dropdown to select the motion model. Choices:
        * Translation
        * Translation, rotation
        * Translation, scale
        * Translation, rotation, scale
        * Affine
        * Perspective
  * The old "Hybrid" mode is gone; instead there is a toggle to
    enable or disable translation-only tracker initialization. This
    is the equivalent of the hyrbid mode before, but rewritten to work
    with the new planar tracking modes.
  * The pyramid levels setting is gone. At a future date, the planar
    tracker will decide to use pyramids or not automatically. The
    pyramid setting was ultimately a mistake; with the brute force
    initialization it is unnecessary.
- Add light-normalized tracking
  Added the ability to normalize patterns by their average value while
  tracking, to make them invariant to global illumination changes.
Additional details could be found at wiki page [2]
  [1] http://code.google.com/p/ceres-solver
  [2] http://wiki.blender.org/index.php/Dev:Ref/Release_Notes/2.64/Motion_Tracker
											
										 
											2012-06-10 15:28:19 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!ok && scopes->track_preview) { | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 		GPU_matrix_push(); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* draw content of pattern area */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 		GPU_scissor(rect.xmin, rect.ymin, scissor[2], scissor[3]); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (width > 0 && height > 0) { | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 			ImBuf *drawibuf = scopes->track_preview; | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 			float col_sel[4], col_outline[4]; | 
					
						
							| 
									
										
										
										
											2012-01-25 13:37:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-12 11:13:53 +00:00
										 |  |  | 			if (scopes->use_track_mask) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 				float color[4] = {0.0f, 0.0f, 0.0f, 0.3f}; | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 				UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 				UI_draw_roundbox_4fv(true, rect.xmin - 1, rect.ymin, rect.xmax + 1, rect.ymax + 1, 3.0f, color); | 
					
						
							| 
									
										
										
										
											2012-06-12 11:13:53 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-11 16:30:00 +02:00
										 |  |  | 			IMMDrawPixelsTexState state = immDrawPixelsTexSetup(GPU_SHADER_2D_IMAGE_COLOR); | 
					
						
							|  |  |  | 			immDrawPixelsTex(&state, rect.xmin, rect.ymin + 1, drawibuf->x, drawibuf->y, GL_RGBA, GL_UNSIGNED_BYTE, GL_LINEAR, drawibuf->rect, 1.0f, 1.0f, NULL); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 			/* draw cross for pixel position */ | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 			GPU_matrix_translate_2f(rect.xmin + scopes->track_pos[0], rect.ymin + scopes->track_pos[1]); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 			GPU_scissor( | 
					
						
							|  |  |  | 			        rect.xmin, | 
					
						
							|  |  |  | 			        rect.ymin, | 
					
						
							|  |  |  | 			        BLI_rctf_size_x(&rect), | 
					
						
							|  |  |  | 			        BLI_rctf_size_y(&rect)); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 			GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 			uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 			uint col = GPU_vertformat_attr_add(format, "color", GPU_COMP_F32, 4, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 			immBindBuiltinProgram(GPU_SHADER_2D_FLAT_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			UI_GetThemeColor4fv(TH_SEL_MARKER, col_sel); | 
					
						
							|  |  |  | 			UI_GetThemeColor4fv(TH_MARKER_OUTLINE, col_outline); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/* Do stipple cross with geometry */ | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 			immBegin(GPU_PRIM_LINES, 7 * 2 * 2); | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 			float pos_sel[8] = {-10.0f, -7.0f, -4.0f, -1.0f, 2.0f, 5.0f, 8.0f, 11.0f}; | 
					
						
							|  |  |  | 			for (int axe = 0; axe < 2; ++axe) { | 
					
						
							|  |  |  | 				for (int i = 0; i < 7; ++i) { | 
					
						
							|  |  |  | 					float x1 = pos_sel[i] * (1 - axe); | 
					
						
							|  |  |  | 					float y1 = pos_sel[i] * axe; | 
					
						
							| 
									
										
										
										
											2017-10-07 15:57:14 +11:00
										 |  |  | 					float x2 = pos_sel[i + 1] * (1 - axe); | 
					
						
							|  |  |  | 					float y2 = pos_sel[i + 1] * axe; | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 					if (i % 2 == 1) | 
					
						
							|  |  |  | 						immAttrib4fv(col, col_sel); | 
					
						
							|  |  |  | 					else | 
					
						
							|  |  |  | 						immAttrib4fv(col, col_outline); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					immVertex2f(pos, x1, y1); | 
					
						
							|  |  |  | 					immVertex2f(pos, x2, y2); | 
					
						
							| 
									
										
										
										
											2012-01-30 09:05:26 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 			immEnd(); | 
					
						
							| 
									
										
										
										
											2016-06-10 07:39:12 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 			immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-15 15:27:15 +02:00
										 |  |  | 		GPU_matrix_pop(); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 		ok = true; | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!ok) { | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		float color[4] = {0.0f, 0.0f, 0.0f, 0.3f}; | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | 		UI_draw_roundbox_corner_set(UI_CNR_ALL); | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 		UI_draw_roundbox_4fv(true, rect.xmin - 1, rect.ymin, rect.xmax + 1, rect.ymax + 1, 3.0f, color); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-02 13:09:43 +02:00
										 |  |  | 	/* outline */ | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | 	draw_scope_end(&rect, scissor); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2011-11-07 12:55:18 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-04 00:05:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-07 15:47:57 +11:00
										 |  |  | void ui_draw_but_NODESOCKET(ARegion *ar, uiBut *but, uiWidgetColors *UNUSED(wcol), const rcti *recti) | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	static const float size = 5.0f; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | 	/* 16 values of sin function */ | 
					
						
							| 
									
										
										
										
											2014-04-27 07:50:08 +10:00
										 |  |  | 	const float si[16] = { | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | 	    0.00000000f, 0.39435585f, 0.72479278f, 0.93775213f, | 
					
						
							|  |  |  | 	    0.99871650f, 0.89780453f, 0.65137248f, 0.29936312f, | 
					
						
							|  |  |  | 	    -0.10116832f, -0.48530196f, -0.79077573f, -0.96807711f, | 
					
						
							|  |  |  | 	    -0.98846832f, -0.84864425f, -0.57126821f, -0.20129852f | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 	/* 16 values of cos function */ | 
					
						
							| 
									
										
										
										
											2014-04-27 07:50:08 +10:00
										 |  |  | 	const float co[16] = { | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | 	    1.00000000f, 0.91895781f, 0.68896691f, 0.34730525f, | 
					
						
							|  |  |  | 	    -0.05064916f, -0.44039415f, -0.75875812f, -0.95413925f, | 
					
						
							|  |  |  | 	    -0.99486932f, -0.87434661f, -0.61210598f, -0.25065253f, | 
					
						
							|  |  |  | 	    0.15142777f, 0.52896401f, 0.82076344f, 0.97952994f, | 
					
						
							|  |  |  | 	}; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	int scissor[4]; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | 	/* need scissor test, can draw outside of boundary */ | 
					
						
							| 
									
										
										
										
											2018-07-02 18:27:05 +02:00
										 |  |  | 	GPU_scissor_get_i(scissor); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	rcti scissor_new = { | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | 		.xmin = recti->xmin, | 
					
						
							|  |  |  | 		.ymin = recti->ymin, | 
					
						
							|  |  |  | 		.xmax = recti->xmax, | 
					
						
							|  |  |  | 		.ymax = recti->ymax | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-27 10:22:37 +02:00
										 |  |  | 	rcti scissor_region = {0, ar->winx, 0, ar->winy}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BLI_rcti_isect(&scissor_new, &scissor_region, &scissor_new); | 
					
						
							| 
									
										
										
										
											2018-07-01 20:15:21 +02:00
										 |  |  | 	GPU_scissor( | 
					
						
							|  |  |  | 	        scissor_new.xmin, | 
					
						
							|  |  |  | 	        scissor_new.ymin, | 
					
						
							|  |  |  | 	        BLI_rcti_size_x(&scissor_new), | 
					
						
							|  |  |  | 	        BLI_rcti_size_y(&scissor_new)); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	float x = 0.5f * (recti->xmin + recti->xmax); | 
					
						
							|  |  |  | 	float y = 0.5f * (recti->ymin + recti->ymax); | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_UNIFORM_COLOR); | 
					
						
							|  |  |  | 	immUniformColor4ubv(but->col); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_TRI_FAN, 16); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int a = 0; a < 16; a++) | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 		immVertex2f(pos, x + size * si[a], y + size * co[a]); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 	immUniformColor4ub(0, 0, 0, 150); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_width(1); | 
					
						
							|  |  |  | 	GPU_line_smooth(true); | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_LINE_LOOP, 16); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	for (int a = 0; a < 16; a++) | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 		immVertex2f(pos, x + size * si[a], y + size * co[a]); | 
					
						
							|  |  |  | 	immEnd(); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(false); | 
					
						
							|  |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
										
										
											2017-02-10 17:36:32 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:50:35 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | 	/* restore scissortest */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_scissor(scissor[0], scissor[1], scissor[2], scissor[3]); | 
					
						
							| 
									
										
										
										
											2013-03-18 16:34:57 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-06 15:44:30 +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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-07 15:03:24 -04:00
										 |  |  | /* TODO: high quality UI drop shadows using GLSL shader and single draw call
 | 
					
						
							|  |  |  |  * would replace / modify the following 3 functions  - merwin | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | static void ui_shadowbox(unsigned pos, unsigned color, float minx, float miny, float maxx, float maxy, float shadsize, unsigned char alpha) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2017-04-10 15:16:59 +02:00
										 |  |  | 	/*          v1-_
 | 
					
						
							|  |  |  | 	 *          |   -_v2 | 
					
						
							|  |  |  | 	 *          |     | | 
					
						
							|  |  |  | 	 *          |     | | 
					
						
							|  |  |  | 	 *          |     | | 
					
						
							|  |  |  | 	 * v7_______v3____v4 | 
					
						
							|  |  |  | 	 * \        |     / | 
					
						
							|  |  |  | 	 *  \       |   _v5 | 
					
						
							|  |  |  | 	 *  v8______v6_- | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	const float v1[2] = {maxx,                   maxy - 0.3f * shadsize}; | 
					
						
							|  |  |  | 	const float v2[2] = {maxx + shadsize,        maxy - 0.75f * shadsize}; | 
					
						
							|  |  |  | 	const float v3[2] = {maxx,                   miny}; | 
					
						
							|  |  |  | 	const float v4[2] = {maxx + shadsize,        miny}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const float v5[2] = {maxx + 0.7f * shadsize, miny - 0.7f * shadsize}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const float v6[2] = {maxx,                   miny - shadsize}; | 
					
						
							|  |  |  | 	const float v7[2] = {minx + 0.3f * shadsize, miny}; | 
					
						
							|  |  |  | 	const float v8[2] = {minx + 0.5f * shadsize, miny - shadsize}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-06 15:44:30 +00:00
										 |  |  | 	/* right quad */ | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	immAttrib4ub(color, 0, 0, 0, alpha); | 
					
						
							| 
									
										
										
										
											2017-04-10 15:16:59 +02:00
										 |  |  | 	immVertex2fv(pos, v3); | 
					
						
							|  |  |  | 	immVertex2fv(pos, v1); | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	immAttrib4ub(color, 0, 0, 0, 0); | 
					
						
							| 
									
										
										
										
											2017-04-10 15:16:59 +02:00
										 |  |  | 	immVertex2fv(pos, v2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immVertex2fv(pos, v2); | 
					
						
							|  |  |  | 	immVertex2fv(pos, v4); | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	immAttrib4ub(color, 0, 0, 0, alpha); | 
					
						
							| 
									
										
										
										
											2017-04-10 15:16:59 +02:00
										 |  |  | 	immVertex2fv(pos, v3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* corner shape */ | 
					
						
							|  |  |  | 	/* immAttrib4ub(color, 0, 0, 0, alpha); */  /* Not needed, done above in previous tri */ | 
					
						
							|  |  |  | 	immVertex2fv(pos, v3); | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	immAttrib4ub(color, 0, 0, 0, 0); | 
					
						
							| 
									
										
										
										
											2017-04-10 15:16:59 +02:00
										 |  |  | 	immVertex2fv(pos, v4); | 
					
						
							|  |  |  | 	immVertex2fv(pos, v5); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immVertex2fv(pos, v5); | 
					
						
							|  |  |  | 	immVertex2fv(pos, v6); | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	immAttrib4ub(color, 0, 0, 0, alpha); | 
					
						
							| 
									
										
										
										
											2017-04-10 15:16:59 +02:00
										 |  |  | 	immVertex2fv(pos, v3); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* bottom quad */ | 
					
						
							|  |  |  | 	/* immAttrib4ub(color, 0, 0, 0, alpha); */  /* Not needed, done above in previous tri */ | 
					
						
							|  |  |  | 	immVertex2fv(pos, v3); | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	immAttrib4ub(color, 0, 0, 0, 0); | 
					
						
							| 
									
										
										
										
											2017-04-10 15:16:59 +02:00
										 |  |  | 	immVertex2fv(pos, v6); | 
					
						
							|  |  |  | 	immVertex2fv(pos, v8); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immVertex2fv(pos, v8); | 
					
						
							|  |  |  | 	immAttrib4ub(color, 0, 0, 0, alpha); | 
					
						
							|  |  |  | 	immVertex2fv(pos, v7); | 
					
						
							|  |  |  | 	immVertex2fv(pos, v3); | 
					
						
							| 
									
										
											  
											
												
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_draw_box_shadow(unsigned char alpha, float minx, float miny, float maxx, float maxy) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUVertFormat *format = immVertexFormat(); | 
					
						
							|  |  |  | 	uint pos = GPU_vertformat_attr_add(format, "pos", GPU_COMP_F32, 2, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 	uint color = GPU_vertformat_attr_add(format, "color", GPU_COMP_U8, 4, GPU_FETCH_INT_TO_FLOAT_UNIT); | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	immBindBuiltinProgram(GPU_SHADER_2D_SMOOTH_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	immBegin(GPU_PRIM_TRIS, 54); | 
					
						
							| 
									
										
										
										
											2016-01-16 01:17:51 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-06 15:44:30 +00:00
										 |  |  | 	/* accumulated outline boxes to make shade not linear, is more pleasant */ | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	ui_shadowbox(pos, color, minx, miny, maxx, maxy, 11.0, (20 * alpha) >> 8); | 
					
						
							|  |  |  | 	ui_shadowbox(pos, color, minx, miny, maxx, maxy, 7.0, (40 * alpha) >> 8); | 
					
						
							|  |  |  | 	ui_shadowbox(pos, color, minx, miny, maxx, maxy, 5.0, (80 * alpha) >> 8); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-11 01:06:17 -04:00
										 |  |  | 	immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
											  
											
												
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-04-06 15:44:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-09 21:20:40 +01:00
										 |  |  | void ui_draw_dropshadow(const rctf *rct, float radius, float aspect, float alpha, int UNUSED(select)) | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | { | 
					
						
							|  |  |  | 	float rad; | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-08 01:43:53 -05:00
										 |  |  | 	if (radius > (BLI_rctf_size_y(rct) - 10.0f) * 0.5f) | 
					
						
							|  |  |  | 		rad = (BLI_rctf_size_y(rct) - 10.0f) * 0.5f; | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		rad = radius; | 
					
						
							| 
									
										
										
										
											2011-01-23 11:42:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	int a, i = 12; | 
					
						
							| 
									
										
										
										
											2011-05-01 10:14:09 +00:00
										 |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (select) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		a = i * aspect; /* same as below */ | 
					
						
							| 
									
										
										
										
											2011-05-01 10:14:09 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		a = i * aspect; | 
					
						
							| 
									
										
										
										
											2011-05-01 10:14:09 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(true); | 
					
						
							| 
									
										
										
										
											2016-01-16 02:17:05 -05:00
										 |  |  | 	const float dalpha = alpha * 2.0f / 255.0f; | 
					
						
							|  |  |  | 	float calpha = dalpha; | 
					
						
							| 
									
										
										
										
											2018-04-06 10:09:23 +02:00
										 |  |  | 	float visibility = 1.0f; | 
					
						
							|  |  |  | 	for (; i--;) { | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 		/* alpha ranges from 2 to 20 or so */ | 
					
						
							| 
									
										
										
										
											2018-04-06 10:09:23 +02:00
										 |  |  | #if 0 /* Old Method (pre 2.8) */
 | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 		float color[4] = {0.0f, 0.0f, 0.0f, calpha}; | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 		UI_draw_roundbox_4fv(true, rct->xmin - a, rct->ymin - a, rct->xmax + a, rct->ymax - 10.0f + a, rad + a, color); | 
					
						
							| 
									
										
										
										
											2018-04-06 10:09:23 +02:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 		/* Compute final visibility to match old method result. */ | 
					
						
							|  |  |  | 		/* TODO we could just find a better fit function inside the shader instead of this. */ | 
					
						
							|  |  |  | 		visibility = visibility * (1.0f - calpha); | 
					
						
							| 
									
										
										
										
											2012-06-01 14:42:21 +00:00
										 |  |  | 		calpha += dalpha; | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-06 10:09:23 +02:00
										 |  |  | 	uiWidgetBaseParameters widget_params = { | 
					
						
							|  |  |  | 		.recti.xmin = rct->xmin, .recti.ymin = rct->ymin, | 
					
						
							|  |  |  | 		.recti.xmax = rct->xmax, .recti.ymax = rct->ymax - 10.0f, | 
					
						
							|  |  |  | 		.rect.xmin = rct->xmin - a, .rect.ymin = rct->ymin - a, | 
					
						
							|  |  |  | 		.rect.xmax = rct->xmax + a, .rect.ymax = rct->ymax - 10.0f + a, | 
					
						
							|  |  |  | 		.radi = rad, | 
					
						
							|  |  |  | 		.rad = rad + a, | 
					
						
							|  |  |  | 		.round_corners[0] = (roundboxtype & UI_CNR_BOTTOM_LEFT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[1] = (roundboxtype & UI_CNR_BOTTOM_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[2] = (roundboxtype & UI_CNR_TOP_RIGHT) ? 1.0f : 0.0f, | 
					
						
							|  |  |  | 		.round_corners[3] = (roundboxtype & UI_CNR_TOP_LEFT) ? 1.0f : 0.0f, | 
					
						
							| 
									
										
										
										
											2018-05-03 09:56:20 +02:00
										 |  |  | 		.alpha_discard = 1.0f, | 
					
						
							| 
									
										
										
										
											2018-04-06 10:09:23 +02:00
										 |  |  | 	}; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 00:12:21 +02:00
										 |  |  | 	GPUBatch *batch = ui_batch_roundbox_shadow_get(); | 
					
						
							|  |  |  | 	GPU_batch_program_set_builtin(batch, GPU_SHADER_2D_WIDGET_SHADOW); | 
					
						
							|  |  |  | 	GPU_batch_uniform_4fv_array(batch, "parameters", 4, (float *)&widget_params); | 
					
						
							|  |  |  | 	GPU_batch_uniform_1f(batch, "alpha", 1.0f - visibility); | 
					
						
							|  |  |  | 	GPU_batch_draw(batch); | 
					
						
							| 
									
										
										
										
											2018-04-06 10:09:23 +02: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
										 |  |  | 	/* outline emphasis */ | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(true); | 
					
						
							| 
									
										
										
										
											2016-10-07 14:56:08 -04:00
										 |  |  | 	float color[4] = {0.0f, 0.0f, 0.0f, 0.4f}; | 
					
						
							| 
									
										
										
										
											2017-04-06 19:15:26 -04:00
										 |  |  | 	UI_draw_roundbox_4fv(false, rct->xmin - 0.5f, rct->ymin - 0.5f, rct->xmax + 0.5f, rct->ymax + 0.5f, radius + 0.5f, color); | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_line_smooth(false); | 
					
						
							| 
									
										
										
										
											2018-05-23 10:47:12 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | 	GPU_blend(false); | 
					
						
							| 
									
										
											  
											
												
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
										 |  |  | } |