| 
									
										
										
										
											2011-02-23 10:52:22 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  |  * ***** 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. | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Blender Foundation 2009. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  | /** \file blender/editors/interface/interface_layout.c
 | 
					
						
							|  |  |  |  *  \ingroup edinterface | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | #include <limits.h>
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							| 
									
										
										
										
											2011-01-24 05:15:14 +00:00
										 |  |  | #include <assert.h>
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_screen_types.h"
 | 
					
						
							| 
									
										
										
										
											2010-12-12 18:16:54 +00:00
										 |  |  | #include "DNA_armature_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-04-27 18:05:58 +00:00
										 |  |  | #include "DNA_userdef_types.h"
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "BLI_listbase.h"
 | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | #include "BLI_string.h"
 | 
					
						
							| 
									
										
										
										
											2012-08-21 19:35:06 +00:00
										 |  |  | #include "BLI_rect.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
										
											2012-10-24 05:06:40 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-20 07:39:25 +00:00
										 |  |  | #include "BLF_translation.h"
 | 
					
						
							| 
									
										
										
										
											2011-06-15 11:41:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | #include "BKE_context.h"
 | 
					
						
							|  |  |  | #include "BKE_global.h"
 | 
					
						
							|  |  |  | #include "BKE_idprop.h"
 | 
					
						
							| 
									
										
										
										
											2009-03-29 19:44:39 +00:00
										 |  |  | #include "BKE_screen.h"
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "RNA_access.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "UI_interface.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "WM_api.h"
 | 
					
						
							|  |  |  | #include "WM_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-02 01:39:33 +00:00
										 |  |  | #include "interface_intern.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | /************************ Structs and Defines *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | #define RNA_NO_INDEX    -1
 | 
					
						
							|  |  |  | #define RNA_ENUM_VALUE  -2
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:44:48 +00:00
										 |  |  | // #define USE_OP_RESET_BUT  // we may want to make this optional, disable for now.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 19:52:41 +00:00
										 |  |  | #define UI_OPERATOR_ERROR_RET(_ot, _opname, return_statement)                 \
 | 
					
						
							|  |  |  | 	if (ot == NULL) {                                                         \ | 
					
						
							|  |  |  | 		ui_item_disabled(layout, _opname);                                    \ | 
					
						
							|  |  |  | 		RNA_warning("'%s' unknown operator", _opname);                        \ | 
					
						
							|  |  |  | 		return_statement;                                                     \ | 
					
						
							|  |  |  | 	} (void)0                                                                 \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | /* uiLayoutRoot */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct uiLayoutRoot { | 
					
						
							|  |  |  | 	struct uiLayoutRoot *next, *prev; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int type; | 
					
						
							|  |  |  | 	int opcontext; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int emw, emh; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiMenuHandleFunc handlefunc; | 
					
						
							|  |  |  | 	void *argv; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiStyle *style; | 
					
						
							|  |  |  | 	uiBlock *block; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiLayout *layout; | 
					
						
							|  |  |  | } uiLayoutRoot; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* Item */ | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | typedef enum uiItemType { | 
					
						
							|  |  |  | 	ITEM_BUTTON, | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	ITEM_LAYOUT_ROW, | 
					
						
							|  |  |  | 	ITEM_LAYOUT_COLUMN, | 
					
						
							|  |  |  | 	ITEM_LAYOUT_COLUMN_FLOW, | 
					
						
							|  |  |  | 	ITEM_LAYOUT_ROW_FLOW, | 
					
						
							|  |  |  | 	ITEM_LAYOUT_BOX, | 
					
						
							| 
									
										
										
										
											2009-10-09 10:45:11 +00:00
										 |  |  | 	ITEM_LAYOUT_ABSOLUTE, | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	ITEM_LAYOUT_SPLIT, | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 	ITEM_LAYOUT_OVERLAP, | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	ITEM_LAYOUT_ROOT | 
					
						
							|  |  |  | #if 0
 | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 	TEMPLATE_COLUMN_FLOW, | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 	TEMPLATE_SPLIT, | 
					
						
							|  |  |  | 	TEMPLATE_BOX, | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	TEMPLATE_HEADER, | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	TEMPLATE_HEADER_ID | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | } uiItemType; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | typedef struct uiItem { | 
					
						
							|  |  |  | 	void *next, *prev; | 
					
						
							|  |  |  | 	uiItemType type; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 	int flag; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } uiItem; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct uiButtonItem { | 
					
						
							|  |  |  | 	uiItem item; | 
					
						
							|  |  |  | 	uiBut *but; | 
					
						
							|  |  |  | } uiButtonItem; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct uiLayout { | 
					
						
							|  |  |  | 	uiItem item; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiLayoutRoot *root; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:13:42 +00:00
										 |  |  | 	bContextStore *context; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	ListBase items; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int x, y, w, h; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 	float scale[2]; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | 	short space; | 
					
						
							|  |  |  | 	char align; | 
					
						
							|  |  |  | 	char active; | 
					
						
							|  |  |  | 	char enabled; | 
					
						
							|  |  |  | 	char redalert; | 
					
						
							|  |  |  | 	char keepaspect; | 
					
						
							|  |  |  | 	char alignment; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct uiLayoutItemFlow { | 
					
						
							|  |  |  | 	uiLayout litem; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 	int number; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int totcol; | 
					
						
							|  |  |  | } uiLayoutItemFlow; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | typedef struct uiLayoutItemBx { | 
					
						
							|  |  |  | 	uiLayout litem; | 
					
						
							| 
									
										
										
										
											2009-05-21 15:34:09 +00:00
										 |  |  | 	uiBut *roundbox; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } uiLayoutItemBx; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-07-26 20:22:54 +00:00
										 |  |  | typedef struct uiLayoutItemSplit { | 
					
						
							| 
									
										
										
										
											2009-06-07 13:20:41 +00:00
										 |  |  | 	uiLayout litem; | 
					
						
							|  |  |  | 	float percentage; | 
					
						
							| 
									
										
										
										
											2011-07-26 20:22:54 +00:00
										 |  |  | } uiLayoutItemSplit; | 
					
						
							| 
									
										
										
										
											2009-06-07 13:20:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | typedef struct uiLayoutItemRoot { | 
					
						
							|  |  |  | 	uiLayout litem; | 
					
						
							|  |  |  | } uiLayoutItemRoot; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /************************** Item ***************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static const char *ui_item_name_add_colon(const char *name, char namestr[UI_MAX_NAME_STR]) | 
					
						
							| 
									
										
										
										
											2009-04-27 18:05:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	int len = strlen(name); | 
					
						
							| 
									
										
										
										
											2009-04-27 18:05:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (len != 0 && len + 1 < UI_MAX_NAME_STR) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		BLI_strncpy(namestr, name, UI_MAX_NAME_STR); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		namestr[len] = ':'; | 
					
						
							|  |  |  | 		namestr[len + 1] = '\0'; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		return namestr; | 
					
						
							| 
									
										
										
										
											2009-04-27 18:05:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return name; | 
					
						
							| 
									
										
										
										
											2009-04-27 18:05:58 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | static int ui_item_fit(int item, int pos, int all, int available, int last, int alignment, int *offset) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-24 14:21:14 +00:00
										 |  |  | 	if (offset) | 
					
						
							|  |  |  | 		*offset = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* available == 0 is unlimited */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (available == 0) | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 		return item; | 
					
						
							| 
									
										
										
										
											2012-12-24 14:21:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (all > available) { | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 		/* contents is bigger than available space */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (last) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			return available - pos; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			return (item * available) / all; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* contents is smaller or equal to available space */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (alignment == UI_LAYOUT_ALIGN_EXPAND) { | 
					
						
							|  |  |  | 			if (last) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				return available - pos; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				return (item * available) / all; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			return item; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* variable button size in which direction? */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | #define UI_ITEM_VARY_X  1
 | 
					
						
							|  |  |  | #define UI_ITEM_VARY_Y  2
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | static int ui_layout_vary_direction(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	return (layout->root->type == UI_LAYOUT_HEADER || layout->alignment != UI_LAYOUT_ALIGN_EXPAND) ? UI_ITEM_VARY_X : UI_ITEM_VARY_Y; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* estimated size of text + icon */ | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static int ui_text_icon_width(uiLayout *layout, const char *name, int icon, int compact) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	float f5 = 0.25f * UI_UNIT_X; | 
					
						
							|  |  |  | 	float f10 = 0.5f * UI_UNIT_X; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int variable = ui_layout_vary_direction(layout) == UI_ITEM_VARY_X; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (icon && !name[0]) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		return UI_UNIT_X;  /* icon only */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (icon) | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		return (variable) ? UI_GetStringWidth(name) + (compact ? f5 : f10) + UI_UNIT_X : 10 * UI_UNIT_X;  /* icon + text */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		return (variable) ? UI_GetStringWidth(name) + (compact ? f5 : f10) + UI_UNIT_X : 10 * UI_UNIT_X;  /* text only */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_item_size(uiItem *item, int *r_w, int *r_h) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (item->type == ITEM_BUTTON) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiButtonItem *bitem = (uiButtonItem *)item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-15 11:48:20 +00:00
										 |  |  | 		if (r_w) *r_w = BLI_rctf_size_x(&bitem->but->rect); | 
					
						
							|  |  |  | 		if (r_h) *r_h = BLI_rctf_size_y(&bitem->but->rect); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiLayout *litem = (uiLayout *)item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (r_w) *r_w = litem->w; | 
					
						
							|  |  |  | 		if (r_h) *r_h = litem->h; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_item_offset(uiItem *item, int *r_x, int *r_y) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (item->type == ITEM_BUTTON) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiButtonItem *bitem = (uiButtonItem *)item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-18 16:53:46 +00:00
										 |  |  | 		if (r_x) *r_x = bitem->but->rect.xmin; | 
					
						
							|  |  |  | 		if (r_y) *r_y = bitem->but->rect.ymin; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (r_x) *r_x = 0; | 
					
						
							|  |  |  | 		if (r_y) *r_y = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_item_position(uiItem *item, int x, int y, int w, int h) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (item->type == ITEM_BUTTON) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiButtonItem *bitem = (uiButtonItem *)item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-18 16:53:46 +00:00
										 |  |  | 		bitem->but->rect.xmin = x; | 
					
						
							|  |  |  | 		bitem->but->rect.ymin = y; | 
					
						
							|  |  |  | 		bitem->but->rect.xmax = x + w; | 
					
						
							|  |  |  | 		bitem->but->rect.ymax = y + h; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		ui_check_but(bitem->but); /* for strlen */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiLayout *litem = (uiLayout *)item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		litem->x = x; | 
					
						
							|  |  |  | 		litem->y = y + h; | 
					
						
							|  |  |  | 		litem->w = w; | 
					
						
							|  |  |  | 		litem->h = h; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /******************** Special RNA Items *********************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int ui_layout_local_dir(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	switch (layout->item.type) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		case ITEM_LAYOUT_ROW: | 
					
						
							|  |  |  | 		case ITEM_LAYOUT_ROOT: | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 		case ITEM_LAYOUT_OVERLAP: | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			return UI_LAYOUT_HORIZONTAL; | 
					
						
							|  |  |  | 		case ITEM_LAYOUT_COLUMN: | 
					
						
							|  |  |  | 		case ITEM_LAYOUT_COLUMN_FLOW: | 
					
						
							|  |  |  | 		case ITEM_LAYOUT_SPLIT: | 
					
						
							| 
									
										
										
										
											2009-10-09 10:45:11 +00:00
										 |  |  | 		case ITEM_LAYOUT_ABSOLUTE: | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		case ITEM_LAYOUT_BOX: | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			return UI_LAYOUT_VERTICAL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static uiLayout *ui_item_local_sublayout(uiLayout *test, uiLayout *layout, int align) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiLayout *sub; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ui_layout_local_dir(test) == UI_LAYOUT_HORIZONTAL) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		sub = uiLayoutRow(layout, align); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		sub = uiLayoutColumn(layout, align); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	sub->space = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	return sub; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | static void ui_layer_but_cb(bContext *C, void *arg_but, void *arg_index) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	wmWindow *win = CTX_wm_window(C); | 
					
						
							|  |  |  | 	uiBut *but = arg_but, *cbut; | 
					
						
							|  |  |  | 	PointerRNA *ptr = &but->rnapoin; | 
					
						
							|  |  |  | 	PropertyRNA *prop = but->rnaprop; | 
					
						
							|  |  |  | 	int i, index = GET_INT_FROM_POINTER(arg_index); | 
					
						
							|  |  |  | 	int shift = win->eventstate->shift; | 
					
						
							|  |  |  | 	int len = RNA_property_array_length(ptr, prop); | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!shift) { | 
					
						
							| 
									
										
										
										
											2012-01-16 16:12:03 +00:00
										 |  |  | 		RNA_property_boolean_set_index(ptr, prop, index, TRUE); | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (i = 0; i < len; i++) | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (i != index) | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 				RNA_property_boolean_set_index(ptr, prop, i, 0); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		RNA_property_update(C, ptr, prop); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (cbut = but->block->buttons.first; cbut; cbut = cbut->next) | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 			ui_check_but(cbut); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | /* create buttons for an item with an RNA array */ | 
					
						
							| 
									
										
										
										
											2012-12-23 01:18:35 +00:00
										 |  |  | static void ui_item_array(uiLayout *layout, uiBlock *block, const char *name, int icon, | 
					
						
							|  |  |  |                           PointerRNA *ptr, PropertyRNA *prop, int len, int x, int y, int w, int UNUSED(h), | 
					
						
							|  |  |  |                           int expand, int slider, int toggle, int icon_only) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiStyle *style = layout->root->style; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	PropertyType type; | 
					
						
							|  |  |  | 	PropertySubType subtype; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayout *sub; | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 	int a, b; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* retrieve type and subtype */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	type = RNA_property_type(prop); | 
					
						
							|  |  |  | 	subtype = RNA_property_subtype(prop); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	sub = ui_item_local_sublayout(layout, layout, 1); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, sub); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* create label */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (name[0]) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		uiDefBut(block, LABEL, 0, name, 0, 0, w, UI_UNIT_Y, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* create buttons */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (type == PROP_BOOLEAN && ELEM(subtype, PROP_LAYER, PROP_LAYER_MEMBER)) { | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 		/* special check for layer layout */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		int butw, buth, unit; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		int cols = (len >= 20) ? 2 : 1; | 
					
						
							|  |  |  | 		int colbuts = len / (2 * cols); | 
					
						
							|  |  |  | 		int layer_used = 0; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 		uiBlockSetCurLayout(block, uiLayoutAbsolute(layout, FALSE)); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		unit = UI_UNIT_X * 0.75; | 
					
						
							|  |  |  | 		butw = unit; | 
					
						
							|  |  |  | 		buth = unit; | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (ptr->type == &RNA_Armature) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			bArmature *arm = (bArmature *)ptr->data; | 
					
						
							|  |  |  | 			layer_used = arm->layer_used; | 
					
						
							| 
									
										
										
										
											2010-12-12 18:16:54 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (b = 0; b < cols; b++) { | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 			uiBlockBeginAlign(block); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			for (a = 0; a < colbuts; a++) { | 
					
						
							|  |  |  | 				if (layer_used & (1 << (a + b * colbuts))) icon = ICON_LAYER_USED; | 
					
						
							|  |  |  | 				else icon = ICON_BLANK1; | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				but = uiDefAutoButR(block, ptr, prop, a + b * colbuts, "", icon, x + butw * a, y + buth, butw, buth); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 				if (subtype == PROP_LAYER_MEMBER) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					uiButSetFunc(but, ui_layer_but_cb, but, SET_INT_IN_POINTER(a + b * colbuts)); | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			for (a = 0; a < colbuts; a++) { | 
					
						
							|  |  |  | 				if (layer_used & (1 << (a + len / 2 + b * colbuts))) icon = ICON_LAYER_USED; | 
					
						
							|  |  |  | 				else icon = ICON_BLANK1; | 
					
						
							| 
									
										
										
										
											2011-08-14 10:17:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				but = uiDefAutoButR(block, ptr, prop, a + len / 2 + b * colbuts, "", icon, x + butw * a, y, butw, buth); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 				if (subtype == PROP_LAYER_MEMBER) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					uiButSetFunc(but, ui_layer_but_cb, but, SET_INT_IN_POINTER(a + len / 2 + b * colbuts)); | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			uiBlockEndAlign(block); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			x += colbuts * butw + style->buttonspacex; | 
					
						
							| 
									
										
										
										
											2009-09-09 17:39:19 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (subtype == PROP_MATRIX) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		int totdim, dim_size[3];    /* 3 == RNA_MAX_ARRAY_DIMENSION */ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 		int row, col; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 		uiBlockSetCurLayout(block, uiLayoutAbsolute(layout, TRUE)); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		totdim = RNA_property_array_dimension(ptr, prop, dim_size); | 
					
						
							|  |  |  | 		if (totdim != 2) return;    /* only 2D matrices supported in UI so far */ | 
					
						
							| 
									
										
										
										
											2010-01-06 01:41:00 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		w /= dim_size[0]; | 
					
						
							| 
									
										
										
										
											2011-09-12 00:00:21 +00:00
										 |  |  | 		/* h /= dim_size[1]; */ /* UNUSED */ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (a = 0; a < len; a++) { | 
					
						
							|  |  |  | 			col = a % dim_size[0]; | 
					
						
							|  |  |  | 			row = a / dim_size[0]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			but = uiDefAutoButR(block, ptr, prop, a, "", ICON_NONE, x + w * col, y + (dim_size[1] * UI_UNIT_Y) - (row * UI_UNIT_Y), w, UI_UNIT_Y); | 
					
						
							|  |  |  | 			if (slider && but->type == NUM) | 
					
						
							|  |  |  | 				but->type = NUMSLI; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-11-17 16:11:02 +00:00
										 |  |  | 	else if (subtype == PROP_DIRECTION && !expand) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiDefButR_prop(block, BUT_NORMAL, 0, name, x, y, UI_UNIT_X * 3, UI_UNIT_Y * 3, ptr, prop, 0, 0, 0, -1, -1, NULL); | 
					
						
							| 
									
										
										
										
											2011-05-19 11:18:09 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
											
												RNA: subtypes and units
* Reviewed subtypes, making them more specific and adding new ones.
* Subtypes now have an associated type of units (length, area, volume,
  mass, rotation, time, velocity, acceleration). These are not used
  yet anywhere.
* Centralized code that decides the name of array items based on
  subtype (XYZ, RGB), was copied in 3 places.
* RNA_def_float etc functions still need to be update, will do this
  later together with another change.
											
										 
											2009-08-10 21:31:05 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 		/* note, this block of code is a bit arbitrary and has just been made
 | 
					
						
							|  |  |  | 		 * to work with common cases, but may need to be re-worked */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* special case, boolean array in a menu, this could be used in a more generic way too */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (ELEM(subtype, PROP_COLOR, PROP_COLOR_GAMMA) && !expand) { | 
					
						
							| 
									
										
										
										
											2011-02-27 18:03:19 +00:00
										 |  |  | 			uiDefAutoButR(block, ptr, prop, -1, "", ICON_NONE, 0, 0, w, UI_UNIT_Y); | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			int *boolarr = NULL; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 			/* even if 'expand' is fale, expanding anyway */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* layout for known array subtypes */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			char str[3] = {'\0'}; | 
					
						
							| 
									
										
										
											
												RNA: subtypes and units
* Reviewed subtypes, making them more specific and adding new ones.
* Subtypes now have an associated type of units (length, area, volume,
  mass, rotation, time, velocity, acceleration). These are not used
  yet anywhere.
* Centralized code that decides the name of array items based on
  subtype (XYZ, RGB), was copied in 3 places.
* RNA_def_float etc functions still need to be update, will do this
  later together with another change.
											
										 
											2009-08-10 21:31:05 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (!icon_only) { | 
					
						
							|  |  |  | 				if (type != PROP_BOOLEAN) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					str[1] = ':'; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 			/* show checkboxes for rna on a non-emboss block (menu for eg) */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (type == PROP_BOOLEAN && ELEM(layout->root->block->dt, UI_EMBOSSN, UI_EMBOSSP)) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				boolarr = MEM_callocN(sizeof(int) * len, "ui_item_array"); | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 				RNA_property_boolean_get_array(ptr, prop, boolarr); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			for (a = 0; a < len; a++) { | 
					
						
							|  |  |  | 				if (!icon_only) str[0] = RNA_property_array_item_char(prop, a); | 
					
						
							|  |  |  | 				if (boolarr) icon = boolarr[a] ? ICON_CHECKBOX_HLT : ICON_CHECKBOX_DEHLT; | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 				but = uiDefAutoButR(block, ptr, prop, a, str, icon, 0, 0, w, UI_UNIT_Y); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				if (slider && but->type == NUM) | 
					
						
							|  |  |  | 					but->type = NUMSLI; | 
					
						
							|  |  |  | 				if (toggle && but->type == OPTION) | 
					
						
							|  |  |  | 					but->type = TOG; | 
					
						
							| 
									
										
										
										
											2009-03-25 20:49:15 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (boolarr) { | 
					
						
							| 
									
										
										
										
											2011-08-14 11:38:17 +00:00
										 |  |  | 				MEM_freeN(boolarr); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static void ui_item_enum_expand(uiLayout *layout, uiBlock *block, PointerRNA *ptr, PropertyRNA *prop, const char *uiname, int h, int icon_only) | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-06-26 20:00:45 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 	EnumPropertyItem *item; | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | 	const char *name; | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 	int a, totitem, itemw, icon, value, free; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-15 13:20:18 +00:00
										 |  |  | 	RNA_property_enum_items_gettexted(block->evil_C, ptr, prop, &item, &totitem, &free); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-17 01:03:56 +00:00
										 |  |  | 	/* we dont want nested rows, cols in menus */ | 
					
						
							|  |  |  | 	if (layout->root->type != UI_LAYOUT_MENU) { | 
					
						
							|  |  |  | 		uiBlockSetCurLayout(block, ui_item_local_sublayout(layout, layout, 1)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		uiBlockSetCurLayout(block, layout); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (a = 0; a < totitem; a++) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (!item[a].identifier[0]) | 
					
						
							| 
									
										
										
										
											2009-07-10 11:36:02 +00:00
										 |  |  | 			continue; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = (!uiname || uiname[0]) ? item[a].name : ""; | 
					
						
							|  |  |  | 		icon = item[a].icon; | 
					
						
							|  |  |  | 		value = item[a].value; | 
					
						
							|  |  |  | 		itemw = ui_text_icon_width(block->curlayout, name, icon, 0); | 
					
						
							| 
									
										
										
										
											2009-06-16 01:08:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (icon && name[0] && !icon_only) | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 			but = uiDefIconTextButR_prop(block, ROW, 0, icon, name, 0, 0, itemw, h, ptr, prop, -1, 0, value, -1, -1, NULL); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (icon) | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 			but = uiDefIconButR_prop(block, ROW, 0, icon, 0, 0, itemw, h, ptr, prop, -1, 0, value, -1, -1, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-16 01:08:39 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 			but = uiDefButR_prop(block, ROW, 0, name, 0, 0, itemw, h, ptr, prop, -1, 0, value, -1, -1, NULL); | 
					
						
							| 
									
										
										
										
											2010-06-26 20:00:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (ui_layout_local_dir(layout) != UI_LAYOUT_HORIZONTAL) | 
					
						
							| 
									
										
										
										
											2010-06-26 20:00:45 +00:00
										 |  |  | 			but->flag |= UI_TEXT_LEFT; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 	if (free) { | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 		MEM_freeN(item); | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
											
										 
											2009-10-08 18:40:03 +00:00
										 |  |  | /* callback for keymap item change button */ | 
					
						
							| 
									
										
										
										
											2010-10-14 12:24:08 +00:00
										 |  |  | static void ui_keymap_but_cb(bContext *UNUSED(C), void *but_v, void *UNUSED(key_v)) | 
					
						
							| 
									
										
											  
											
												Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
											
										 
											2009-10-08 18:40:03 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBut *but = but_v; | 
					
						
							| 
									
										
											  
											
												Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
											
										 
											2009-10-08 18:40:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-24 09:26:06 +00:00
										 |  |  | 	RNA_boolean_set(&but->rnapoin, "shift", (but->modifier_key & KM_SHIFT) != 0); | 
					
						
							|  |  |  | 	RNA_boolean_set(&but->rnapoin, "ctrl", (but->modifier_key & KM_CTRL) != 0); | 
					
						
							|  |  |  | 	RNA_boolean_set(&but->rnapoin, "alt", (but->modifier_key & KM_ALT) != 0); | 
					
						
							|  |  |  | 	RNA_boolean_set(&but->rnapoin, "oskey", (but->modifier_key & KM_OSKEY) != 0); | 
					
						
							| 
									
										
											  
											
												Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
											
										 
											2009-10-08 18:40:03 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | /* create label + button for RNA property */ | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static uiBut *ui_item_with_label(uiLayout *layout, uiBlock *block, const char *name, int icon, PointerRNA *ptr, PropertyRNA *prop, int index, int x, int y, int w, int h, int flag) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayout *sub; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBut *but = NULL; | 
					
						
							| 
									
										
										
										
											2009-09-16 18:47:42 +00:00
										 |  |  | 	PropertyType type; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	PropertySubType subtype; | 
					
						
							| 
									
										
											  
											
												2.5: Render
* UI layout for scene buttons has quite some changes, I tried to
  better organize things according to the pipeline, and also showing
  important properties by default, and collapsing less important ones.
Some changes compared to 2.4x:
* Panorama is now a Camera property.
* Sequence and Compositing are now enabled by default, but will only
  do something when there is a node tree using nodes, or a strip in the
  sequence editor.
* Enabling Full Sample now automatically enables Save Buffers too.
* Stamp option to include info in file is removed, it now simply always
  does this if one of the stamp infos is enabled.
* Xvid, H.264 and Ogg Theora are now directly in the file format menu,
  but still using FFMPEG. Unfortunately Ogg is broken at the moment
  (also in 2.4x), so that's disabled. And Xvid crashes on 64bit linux,
  maybe solvable by upgrading extern/xvidcore/, using ubuntu libs makes
  it work.
* Organized file format menu by image/movie types.
Added:
* Render layers RNA wrapped, operatorized, layouted.
* FFMPEG format/codec options are now working.
Defaults changed:
* Compositing & Sequencer enabled.
* Tiles set to 8x8.
* Time/Date/Frame/Scene/Camera/Filename enabled for stamp.
											
										 
											2009-07-13 19:09:13 +00:00
										 |  |  | 	int labelw; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 	sub = uiLayoutRow(layout, FALSE); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, sub); | 
					
						
							| 
									
										
										
										
											2009-03-30 18:26:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (name[0]) { | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | 		/* XXX UI_GetStringWidth is not accurate */ | 
					
						
							|  |  |  | #if 0
 | 
					
						
							|  |  |  | 		labelw = UI_GetStringWidth(name); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		CLAMP(labelw, w / 4, 3 * w / 4); | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		labelw = w / 3; | 
					
						
							| 
									
										
											  
											
												2.5: Render
* UI layout for scene buttons has quite some changes, I tried to
  better organize things according to the pipeline, and also showing
  important properties by default, and collapsing less important ones.
Some changes compared to 2.4x:
* Panorama is now a Camera property.
* Sequence and Compositing are now enabled by default, but will only
  do something when there is a node tree using nodes, or a strip in the
  sequence editor.
* Enabling Full Sample now automatically enables Save Buffers too.
* Stamp option to include info in file is removed, it now simply always
  does this if one of the stamp infos is enabled.
* Xvid, H.264 and Ogg Theora are now directly in the file format menu,
  but still using FFMPEG. Unfortunately Ogg is broken at the moment
  (also in 2.4x), so that's disabled. And Xvid crashes on 64bit linux,
  maybe solvable by upgrading extern/xvidcore/, using ubuntu libs makes
  it work.
* Organized file format menu by image/movie types.
Added:
* Render layers RNA wrapped, operatorized, layouted.
* FFMPEG format/codec options are now working.
Defaults changed:
* Compositing & Sequencer enabled.
* Tiles set to 8x8.
* Time/Date/Frame/Scene/Camera/Filename enabled for stamp.
											
										 
											2009-07-13 19:09:13 +00:00
										 |  |  | 		uiDefBut(block, LABEL, 0, name, x, y, labelw, h, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		w = w - labelw; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	type = RNA_property_type(prop); | 
					
						
							|  |  |  | 	subtype = RNA_property_subtype(prop); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (subtype == PROP_FILEPATH || subtype == PROP_DIRPATH) { | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 		uiBlockSetCurLayout(block, uiLayoutRow(sub, TRUE)); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiDefAutoButR(block, ptr, prop, index, "", icon, x, y, w - UI_UNIT_X, h); | 
					
						
							| 
									
										
										
										
											2009-07-28 18:51:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* BUTTONS_OT_file_browse calls uiFileBrowseContextProperty */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		but = uiDefIconButO(block, BUT, subtype == PROP_DIRPATH ? | 
					
						
							|  |  |  | 		                    "BUTTONS_OT_directory_browse" : | 
					
						
							|  |  |  | 		                    "BUTTONS_OT_file_browse", | 
					
						
							|  |  |  | 		                    WM_OP_INVOKE_DEFAULT, ICON_FILESEL, x, y, UI_UNIT_X, h, NULL); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (flag & UI_ITEM_R_EVENT) { | 
					
						
							| 
									
										
										
										
											2011-08-06 16:00:00 +00:00
										 |  |  | 		uiDefButR_prop(block, KEYEVT, 0, name, x, y, w, h, ptr, prop, index, 0, 0, -1, -1, NULL); | 
					
						
							| 
									
										
											  
											
												Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
											
										 
											2009-10-08 18:40:03 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (flag & UI_ITEM_R_FULL_EVENT) { | 
					
						
							|  |  |  | 		if (RNA_struct_is_a(ptr->type, &RNA_KeyMapItem)) { | 
					
						
							| 
									
										
											  
											
												Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
											
										 
											2009-10-08 18:40:03 +00:00
										 |  |  | 			char buf[128]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			WM_keymap_item_to_string(ptr->data, buf, sizeof(buf)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 			but = uiDefButR_prop(block, HOTKEYEVT, 0, buf, x, y, w, h, ptr, prop, 0, 0, 0, -1, -1, NULL); | 
					
						
							| 
									
										
										
										
											2009-12-24 09:26:06 +00:00
										 |  |  | 			uiButSetFunc(but, ui_keymap_but_cb, but, NULL); | 
					
						
							|  |  |  | 			if (flag & UI_ITEM_R_IMMEDIATE) | 
					
						
							|  |  |  | 				uiButSetFlag(but, UI_BUT_IMMEDIATE); | 
					
						
							| 
									
										
											  
											
												Key Configuration
Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.
There's actually 3 levels now:
* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.
Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.
Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.
											
										 
											2009-10-08 18:40:03 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		but = uiDefAutoButR(block, ptr, prop, index, (type == PROP_ENUM && !(flag & UI_ITEM_R_ICON_ONLY)) ? NULL : "", icon, x, y, w, h); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 	return but; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-28 18:51:06 +00:00
										 |  |  | void uiFileBrowseContextProperty(const bContext *C, PointerRNA *ptr, PropertyRNA **prop) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	ARegion *ar = CTX_wm_region(C); | 
					
						
							| 
									
										
										
										
											2009-07-28 18:51:06 +00:00
										 |  |  | 	uiBlock *block; | 
					
						
							|  |  |  | 	uiBut *but, *prevbut; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	memset(ptr, 0, sizeof(*ptr)); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	*prop = NULL; | 
					
						
							| 
									
										
										
										
											2009-07-28 18:51:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!ar) | 
					
						
							| 
									
										
										
										
											2009-07-28 18:51:06 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (block = ar->uiblocks.first; block; block = block->next) { | 
					
						
							|  |  |  | 		for (but = block->buttons.first; but; but = but->next) { | 
					
						
							|  |  |  | 			prevbut = but->prev; | 
					
						
							| 
									
										
										
										
											2009-07-28 18:51:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* find the button before the active one */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if ((but->flag & UI_BUT_LAST_ACTIVE) && prevbut && prevbut->rnapoin.data) { | 
					
						
							|  |  |  | 				if (RNA_property_type(prevbut->rnaprop) == PROP_STRING) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					*ptr = prevbut->rnapoin; | 
					
						
							|  |  |  | 					*prop = prevbut->rnaprop; | 
					
						
							| 
									
										
										
										
											2009-07-28 18:51:06 +00:00
										 |  |  | 					return; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /********************* Button Items *************************/ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-05 05:39:18 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Update a buttons tip with an enum's description if possible. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void ui_but_tip_from_enum_item(uiBut *but, EnumPropertyItem *item) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (but->tip == NULL || but->tip[0] == '\0') { | 
					
						
							|  |  |  | 		if (item->description && item->description[0]) { | 
					
						
							|  |  |  | 			but->tip = item->description; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | /* disabled item */ | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static void ui_item_disabled(uiLayout *layout, const char *name) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							|  |  |  | 	int w; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = ""; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = ui_text_icon_width(layout, name, 0, 0); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 	but = uiDefBut(block, LABEL, 0, name, 0, 0, w, UI_UNIT_Y, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	but->flag |= UI_BUT_DISABLED; | 
					
						
							| 
									
										
										
										
											2012-08-25 20:49:51 +00:00
										 |  |  | 	but->lock = TRUE; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	but->lockstr = ""; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | /* operator items */ | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | PointerRNA uiItemFullO_ptr(uiLayout *layout, wmOperatorType *ot, const char *name, int icon, IDProperty *properties, int context, int flag) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							|  |  |  | 	int w; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) { | 
					
						
							| 
									
										
										
										
											2012-03-16 15:39:25 +00:00
										 |  |  | 		if (ot && ot->srna) | 
					
						
							|  |  |  | 			name = RNA_struct_ui_name(ot->srna); | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			name = ""; | 
					
						
							| 
									
										
										
										
											2011-09-15 13:20:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU && !icon) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_BLANK1; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* create button */ | 
					
						
							|  |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = ui_text_icon_width(layout, name, icon, 0); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-06-26 20:00:45 +00:00
										 |  |  | 	if (flag & UI_ITEM_R_NO_BG) | 
					
						
							|  |  |  | 		uiBlockSetEmboss(block, UI_EMBOSSN); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	/* create the button */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (icon) { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 		if (name[0]) { | 
					
						
							|  |  |  | 			but = uiDefIconTextButO_ptr(block, BUT, ot, context, icon, name, 0, 0, w, UI_UNIT_Y, NULL); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			but = uiDefIconButO_ptr(block, BUT, ot, context, icon, 0, 0, w, UI_UNIT_Y, NULL); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefButO_ptr(block, BUT, ot, context, name, 0, 0, w, UI_UNIT_Y, NULL); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2011-01-24 05:15:14 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	assert(but->optype != NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-23 09:47:56 +00:00
										 |  |  | 	/* text alignment for toolbar buttons */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if ((layout->root->type == UI_LAYOUT_TOOLBAR) && !icon) | 
					
						
							| 
									
										
										
										
											2009-11-23 09:47:56 +00:00
										 |  |  | 		but->flag |= UI_TEXT_LEFT; | 
					
						
							| 
									
										
										
										
											2010-06-26 20:00:45 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (flag & UI_ITEM_R_NO_BG) | 
					
						
							|  |  |  | 		uiBlockSetEmboss(block, UI_EMBOSS); | 
					
						
							| 
									
										
										
										
											2011-06-05 17:02:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->redalert) | 
					
						
							| 
									
										
										
										
											2011-06-05 17:02:57 +00:00
										 |  |  | 		uiButSetFlag(but, UI_BUT_REDALERT); | 
					
						
							| 
									
										
										
										
											2010-06-26 20:00:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* assign properties */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (properties || (flag & UI_ITEM_O_RETURN_PROPS)) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		PointerRNA *opptr = uiButGetOperatorPtrRNA(but); | 
					
						
							| 
									
										
										
										
											2009-08-21 12:57:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (properties) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			opptr->data = properties; | 
					
						
							| 
									
										
										
										
											2009-08-21 12:57:47 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			IDPropertyTemplate val = {0}; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			opptr->data = IDP_New(IDP_GROUP, &val, "wmOperatorProperties"); | 
					
						
							| 
									
										
										
										
											2009-08-21 12:57:47 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return *opptr; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-08-21 12:57:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return PointerRNA_NULL; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | PointerRNA uiItemFullO(uiLayout *layout, const char *opname, const char *name, int icon, IDProperty *properties, int context, int flag) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 19:52:41 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return PointerRNA_NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return uiItemFullO_ptr(layout, ot, name, icon, properties, context, flag); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | } | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | static const char *ui_menu_enumpropname(uiLayout *layout, PointerRNA *ptr, PropertyRNA *prop, int retval) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	EnumPropertyItem *item; | 
					
						
							|  |  |  | 	int totitem, free; | 
					
						
							|  |  |  | 	const char *name; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-18 13:46:37 +00:00
										 |  |  | 	RNA_property_enum_items(layout->root->block->evil_C, ptr, prop, &item, &totitem, &free); | 
					
						
							|  |  |  | 	if (RNA_enum_name(item, retval, &name)) { | 
					
						
							| 
									
										
										
										
											2012-12-18 18:25:48 +00:00
										 |  |  | 		name = CTX_IFACE_(RNA_property_translation_context(prop), name); | 
					
						
							| 
									
										
										
										
											2012-12-18 13:46:37 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 		name = ""; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	if (free) { | 
					
						
							|  |  |  | 		MEM_freeN(item); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 11:59:30 +00:00
										 |  |  | 	return name; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | /* same as below but 'prop' is already known */ | 
					
						
							|  |  |  | static void uiItemEnumO_ptr__internal(uiLayout *layout, wmOperatorType *ot, const char *name, int icon, PropertyRNA *prop, int value) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PointerRNA ptr; | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							|  |  |  | 	RNA_property_enum_set(&ptr, prop, value); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 		name = ui_menu_enumpropname(layout, &ptr, prop, value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | void uiItemEnumO_ptr(uiLayout *layout, wmOperatorType *ot, const char *name, int icon, const char *propname, int value) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if ((prop = RNA_struct_find_property(&ptr, propname))) { | 
					
						
							|  |  |  | 		/* pass */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		RNA_warning("%s.%s not found", RNA_struct_identifier(ptr.type), propname); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	RNA_property_enum_set(&ptr, prop, value); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 		name = ui_menu_enumpropname(layout, &ptr, prop, value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | void uiItemEnumO(uiLayout *layout, const char *opname, const char *name, int icon, const char *propname, int value) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ot) { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 		uiItemEnumO_ptr(layout, ot, name, icon, propname, value); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		ui_item_disabled(layout, opname); | 
					
						
							|  |  |  | 		RNA_warning("unknown operator '%s'", opname); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemsFullEnumO(uiLayout *layout, const char *opname, const char *propname, IDProperty *properties, int context, int flag) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 	PropertyRNA *prop; | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 	uiBut *bt; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!ot || !ot->srna) { | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		ui_item_disabled(layout, opname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("%s '%s'", ot ? "unknown operator" : "operator missing srna", opname); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	RNA_pointer_create(NULL, ot->srna, NULL, &ptr); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	prop = RNA_struct_find_property(&ptr, propname); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-25 10:07:59 +00:00
										 |  |  | 	/* don't let bad properties slip through */ | 
					
						
							|  |  |  | 	BLI_assert((prop == NULL) || (RNA_property_type(prop) == PROP_ENUM)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (prop && RNA_property_type(prop) == PROP_ENUM) { | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 		EnumPropertyItem *item; | 
					
						
							|  |  |  | 		int totitem, i, free; | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 		uiLayout *split = uiLayoutSplit(layout, 0.0f, FALSE); | 
					
						
							|  |  |  | 		uiLayout *column = uiLayoutColumn(split, FALSE); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-15 13:20:18 +00:00
										 |  |  | 		RNA_property_enum_items_gettexted(block->evil_C, &ptr, prop, &item, &totitem, &free); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (i = 0; i < totitem; i++) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (item[i].identifier[0]) { | 
					
						
							|  |  |  | 				if (properties) { | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | 					PointerRNA tptr; | 
					
						
							| 
									
										
										
										
											2009-12-22 11:59:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-05 12:20:38 +00:00
										 |  |  | 					WM_operator_properties_create_ptr(&tptr, ot); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 					if (tptr.data) { | 
					
						
							| 
									
										
										
										
											2010-12-03 12:30:59 +00:00
										 |  |  | 						IDP_FreeProperty(tptr.data); | 
					
						
							|  |  |  | 						MEM_freeN(tptr.data); | 
					
						
							| 
									
										
										
										
											2009-12-22 11:59:30 +00:00
										 |  |  | 					} | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					tptr.data = IDP_CopyProperty(properties); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 					RNA_property_enum_set(&tptr, prop, item[i].value); | 
					
						
							| 
									
										
										
										
											2009-12-22 11:59:30 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 					uiItemFullO_ptr(column, ot, item[i].name, item[i].icon, tptr.data, context, flag); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				else { | 
					
						
							|  |  |  | 					uiItemEnumO_ptr__internal(column, ot, item[i].name, item[i].icon, prop, item[i].value); | 
					
						
							| 
									
										
										
										
											2009-12-22 11:59:30 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2013-02-05 05:39:18 +00:00
										 |  |  | 				ui_but_tip_from_enum_item(block->buttons.last, &item[i]); | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 				if (item[i].name) { | 
					
						
							|  |  |  | 					if (i != 0) { | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 						column = uiLayoutColumn(split, FALSE); | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 						/* inconsistent, but menus with labels do not look good flipped */ | 
					
						
							|  |  |  | 						block->flag |= UI_BLOCK_NO_FLIP; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 18:03:19 +00:00
										 |  |  | 					uiItemL(column, item[i].name, ICON_NONE); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					bt = block->buttons.last; | 
					
						
							|  |  |  | 					bt->flag = UI_TEXT_LEFT; | 
					
						
							| 
									
										
										
										
											2013-02-05 05:39:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 					ui_but_tip_from_enum_item(bt, &item[i]); | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2012-10-07 03:26:30 +00:00
										 |  |  | 				else {  /* XXX bug here, colums draw bottom item badly */ | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 					uiItemS(column); | 
					
						
							| 
									
										
										
										
											2012-10-07 03:26:30 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 		if (free) { | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 			MEM_freeN(item); | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-21 20:14:27 +00:00
										 |  |  | 	else if (prop && RNA_property_type(prop) != PROP_ENUM) { | 
					
						
							|  |  |  | 		RNA_warning("%s.%s, not an enum type", RNA_struct_identifier(ptr.type), propname); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		RNA_warning("%s.%s not found", RNA_struct_identifier(ptr.type), propname); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemsEnumO(uiLayout *layout, const char *opname, const char *propname) | 
					
						
							| 
									
										
										
										
											2009-12-22 11:59:30 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	uiItemsFullEnumO(layout, opname, propname, NULL, layout->root->opcontext, 0); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | /* for use in cases where we have */ | 
					
						
							| 
									
										
										
										
											2011-03-24 12:36:12 +00:00
										 |  |  | void uiItemEnumO_value(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2011-03-24 12:36:12 +00:00
										 |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return ); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							| 
									
										
										
										
											2011-03-24 12:36:12 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* enum lookup */ | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	if ((prop = RNA_struct_find_property(&ptr, propname))) { | 
					
						
							| 
									
										
										
										
											2011-03-24 12:36:12 +00:00
										 |  |  | 		/* pass */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-09-19 12:26:20 +00:00
										 |  |  | 		RNA_warning("%s.%s not found", RNA_struct_identifier(ptr.type), propname); | 
					
						
							| 
									
										
										
										
											2011-03-24 12:36:12 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	RNA_property_enum_set(&ptr, prop, value); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* same as uiItemEnumO */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 		name = ui_menu_enumpropname(layout, &ptr, prop, value); | 
					
						
							| 
									
										
										
										
											2011-03-24 12:36:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							| 
									
										
										
										
											2011-03-24 12:36:12 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | void uiItemEnumO_string(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, const char *value_str) | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 	PropertyRNA *prop; | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 	EnumPropertyItem *item; | 
					
						
							|  |  |  | 	int value, free; | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return ); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							| 
									
										
										
										
											2012-12-18 18:25:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-09 05:39:01 +00:00
										 |  |  | 	/* enum lookup */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if ((prop = RNA_struct_find_property(&ptr, propname))) { | 
					
						
							| 
									
										
										
										
											2012-12-18 13:46:37 +00:00
										 |  |  | 		/* no need for translations here */ | 
					
						
							|  |  |  | 		RNA_property_enum_items(layout->root->block->evil_C, &ptr, prop, &item, NULL, &free); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (item == NULL || RNA_enum_value_from_id(item, value_str, &value) == 0) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (free) { | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 				MEM_freeN(item); | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2011-09-19 12:26:20 +00:00
										 |  |  | 			RNA_warning("%s.%s, enum %s not found", RNA_struct_identifier(ptr.type), propname, value_str); | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 		if (free) { | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 			MEM_freeN(item); | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2011-09-19 12:26:20 +00:00
										 |  |  | 		RNA_warning("%s.%s not found", RNA_struct_identifier(ptr.type), propname); | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-12-18 18:25:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-09 05:39:01 +00:00
										 |  |  | 	RNA_property_enum_set(&ptr, prop, value); | 
					
						
							| 
									
										
										
										
											2012-12-18 18:25:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | 	/* same as uiItemEnumO */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 		name = ui_menu_enumpropname(layout, &ptr, prop, value); | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							| 
									
										
										
										
											2009-06-07 14:53:08 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | void uiItemBooleanO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return ); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	RNA_boolean_set(&ptr, propname, value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemIntO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, int value) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return ); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	RNA_int_set(&ptr, propname, value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemFloatO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, float value) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return ); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	RNA_float_set(&ptr, propname, value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | void uiItemStringO(uiLayout *layout, const char *name, int icon, const char *opname, const char *propname, const char *value) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	PointerRNA ptr; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return ); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_create_ptr(&ptr, ot); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	RNA_string_set(&ptr, propname, value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	uiItemFullO_ptr(layout, ot, name, icon, ptr.data, layout->root->opcontext, 0); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemO(uiLayout *layout, const char *name, int icon, const char *opname) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2010-03-23 15:25:33 +00:00
										 |  |  | 	uiItemFullO(layout, opname, name, icon, NULL, layout->root->opcontext, 0); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* RNA property items */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static void ui_item_rna_size(uiLayout *layout, const char *name, int icon, PointerRNA *ptr, PropertyRNA *prop, int index, int icon_only, int *r_w, int *r_h) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PropertyType type; | 
					
						
							|  |  |  | 	PropertySubType subtype; | 
					
						
							|  |  |  | 	int len, w, h; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* arbitrary extended width by type */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	type = RNA_property_type(prop); | 
					
						
							|  |  |  | 	subtype = RNA_property_subtype(prop); | 
					
						
							|  |  |  | 	len = RNA_property_array_length(ptr, prop); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ELEM3(type, PROP_STRING, PROP_POINTER, PROP_ENUM) && !name[0] && !icon_only) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = "non-empty text"; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (type == PROP_BOOLEAN && !name[0] && !icon_only) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_DOT; | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = ui_text_icon_width(layout, name, icon, 0); | 
					
						
							|  |  |  | 	h = UI_UNIT_Y; | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* increase height for arrays */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (index == RNA_NO_INDEX && len > 0) { | 
					
						
							|  |  |  | 		if (!name[0] && icon == ICON_NONE) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			h = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (ELEM(subtype, PROP_LAYER, PROP_LAYER_MEMBER)) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			h += 2 * UI_UNIT_Y; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (subtype == PROP_MATRIX) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			h += ceil(sqrt(len)) * UI_UNIT_Y; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			h += len * UI_UNIT_Y; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (ui_layout_vary_direction(layout) == UI_ITEM_VARY_X) { | 
					
						
							|  |  |  | 		if (type == PROP_BOOLEAN && name[0]) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			w += UI_UNIT_X / 5; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (type == PROP_ENUM) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			w += UI_UNIT_X / 4; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (type == PROP_FLOAT || type == PROP_INT) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			w += UI_UNIT_X * 3; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	*r_w = w; | 
					
						
							|  |  |  | 	*r_h = h; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemFullR(uiLayout *layout, PointerRNA *ptr, PropertyRNA *prop, int index, int value, int flag, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	PropertyType type; | 
					
						
							|  |  |  | 	char namestr[UI_MAX_NAME_STR]; | 
					
						
							| 
									
										
										
										
											2011-08-14 10:17:41 +00:00
										 |  |  | 	int len, is_array, w, h, slider, toggle, expand, icon_only, no_bg; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* retrieve info */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	type = RNA_property_type(prop); | 
					
						
							|  |  |  | 	is_array = RNA_property_array_check(prop); | 
					
						
							|  |  |  | 	len = (is_array) ? RNA_property_array_length(ptr, prop) : 0; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* set name and icon */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = RNA_property_ui_name(prop); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (icon == ICON_NONE) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = RNA_property_ui_icon(prop); | 
					
						
							| 
									
										
										
										
											2010-01-06 01:41:00 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ELEM4(type, PROP_INT, PROP_FLOAT, PROP_STRING, PROP_POINTER)) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = ui_item_name_add_colon(name, namestr); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (type == PROP_BOOLEAN && is_array && index == RNA_NO_INDEX) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = ui_item_name_add_colon(name, namestr); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (type == PROP_ENUM && index != RNA_ENUM_VALUE) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = ui_item_name_add_colon(name, namestr); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU) { | 
					
						
							|  |  |  | 		if (type == PROP_BOOLEAN && ((is_array == FALSE) || (index != RNA_NO_INDEX))) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			if (is_array) icon = (RNA_property_boolean_get_index(ptr, prop, index)) ? ICON_CHECKBOX_HLT : ICON_CHECKBOX_DEHLT; | 
					
						
							|  |  |  | 			else icon = (RNA_property_boolean_get(ptr, prop)) ? ICON_CHECKBOX_HLT : ICON_CHECKBOX_DEHLT; | 
					
						
							| 
									
										
										
										
											2011-08-14 10:17:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (type == PROP_ENUM && index == RNA_ENUM_VALUE) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			int enum_value = RNA_property_enum_get(ptr, prop); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (RNA_property_flag(prop) & PROP_ENUM_FLAG) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				icon = (enum_value & value) ? ICON_CHECKBOX_HLT : ICON_CHECKBOX_DEHLT; | 
					
						
							| 
									
										
										
										
											2010-09-23 07:31:44 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				icon = (enum_value == value) ? ICON_CHECKBOX_HLT : ICON_CHECKBOX_DEHLT; | 
					
						
							| 
									
										
										
										
											2010-09-23 07:31:44 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	slider = (flag & UI_ITEM_R_SLIDER); | 
					
						
							|  |  |  | 	toggle = (flag & UI_ITEM_R_TOGGLE); | 
					
						
							|  |  |  | 	expand = (flag & UI_ITEM_R_EXPAND); | 
					
						
							|  |  |  | 	icon_only = (flag & UI_ITEM_R_ICON_ONLY); | 
					
						
							|  |  |  | 	no_bg = (flag & UI_ITEM_R_NO_BG); | 
					
						
							| 
									
										
										
										
											2009-08-21 12:57:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* get size */ | 
					
						
							| 
									
										
										
										
											2009-09-10 14:20:21 +00:00
										 |  |  | 	ui_item_rna_size(layout, name, icon, ptr, prop, index, icon_only, &w, &h); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-16 10:13:26 +00:00
										 |  |  | 	if (no_bg) | 
					
						
							|  |  |  | 		uiBlockSetEmboss(block, UI_EMBOSSN); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* array property */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (index == RNA_NO_INDEX && is_array) | 
					
						
							| 
									
										
										
										
											2009-11-04 23:14:20 +00:00
										 |  |  | 		ui_item_array(layout, block, name, icon, ptr, prop, len, 0, 0, w, h, expand, slider, toggle, icon_only); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* enum item */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (type == PROP_ENUM && index == RNA_ENUM_VALUE) { | 
					
						
							|  |  |  | 		if (icon && name[0] && !icon_only) | 
					
						
							| 
									
										
										
										
											2011-08-06 16:00:00 +00:00
										 |  |  | 			uiDefIconTextButR_prop(block, ROW, 0, icon, name, 0, 0, w, h, ptr, prop, -1, 0, value, -1, -1, NULL); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (icon) | 
					
						
							| 
									
										
										
										
											2011-08-18 19:07:37 +00:00
										 |  |  | 			uiDefIconButR_prop(block, ROW, 0, icon, 0, 0, w, h, ptr, prop, -1, 0, value, -1, -1, NULL); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2011-08-06 16:00:00 +00:00
										 |  |  | 			uiDefButR_prop(block, ROW, 0, name, 0, 0, w, h, ptr, prop, -1, 0, value, -1, -1, NULL); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	/* expanded enum */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (type == PROP_ENUM && (expand || RNA_property_flag(prop) & PROP_ENUM_FLAG)) | 
					
						
							| 
									
										
										
										
											2010-10-16 02:40:31 +00:00
										 |  |  | 		ui_item_enum_expand(layout, block, ptr, prop, name, h, icon_only); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* property with separate label */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (type == PROP_ENUM || type == PROP_STRING || type == PROP_POINTER) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		but = ui_item_with_label(layout, block, name, icon, ptr, prop, index, 0, 0, w, h, flag); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		ui_but_add_search(but, ptr, prop, NULL, NULL); | 
					
						
							| 
									
										
										
										
											2010-12-11 17:47:36 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (layout->redalert) | 
					
						
							| 
									
										
										
										
											2010-12-11 17:47:36 +00:00
										 |  |  | 			uiButSetFlag(but, UI_BUT_REDALERT); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* single button */ | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefAutoButR(block, ptr, prop, index, name, icon, 0, 0, w, h); | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (slider && but->type == NUM) | 
					
						
							|  |  |  | 			but->type = NUMSLI; | 
					
						
							| 
									
										
										
										
											2009-05-27 00:03:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (toggle && but->type == OPTION) | 
					
						
							|  |  |  | 			but->type = TOG; | 
					
						
							| 
									
										
										
										
											2010-12-11 17:47:36 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (layout->redalert) | 
					
						
							| 
									
										
										
										
											2010-12-11 17:47:36 +00:00
										 |  |  | 			uiButSetFlag(but, UI_BUT_REDALERT); | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-12-16 10:13:26 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (no_bg) | 
					
						
							|  |  |  | 		uiBlockSetEmboss(block, UI_EMBOSS); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, int flag, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	PropertyRNA *prop = RNA_struct_find_property(ptr, propname); | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!prop) { | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		ui_item_disabled(layout, propname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("property not found: %s.%s", RNA_struct_identifier(ptr->type), propname); | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-23 15:31:12 +00:00
										 |  |  | 	uiItemFullR(layout, ptr, prop, RNA_NO_INDEX, 0, flag, name, icon); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemEnumR(uiLayout *layout, const char *name, int icon, struct PointerRNA *ptr, const char *propname, int value) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	PropertyRNA *prop = RNA_struct_find_property(ptr, propname); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!prop || RNA_property_type(prop) != PROP_ENUM) { | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		ui_item_disabled(layout, propname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("property not found: %s.%s", RNA_struct_identifier(ptr->type), propname); | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-03-23 15:31:12 +00:00
										 |  |  | 	uiItemFullR(layout, ptr, prop, RNA_ENUM_VALUE, value, 0, name, icon); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemEnumR_string(uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *value, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	PropertyRNA *prop = RNA_struct_find_property(ptr, propname); | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 	EnumPropertyItem *item; | 
					
						
							|  |  |  | 	int ivalue, a, free; | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!prop || RNA_property_type(prop) != PROP_ENUM) { | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 		ui_item_disabled(layout, propname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("enum property not found: %s.%s", RNA_struct_identifier(ptr->type), propname); | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-18 13:46:37 +00:00
										 |  |  | 	RNA_property_enum_items(layout->root->block->evil_C, ptr, prop, &item, NULL, &free); | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!RNA_enum_value_from_id(item, value, &ivalue)) { | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 		if (free) { | 
					
						
							|  |  |  | 			MEM_freeN(item); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 		ui_item_disabled(layout, propname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("enum property value not found: %s", value); | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (a = 0; item[a].identifier; a++) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item[a].value == ivalue) { | 
					
						
							| 
									
										
										
										
											2012-12-18 18:25:48 +00:00
										 |  |  | 			const char *item_name = CTX_IFACE_(RNA_property_translation_context(prop), item[a].name); | 
					
						
							| 
									
										
										
										
											2012-12-18 13:46:37 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			uiItemFullR(layout, ptr, prop, RNA_ENUM_VALUE, ivalue, 0, item_name ? item_name : name, icon ? icon : item[a].icon); | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 	if (free) { | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 		MEM_freeN(item); | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-02 19:41:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemsEnumR(uiLayout *layout, struct PointerRNA *ptr, const char *propname) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PropertyRNA *prop; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 	uiBut *bt; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	prop = RNA_struct_find_property(ptr, propname); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!prop) { | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		ui_item_disabled(layout, propname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("enum property not found: %s.%s", RNA_struct_identifier(ptr->type), propname); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (RNA_property_type(prop) != PROP_ENUM) { | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("not an enum property: %s.%s", RNA_struct_identifier(ptr->type), propname); | 
					
						
							| 
									
										
										
										
											2011-03-25 04:36:10 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 		EnumPropertyItem *item; | 
					
						
							|  |  |  | 		int totitem, i, free; | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 		uiLayout *split = uiLayoutSplit(layout, 0.0f, FALSE); | 
					
						
							|  |  |  | 		uiLayout *column = uiLayoutColumn(split, FALSE); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-15 13:20:18 +00:00
										 |  |  | 		RNA_property_enum_items_gettexted(block->evil_C, ptr, prop, &item, &totitem, &free); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (i = 0; i < totitem; i++) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (item[i].identifier[0]) { | 
					
						
							| 
									
										
										
										
											2011-02-27 18:03:19 +00:00
										 |  |  | 				uiItemEnumR(column, item[i].name, ICON_NONE, ptr, propname, item[i].value); | 
					
						
							| 
									
										
										
										
											2013-02-05 05:39:18 +00:00
										 |  |  | 				ui_but_tip_from_enum_item(block->buttons.last, &item[i]); | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 				if (item[i].name) { | 
					
						
							|  |  |  | 					if (i != 0) { | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 						column = uiLayoutColumn(split, FALSE); | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 						/* inconsistent, but menus with labels do not look good flipped */ | 
					
						
							|  |  |  | 						block->flag |= UI_BLOCK_NO_FLIP; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 18:03:19 +00:00
										 |  |  | 					uiItemL(column, item[i].name, ICON_NONE); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					bt = block->buttons.last; | 
					
						
							|  |  |  | 					bt->flag = UI_TEXT_LEFT; | 
					
						
							| 
									
										
										
										
											2013-02-05 05:39:18 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 					ui_but_tip_from_enum_item(bt, &item[i]); | 
					
						
							| 
									
										
										
										
											2009-08-21 02:51:56 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				else | 
					
						
							|  |  |  | 					uiItemS(column); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 		if (free) { | 
					
						
							| 
									
										
										
											
												RNA
* Enums can now be dynamically created in the _itemf callback,
  using RNA_enum_item(s)_add, RNA_enum_item_end. All places asking
  for enum items now need to potentially free the items.
* This callback now also gets context, this was added specifically
  for operators. This doesn't fit design well at all, needed to do
  some ugly hacks, but can't find a good solution at the moment.
* All enums must have a default list of items too, even with an
  _itemf callback, for docs and fallback in case there is no context.
* Used by MESH_OT_merge, MESH_OT_select_similar, TFM_OT_select_orientation.
* Also changes some operator properties that were enums to booleas
  (unselected, deselect), to make them consistent with other ops.
											
										 
											2009-07-10 19:56:13 +00:00
										 |  |  | 			MEM_freeN(item); | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | /* Pointer RNA button with search */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | typedef struct CollItemSearch { | 
					
						
							|  |  |  | 	struct CollItemSearch *next, *prev; | 
					
						
							|  |  |  | 	char *name; | 
					
						
							|  |  |  | 	int index; | 
					
						
							|  |  |  | 	int iconid; | 
					
						
							|  |  |  | } CollItemSearch; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-13 14:16:36 +00:00
										 |  |  | static int sort_search_items_list(void *a, void *b) | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	CollItemSearch *cis1 = (CollItemSearch *)a; | 
					
						
							|  |  |  | 	CollItemSearch *cis2 = (CollItemSearch *)b; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (BLI_strcasecmp(cis1->name, cis2->name) > 0) | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | 		return 1; | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static void rna_search_cb(const struct bContext *C, void *arg_but, const char *str, uiSearchItems *items) | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBut *but = arg_but; | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 	char *name; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	int i = 0, iconid = 0, flag = RNA_property_flag(but->rnaprop); | 
					
						
							|  |  |  | 	ListBase *items_list = MEM_callocN(sizeof(ListBase), "items_list"); | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | 	CollItemSearch *cis; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	const int skip_filter = !but->changed; | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | 	/* build a temporary list of relevant items first */ | 
					
						
							| 
									
										
										
										
											2012-04-30 16:22:40 +00:00
										 |  |  | 	RNA_PROP_BEGIN (&but->rnasearchpoin, itemptr, but->rnasearchprop) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (flag & PROP_ID_SELF_CHECK) | 
					
						
							|  |  |  | 			if (itemptr.data == but->rnapoin.id.data) | 
					
						
							| 
									
										
										
										
											2009-10-19 12:13:32 +00:00
										 |  |  | 				continue; | 
					
						
							| 
									
										
										
										
											2010-04-26 20:30:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-03 06:51:36 +00:00
										 |  |  | 		/* use filter */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (RNA_property_type(but->rnaprop) == PROP_POINTER) { | 
					
						
							|  |  |  | 			if (RNA_property_pointer_poll(&but->rnapoin, but->rnaprop, &itemptr) == 0) | 
					
						
							| 
									
										
										
										
											2010-08-03 06:51:36 +00:00
										 |  |  | 				continue; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (itemptr.type && RNA_struct_is_ID(itemptr.type)) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			ID *id = itemptr.data; | 
					
						
							| 
									
										
										
										
											2012-01-11 08:51:06 +00:00
										 |  |  | 			char name_ui[MAX_ID_NAME]; | 
					
						
							| 
									
										
										
										
											2010-07-31 01:06:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | #if 0       /* this name is used for a string comparison and can't be modified, TODO */
 | 
					
						
							| 
									
										
										
										
											2010-07-31 01:06:08 +00:00
										 |  |  | 			name_uiprefix_id(name_ui, id); | 
					
						
							| 
									
										
										
										
											2010-08-01 15:42:22 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			BLI_strncpy(name_ui, id->name + 2, sizeof(name_ui)); | 
					
						
							| 
									
										
										
										
											2010-08-01 15:42:22 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			name = BLI_strdup(name_ui); | 
					
						
							|  |  |  | 			iconid = ui_id_icon_get((bContext *)C, id, 0); | 
					
						
							| 
									
										
										
										
											2011-04-21 13:11:51 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-31 01:06:08 +00:00
										 |  |  | 		else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			name = RNA_struct_name_get_alloc(&itemptr, NULL, 0, NULL); /* could use the string length here */ | 
					
						
							| 
									
										
										
										
											2011-04-21 13:11:51 +00:00
										 |  |  | 			iconid = 0; | 
					
						
							| 
									
										
										
										
											2010-07-31 01:06:08 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (name) { | 
					
						
							|  |  |  | 			if (skip_filter || BLI_strcasestr(name, str)) { | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | 				cis = MEM_callocN(sizeof(CollItemSearch), "CollectionItemSearch"); | 
					
						
							|  |  |  | 				cis->name = MEM_dupallocN(name); | 
					
						
							|  |  |  | 				cis->index = i; | 
					
						
							|  |  |  | 				cis->iconid = iconid; | 
					
						
							|  |  |  | 				BLI_addtail(items_list, cis); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-07-31 01:06:08 +00:00
										 |  |  | 			MEM_freeN(name); | 
					
						
							| 
									
										
										
										
											2012-10-21 05:46:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-07-31 01:06:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		i++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	RNA_PROP_END; | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	BLI_sortlist(items_list, sort_search_items_list); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* add search items from temporary list */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (cis = items_list->first; cis; cis = cis->next) { | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | 		if (!uiSearchItemAdd(items, cis->name, SET_INT_IN_POINTER(cis->index), cis->iconid)) { | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (cis = items_list->first; cis; cis = cis->next) { | 
					
						
							| 
									
										
										
										
											2009-12-10 01:29:43 +00:00
										 |  |  | 		MEM_freeN(cis->name); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	BLI_freelistN(items_list); | 
					
						
							|  |  |  | 	MEM_freeN(items_list); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void search_id_collection(StructRNA *ptype, PointerRNA *ptr, PropertyRNA **prop) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	StructRNA *srna; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* look for collection property in Main */ | 
					
						
							|  |  |  | 	RNA_main_pointer_create(G.main, ptr); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	*prop = NULL; | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-30 16:22:40 +00:00
										 |  |  | 	RNA_STRUCT_BEGIN (ptr, iprop) | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		/* if it's a collection and has same pointer type, we've got it */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (RNA_property_type(iprop) == PROP_COLLECTION) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			srna = RNA_property_pointer_type(ptr, iprop); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (ptype == srna) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				*prop = iprop; | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	RNA_STRUCT_END; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void ui_but_add_search(uiBut *but, PointerRNA *ptr, PropertyRNA *prop, PointerRNA *searchptr, PropertyRNA *searchprop) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	StructRNA *ptype; | 
					
						
							|  |  |  | 	PointerRNA sptr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* for ID's we do automatic lookup */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!searchprop) { | 
					
						
							|  |  |  | 		if (RNA_property_type(prop) == PROP_POINTER) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			ptype = RNA_property_pointer_type(ptr, prop); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 			search_id_collection(ptype, &sptr, &searchprop); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			searchptr = &sptr; | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* turn button into search button */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (searchprop) { | 
					
						
							| 
									
										
										
										
											2013-01-31 21:15:38 +00:00
										 |  |  | 		if (RNA_property_flag(prop) & PROP_NEVER_UNLINK) | 
					
						
							| 
									
										
										
										
											2013-01-31 13:44:13 +00:00
										 |  |  | 			but->type = SEARCH_MENU; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			but->type = SEARCH_MENU_UNLINK; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-27 11:18:54 +00:00
										 |  |  | 		but->hardmax = MAX2(but->hardmax, 256.0f); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		but->rnasearchpoin = *searchptr; | 
					
						
							|  |  |  | 		but->rnasearchprop = searchprop; | 
					
						
							|  |  |  | 		but->flag |= UI_ICON_LEFT | UI_TEXT_LEFT; | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-24 05:15:48 +00:00
										 |  |  | 		if (RNA_property_type(prop) == PROP_ENUM) { | 
					
						
							|  |  |  | 			/* XXX, this will have a menu string,
 | 
					
						
							|  |  |  | 			 * but in this case we just want the text */ | 
					
						
							|  |  |  | 			but->str[0] = 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-29 11:29:52 +00:00
										 |  |  | 		uiButSetSearchFunc(but, rna_search_cb, but, NULL, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemPointerR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, struct PointerRNA *searchptr, const char *searchpropname, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PropertyRNA *prop, *searchprop; | 
					
						
							|  |  |  | 	PropertyType type; | 
					
						
							|  |  |  | 	uiBut *but; | 
					
						
							|  |  |  | 	uiBlock *block; | 
					
						
							|  |  |  | 	StructRNA *icontype; | 
					
						
							|  |  |  | 	int w, h; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* validate arguments */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	prop = RNA_struct_find_property(ptr, propname); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!prop) { | 
					
						
							| 
									
										
										
										
											2012-11-24 04:51:56 +00:00
										 |  |  | 		RNA_warning("property not found: %s.%s", | 
					
						
							|  |  |  | 		            RNA_struct_identifier(ptr->type), propname); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	type = RNA_property_type(prop); | 
					
						
							| 
									
										
										
										
											2012-11-24 05:15:48 +00:00
										 |  |  | 	if (!ELEM3(type, PROP_POINTER, PROP_STRING, PROP_ENUM)) { | 
					
						
							|  |  |  | 		RNA_warning("Property %s must be a pointer, string or enum", propname); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	searchprop = RNA_struct_find_property(searchptr, searchpropname); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												use ICON_NULL define rather then 0, makes UI calls less confusing. (no functional change)
 eg: uiItemR(row, &dvar_ptr, "type", 0, "", 0); -> uiItemR(row, &dvar_ptr, "type", 0, "", ICON_NULL);
											
										 
											2010-12-23 02:43:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!searchprop) { | 
					
						
							| 
									
										
										
										
											2012-11-24 04:51:56 +00:00
										 |  |  | 		RNA_warning("search collection property not found: %s.%s", | 
					
						
							|  |  |  | 		            RNA_struct_identifier(searchptr->type), searchpropname); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
											
												use ICON_NULL define rather then 0, makes UI calls less confusing. (no functional change)
 eg: uiItemR(row, &dvar_ptr, "type", 0, "", 0); -> uiItemR(row, &dvar_ptr, "type", 0, "", ICON_NULL);
											
										 
											2010-12-23 02:43:40 +00:00
										 |  |  | 	else if (RNA_property_type(searchprop) != PROP_COLLECTION) { | 
					
						
							| 
									
										
										
										
											2012-11-24 04:51:56 +00:00
										 |  |  | 		RNA_warning("search collection property is not a collection type: %s.%s", | 
					
						
							|  |  |  | 		            RNA_struct_identifier(searchptr->type), searchpropname); | 
					
						
							| 
									
										
										
											
												use ICON_NULL define rather then 0, makes UI calls less confusing. (no functional change)
 eg: uiItemR(row, &dvar_ptr, "type", 0, "", 0); -> uiItemR(row, &dvar_ptr, "type", 0, "", ICON_NULL);
											
										 
											2010-12-23 02:43:40 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* get icon & name */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (icon == ICON_NONE) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (type == PROP_POINTER) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			icontype = RNA_property_pointer_type(ptr, prop); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			icontype = RNA_property_pointer_type(searchptr, searchprop); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = RNA_struct_ui_icon(icontype); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = RNA_property_ui_name(prop); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* create button */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	block = uiLayoutGetBlock(layout); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-10 14:20:21 +00:00
										 |  |  | 	ui_item_rna_size(layout, name, icon, ptr, prop, 0, 0, &w, &h); | 
					
						
							| 
									
										
										
										
											2013-01-24 13:02:00 +00:00
										 |  |  | 	w += UI_UNIT_X; /* X icon needs more space */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	but = ui_item_with_label(layout, block, name, icon, ptr, prop, 0, 0, 0, w, h, 0); | 
					
						
							| 
									
										
										
										
											2009-06-27 01:15:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	ui_but_add_search(but, ptr, prop, searchptr, searchprop); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | /* menu item */ | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | static void ui_item_menutype_func(bContext *C, uiLayout *layout, void *arg_mt) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	MenuType *mt = (MenuType *)arg_mt; | 
					
						
							| 
									
										
										
										
											2011-08-28 05:06:30 +00:00
										 |  |  | 	Menu menu = {NULL}; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	menu.type = mt; | 
					
						
							|  |  |  | 	menu.layout = layout; | 
					
						
							| 
									
										
										
										
											2012-10-26 06:22:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (G.debug & G_DEBUG_WM) { | 
					
						
							|  |  |  | 		printf("%s: opening menu \"%s\"\n", __func__, mt->idname); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-12 12:50:49 +00:00
										 |  |  | 	if (layout->context) | 
					
						
							|  |  |  | 		CTX_store_set(C, layout->context); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	mt->draw(C, &menu); | 
					
						
							| 
									
										
										
										
											2012-12-12 12:50:49 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (layout->context) | 
					
						
							|  |  |  | 		CTX_store_set(C, NULL); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 14:20:57 +00:00
										 |  |  | static void ui_item_menu(uiLayout *layout, const char *name, int icon, uiMenuCreateFunc func, void *arg, void *argN, const char *tip) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							|  |  |  | 	int w, h; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_HEADER) | 
					
						
							| 
									
										
										
										
											2009-06-16 01:08:39 +00:00
										 |  |  | 		uiBlockSetEmboss(block, UI_EMBOSS); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = ""; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU && !icon) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_BLANK1; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = ui_text_icon_width(layout, name, icon, 1); | 
					
						
							|  |  |  | 	h = UI_UNIT_Y; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_HEADER) /* ugly .. */ | 
					
						
							| 
									
										
										
										
											2012-12-13 01:00:21 +00:00
										 |  |  | 		w -= UI_UNIT_Y / 2; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (name[0] && icon) | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefIconTextMenuBut(block, func, arg, icon, name, 0, 0, w, h, tip); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (icon) | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefIconMenuBut(block, func, arg, icon, 0, 0, w, h, tip); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefMenuBut(block, func, arg, name, 0, 0, w, h, tip); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (argN) { /* ugly .. */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		but->poin = (char *)but; | 
					
						
							|  |  |  | 		but->func_argN = argN; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_HEADER) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		uiBlockSetEmboss(block, UI_EMBOSS); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (ELEM(layout->root->type, UI_LAYOUT_PANEL, UI_LAYOUT_TOOLBAR)) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		but->type = MENU; | 
					
						
							| 
									
										
										
										
											2010-06-27 19:10:36 +00:00
										 |  |  | 		but->flag |= UI_TEXT_LEFT; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemM(uiLayout *layout, bContext *UNUSED(C), const char *menuname, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	MenuType *mt; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 	mt = WM_menutype_find(menuname, FALSE); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (mt == NULL) { | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("not found %s", menuname); | 
					
						
							| 
									
										
										
										
											2009-10-06 13:04:31 +00:00
										 |  |  | 		return; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-08 21:31:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) { | 
					
						
							| 
									
										
										
										
											2013-03-15 14:32:29 +00:00
										 |  |  | 		name = CTX_IFACE_(mt->translation_context, mt->label); | 
					
						
							| 
									
										
										
										
											2011-09-15 13:20:18 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU && !icon) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_BLANK1; | 
					
						
							| 
									
										
										
										
											2009-10-06 13:04:31 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-13 19:59:29 +00:00
										 |  |  | 	ui_item_menu(layout, name, icon, ui_item_menutype_func, mt, NULL, TIP_(mt->description)); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* label item */ | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | static uiBut *uiItemL_(uiLayout *layout, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							|  |  |  | 	int w; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = ""; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU && !icon) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_BLANK1; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = ui_text_icon_width(layout, name, icon, 0); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (icon && name[0]) | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefIconTextBut(block, LABEL, 0, icon, name, 0, 0, w, UI_UNIT_Y, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (icon) | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefIconBut(block, LABEL, 0, icon, 0, 0, w, UI_UNIT_Y, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-03-24 02:51:46 +00:00
										 |  |  | 		but = uiDefBut(block, LABEL, 0, name, 0, 0, w, UI_UNIT_Y, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	 | 
					
						
							|  |  |  | 	return but; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemL(uiLayout *layout, const char *name, int icon) | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | { | 
					
						
							|  |  |  | 	uiItemL_(layout, name, icon); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | void uiItemLDrag(uiLayout *layout, PointerRNA *ptr, const char *name, int icon) | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBut *but = uiItemL_(layout, name, icon); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ptr && ptr->type) | 
					
						
							|  |  |  | 		if (RNA_struct_is_ID(ptr->type)) | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 			uiButSetDragID(but, ptr->id.data); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* value item */ | 
					
						
							| 
									
										
										
										
											2010-12-03 17:05:21 +00:00
										 |  |  | void uiItemV(uiLayout *layout, const char *name, int icon, int argval) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* label */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							|  |  |  | 	float *retvalue = (block->handle) ? &block->handle->retvalue : NULL; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int w; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = ""; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU && !icon) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_BLANK1; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = ui_text_icon_width(layout, name, icon, 0); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (icon && name[0]) | 
					
						
							| 
									
										
										
										
											2011-11-15 18:24:17 +00:00
										 |  |  | 		uiDefIconTextButF(block, BUT, argval, icon, name, 0, 0, w, UI_UNIT_Y, retvalue, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	else if (icon) | 
					
						
							| 
									
										
										
										
											2011-11-15 18:24:17 +00:00
										 |  |  | 		uiDefIconButF(block, BUT, argval, icon, 0, 0, w, UI_UNIT_Y, retvalue, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
										
										
											2011-11-15 18:24:17 +00:00
										 |  |  | 		uiDefButF(block, BUT, argval, name, 0, 0, w, UI_UNIT_Y, retvalue, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* separator item */ | 
					
						
							|  |  |  | void uiItemS(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	uiBlockSetCurLayout(block, layout); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 	uiDefBut(block, SEPR, 0, "", 0, 0, 0.3f * UI_UNIT_X, 0.3f * UI_UNIT_Y, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* level items */ | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemMenuF(uiLayout *layout, const char *name, int icon, uiMenuCreateFunc func, void *arg) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!func) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 14:20:57 +00:00
										 |  |  | 	ui_item_menu(layout, name, icon, func, arg, NULL, ""); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | typedef struct MenuItemLevel { | 
					
						
							|  |  |  | 	int opcontext; | 
					
						
							| 
									
										
										
										
											2012-03-18 07:38:51 +00:00
										 |  |  | 	/* don't use pointers to the strings because python can dynamically
 | 
					
						
							| 
									
										
										
										
											2011-05-06 02:55:09 +00:00
										 |  |  | 	 * allocate strings and free before the menu draws, see [#27304] */ | 
					
						
							|  |  |  | 	char opname[OP_MAX_TYPENAME]; | 
					
						
							|  |  |  | 	char propname[MAX_IDPROP_NAME]; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	PointerRNA rnapoin; | 
					
						
							|  |  |  | } MenuItemLevel; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 12:24:08 +00:00
										 |  |  | static void menu_item_enum_opname_menu(bContext *UNUSED(C), uiLayout *layout, void *arg) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	MenuItemLevel *lvl = (MenuItemLevel *)(((uiBut *)arg)->func_argN); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-05 17:57:04 +00:00
										 |  |  | 	uiLayoutSetOperatorContext(layout, lvl->opcontext); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	uiItemsEnumO(layout, lvl->opname, lvl->propname); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemMenuEnumO(uiLayout *layout, const char *opname, const char *propname, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 	wmOperatorType *ot = WM_operatortype_find(opname, 0); /* print error next */ | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	MenuItemLevel *lvl; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	UI_OPERATOR_ERROR_RET(ot, opname, return ); | 
					
						
							| 
									
										
										
										
											2012-01-22 03:30:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!ot->srna) { | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		ui_item_disabled(layout, opname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("operator missing srna '%s'", opname); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-04-13 19:59:29 +00:00
										 |  |  | 		name = RNA_struct_ui_name(ot->srna); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU && !icon) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_BLANK1; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	lvl = MEM_callocN(sizeof(MenuItemLevel), "MenuItemLevel"); | 
					
						
							| 
									
										
										
										
											2011-05-06 02:55:09 +00:00
										 |  |  | 	BLI_strncpy(lvl->opname, opname, sizeof(lvl->opname)); | 
					
						
							|  |  |  | 	BLI_strncpy(lvl->propname, propname, sizeof(lvl->propname)); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	lvl->opcontext = layout->root->opcontext; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-13 19:59:29 +00:00
										 |  |  | 	ui_item_menu(layout, name, icon, menu_item_enum_opname_menu, NULL, lvl, RNA_struct_ui_description(ot->srna)); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-14 12:24:08 +00:00
										 |  |  | static void menu_item_enum_rna_menu(bContext *UNUSED(C), uiLayout *layout, void *arg) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	MenuItemLevel *lvl = (MenuItemLevel *)(((uiBut *)arg)->func_argN); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | 	uiLayoutSetOperatorContext(layout, lvl->opcontext); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	uiItemsEnumR(layout, &lvl->rnapoin, lvl->propname); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiItemMenuEnumR(uiLayout *layout, struct PointerRNA *ptr, const char *propname, const char *name, int icon) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	MenuItemLevel *lvl; | 
					
						
							|  |  |  | 	PropertyRNA *prop; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	prop = RNA_struct_find_property(ptr, propname); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!prop) { | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		ui_item_disabled(layout, propname); | 
					
						
							| 
									
										
										
										
											2011-09-09 01:29:53 +00:00
										 |  |  | 		RNA_warning("property not found: %s.%s", RNA_struct_identifier(ptr->type), propname); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!name) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		name = RNA_property_ui_name(prop); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->type == UI_LAYOUT_MENU && !icon) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		icon = ICON_BLANK1; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	lvl = MEM_callocN(sizeof(MenuItemLevel), "MenuItemLevel"); | 
					
						
							|  |  |  | 	lvl->rnapoin = *ptr; | 
					
						
							| 
									
										
										
										
											2011-05-06 02:55:09 +00:00
										 |  |  | 	BLI_strncpy(lvl->propname, propname, sizeof(lvl->propname)); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	lvl->opcontext = layout->root->opcontext; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-15 14:20:57 +00:00
										 |  |  | 	ui_item_menu(layout, name, icon, menu_item_enum_rna_menu, NULL, lvl, RNA_property_description(prop)); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /**************************** Layout Items ***************************/ | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* single-row layout */ | 
					
						
							|  |  |  | static void ui_litem_estimate_row(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int itemw, itemh; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w = 0; | 
					
						
							|  |  |  | 	litem->h = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		litem->w += itemw; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		litem->h = MAX2(itemh, litem->h); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->next) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			litem->w += litem->space; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | static int ui_litem_min_width(int itemw) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	return MIN2(2 * UI_UNIT_X, itemw); | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | static void ui_litem_layout_row(uiLayout *litem) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 	int x, y, w, tot, totw, neww, itemw, minw, itemh, offset; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	int fixedw, freew, fixedx, freex, flag = 0, lastw = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-23 03:38:26 +00:00
										 |  |  | 	/* x = litem->x; */ /* UNUSED */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	y = litem->y; | 
					
						
							|  |  |  | 	w = litem->w; | 
					
						
							|  |  |  | 	totw = 0; | 
					
						
							|  |  |  | 	tot = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 		totw += itemw; | 
					
						
							|  |  |  | 		tot++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (totw == 0) | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (w != 0) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		w -= (tot - 1) * litem->space; | 
					
						
							|  |  |  | 	fixedw = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 	/* keep clamping items to fixed minimum size until all are done */ | 
					
						
							|  |  |  | 	do { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		freew = 0; | 
					
						
							|  |  |  | 		x = 0; | 
					
						
							|  |  |  | 		flag = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (item->flag) | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 				continue; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			minw = ui_litem_min_width(itemw); | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (w - lastw > 0) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				neww = ui_item_fit(itemw, x, totw, w - lastw, !item->next, litem->alignment, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				neww = 0;  /* no space left, all will need clamping to minimum size */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			x += neww; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if ((neww < minw || itemw == minw) && w != 0) { | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 				/* fixed size */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				item->flag = 1; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 				fixedw += minw; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				flag = 1; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 				totw -= itemw; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			else { | 
					
						
							|  |  |  | 				/* keep free size */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 				item->flag = 0; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 				freew += itemw; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		lastw = fixedw; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	} while (flag); | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	freex = 0; | 
					
						
							|  |  |  | 	fixedx = 0; | 
					
						
							|  |  |  | 	x = litem->x; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		minw = ui_litem_min_width(itemw); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->flag) { | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			/* fixed minimum size items */ | 
					
						
							| 
									
										
										
										
											2012-11-07 12:31:05 +00:00
										 |  |  | 			itemw = ui_item_fit(minw, fixedx, fixedw, min_ii(w, fixedw), !item->next, litem->alignment, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			fixedx += itemw; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			/* free size item */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			itemw = ui_item_fit(itemw, freex, freew, w - fixedw, !item->next, litem->alignment, NULL); | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			freex += itemw; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 		/* align right/center */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		offset = 0; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (litem->alignment == UI_LAYOUT_ALIGN_RIGHT) { | 
					
						
							| 
									
										
										
										
											2012-05-11 17:05:10 +00:00
										 |  |  | 			if (freew + fixedw > 0 && freew + fixedw < w) | 
					
						
							|  |  |  | 				offset = w - (fixedw + freew); | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (litem->alignment == UI_LAYOUT_ALIGN_CENTER) { | 
					
						
							| 
									
										
										
										
											2012-05-11 17:05:10 +00:00
										 |  |  | 			if (freew + fixedw > 0 && freew + fixedw < w) | 
					
						
							|  |  |  | 				offset = (w - (fixedw + freew)) / 2; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* position item */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		ui_item_position(item, x + offset, y - itemh, itemw, itemh); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 		x += itemw; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->next) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			x += litem->space; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w = x - litem->x; | 
					
						
							|  |  |  | 	litem->h = litem->y - y; | 
					
						
							|  |  |  | 	litem->x = x; | 
					
						
							|  |  |  | 	litem->y = y; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* single-column layout */ | 
					
						
							|  |  |  | static void ui_litem_estimate_column(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int itemw, itemh; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w = 0; | 
					
						
							|  |  |  | 	litem->h = 0; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		litem->w = MAX2(litem->w, itemw); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		litem->h += itemh; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->next) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			litem->h += litem->space; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | static void ui_litem_layout_column(uiLayout *litem) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							|  |  |  | 	int itemh, x, y; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	x = litem->x; | 
					
						
							|  |  |  | 	y = litem->y; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, NULL, &itemh); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		y -= itemh; | 
					
						
							|  |  |  | 		ui_item_position(item, x, y, litem->w, itemh); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->next) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			y -= litem->space; | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->h = litem->y - y; | 
					
						
							|  |  |  | 	litem->x = x; | 
					
						
							|  |  |  | 	litem->y = y; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* root layout */ | 
					
						
							| 
									
										
										
										
											2010-10-14 12:24:08 +00:00
										 |  |  | static void ui_litem_estimate_root(uiLayout *UNUSED(litem)) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* nothing to do */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_litem_layout_root(uiLayout *litem) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (litem->root->type == UI_LAYOUT_HEADER) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_litem_layout_row(litem); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		ui_litem_layout_column(litem); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* box layout */ | 
					
						
							|  |  |  | static void ui_litem_estimate_box(uiLayout *litem) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiStyle *style = litem->root->style; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	ui_litem_estimate_column(litem); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w += 2 * style->boxspace; | 
					
						
							| 
									
										
										
										
											2009-05-21 15:34:09 +00:00
										 |  |  | 	litem->h += style->boxspace; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_litem_layout_box(uiLayout *litem) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiLayoutItemBx *box = (uiLayoutItemBx *)litem; | 
					
						
							|  |  |  | 	uiStyle *style = litem->root->style; | 
					
						
							| 
									
										
										
										
											2009-05-21 15:34:09 +00:00
										 |  |  | 	uiBut *but; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int w, h; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = litem->w; | 
					
						
							|  |  |  | 	h = litem->h; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	litem->x += style->boxspace; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (w != 0) litem->w -= 2 * style->boxspace; | 
					
						
							|  |  |  | 	if (h != 0) litem->h -= 2 * style->boxspace; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	ui_litem_layout_column(litem); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	litem->x -= style->boxspace; | 
					
						
							|  |  |  | 	litem->y -= style->boxspace; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (w != 0) litem->w += 2 * style->boxspace; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (h != 0) litem->h += style->boxspace; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* roundbox around the sublayout */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	but = box->roundbox; | 
					
						
							| 
									
										
										
										
											2012-08-18 16:53:46 +00:00
										 |  |  | 	but->rect.xmin = litem->x; | 
					
						
							|  |  |  | 	but->rect.ymin = litem->y; | 
					
						
							|  |  |  | 	but->rect.xmax = litem->x + litem->w; | 
					
						
							|  |  |  | 	but->rect.ymax = litem->y + litem->h; | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | /* multi-column layout, automatically flowing to the next */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | static void ui_litem_estimate_column_flow(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiStyle *style = litem->root->style; | 
					
						
							|  |  |  | 	uiLayoutItemFlow *flow = (uiLayoutItemFlow *)litem; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 	uiItem *item; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	int col, x, y, emh, emy, miny, itemw, itemh, maxw = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int toth, totitem; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* compute max needed width and total height */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	toth = 0; | 
					
						
							|  |  |  | 	totitem = 0; | 
					
						
							|  |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		maxw = MAX2(maxw, itemw); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 		toth += itemh; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 		totitem++; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (flow->number <= 0) { | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 		/* auto compute number of columns, not very good */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (maxw == 0) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			flow->totcol = 1; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 			return; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-24 05:06:40 +00:00
										 |  |  | 		flow->totcol = max_ii(litem->root->emw / maxw, 1); | 
					
						
							|  |  |  | 		flow->totcol = min_ii(flow->totcol, totitem); | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		flow->totcol = flow->number; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* compute sizes */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	x = 0; | 
					
						
							|  |  |  | 	y = 0; | 
					
						
							|  |  |  | 	emy = 0; | 
					
						
							|  |  |  | 	miny = 0; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	maxw = 0; | 
					
						
							|  |  |  | 	emh = toth / flow->totcol; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* create column per column */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	col = 0; | 
					
						
							|  |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		y -= itemh + style->buttonspacey; | 
					
						
							| 
									
										
										
										
											2012-11-07 12:31:05 +00:00
										 |  |  | 		miny = min_ii(miny, y); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		emy -= itemh; | 
					
						
							| 
									
										
										
										
											2012-11-07 12:31:05 +00:00
										 |  |  | 		maxw = max_ii(itemw, maxw); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* decide to go to next one */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (col < flow->totcol - 1 && emy <= -emh) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			x += maxw + litem->space; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			maxw = 0; | 
					
						
							|  |  |  | 			y = 0; | 
					
						
							| 
									
										
										
										
											2012-08-01 17:52:14 +00:00
										 |  |  | 			emy = 0; /* need to reset height again for next column */ | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 			col++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w = x; | 
					
						
							|  |  |  | 	litem->h = litem->y - miny; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | static void ui_litem_layout_column_flow(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiStyle *style = litem->root->style; | 
					
						
							|  |  |  | 	uiLayoutItemFlow *flow = (uiLayoutItemFlow *)litem; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	uiItem *item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int col, x, y, w, emh, emy, miny, itemw, itemh; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 	int toth, totitem, offset; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* compute max needed width and total height */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	toth = 0; | 
					
						
							|  |  |  | 	totitem = 0; | 
					
						
							|  |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							|  |  |  | 		toth += itemh; | 
					
						
							|  |  |  | 		totitem++; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* compute sizes */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	x = litem->x; | 
					
						
							|  |  |  | 	y = litem->y; | 
					
						
							|  |  |  | 	emy = 0; | 
					
						
							|  |  |  | 	miny = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = litem->w - (flow->totcol - 1) * style->columnspace; | 
					
						
							|  |  |  | 	emh = toth / flow->totcol; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* create column per column */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	col = 0; | 
					
						
							|  |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, NULL, &itemh); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		itemw = ui_item_fit(1, x - litem->x, flow->totcol, w, col == flow->totcol - 1, litem->alignment, &offset); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		y -= itemh; | 
					
						
							|  |  |  | 		emy -= itemh; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		ui_item_position(item, x + offset, y, itemw, itemh); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		y -= style->buttonspacey; | 
					
						
							| 
									
										
										
										
											2012-10-24 05:06:40 +00:00
										 |  |  | 		miny = min_ii(miny, y); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* decide to go to next one */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		if (col < flow->totcol - 1 && emy <= -emh) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			x += itemw + style->columnspace; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			y = litem->y; | 
					
						
							| 
									
										
										
										
											2012-08-01 17:52:14 +00:00
										 |  |  | 			emy = 0; /* need to reset height again for next column */ | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			col++; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->h = litem->y - miny; | 
					
						
							|  |  |  | 	litem->x = x; | 
					
						
							|  |  |  | 	litem->y = miny; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* free layout */ | 
					
						
							| 
									
										
										
										
											2009-10-09 10:45:11 +00:00
										 |  |  | static void ui_litem_estimate_absolute(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiItem *item; | 
					
						
							|  |  |  | 	int itemx, itemy, itemw, itemh, minx, miny; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	minx = 1e6; | 
					
						
							|  |  |  | 	miny = 1e6; | 
					
						
							|  |  |  | 	litem->w = 0; | 
					
						
							|  |  |  | 	litem->h = 0; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_offset(item, &itemx, &itemy); | 
					
						
							|  |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-24 05:06:40 +00:00
										 |  |  | 		minx = min_ii(minx, itemx); | 
					
						
							|  |  |  | 		miny = min_ii(miny, itemy); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		litem->w = MAX2(litem->w, itemx + itemw); | 
					
						
							|  |  |  | 		litem->h = MAX2(litem->h, itemy + itemh); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	litem->w -= minx; | 
					
						
							|  |  |  | 	litem->h -= miny; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-09 10:45:11 +00:00
										 |  |  | static void ui_litem_layout_absolute(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiItem *item; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	float scalex = 1.0f, scaley = 1.0f; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	int x, y, newx, newy, itemx, itemy, itemh, itemw, minx, miny, totw, toth; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	minx = 1e6; | 
					
						
							|  |  |  | 	miny = 1e6; | 
					
						
							|  |  |  | 	totw = 0; | 
					
						
							|  |  |  | 	toth = 0; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_offset(item, &itemx, &itemy); | 
					
						
							|  |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-24 05:06:40 +00:00
										 |  |  | 		minx = min_ii(minx, itemx); | 
					
						
							|  |  |  | 		miny = min_ii(miny, itemy); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-24 05:06:40 +00:00
										 |  |  | 		totw = max_ii(totw, itemx + itemw); | 
					
						
							|  |  |  | 		toth = max_ii(toth, itemy + itemh); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	totw -= minx; | 
					
						
							|  |  |  | 	toth -= miny; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (litem->w && totw > 0) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		scalex = (float)litem->w / (float)totw; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (litem->h && toth > 0) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		scaley = (float)litem->h / (float)toth; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	x = litem->x; | 
					
						
							|  |  |  | 	y = litem->y - scaley * toth; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_offset(item, &itemx, &itemy); | 
					
						
							|  |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (scalex != 1.0f) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			newx = (itemx - minx) * scalex; | 
					
						
							|  |  |  | 			itemw = (itemx - minx + itemw) * scalex - newx; | 
					
						
							|  |  |  | 			itemx = minx + newx; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (scaley != 1.0f) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			newy = (itemy - miny) * scaley; | 
					
						
							|  |  |  | 			itemh = (itemy - miny + itemh) * scaley - newy; | 
					
						
							|  |  |  | 			itemy = miny + newy; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		ui_item_position(item, x + itemx - minx, y + itemy - miny, itemw, itemh); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w = scalex * totw; | 
					
						
							|  |  |  | 	litem->h = litem->y - y; | 
					
						
							|  |  |  | 	litem->x = x + litem->w; | 
					
						
							|  |  |  | 	litem->y = y; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* split layout */ | 
					
						
							|  |  |  | static void ui_litem_estimate_split(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	ui_litem_estimate_row(litem); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | static void ui_litem_layout_split(uiLayout *litem) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiLayoutItemSplit *split = (uiLayoutItemSplit *)litem; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiItem *item; | 
					
						
							| 
									
										
										
										
											2009-06-16 01:08:39 +00:00
										 |  |  | 	float percentage; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	const int tot = BLI_countlist(&litem->items); | 
					
						
							|  |  |  | 	int itemh, x, y, w, colw = 0; | 
					
						
							| 
									
										
										
										
											2011-03-19 05:06:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (tot == 0) | 
					
						
							| 
									
										
										
										
											2011-03-19 05:06:06 +00:00
										 |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	x = litem->x; | 
					
						
							|  |  |  | 	y = litem->y; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	percentage = (split->percentage == 0.0f) ? 1.0f / (float)tot : split->percentage; | 
					
						
							| 
									
										
										
										
											2009-06-16 01:08:39 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	w = (litem->w - (tot - 1) * litem->space); | 
					
						
							|  |  |  | 	colw = w * percentage; | 
					
						
							|  |  |  | 	colw = MAX2(colw, 0); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		ui_item_size(item, NULL, &itemh); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		ui_item_position(item, x, y - itemh, colw, itemh); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		x += colw; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->next) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			colw = (w - (int)(w * percentage)) / (tot - 1); | 
					
						
							|  |  |  | 			colw = MAX2(colw, 0); | 
					
						
							| 
									
										
										
										
											2009-06-07 13:20:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			x += litem->space; | 
					
						
							| 
									
										
										
										
											2009-06-07 13:20:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w = x - litem->x; | 
					
						
							|  |  |  | 	litem->h = litem->y - y; | 
					
						
							|  |  |  | 	litem->x = x; | 
					
						
							|  |  |  | 	litem->y = y; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | /* overlap layout */ | 
					
						
							|  |  |  | static void ui_litem_estimate_overlap(uiLayout *litem) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							|  |  |  | 	int itemw, itemh; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->w = 0; | 
					
						
							|  |  |  | 	litem->h = 0; | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		litem->w = MAX2(itemw, litem->w); | 
					
						
							|  |  |  | 		litem->h = MAX2(itemh, litem->h); | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_litem_layout_overlap(uiLayout *litem) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							|  |  |  | 	int itemw, itemh, x, y; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	x = litem->x; | 
					
						
							|  |  |  | 	y = litem->y; | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.first; item; item = item->next) { | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 		ui_item_size(item, &itemw, &itemh); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		ui_item_position(item, x, y - itemh, litem->w, itemh); | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		litem->h = MAX2(litem->h, itemh); | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem->x = x; | 
					
						
							|  |  |  | 	litem->y = y - litem->h; | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /* layout create functions */ | 
					
						
							|  |  |  | uiLayout *uiLayoutRow(uiLayout *layout, int align) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayout *litem; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem = MEM_callocN(sizeof(uiLayout), "uiLayoutRow"); | 
					
						
							|  |  |  | 	litem->item.type = ITEM_LAYOUT_ROW; | 
					
						
							|  |  |  | 	litem->root = layout->root; | 
					
						
							|  |  |  | 	litem->align = align; | 
					
						
							|  |  |  | 	litem->active = 1; | 
					
						
							|  |  |  | 	litem->enabled = 1; | 
					
						
							|  |  |  | 	litem->context = layout->context; | 
					
						
							|  |  |  | 	litem->space = (align) ? 0 : layout->root->style->buttonspacex; | 
					
						
							| 
									
										
										
										
											2013-02-28 07:13:33 +00:00
										 |  |  | 	litem->redalert = layout->redalert; | 
					
						
							| 
									
										
										
										
											2010-07-27 12:11:25 +00:00
										 |  |  | 	litem->w = layout->w; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	BLI_addtail(&layout->items, litem); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiBlockSetCurLayout(layout->root->block, litem); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	return litem; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | uiLayout *uiLayoutColumn(uiLayout *layout, int align) | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayout *litem; | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem = MEM_callocN(sizeof(uiLayout), "uiLayoutColumn"); | 
					
						
							|  |  |  | 	litem->item.type = ITEM_LAYOUT_COLUMN; | 
					
						
							|  |  |  | 	litem->root = layout->root; | 
					
						
							|  |  |  | 	litem->align = align; | 
					
						
							|  |  |  | 	litem->active = 1; | 
					
						
							|  |  |  | 	litem->enabled = 1; | 
					
						
							|  |  |  | 	litem->context = layout->context; | 
					
						
							|  |  |  | 	litem->space = (litem->align) ? 0 : layout->root->style->buttonspacey; | 
					
						
							| 
									
										
										
										
											2013-02-28 07:13:33 +00:00
										 |  |  | 	litem->redalert = layout->redalert; | 
					
						
							| 
									
										
										
										
											2010-07-27 12:11:25 +00:00
										 |  |  | 	litem->w = layout->w; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	BLI_addtail(&layout->items, litem); | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiBlockSetCurLayout(layout->root->block, litem); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	return litem; | 
					
						
							| 
									
										
										
										
											2009-04-15 15:09:36 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | uiLayout *uiLayoutColumnFlow(uiLayout *layout, int number, int align) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayoutItemFlow *flow; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	flow = MEM_callocN(sizeof(uiLayoutItemFlow), "uiLayoutItemFlow"); | 
					
						
							|  |  |  | 	flow->litem.item.type = ITEM_LAYOUT_COLUMN_FLOW; | 
					
						
							|  |  |  | 	flow->litem.root = layout->root; | 
					
						
							|  |  |  | 	flow->litem.align = align; | 
					
						
							|  |  |  | 	flow->litem.active = 1; | 
					
						
							|  |  |  | 	flow->litem.enabled = 1; | 
					
						
							|  |  |  | 	flow->litem.context = layout->context; | 
					
						
							|  |  |  | 	flow->litem.space = (flow->litem.align) ? 0 : layout->root->style->columnspace; | 
					
						
							| 
									
										
										
										
											2013-02-28 07:13:33 +00:00
										 |  |  | 	flow->litem.redalert = layout->redalert; | 
					
						
							| 
									
										
										
										
											2010-07-27 12:11:25 +00:00
										 |  |  | 	flow->litem.w = layout->w; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	flow->number = number; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	BLI_addtail(&layout->items, flow); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiBlockSetCurLayout(layout->root->block, &flow->litem); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	return &flow->litem; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | static uiLayoutItemBx *ui_layout_box(uiLayout *layout, int type) | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayoutItemBx *box; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	box = MEM_callocN(sizeof(uiLayoutItemBx), "uiLayoutItemBx"); | 
					
						
							|  |  |  | 	box->litem.item.type = ITEM_LAYOUT_BOX; | 
					
						
							|  |  |  | 	box->litem.root = layout->root; | 
					
						
							|  |  |  | 	box->litem.active = 1; | 
					
						
							|  |  |  | 	box->litem.enabled = 1; | 
					
						
							|  |  |  | 	box->litem.context = layout->context; | 
					
						
							|  |  |  | 	box->litem.space = layout->root->style->columnspace; | 
					
						
							| 
									
										
										
										
											2013-02-28 07:13:33 +00:00
										 |  |  | 	box->litem.redalert = layout->redalert; | 
					
						
							| 
									
										
										
										
											2010-07-27 12:11:25 +00:00
										 |  |  | 	box->litem.w = layout->w; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	BLI_addtail(&layout->items, box); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiBlockSetCurLayout(layout->root->block, &box->litem); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	box->roundbox = uiDefBut(layout->root->block, type, 0, "", 0, 0, 0, 0, NULL, 0.0, 0.0, 0, 0, ""); | 
					
						
							| 
									
										
										
										
											2009-05-21 15:34:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 	return box; | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-21 01:26:17 +00:00
										 |  |  | uiLayout *uiLayoutBox(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	return (uiLayout *)ui_layout_box(layout, ROUNDBOX); | 
					
						
							| 
									
										
										
										
											2009-07-21 01:26:17 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-28 10:32:49 +00:00
										 |  |  | uiLayout *uiLayoutListBox(uiLayout *layout, uiList *ui_list, PointerRNA *ptr, PropertyRNA *prop, PointerRNA *actptr, | 
					
						
							| 
									
										
											  
											
												This commit frees list ui items from their dependencies to Panel, and hence from all the limitations this implied (mostly, the "only one list per panel" one).
It introduces a new (py-extendable and registrable) RNA type, UIList (roughly similar to Panel one), which currently contains only "standard" list's scroll pos and size (but may be expended to include e.g. some filtering data, etc.). This now makes lists completely independent from Panels!
This UIList has a draw_item callback which allows to customize items' drawing from python, that all addons can now use. Incidentally, this also greatly simplifies the C code of this widget, as we do not code any "special case" here anymore!
To make all this work, other changes were also necessary:
* Now all buttons (uiBut struct) have a 'custom_data' void pointer, used currently to store the uiList struct associated with a given uiLayoutListBox.
* DynamicPaintSurface now exposes a new bool, use_color_preview (readonly), saying whether that surface has some 3D view preview data or not.
* UILayout class has now four new (static) functions, to get the actual icon of any RNA object (important e.g. with materials or textures), and to get an enum item's UI name, description and icon.
* UILayout's label() func now takes an optional 'icon_value' integer parameter, which if not zero will override the 'icon' one (mandatory to use "custom" icons as generated for material/texture/... previews).
  Note: not sure whether we should add that one to all UILayout's prop funcs?
Note: will update addons using template list asap.
											
										 
											2012-12-28 09:20:16 +00:00
										 |  |  |                           PropertyRNA *actprop) | 
					
						
							| 
									
										
										
										
											2009-07-21 01:26:17 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiLayoutItemBx *box = ui_layout_box(layout, LISTBOX); | 
					
						
							|  |  |  | 	uiBut *but = box->roundbox; | 
					
						
							| 
									
										
										
										
											2009-07-21 01:26:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-28 10:32:49 +00:00
										 |  |  | 	but->custom_data = ui_list; | 
					
						
							| 
									
										
											  
											
												This commit frees list ui items from their dependencies to Panel, and hence from all the limitations this implied (mostly, the "only one list per panel" one).
It introduces a new (py-extendable and registrable) RNA type, UIList (roughly similar to Panel one), which currently contains only "standard" list's scroll pos and size (but may be expended to include e.g. some filtering data, etc.). This now makes lists completely independent from Panels!
This UIList has a draw_item callback which allows to customize items' drawing from python, that all addons can now use. Incidentally, this also greatly simplifies the C code of this widget, as we do not code any "special case" here anymore!
To make all this work, other changes were also necessary:
* Now all buttons (uiBut struct) have a 'custom_data' void pointer, used currently to store the uiList struct associated with a given uiLayoutListBox.
* DynamicPaintSurface now exposes a new bool, use_color_preview (readonly), saying whether that surface has some 3D view preview data or not.
* UILayout class has now four new (static) functions, to get the actual icon of any RNA object (important e.g. with materials or textures), and to get an enum item's UI name, description and icon.
* UILayout's label() func now takes an optional 'icon_value' integer parameter, which if not zero will override the 'icon' one (mandatory to use "custom" icons as generated for material/texture/... previews).
  Note: not sure whether we should add that one to all UILayout's prop funcs?
Note: will update addons using template list asap.
											
										 
											2012-12-28 09:20:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	but->rnasearchpoin = *ptr; | 
					
						
							|  |  |  | 	but->rnasearchprop = prop; | 
					
						
							|  |  |  | 	but->rnapoin = *actptr; | 
					
						
							|  |  |  | 	but->rnaprop = actprop; | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	return (uiLayout *)box; | 
					
						
							| 
									
										
										
										
											2009-07-21 01:26:17 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | uiLayout *uiLayoutAbsolute(uiLayout *layout, int align) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayout *litem; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem = MEM_callocN(sizeof(uiLayout), "uiLayoutAbsolute"); | 
					
						
							|  |  |  | 	litem->item.type = ITEM_LAYOUT_ABSOLUTE; | 
					
						
							|  |  |  | 	litem->root = layout->root; | 
					
						
							|  |  |  | 	litem->align = align; | 
					
						
							|  |  |  | 	litem->active = 1; | 
					
						
							|  |  |  | 	litem->enabled = 1; | 
					
						
							|  |  |  | 	litem->context = layout->context; | 
					
						
							| 
									
										
										
										
											2013-03-16 03:59:03 +00:00
										 |  |  | 	litem->redalert = layout->redalert; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	BLI_addtail(&layout->items, litem); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiBlockSetCurLayout(layout->root->block, litem); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	return litem; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-09 10:45:11 +00:00
										 |  |  | uiBlock *uiLayoutAbsoluteBlock(uiLayout *layout) | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	uiBlock *block; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	block = uiLayoutGetBlock(layout); | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 	uiLayoutAbsolute(layout, FALSE); | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return block; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | uiLayout *uiLayoutOverlap(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiLayout *litem; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	litem = MEM_callocN(sizeof(uiLayout), "uiLayoutOverlap"); | 
					
						
							|  |  |  | 	litem->item.type = ITEM_LAYOUT_OVERLAP; | 
					
						
							|  |  |  | 	litem->root = layout->root; | 
					
						
							|  |  |  | 	litem->active = 1; | 
					
						
							|  |  |  | 	litem->enabled = 1; | 
					
						
							|  |  |  | 	litem->context = layout->context; | 
					
						
							| 
									
										
										
										
											2013-03-16 03:59:03 +00:00
										 |  |  | 	litem->redalert = layout->redalert; | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 	BLI_addtail(&layout->items, litem); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	uiBlockSetCurLayout(layout->root->block, litem); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return litem; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-12-10 14:47:07 +00:00
										 |  |  | uiLayout *uiLayoutSplit(uiLayout *layout, float percentage, int align) | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2011-07-26 20:22:54 +00:00
										 |  |  | 	uiLayoutItemSplit *split; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	split = MEM_callocN(sizeof(uiLayoutItemSplit), "uiLayoutItemSplit"); | 
					
						
							|  |  |  | 	split->litem.item.type = ITEM_LAYOUT_SPLIT; | 
					
						
							|  |  |  | 	split->litem.root = layout->root; | 
					
						
							|  |  |  | 	split->litem.align = align; | 
					
						
							|  |  |  | 	split->litem.active = 1; | 
					
						
							|  |  |  | 	split->litem.enabled = 1; | 
					
						
							|  |  |  | 	split->litem.context = layout->context; | 
					
						
							|  |  |  | 	split->litem.space = layout->root->style->columnspace; | 
					
						
							| 
									
										
										
										
											2013-03-16 03:59:03 +00:00
										 |  |  | 	split->litem.redalert = layout->redalert; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	split->litem.w = layout->w; | 
					
						
							|  |  |  | 	split->percentage = percentage; | 
					
						
							| 
									
										
										
										
											2009-06-07 13:20:41 +00:00
										 |  |  | 	BLI_addtail(&layout->items, split); | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-07 13:20:41 +00:00
										 |  |  | 	uiBlockSetCurLayout(layout->root->block, &split->litem); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-07 13:20:41 +00:00
										 |  |  | 	return &split->litem; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | void uiLayoutSetActive(uiLayout *layout, int active) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->active = active; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void uiLayoutSetEnabled(uiLayout *layout, int enabled) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->enabled = enabled; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void uiLayoutSetRedAlert(uiLayout *layout, int redalert) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->redalert = redalert; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void uiLayoutSetKeepAspect(uiLayout *layout, int keepaspect) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->keepaspect = keepaspect; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void uiLayoutSetAlignment(uiLayout *layout, int alignment) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->alignment = alignment; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | void uiLayoutSetScaleX(uiLayout *layout, float scale) | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->scale[0] = scale; | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void uiLayoutSetScaleY(uiLayout *layout, float scale) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->scale[1] = scale; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int uiLayoutGetActive(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->active; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int uiLayoutGetEnabled(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->enabled; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int uiLayoutGetRedAlert(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->redalert; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int uiLayoutGetKeepAspect(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->keepaspect; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int uiLayoutGetAlignment(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->alignment; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-16 13:01:40 +00:00
										 |  |  | int uiLayoutGetWidth(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->w; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | float uiLayoutGetScaleX(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->scale[0]; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | float uiLayoutGetScaleY(uiLayout *layout) | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-23 15:54:43 +00:00
										 |  |  | 	return layout->scale[1]; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | /********************** Layout *******************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | static void ui_item_scale(uiLayout *litem, float scale[2]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							|  |  |  | 	int x, y, w, h; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.last; item; item = item->prev) { | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 		ui_item_size(item, &w, &h); | 
					
						
							|  |  |  | 		ui_item_offset(item, &x, &y); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (scale[0] != 0.0f) { | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			x *= scale[0]; | 
					
						
							|  |  |  | 			w *= scale[0]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (scale[1] != 0.0f) { | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			y *= scale[1]; | 
					
						
							|  |  |  | 			h *= scale[1]; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		ui_item_position(item, x, y, w, h); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | static void ui_item_estimate(uiItem *item) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiItem *subitem; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (item->type != ITEM_BUTTON) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiLayout *litem = (uiLayout *)item; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (subitem = litem->items.first; subitem; subitem = subitem->next) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			ui_item_estimate(subitem); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (litem->items.first == NULL) | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (litem->scale[0] != 0.0f || litem->scale[1] != 0.0f) | 
					
						
							| 
									
										
										
										
											2009-06-03 00:04:48 +00:00
										 |  |  | 			ui_item_scale(litem, litem->scale); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		switch (litem->item.type) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			case ITEM_LAYOUT_COLUMN: | 
					
						
							|  |  |  | 				ui_litem_estimate_column(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_COLUMN_FLOW: | 
					
						
							|  |  |  | 				ui_litem_estimate_column_flow(litem); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 				break; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			case ITEM_LAYOUT_ROW: | 
					
						
							|  |  |  | 				ui_litem_estimate_row(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_BOX: | 
					
						
							|  |  |  | 				ui_litem_estimate_box(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_ROOT: | 
					
						
							|  |  |  | 				ui_litem_estimate_root(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-10-09 10:45:11 +00:00
										 |  |  | 			case ITEM_LAYOUT_ABSOLUTE: | 
					
						
							|  |  |  | 				ui_litem_estimate_absolute(litem); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_SPLIT: | 
					
						
							|  |  |  | 				ui_litem_estimate_split(litem); | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 			case ITEM_LAYOUT_OVERLAP: | 
					
						
							|  |  |  | 				ui_litem_estimate_overlap(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-04-16 12:17:58 +00:00
										 |  |  | 			default: | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-03 01:01:01 +00:00
										 |  |  | static void ui_item_align(uiLayout *litem, short nr) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiItem *item; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiButtonItem *bitem; | 
					
						
							| 
									
										
										
										
											2009-05-21 15:34:09 +00:00
										 |  |  | 	uiLayoutItemBx *box; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.last; item; item = item->prev) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->type == ITEM_BUTTON) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			bitem = (uiButtonItem *)item; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 			if (ui_but_can_align(bitem->but)) | 
					
						
							|  |  |  | 				if (!bitem->but->alignnr) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 					bitem->but->alignnr = nr; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-10-07 09:48:59 +00:00
										 |  |  | 		else if (item->type == ITEM_LAYOUT_ABSOLUTE) { | 
					
						
							|  |  |  | 			/* pass */ | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (item->type == ITEM_LAYOUT_OVERLAP) { | 
					
						
							|  |  |  | 			/* pass */ | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		else if (item->type == ITEM_LAYOUT_BOX) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			box = (uiLayoutItemBx *)item; | 
					
						
							|  |  |  | 			box->roundbox->alignnr = nr; | 
					
						
							| 
									
										
										
										
											2009-05-21 15:34:09 +00:00
										 |  |  | 			BLI_remlink(&litem->root->block->buttons, box->roundbox); | 
					
						
							|  |  |  | 			BLI_addhead(&litem->root->block->buttons, box->roundbox); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			ui_item_align((uiLayout *)item, nr); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | static void ui_item_flag(uiLayout *litem, int flag) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							|  |  |  | 	uiButtonItem *bitem; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = litem->items.last; item; item = item->prev) { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->type == ITEM_BUTTON) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			bitem = (uiButtonItem *)item; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | 			bitem->but->flag |= flag; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			ui_item_flag((uiLayout *)item, flag); | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-27 00:03:49 +00:00
										 |  |  | static void ui_item_layout(uiItem *item) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiItem *subitem; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (item->type != ITEM_BUTTON) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiLayout *litem = (uiLayout *)item; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (litem->items.first == NULL) | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (litem->align) | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 			ui_item_align(litem, ++litem->root->block->alignnr); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (!litem->active) | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | 			ui_item_flag(litem, UI_BUT_INACTIVE); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (!litem->enabled) | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | 			ui_item_flag(litem, UI_BUT_DISABLED); | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		switch (litem->item.type) { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			case ITEM_LAYOUT_COLUMN: | 
					
						
							|  |  |  | 				ui_litem_layout_column(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_COLUMN_FLOW: | 
					
						
							|  |  |  | 				ui_litem_layout_column_flow(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_ROW: | 
					
						
							|  |  |  | 				ui_litem_layout_row(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_BOX: | 
					
						
							|  |  |  | 				ui_litem_layout_box(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_ROOT: | 
					
						
							|  |  |  | 				ui_litem_layout_root(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-10-09 10:45:11 +00:00
										 |  |  | 			case ITEM_LAYOUT_ABSOLUTE: | 
					
						
							|  |  |  | 				ui_litem_layout_absolute(litem); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_SPLIT: | 
					
						
							|  |  |  | 				ui_litem_layout_split(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-10-21 20:58:10 +00:00
										 |  |  | 			case ITEM_LAYOUT_OVERLAP: | 
					
						
							|  |  |  | 				ui_litem_layout_overlap(litem); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			default: | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (subitem = litem->items.first; subitem; subitem = subitem->next) | 
					
						
							| 
									
										
										
										
											2009-05-27 00:03:49 +00:00
										 |  |  | 			ui_item_layout(subitem); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-04-11 01:52:27 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 18:47:42 +00:00
										 |  |  | static void ui_layout_end(uiBlock *block, uiLayout *layout, int *x, int *y) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->root->handlefunc) | 
					
						
							| 
									
										
										
										
											2011-11-15 18:24:17 +00:00
										 |  |  | 		uiBlockSetHandleFunc(block, layout->root->handlefunc, layout->root->argv); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 18:47:42 +00:00
										 |  |  | 	ui_item_estimate(&layout->item); | 
					
						
							|  |  |  | 	ui_item_layout(&layout->item); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (x) *x = layout->x; | 
					
						
							|  |  |  | 	if (y) *y = layout->y; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | static void ui_layout_free(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item, *next; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = layout->items.first; item; item = next) { | 
					
						
							|  |  |  | 		next = item->next; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item->type == ITEM_BUTTON) | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 			MEM_freeN(item); | 
					
						
							|  |  |  | 		else | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 			ui_layout_free((uiLayout *)item); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	MEM_freeN(layout); | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | uiLayout *uiBlockLayout(uiBlock *block, int dir, int type, int x, int y, int size, int em, uiStyle *style) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiLayout *layout; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiLayoutRoot *root; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	root = MEM_callocN(sizeof(uiLayoutRoot), "uiLayoutRoot"); | 
					
						
							|  |  |  | 	root->type = type; | 
					
						
							|  |  |  | 	root->style = style; | 
					
						
							|  |  |  | 	root->block = block; | 
					
						
							|  |  |  | 	root->opcontext = WM_OP_INVOKE_REGION_WIN; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout = MEM_callocN(sizeof(uiLayout), "uiLayout"); | 
					
						
							|  |  |  | 	layout->item.type = ITEM_LAYOUT_ROOT; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->x = x; | 
					
						
							|  |  |  | 	layout->y = y; | 
					
						
							|  |  |  | 	layout->root = root; | 
					
						
							|  |  |  | 	layout->space = style->templatespace; | 
					
						
							|  |  |  | 	layout->active = 1; | 
					
						
							|  |  |  | 	layout->enabled = 1; | 
					
						
							|  |  |  | 	layout->context = NULL; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (type == UI_LAYOUT_MENU) | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		layout->space = 0; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (dir == UI_LAYOUT_HORIZONTAL) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		layout->h = size; | 
					
						
							|  |  |  | 		layout->root->emh = em * UI_UNIT_Y; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		layout->w = size; | 
					
						
							|  |  |  | 		layout->root->emw = em * UI_UNIT_X; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	block->curlayout = layout; | 
					
						
							|  |  |  | 	root->layout = layout; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	BLI_addtail(&block->layouts, root); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	return layout; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | uiBlock *uiLayoutGetBlock(uiLayout *layout) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	return layout->root->block; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-06-09 10:30:11 +00:00
										 |  |  | int uiLayoutGetOperatorContext(uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return layout->root->opcontext; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | void uiBlockSetCurLayout(uiBlock *block, uiLayout *layout) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	block->curlayout = layout; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | void ui_layout_add_but(uiLayout *layout, uiBut *but) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	uiButtonItem *bitem; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	bitem = MEM_callocN(sizeof(uiButtonItem), "uiButtonItem"); | 
					
						
							|  |  |  | 	bitem->item.type = ITEM_BUTTON; | 
					
						
							|  |  |  | 	bitem->but = but; | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	BLI_addtail(&layout->items, bitem); | 
					
						
							| 
									
										
										
										
											2009-05-28 23:13:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (layout->context) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		but->context = layout->context; | 
					
						
							| 
									
										
										
										
											2012-05-19 13:28:19 +00:00
										 |  |  | 		but->context->used = TRUE; | 
					
						
							| 
									
										
										
										
											2009-05-28 23:13:42 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | void uiLayoutSetOperatorContext(uiLayout *layout, int opcontext) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->root->opcontext = opcontext; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-28 23:37:55 +00:00
										 |  |  | void uiLayoutSetFunc(uiLayout *layout, uiMenuHandleFunc handlefunc, void *argv) | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	layout->root->handlefunc = handlefunc; | 
					
						
							|  |  |  | 	layout->root->argv = argv; | 
					
						
							| 
									
										
										
										
											2009-04-22 18:39:44 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-09-16 18:47:42 +00:00
										 |  |  | void uiBlockLayoutResolve(uiBlock *block, int *x, int *y) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	uiLayoutRoot *root; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	if (x) *x = 0; | 
					
						
							|  |  |  | 	if (y) *y = 0; | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	block->curlayout = NULL; | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (root = block->layouts.first; root; root = root->next) { | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 		/* NULL in advance so we don't interfere when adding button */ | 
					
						
							| 
									
										
										
										
											2009-09-16 18:47:42 +00:00
										 |  |  | 		ui_layout_end(block, root->layout, x, y); | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 		ui_layout_free(root->layout); | 
					
						
							| 
									
										
										
										
											2009-03-29 19:44:39 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-05-19 17:13:33 +00:00
										 |  |  | 	BLI_freelistN(&block->layouts); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	/* XXX silly trick, interface_templates.c doesn't get linked
 | 
					
						
							|  |  |  | 	 * because it's not used by other files in this module? */ | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2011-02-13 14:16:36 +00:00
										 |  |  | 		UI_template_fix_linking(); | 
					
						
							| 
									
										
											  
											
												UI: Layout Engine
* Buttons are now created first, and after that the layout is computed.
  This means the layout engine now works at button level, and makes it
  easier to write templates. Otherwise you had to store all info and
  create the buttons later.
* Added interface_templates.c as a separate file to put templates in.
  These can contain regular buttons, and can be put in a Free layout,
  which means you can specify manual coordinates, but still get nested
  correct inside other layouts.
* API was changed to allow better nesting. Previously items were added
  in the last added layout specifier, i.e. one level up in the layout
  hierarchy. This doesn't work well in always, so now when creating things
  like rows or columns it always returns a layout which you have to add
  the items in. All py scripts were updated to follow this.
* Computing the layout now goes in two passes, first estimating the
  required width/height of all nested layouts, and then in the second
  pass using the results of that to decide on the actual locations.
* Enum and array buttons now follow the direction of the layout, i.e.
  they are vertical or horizontal depending if they are in a column or row.
* Color properties now get a color picker, and only get the additional
  RGB sliders with Expand=True.
* File/directory string properties now get a button next to them for
  opening the file browse, though this is not implemented yet.
* Layout items can now be aligned, set align=True when creating a column,
  row, etc.
* Buttons now get a minimum width of one icon (avoids squashing icon
  buttons).
* Moved some more space variables into Style.
											
										 
											2009-05-15 11:19:59 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void uiLayoutSetContextPointer(uiLayout *layout, const char *name, PointerRNA *ptr) | 
					
						
							| 
									
										
										
										
											2009-03-13 13:38:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							|  |  |  | 	layout->context = CTX_store_add(&block->contexts, name, ptr); | 
					
						
							| 
									
										
										
										
											2009-03-29 19:44:39 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-03-25 14:34:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-03 15:18:59 +00:00
										 |  |  | void uiLayoutContextCopy(uiLayout *layout, bContextStore *context) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-05-08 18:29:02 +00:00
										 |  |  | 	uiBlock *block = layout->root->block; | 
					
						
							|  |  |  | 	layout->context = CTX_store_add_all(&block->contexts, context); | 
					
						
							| 
									
										
										
										
											2012-04-03 15:18:59 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* introspect funcs */ | 
					
						
							|  |  |  | #include "BLI_dynstr.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_intro_button(DynStr *ds, uiButtonItem *bitem) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiBut *but = bitem->but; | 
					
						
							|  |  |  | 	BLI_dynstr_appendf(ds, "'type':%d, ", but->type); /* see ~ UI_interface.h:200 */ | 
					
						
							|  |  |  | 	BLI_dynstr_appendf(ds, "'draw_string':'''%s''', ", but->drawstr); | 
					
						
							| 
									
										
										
										
											2012-08-19 10:41:27 +00:00
										 |  |  | 	BLI_dynstr_appendf(ds, "'tip':'''%s''', ", but->tip ? but->tip : "");  /* not exactly needed, rna has this */ | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (but->optype) { | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 		char *opstr = WM_operator_pystring(but->block->evil_C, but->optype, but->opptr, 0); | 
					
						
							|  |  |  | 		BLI_dynstr_appendf(ds, "'operator':'''%s''', ", opstr ? opstr : ""); | 
					
						
							|  |  |  | 		MEM_freeN(opstr); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (but->rnaprop) { | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 		BLI_dynstr_appendf(ds, "'rna':'%s.%s[%d]', ", RNA_struct_identifier(but->rnapoin.type), RNA_property_identifier(but->rnaprop), but->rnaindex); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_intro_items(DynStr *ds, ListBase *lb) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uiItem *item; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BLI_dynstr_append(ds, "["); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	for (item = lb->first; item; item = item->next) { | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		BLI_dynstr_append(ds, "{"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* could also use the INT but this is nicer*/ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		switch (item->type) { | 
					
						
							|  |  |  | 			case ITEM_BUTTON:             BLI_dynstr_append(ds, "'type':'BUTTON', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_ROW:         BLI_dynstr_append(ds, "'type':'ROW', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_COLUMN:      BLI_dynstr_append(ds, "'type':'COLUMN', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_COLUMN_FLOW: BLI_dynstr_append(ds, "'type':'COLUMN_FLOW', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_ROW_FLOW:    BLI_dynstr_append(ds, "'type':'ROW_FLOW', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_BOX:         BLI_dynstr_append(ds, "'type':'BOX', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_ABSOLUTE:    BLI_dynstr_append(ds, "'type':'ABSOLUTE', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_SPLIT:       BLI_dynstr_append(ds, "'type':'SPLIT', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_OVERLAP:     BLI_dynstr_append(ds, "'type':'OVERLAP', "); break; | 
					
						
							|  |  |  | 			case ITEM_LAYOUT_ROOT:        BLI_dynstr_append(ds, "'type':'ROOT', "); break; | 
					
						
							|  |  |  | 			default:                      BLI_dynstr_append(ds, "'type':'UNKNOWN', "); break; | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		switch (item->type) { | 
					
						
							|  |  |  | 			case ITEM_BUTTON: | 
					
						
							|  |  |  | 				ui_intro_button(ds, (uiButtonItem *)item); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			default: | 
					
						
							|  |  |  | 				BLI_dynstr_append(ds, "'items':"); | 
					
						
							|  |  |  | 				ui_intro_items(ds, &((uiLayout *)item)->items); | 
					
						
							|  |  |  | 				break; | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BLI_dynstr_append(ds, "}"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (item != lb->last) | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 			BLI_dynstr_append(ds, ", "); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	BLI_dynstr_append(ds, "], "); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void ui_intro_uiLayout(DynStr *ds, uiLayout *layout) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ui_intro_items(ds, &layout->items); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-19 10:41:27 +00:00
										 |  |  | static char *str = NULL;  /* XXX, constant re-freeing, far from ideal. */ | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | const char *uiLayoutIntrospect(uiLayout *layout) | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 	DynStr *ds = BLI_dynstr_new(); | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 	if (str) { | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 		MEM_freeN(str); | 
					
						
							| 
									
										
										
										
											2012-01-21 22:00:40 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-28 17:45:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	ui_intro_uiLayout(ds, layout); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	str = BLI_dynstr_get_cstring(ds); | 
					
						
							|  |  |  | 	BLI_dynstr_free(ds); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return str; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:44:48 +00:00
										 |  |  | #ifdef USE_OP_RESET_BUT
 | 
					
						
							| 
									
										
										
										
											2012-01-11 19:33:14 +00:00
										 |  |  | static void ui_layout_operator_buts__reset_cb(bContext *UNUSED(C), void *op_pt, void *UNUSED(arg_dummy2)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	WM_operator_properties_reset((wmOperator *)op_pt); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2012-11-12 21:44:48 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-01-11 19:33:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | /* this function does not initialize the layout, functions can be called on the layout before and after */ | 
					
						
							| 
									
										
										
										
											2012-09-04 18:47:08 +00:00
										 |  |  | void uiLayoutOperatorButs(const bContext *C, uiLayout *layout, wmOperator *op, | 
					
						
							|  |  |  |                           int (*check_prop)(struct PointerRNA *, struct PropertyRNA *), | 
					
						
							|  |  |  |                           const char label_align, const short flag) | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!op->properties) { | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 		IDPropertyTemplate val = {0}; | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		op->properties = IDP_New(IDP_GROUP, &val, "wmOperatorProperties"); | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (flag & UI_LAYOUT_OP_SHOW_TITLE) { | 
					
						
							| 
									
										
										
										
											2012-04-13 19:59:29 +00:00
										 |  |  | 		uiItemL(layout, RNA_struct_ui_name(op->type->srna), ICON_NONE); | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* poll() on this operator may still fail, at the moment there is no nice feedback when this happens
 | 
					
						
							|  |  |  | 	 * just fails silently */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (!WM_operator_repeat_check(C, op)) { | 
					
						
							| 
									
										
										
										
											2012-08-19 10:41:27 +00:00
										 |  |  | 		uiBlockSetButLock(uiLayoutGetBlock(layout), TRUE, "Operator can't' redo"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* XXX, could give some nicer feedback or not show redo panel at all? */ | 
					
						
							|  |  |  | 		uiItemL(layout, IFACE_("* Redo Unsupported *"), ICON_NONE); | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-08-08 14:50:10 +00:00
										 |  |  | 	/* menu */ | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (op->type->flag & OPTYPE_PRESET) { | 
					
						
							| 
									
										
										
										
											2011-08-08 14:50:10 +00:00
										 |  |  | 		/* XXX, no simple way to get WM_MT_operator_presets.bl_label from python! Label remains the same always! */ | 
					
						
							|  |  |  | 		PointerRNA op_ptr; | 
					
						
							|  |  |  | 		uiLayout *row; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		uiLayoutGetBlock(layout)->ui_operator = op; | 
					
						
							| 
									
										
										
										
											2011-11-10 03:44:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		row = uiLayoutRow(layout, TRUE); | 
					
						
							| 
									
										
										
										
											2011-08-08 14:50:10 +00:00
										 |  |  | 		uiItemM(row, (bContext *)C, "WM_MT_operator_presets", NULL, ICON_NONE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		WM_operator_properties_create(&op_ptr, "WM_OT_operator_preset_add"); | 
					
						
							|  |  |  | 		RNA_string_set(&op_ptr, "operator", op->type->idname); | 
					
						
							| 
									
										
										
										
											2012-10-01 15:27:50 +00:00
										 |  |  | 		uiItemFullO(row, "WM_OT_operator_preset_add", "", ICON_ZOOMIN, op_ptr.data, WM_OP_INVOKE_DEFAULT, 0); | 
					
						
							| 
									
										
										
										
											2011-08-08 14:50:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		WM_operator_properties_create(&op_ptr, "WM_OT_operator_preset_add"); | 
					
						
							|  |  |  | 		RNA_string_set(&op_ptr, "operator", op->type->idname); | 
					
						
							| 
									
										
										
										
											2012-01-16 16:12:03 +00:00
										 |  |  | 		RNA_boolean_set(&op_ptr, "remove_active", TRUE); | 
					
						
							| 
									
										
										
										
											2012-10-01 15:27:50 +00:00
										 |  |  | 		uiItemFullO(row, "WM_OT_operator_preset_add", "", ICON_ZOOMOUT, op_ptr.data, WM_OP_INVOKE_DEFAULT, 0); | 
					
						
							| 
									
										
										
										
											2011-08-08 14:50:10 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (op->type->ui) { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		op->layout = layout; | 
					
						
							|  |  |  | 		op->type->ui((bContext *)C, op); | 
					
						
							|  |  |  | 		op->layout = NULL; | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* UI_LAYOUT_OP_SHOW_EMPTY ignored */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		wmWindowManager *wm = CTX_wm_manager(C); | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 		PointerRNA ptr; | 
					
						
							|  |  |  | 		int empty; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		RNA_pointer_create(&wm->id, op->type->srna, op->properties, &ptr); | 
					
						
							| 
									
										
										
										
											2010-12-24 07:46:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 		/* main draw call */ | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		empty = uiDefAutoButsRNA(layout, &ptr, check_prop, label_align) == 0; | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (empty && (flag & UI_LAYOUT_OP_SHOW_EMPTY)) { | 
					
						
							| 
									
										
										
										
											2011-10-20 20:38:26 +00:00
										 |  |  | 			uiItemL(layout, IFACE_("No Properties"), ICON_NONE); | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-01-11 19:33:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-12 21:44:48 +00:00
										 |  |  | #ifdef USE_OP_RESET_BUT
 | 
					
						
							| 
									
										
										
										
											2012-01-11 19:33:14 +00:00
										 |  |  | 	/* its possible that reset can do nothing if all have PROP_SKIP_SAVE enabled
 | 
					
						
							|  |  |  | 	 * but this is not so important if this button is drawn in those cases | 
					
						
							|  |  |  | 	 * (which isn't all that likely anyway) - campbell */ | 
					
						
							|  |  |  | 	if (op->properties->len) { | 
					
						
							|  |  |  | 		uiBlock *block; | 
					
						
							|  |  |  | 		uiBut *but; | 
					
						
							|  |  |  | 		uiLayout *col; /* needed to avoid alignment errors with previous buttons */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-19 23:08:16 +00:00
										 |  |  | 		col = uiLayoutColumn(layout, FALSE); | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		block = uiLayoutGetBlock(col); | 
					
						
							| 
									
										
											  
											
												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
										 |  |  | 		but = uiDefIconTextBut(block, BUT, 0, ICON_FILE_REFRESH, IFACE_("Reset"), 0, 0, UI_UNIT_X, UI_UNIT_Y, | 
					
						
							| 
									
										
										
										
											2012-03-03 21:42:21 +00:00
										 |  |  | 		                       NULL, 0.0, 0.0, 0.0, 0.0, TIP_("Reset operator defaults")); | 
					
						
							| 
									
										
										
										
											2012-01-11 19:33:14 +00:00
										 |  |  | 		uiButSetFunc(but, ui_layout_operator_buts__reset_cb, op, NULL); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-11-12 21:44:48 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2012-01-11 19:33:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-15 01:24:12 +00:00
										 |  |  | 	/* set various special settings for buttons */ | 
					
						
							| 
									
										
										
										
											2011-01-19 14:19:20 +00:00
										 |  |  | 	{ | 
					
						
							|  |  |  | 		uiBut *but; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-30 01:51:25 +00:00
										 |  |  | 		for (but = uiLayoutGetBlock(layout)->buttons.first; but; but = but->next) { | 
					
						
							| 
									
										
										
										
											2011-02-15 01:24:12 +00:00
										 |  |  | 			/* no undo for buttons for operator redo panels */ | 
					
						
							| 
									
										
										
										
											2011-01-19 14:19:20 +00:00
										 |  |  | 			uiButClearFlag(but, UI_BUT_UNDO); | 
					
						
							| 
									
										
										
										
											2011-02-15 01:24:12 +00:00
										 |  |  | 			 | 
					
						
							|  |  |  | 			/* if button is operator's default property, and a text-field, enable focus for it
 | 
					
						
							|  |  |  | 			 *	- this is used for allowing operators with popups to rename stuff with fewer clicks | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			if ((but->rnaprop == op->type->prop) && (but->type == TEX)) { | 
					
						
							|  |  |  | 				uiButSetFocusOnEnter(CTX_wm_window(C), but); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2011-01-19 14:19:20 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-12-15 05:42:23 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2011-11-14 14:42:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* this is a bit of a hack but best keep it in one place at least */ | 
					
						
							|  |  |  | MenuType *uiButGetMenuType(uiBut *but) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (but->menu_create_func == ui_item_menutype_func) { | 
					
						
							| 
									
										
										
										
											2011-11-14 14:42:47 +00:00
										 |  |  | 		return (MenuType *)but->poin; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |