787 lines
25 KiB
C
787 lines
25 KiB
C
/*
|
|
* $Id$
|
|
*
|
|
* ***** BEGIN GPL LICENSE BLOCK *****
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version 2
|
|
* of the License, or (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*
|
|
* Contributor(s): Blender Foundation (2009)
|
|
*
|
|
* ***** END GPL LICENSE BLOCK *****
|
|
*/
|
|
|
|
/** \file blender/makesrna/intern/rna_ui.c
|
|
* \ingroup RNA
|
|
*/
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include "DNA_screen_types.h"
|
|
|
|
#include "RNA_define.h"
|
|
|
|
#include "rna_internal.h"
|
|
#include "RNA_enum_types.h"
|
|
|
|
#include "UI_interface.h"
|
|
|
|
#include "WM_types.h"
|
|
|
|
/* see WM_types.h */
|
|
EnumPropertyItem operator_context_items[] = {
|
|
{WM_OP_INVOKE_DEFAULT, "INVOKE_DEFAULT", 0, "Invoke Default", ""},
|
|
{WM_OP_INVOKE_REGION_WIN, "INVOKE_REGION_WIN", 0, "Invoke Region Window", ""},
|
|
{WM_OP_INVOKE_REGION_CHANNELS, "INVOKE_REGION_CHANNELS", 0, "Invoke Region Channels", ""},
|
|
{WM_OP_INVOKE_REGION_PREVIEW, "INVOKE_REGION_PREVIEW", 0, "Invoke Region Preview", ""},
|
|
{WM_OP_INVOKE_AREA, "INVOKE_AREA", 0, "Invoke Area", ""},
|
|
{WM_OP_INVOKE_SCREEN, "INVOKE_SCREEN", 0, "Invoke Screen", ""},
|
|
{WM_OP_EXEC_DEFAULT, "EXEC_DEFAULT", 0, "Exec Default", ""},
|
|
{WM_OP_EXEC_REGION_WIN, "EXEC_REGION_WIN", 0, "Exec Region Window", ""},
|
|
{WM_OP_EXEC_REGION_CHANNELS, "EXEC_REGION_CHANNELS", 0, "Exec Region Channels", ""},
|
|
{WM_OP_EXEC_REGION_PREVIEW, "EXEC_REGION_PREVIEW", 0, "Exec Region Preview", ""},
|
|
{WM_OP_EXEC_AREA, "EXEC_AREA", 0, "Exec Area", ""},
|
|
{WM_OP_EXEC_SCREEN, "EXEC_SCREEN", 0, "Exec Screen", ""},
|
|
{0, NULL, 0, NULL, NULL}};
|
|
|
|
#ifdef RNA_RUNTIME
|
|
|
|
#include "MEM_guardedalloc.h"
|
|
|
|
#include "RNA_access.h"
|
|
|
|
#include "BLI_dynstr.h"
|
|
|
|
#include "BKE_context.h"
|
|
#include "BKE_report.h"
|
|
#include "BKE_screen.h"
|
|
|
|
#include "WM_api.h"
|
|
|
|
static ARegionType *region_type_find(ReportList *reports, int space_type, int region_type)
|
|
{
|
|
SpaceType *st;
|
|
ARegionType *art;
|
|
|
|
st= BKE_spacetype_from_id(space_type);
|
|
|
|
for(art= (st)? st->regiontypes.first: NULL; art; art= art->next) {
|
|
if (art->regionid==region_type)
|
|
break;
|
|
}
|
|
|
|
/* region type not found? abort */
|
|
if (art==NULL) {
|
|
BKE_report(reports, RPT_ERROR, "Region not found in spacetype.");
|
|
return NULL;
|
|
}
|
|
|
|
return art;
|
|
}
|
|
|
|
/* Panel */
|
|
|
|
static int panel_poll(const bContext *C, PanelType *pt)
|
|
{
|
|
PointerRNA ptr;
|
|
ParameterList list;
|
|
FunctionRNA *func;
|
|
void *ret;
|
|
int visible;
|
|
|
|
RNA_pointer_create(NULL, pt->ext.srna, NULL, &ptr); /* dummy */
|
|
func= RNA_struct_find_function(&ptr, "poll");
|
|
|
|
RNA_parameter_list_create(&list, &ptr, func);
|
|
RNA_parameter_set_lookup(&list, "context", &C);
|
|
pt->ext.call((bContext *)C, &ptr, func, &list);
|
|
|
|
RNA_parameter_get_lookup(&list, "visible", &ret);
|
|
visible= *(int*)ret;
|
|
|
|
RNA_parameter_list_free(&list);
|
|
|
|
return visible;
|
|
}
|
|
|
|
static void panel_draw(const bContext *C, Panel *pnl)
|
|
{
|
|
PointerRNA ptr;
|
|
ParameterList list;
|
|
FunctionRNA *func;
|
|
|
|
RNA_pointer_create(&CTX_wm_screen(C)->id, pnl->type->ext.srna, pnl, &ptr);
|
|
func= RNA_struct_find_function(&ptr, "draw");
|
|
|
|
RNA_parameter_list_create(&list, &ptr, func);
|
|
RNA_parameter_set_lookup(&list, "context", &C);
|
|
pnl->type->ext.call((bContext *)C, &ptr, func, &list);
|
|
|
|
RNA_parameter_list_free(&list);
|
|
}
|
|
|
|
static void panel_draw_header(const bContext *C, Panel *pnl)
|
|
{
|
|
PointerRNA ptr;
|
|
ParameterList list;
|
|
FunctionRNA *func;
|
|
|
|
RNA_pointer_create(&CTX_wm_screen(C)->id, pnl->type->ext.srna, pnl, &ptr);
|
|
func= RNA_struct_find_function(&ptr, "draw_header");
|
|
|
|
RNA_parameter_list_create(&list, &ptr, func);
|
|
RNA_parameter_set_lookup(&list, "context", &C);
|
|
pnl->type->ext.call((bContext *)C, &ptr, func, &list);
|
|
|
|
RNA_parameter_list_free(&list);
|
|
}
|
|
|
|
static void rna_Panel_unregister(const bContext *C, StructRNA *type)
|
|
{
|
|
ARegionType *art;
|
|
PanelType *pt= RNA_struct_blender_type_get(type);
|
|
|
|
if(!pt)
|
|
return;
|
|
if(!(art=region_type_find(NULL, pt->space_type, pt->region_type)))
|
|
return;
|
|
|
|
RNA_struct_free_extension(type, &pt->ext);
|
|
|
|
BLI_freelinkN(&art->paneltypes, pt);
|
|
RNA_struct_free(&BLENDER_RNA, type);
|
|
|
|
/* update while blender is running */
|
|
if(C)
|
|
WM_main_add_notifier(NC_SCREEN|NA_EDITED, NULL);
|
|
}
|
|
|
|
static StructRNA *rna_Panel_register(bContext *C, ReportList *reports, void *data, const char *identifier, StructValidateFunc validate, StructCallbackFunc call, StructFreeFunc free)
|
|
{
|
|
ARegionType *art;
|
|
PanelType *pt, dummypt = {0};
|
|
Panel dummypanel= {0};
|
|
PointerRNA dummyptr;
|
|
int have_function[3];
|
|
|
|
/* setup dummy panel & panel type to store static properties in */
|
|
dummypanel.type= &dummypt;
|
|
RNA_pointer_create(NULL, &RNA_Panel, &dummypanel, &dummyptr);
|
|
|
|
/* validate the python class */
|
|
if(validate(&dummyptr, data, have_function) != 0)
|
|
return NULL;
|
|
|
|
if(strlen(identifier) >= sizeof(dummypt.idname)) {
|
|
BKE_reportf(reports, RPT_ERROR, "registering panel class: '%s' is too long, maximum length is %d.", identifier, (int)sizeof(dummypt.idname));
|
|
return NULL;
|
|
}
|
|
|
|
if(!(art=region_type_find(reports, dummypt.space_type, dummypt.region_type)))
|
|
return NULL;
|
|
|
|
/* check if we have registered this panel type before, and remove it */
|
|
for(pt=art->paneltypes.first; pt; pt=pt->next) {
|
|
if(strcmp(pt->idname, dummypt.idname) == 0) {
|
|
if(pt->ext.srna)
|
|
rna_Panel_unregister(C, pt->ext.srna);
|
|
else
|
|
BLI_freelinkN(&art->paneltypes, pt);
|
|
break;
|
|
}
|
|
}
|
|
|
|
/* create a new panel type */
|
|
pt= MEM_callocN(sizeof(PanelType), "python buttons panel");
|
|
memcpy(pt, &dummypt, sizeof(dummypt));
|
|
|
|
pt->ext.srna= RNA_def_struct(&BLENDER_RNA, pt->idname, "Panel");
|
|
pt->ext.data= data;
|
|
pt->ext.call= call;
|
|
pt->ext.free= free;
|
|
RNA_struct_blender_type_set(pt->ext.srna, pt);
|
|
RNA_def_struct_flag(pt->ext.srna, STRUCT_NO_IDPROPERTIES);
|
|
|
|
pt->poll= (have_function[0])? panel_poll: NULL;
|
|
pt->draw= (have_function[1])? panel_draw: NULL;
|
|
pt->draw_header= (have_function[2])? panel_draw_header: NULL;
|
|
|
|
/* XXX use "no header" flag for some ordering of panels until we have real panel ordering */
|
|
if(pt->flag & PNL_NO_HEADER) {
|
|
PanelType *pth = art->paneltypes.first;
|
|
while(pth && pth->flag & PNL_NO_HEADER)
|
|
pth=pth->next;
|
|
|
|
if(pth)
|
|
BLI_insertlinkbefore(&art->paneltypes, pth, pt);
|
|
else
|
|
BLI_addtail(&art->paneltypes, pt);
|
|
}
|
|
else
|
|
BLI_addtail(&art->paneltypes, pt);
|
|
|
|
/* update while blender is running */
|
|
if(C)
|
|
WM_main_add_notifier(NC_SCREEN|NA_EDITED, NULL);
|
|
|
|
return pt->ext.srna;
|
|
}
|
|
|
|
static StructRNA* rna_Panel_refine(PointerRNA *ptr)
|
|
{
|
|
Panel *hdr= (Panel*)ptr->data;
|
|
return (hdr->type && hdr->type->ext.srna)? hdr->type->ext.srna: &RNA_Panel;
|
|
}
|
|
|
|
/* Header */
|
|
|
|
static void header_draw(const bContext *C, Header *hdr)
|
|
{
|
|
PointerRNA htr;
|
|
ParameterList list;
|
|
FunctionRNA *func;
|
|
|
|
RNA_pointer_create(&CTX_wm_screen(C)->id, hdr->type->ext.srna, hdr, &htr);
|
|
func= RNA_struct_find_function(&htr, "draw");
|
|
|
|
RNA_parameter_list_create(&list, &htr, func);
|
|
RNA_parameter_set_lookup(&list, "context", &C);
|
|
hdr->type->ext.call((bContext *)C, &htr, func, &list);
|
|
|
|
RNA_parameter_list_free(&list);
|
|
}
|
|
|
|
static void rna_Header_unregister(const bContext *C, StructRNA *type)
|
|
{
|
|
ARegionType *art;
|
|
HeaderType *ht= RNA_struct_blender_type_get(type);
|
|
|
|
if(!ht)
|
|
return;
|
|
if(!(art=region_type_find(NULL, ht->space_type, RGN_TYPE_HEADER)))
|
|
return;
|
|
|
|
RNA_struct_free_extension(type, &ht->ext);
|
|
|
|
BLI_freelinkN(&art->headertypes, ht);
|
|
RNA_struct_free(&BLENDER_RNA, type);
|
|
|
|
/* update while blender is running */
|
|
if(C)
|
|
WM_main_add_notifier(NC_SCREEN|NA_EDITED, NULL);
|
|
}
|
|
|
|
static StructRNA *rna_Header_register(bContext *C, ReportList *reports, void *data, const char *identifier, StructValidateFunc validate, StructCallbackFunc call, StructFreeFunc free)
|
|
{
|
|
ARegionType *art;
|
|
HeaderType *ht, dummyht = {0};
|
|
Header dummyheader= {0};
|
|
PointerRNA dummyhtr;
|
|
int have_function[1];
|
|
|
|
/* setup dummy header & header type to store static properties in */
|
|
dummyheader.type= &dummyht;
|
|
RNA_pointer_create(NULL, &RNA_Header, &dummyheader, &dummyhtr);
|
|
|
|
/* validate the python class */
|
|
if(validate(&dummyhtr, data, have_function) != 0)
|
|
return NULL;
|
|
|
|
if(strlen(identifier) >= sizeof(dummyht.idname)) {
|
|
BKE_reportf(reports, RPT_ERROR, "registering header class: '%s' is too long, maximum length is %d.", identifier, (int)sizeof(dummyht.idname));
|
|
return NULL;
|
|
}
|
|
|
|
if(!(art=region_type_find(reports, dummyht.space_type, RGN_TYPE_HEADER)))
|
|
return NULL;
|
|
|
|
/* check if we have registered this header type before, and remove it */
|
|
for(ht=art->headertypes.first; ht; ht=ht->next) {
|
|
if(strcmp(ht->idname, dummyht.idname) == 0) {
|
|
if(ht->ext.srna)
|
|
rna_Header_unregister(C, ht->ext.srna);
|
|
break;
|
|
}
|
|
}
|
|
|
|
/* create a new header type */
|
|
ht= MEM_callocN(sizeof(HeaderType), "python buttons header");
|
|
memcpy(ht, &dummyht, sizeof(dummyht));
|
|
|
|
ht->ext.srna= RNA_def_struct(&BLENDER_RNA, ht->idname, "Header");
|
|
ht->ext.data= data;
|
|
ht->ext.call= call;
|
|
ht->ext.free= free;
|
|
RNA_struct_blender_type_set(ht->ext.srna, ht);
|
|
|
|
ht->draw= (have_function[0])? header_draw: NULL;
|
|
|
|
BLI_addtail(&art->headertypes, ht);
|
|
|
|
/* update while blender is running */
|
|
if(C)
|
|
WM_main_add_notifier(NC_SCREEN|NA_EDITED, NULL);
|
|
|
|
return ht->ext.srna;
|
|
}
|
|
|
|
static StructRNA* rna_Header_refine(PointerRNA *htr)
|
|
{
|
|
Header *hdr= (Header*)htr->data;
|
|
return (hdr->type && hdr->type->ext.srna)? hdr->type->ext.srna: &RNA_Header;
|
|
}
|
|
|
|
/* Menu */
|
|
|
|
static int menu_poll(const bContext *C, MenuType *pt)
|
|
{
|
|
PointerRNA ptr;
|
|
ParameterList list;
|
|
FunctionRNA *func;
|
|
void *ret;
|
|
int visible;
|
|
|
|
RNA_pointer_create(NULL, pt->ext.srna, NULL, &ptr); /* dummy */
|
|
func= RNA_struct_find_function(&ptr, "poll");
|
|
|
|
RNA_parameter_list_create(&list, &ptr, func);
|
|
RNA_parameter_set_lookup(&list, "context", &C);
|
|
pt->ext.call((bContext *)C, &ptr, func, &list);
|
|
|
|
RNA_parameter_get_lookup(&list, "visible", &ret);
|
|
visible= *(int*)ret;
|
|
|
|
RNA_parameter_list_free(&list);
|
|
|
|
return visible;
|
|
}
|
|
|
|
static void menu_draw(const bContext *C, Menu *hdr)
|
|
{
|
|
PointerRNA mtr;
|
|
ParameterList list;
|
|
FunctionRNA *func;
|
|
|
|
RNA_pointer_create(&CTX_wm_screen(C)->id, hdr->type->ext.srna, hdr, &mtr);
|
|
func= RNA_struct_find_function(&mtr, "draw");
|
|
|
|
RNA_parameter_list_create(&list, &mtr, func);
|
|
RNA_parameter_set_lookup(&list, "context", &C);
|
|
hdr->type->ext.call((bContext *)C, &mtr, func, &list);
|
|
|
|
RNA_parameter_list_free(&list);
|
|
}
|
|
|
|
static void rna_Menu_unregister(const bContext *C, StructRNA *type)
|
|
{
|
|
MenuType *mt= RNA_struct_blender_type_get(type);
|
|
|
|
if(!mt)
|
|
return;
|
|
|
|
RNA_struct_free_extension(type, &mt->ext);
|
|
|
|
WM_menutype_freelink(mt);
|
|
|
|
RNA_struct_free(&BLENDER_RNA, type);
|
|
|
|
/* update while blender is running */
|
|
if(C)
|
|
WM_main_add_notifier(NC_SCREEN|NA_EDITED, NULL);
|
|
}
|
|
|
|
static StructRNA *rna_Menu_register(bContext *C, ReportList *reports, void *data, const char *identifier, StructValidateFunc validate, StructCallbackFunc call, StructFreeFunc free)
|
|
{
|
|
MenuType *mt, dummymt = {0};
|
|
Menu dummymenu= {0};
|
|
PointerRNA dummymtr;
|
|
int have_function[2];
|
|
|
|
/* setup dummy menu & menu type to store static properties in */
|
|
dummymenu.type= &dummymt;
|
|
RNA_pointer_create(NULL, &RNA_Menu, &dummymenu, &dummymtr);
|
|
|
|
/* validate the python class */
|
|
if(validate(&dummymtr, data, have_function) != 0)
|
|
return NULL;
|
|
|
|
if(strlen(identifier) >= sizeof(dummymt.idname)) {
|
|
BKE_reportf(reports, RPT_ERROR, "registering menu class: '%s' is too long, maximum length is %d.", identifier, (int)sizeof(dummymt.idname));
|
|
return NULL;
|
|
}
|
|
|
|
/* check if we have registered this menu type before, and remove it */
|
|
mt= WM_menutype_find(dummymt.idname, TRUE);
|
|
if(mt && mt->ext.srna)
|
|
rna_Menu_unregister(C, mt->ext.srna);
|
|
|
|
/* create a new menu type */
|
|
mt= MEM_callocN(sizeof(MenuType), "python buttons menu");
|
|
memcpy(mt, &dummymt, sizeof(dummymt));
|
|
|
|
mt->ext.srna= RNA_def_struct(&BLENDER_RNA, mt->idname, "Menu");
|
|
mt->ext.data= data;
|
|
mt->ext.call= call;
|
|
mt->ext.free= free;
|
|
RNA_struct_blender_type_set(mt->ext.srna, mt);
|
|
RNA_def_struct_flag(mt->ext.srna, STRUCT_NO_IDPROPERTIES);
|
|
|
|
mt->poll= (have_function[0])? menu_poll: NULL;
|
|
mt->draw= (have_function[1])? menu_draw: NULL;
|
|
|
|
WM_menutype_add(mt);
|
|
|
|
/* update while blender is running */
|
|
if(C)
|
|
WM_main_add_notifier(NC_SCREEN|NA_EDITED, NULL);
|
|
|
|
return mt->ext.srna;
|
|
}
|
|
|
|
static StructRNA* rna_Menu_refine(PointerRNA *mtr)
|
|
{
|
|
Menu *hdr= (Menu*)mtr->data;
|
|
return (hdr->type && hdr->type->ext.srna)? hdr->type->ext.srna: &RNA_Menu;
|
|
}
|
|
|
|
static int rna_UILayout_active_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetActive(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_active_set(PointerRNA *ptr, int value)
|
|
{
|
|
uiLayoutSetActive(ptr->data, value);
|
|
}
|
|
|
|
static int rna_UILayout_alert_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetRedAlert(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_alert_set(PointerRNA *ptr, int value)
|
|
{
|
|
uiLayoutSetRedAlert(ptr->data, value);
|
|
}
|
|
|
|
static void rna_UILayout_op_context_set(PointerRNA *ptr, int value)
|
|
{
|
|
uiLayoutSetOperatorContext(ptr->data, value);
|
|
}
|
|
|
|
static int rna_UILayout_op_context_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetOperatorContext(ptr->data);
|
|
}
|
|
|
|
static int rna_UILayout_enabled_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetEnabled(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_enabled_set(PointerRNA *ptr, int value)
|
|
{
|
|
uiLayoutSetEnabled(ptr->data, value);
|
|
}
|
|
|
|
#if 0
|
|
static int rna_UILayout_red_alert_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetRedAlert(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_red_alert_set(PointerRNA *ptr, int value)
|
|
{
|
|
uiLayoutSetRedAlert(ptr->data, value);
|
|
}
|
|
|
|
static int rna_UILayout_keep_aspect_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetKeepAspect(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_keep_aspect_set(PointerRNA *ptr, int value)
|
|
{
|
|
uiLayoutSetKeepAspect(ptr->data, value);
|
|
}
|
|
#endif
|
|
|
|
static int rna_UILayout_alignment_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetAlignment(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_alignment_set(PointerRNA *ptr, int value)
|
|
{
|
|
uiLayoutSetAlignment(ptr->data, value);
|
|
}
|
|
|
|
static float rna_UILayout_scale_x_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetScaleX(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_scale_x_set(PointerRNA *ptr, float value)
|
|
{
|
|
uiLayoutSetScaleX(ptr->data, value);
|
|
}
|
|
|
|
static float rna_UILayout_scale_y_get(PointerRNA *ptr)
|
|
{
|
|
return uiLayoutGetScaleY(ptr->data);
|
|
}
|
|
|
|
static void rna_UILayout_scale_y_set(PointerRNA *ptr, float value)
|
|
{
|
|
uiLayoutSetScaleY(ptr->data, value);
|
|
}
|
|
|
|
#else // RNA_RUNTIME
|
|
|
|
static void rna_def_ui_layout(BlenderRNA *brna)
|
|
{
|
|
StructRNA *srna;
|
|
PropertyRNA *prop;
|
|
|
|
static EnumPropertyItem alignment_items[] = {
|
|
{UI_LAYOUT_ALIGN_EXPAND, "EXPAND", 0, "Expand", ""},
|
|
{UI_LAYOUT_ALIGN_LEFT, "LEFT", 0, "Left", ""},
|
|
{UI_LAYOUT_ALIGN_CENTER, "CENTER", 0, "Center", ""},
|
|
{UI_LAYOUT_ALIGN_RIGHT, "RIGHT", 0, "Right", ""},
|
|
{0, NULL, 0, NULL, NULL}};
|
|
|
|
/* layout */
|
|
|
|
srna= RNA_def_struct(brna, "UILayout", NULL);
|
|
RNA_def_struct_sdna(srna, "uiLayout");
|
|
RNA_def_struct_ui_text(srna, "UI Layout", "User interface layout in a panel or header");
|
|
|
|
prop= RNA_def_property(srna, "active", PROP_BOOLEAN, PROP_NONE);
|
|
RNA_def_property_boolean_funcs(prop, "rna_UILayout_active_get", "rna_UILayout_active_set");
|
|
|
|
prop= RNA_def_property(srna, "operator_context", PROP_ENUM, PROP_NONE);
|
|
RNA_def_property_enum_items(prop, operator_context_items);
|
|
RNA_def_property_enum_funcs(prop, "rna_UILayout_op_context_get", "rna_UILayout_op_context_set", NULL);
|
|
|
|
prop= RNA_def_property(srna, "enabled", PROP_BOOLEAN, PROP_NONE);
|
|
RNA_def_property_boolean_funcs(prop, "rna_UILayout_enabled_get", "rna_UILayout_enabled_set");
|
|
RNA_def_property_ui_text(prop, "Enabled", "When false, this (sub)layout is greyed out.");
|
|
|
|
prop= RNA_def_property(srna, "alert", PROP_BOOLEAN, PROP_NONE);
|
|
RNA_def_property_boolean_funcs(prop, "rna_UILayout_alert_get", "rna_UILayout_alert_set");
|
|
|
|
prop= RNA_def_property(srna, "alignment", PROP_ENUM, PROP_NONE);
|
|
RNA_def_property_enum_items(prop, alignment_items);
|
|
RNA_def_property_enum_funcs(prop, "rna_UILayout_alignment_get", "rna_UILayout_alignment_set", NULL);
|
|
|
|
#if 0
|
|
prop= RNA_def_property(srna, "keep_aspect", PROP_BOOLEAN, PROP_NONE);
|
|
RNA_def_property_boolean_funcs(prop, "rna_UILayout_keep_aspect_get", "rna_UILayout_keep_aspect_set");
|
|
#endif
|
|
|
|
prop= RNA_def_property(srna, "scale_x", PROP_FLOAT, PROP_UNSIGNED);
|
|
RNA_def_property_float_funcs(prop, "rna_UILayout_scale_x_get", "rna_UILayout_scale_x_set", NULL);
|
|
RNA_def_property_ui_text(prop, "Scale X", "Scale factor along the X for items in this (sub)layout.");
|
|
|
|
prop= RNA_def_property(srna, "scale_y", PROP_FLOAT, PROP_UNSIGNED);
|
|
RNA_def_property_float_funcs(prop, "rna_UILayout_scale_y_get", "rna_UILayout_scale_y_set", NULL);
|
|
RNA_def_property_ui_text(prop, "Scale Y", "Scale factor along the Y for items in this (sub)layout.");
|
|
RNA_api_ui_layout(srna);
|
|
}
|
|
|
|
static void rna_def_panel(BlenderRNA *brna)
|
|
{
|
|
StructRNA *srna;
|
|
PropertyRNA *prop;
|
|
PropertyRNA *parm;
|
|
FunctionRNA *func;
|
|
|
|
static EnumPropertyItem panel_flag_items[] = {
|
|
{PNL_DEFAULT_CLOSED, "DEFAULT_CLOSED", 0, "Default Closed", "Defines if the panel has to be open or collapsed at the time of its creation."},
|
|
{PNL_NO_HEADER, "HIDE_HEADER", 0, "Show Header", "If set to True, the panel shows a header, which contains a clickable arrow to collapse the panel and the label (see bl_label)."},
|
|
{0, NULL, 0, NULL, NULL}};
|
|
|
|
srna= RNA_def_struct(brna, "Panel", NULL);
|
|
RNA_def_struct_ui_text(srna, "Panel", "Panel containing UI elements");
|
|
RNA_def_struct_sdna(srna, "Panel");
|
|
RNA_def_struct_refine_func(srna, "rna_Panel_refine");
|
|
RNA_def_struct_register_funcs(srna, "rna_Panel_register", "rna_Panel_unregister");
|
|
|
|
/* poll */
|
|
func= RNA_def_function(srna, "poll", NULL);
|
|
RNA_def_function_ui_description(func, "If this method returns a non-null output, then the panel can be drawn.");
|
|
RNA_def_function_flag(func, FUNC_NO_SELF|FUNC_REGISTER|FUNC_REGISTER_OPTIONAL);
|
|
RNA_def_function_return(func, RNA_def_boolean(func, "visible", 1, "", ""));
|
|
parm= RNA_def_pointer(func, "context", "Context", "", "");
|
|
RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
|
|
|
|
/* draw */
|
|
func= RNA_def_function(srna, "draw", NULL);
|
|
RNA_def_function_ui_description(func, "Draw UI elements into the panel UI layout.");
|
|
RNA_def_function_flag(func, FUNC_REGISTER);
|
|
parm= RNA_def_pointer(func, "context", "Context", "", "");
|
|
RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
|
|
|
|
func= RNA_def_function(srna, "draw_header", NULL);
|
|
RNA_def_function_ui_description(func, "Draw UI elements into the panel's header UI layout.");
|
|
RNA_def_function_flag(func, FUNC_REGISTER);
|
|
parm= RNA_def_pointer(func, "context", "Context", "", "");
|
|
RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
|
|
|
|
prop= RNA_def_property(srna, "layout", PROP_POINTER, PROP_NONE);
|
|
RNA_def_property_struct_type(prop, "UILayout");
|
|
RNA_def_property_ui_text(prop, "Layout", "Defines the structure of the panel in the UI.");
|
|
|
|
prop= RNA_def_property(srna, "text", PROP_STRING, PROP_NONE);
|
|
RNA_def_property_string_sdna(prop, NULL, "drawname");
|
|
RNA_def_property_ui_text(prop, "Text", "XXX todo");
|
|
|
|
/* registration */
|
|
prop= RNA_def_property(srna, "bl_idname", PROP_STRING, PROP_NONE);
|
|
RNA_def_property_string_sdna(prop, NULL, "type->idname");
|
|
RNA_def_property_flag(prop, PROP_REGISTER|PROP_NEVER_CLAMP);
|
|
RNA_def_property_ui_text(prop, "ID Name", "If this is set, the panel gets a custom ID, otherwise it takes the name of the class used to define the panel. For example, if the class name is \"OBJECT_PT_hello\", and bl_idname is not set by the script, then bl_idname = \"OBJECT_PT_hello\"");
|
|
|
|
prop= RNA_def_property(srna, "bl_label", PROP_STRING, PROP_NONE);
|
|
RNA_def_property_string_sdna(prop, NULL, "type->label");
|
|
RNA_def_property_flag(prop, PROP_REGISTER);
|
|
RNA_def_property_ui_text(prop, "Label", "The panel label, shows up in the panel header at the right of the triangle used to collapse the panel.");
|
|
|
|
prop= RNA_def_property(srna, "bl_space_type", PROP_ENUM, PROP_NONE);
|
|
RNA_def_property_enum_sdna(prop, NULL, "type->space_type");
|
|
RNA_def_property_enum_items(prop, space_type_items);
|
|
RNA_def_property_flag(prop, PROP_REGISTER);
|
|
RNA_def_property_ui_text(prop, "Space type", "The space where the panel is going to be used in.");
|
|
|
|
prop= RNA_def_property(srna, "bl_region_type", PROP_ENUM, PROP_NONE);
|
|
RNA_def_property_enum_sdna(prop, NULL, "type->region_type");
|
|
RNA_def_property_enum_items(prop, region_type_items);
|
|
RNA_def_property_flag(prop, PROP_REGISTER);
|
|
RNA_def_property_ui_text(prop, "Region Type", "The region where the panel is going to be used in.");
|
|
|
|
prop= RNA_def_property(srna, "bl_context", PROP_STRING, PROP_NONE);
|
|
RNA_def_property_string_sdna(prop, NULL, "type->context");
|
|
RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL); /* should this be optional? - Campbell */
|
|
RNA_def_property_ui_text(prop, "Context", "The context in which the panel belongs to. (TODO: explain the possible combinations bl_context/bl_region_type/bl_space_type)");
|
|
|
|
prop= RNA_def_property(srna, "bl_options", PROP_ENUM, PROP_NONE);
|
|
RNA_def_property_enum_sdna(prop, NULL, "type->flag");
|
|
RNA_def_property_enum_items(prop, panel_flag_items);
|
|
RNA_def_property_flag(prop, PROP_REGISTER_OPTIONAL|PROP_ENUM_FLAG);
|
|
RNA_def_property_ui_text(prop, "Options", "Options for this panel type");
|
|
}
|
|
|
|
static void rna_def_header(BlenderRNA *brna)
|
|
{
|
|
StructRNA *srna;
|
|
PropertyRNA *prop;
|
|
PropertyRNA *parm;
|
|
FunctionRNA *func;
|
|
|
|
srna= RNA_def_struct(brna, "Header", NULL);
|
|
RNA_def_struct_ui_text(srna, "Header", "Editor header containing UI elements.");
|
|
RNA_def_struct_sdna(srna, "Header");
|
|
RNA_def_struct_refine_func(srna, "rna_Header_refine");
|
|
RNA_def_struct_register_funcs(srna, "rna_Header_register", "rna_Header_unregister");
|
|
|
|
/* draw */
|
|
func= RNA_def_function(srna, "draw", NULL);
|
|
RNA_def_function_ui_description(func, "Draw UI elements into the header UI layout.");
|
|
RNA_def_function_flag(func, FUNC_REGISTER);
|
|
parm= RNA_def_pointer(func, "context", "Context", "", "");
|
|
RNA_def_property_flag(parm, PROP_REQUIRED);
|
|
|
|
RNA_define_verify_sdna(0); // not in sdna
|
|
|
|
prop= RNA_def_property(srna, "layout", PROP_POINTER, PROP_NONE);
|
|
RNA_def_property_pointer_sdna(prop, NULL, "layout");
|
|
RNA_def_property_struct_type(prop, "UILayout");
|
|
RNA_def_property_ui_text(prop, "Layout", "Defines the structure of the header in the UI.");
|
|
|
|
/* registration */
|
|
prop= RNA_def_property(srna, "bl_idname", PROP_STRING, PROP_NONE);
|
|
RNA_def_property_string_sdna(prop, NULL, "type->idname");
|
|
RNA_def_property_flag(prop, PROP_REGISTER|PROP_NEVER_CLAMP);
|
|
RNA_def_property_ui_text(prop, "ID Name", "If this is set, the header gets a custom ID, otherwise it takes the name of the class used to define the panel. For example, if the class name is \"OBJECT_HT_hello\", and bl_idname is not set by the script, then bl_idname = \"OBJECT_HT_hello\"");
|
|
|
|
prop= RNA_def_property(srna, "bl_space_type", PROP_ENUM, PROP_NONE);
|
|
RNA_def_property_enum_sdna(prop, NULL, "type->space_type");
|
|
RNA_def_property_enum_items(prop, space_type_items);
|
|
RNA_def_property_flag(prop, PROP_REGISTER);
|
|
RNA_def_property_ui_text(prop, "Space type", "The space where the header is going to be used in.");
|
|
|
|
RNA_define_verify_sdna(1);
|
|
}
|
|
|
|
static void rna_def_menu(BlenderRNA *brna)
|
|
{
|
|
StructRNA *srna;
|
|
PropertyRNA *prop;
|
|
PropertyRNA *parm;
|
|
FunctionRNA *func;
|
|
|
|
srna= RNA_def_struct(brna, "Menu", NULL);
|
|
RNA_def_struct_ui_text(srna, "Menu", "Editor menu containing buttons");
|
|
RNA_def_struct_sdna(srna, "Menu");
|
|
RNA_def_struct_refine_func(srna, "rna_Menu_refine");
|
|
RNA_def_struct_register_funcs(srna, "rna_Menu_register", "rna_Menu_unregister");
|
|
|
|
/* poll */
|
|
func= RNA_def_function(srna, "poll", NULL);
|
|
RNA_def_function_ui_description(func, "If this method returns a non-null output, then the menu can be drawn.");
|
|
RNA_def_function_flag(func, FUNC_NO_SELF|FUNC_REGISTER|FUNC_REGISTER_OPTIONAL);
|
|
RNA_def_function_return(func, RNA_def_boolean(func, "visible", 1, "", ""));
|
|
parm= RNA_def_pointer(func, "context", "Context", "", "");
|
|
RNA_def_property_flag(parm, PROP_REQUIRED);
|
|
|
|
/* draw */
|
|
func= RNA_def_function(srna, "draw", NULL);
|
|
RNA_def_function_ui_description(func, "Draw UI elements into the menu UI layout.");
|
|
RNA_def_function_flag(func, FUNC_REGISTER);
|
|
parm= RNA_def_pointer(func, "context", "Context", "", "");
|
|
RNA_def_property_flag(parm, PROP_REQUIRED);
|
|
|
|
RNA_define_verify_sdna(0); // not in sdna
|
|
|
|
prop= RNA_def_property(srna, "layout", PROP_POINTER, PROP_NONE);
|
|
RNA_def_property_pointer_sdna(prop, NULL, "layout");
|
|
RNA_def_property_struct_type(prop, "UILayout");
|
|
RNA_def_property_ui_text(prop, "Layout", "Defines the structure of the menu in the UI.");
|
|
|
|
/* registration */
|
|
prop= RNA_def_property(srna, "bl_idname", PROP_STRING, PROP_NONE);
|
|
RNA_def_property_string_sdna(prop, NULL, "type->idname");
|
|
RNA_def_property_flag(prop, PROP_REGISTER|PROP_NEVER_CLAMP);
|
|
RNA_def_property_ui_text(prop, "ID Name", "If this is set, the menu gets a custom ID, otherwise it takes the name of the class used to define the panel. For example, if the class name is \"OBJECT_MT_hello\", and bl_idname is not set by the script, then bl_idname = \"OBJECT_MT_hello\"");
|
|
|
|
prop= RNA_def_property(srna, "bl_label", PROP_STRING, PROP_NONE);
|
|
RNA_def_property_string_sdna(prop, NULL, "type->label");
|
|
RNA_def_property_flag(prop, PROP_REGISTER);
|
|
RNA_def_property_ui_text(prop, "Label", "The menu label");
|
|
|
|
RNA_define_verify_sdna(1);
|
|
}
|
|
|
|
void RNA_def_ui(BlenderRNA *brna)
|
|
{
|
|
rna_def_ui_layout(brna);
|
|
rna_def_panel(brna);
|
|
rna_def_header(brna);
|
|
rna_def_menu(brna);
|
|
}
|
|
|
|
#endif // RNA_RUNTIME
|
|
|