Toolbar region for the node editor. This region is, for now, empty and hidden by...
authorLukas Toenne <lukas.toenne@googlemail.com>
Wed, 12 Dec 2012 12:50:39 +0000 (12:50 +0000)
committerLukas Toenne <lukas.toenne@googlemail.com>
Wed, 12 Dec 2012 12:50:39 +0000 (12:50 +0000)
source/blender/editors/space_node/CMakeLists.txt
source/blender/editors/space_node/node_intern.h
source/blender/editors/space_node/node_ops.c
source/blender/editors/space_node/node_toolbar.c [new file with mode: 0644]
source/blender/editors/space_node/space_node.c

index 996c6fb530f8d36d202a805d30775b57d7b80dbd..3803f899cccba7b016260e7a2b86a21e8766f86f 100644 (file)
@@ -52,6 +52,7 @@ set(SRC
        node_relationships.c
        node_select.c
        node_templates.c
+       node_toolbar.c
        node_view.c
        space_node.c
 
index 45509e02226a0469a29167865af2ff4e06521836..671c4fde709378e5eb9609fe570a063b16e4fa56 100644 (file)
@@ -63,6 +63,7 @@ typedef struct bNodeLinkDrag {
 
 /* space_node.c */
 ARegion *node_has_buttons_region(ScrArea *sa);
+ARegion *node_has_tools_region(ScrArea *sa);
 
 /* node_header.c */
 void node_menus_register(void);
@@ -86,6 +87,10 @@ void node_set_cursor(struct wmWindow *win, struct SpaceNode *snode);
 void node_buttons_register(struct ARegionType *art);
 void NODE_OT_properties(struct wmOperatorType *ot);
 
+/* node_toolbar.c */
+void node_toolbar_register(struct ARegionType *art);
+void NODE_OT_toolbar(struct wmOperatorType *ot);
+
 /* node_ops.c */
 void node_operatortypes(void);
 void node_keymap(wmKeyConfig *keyconf);
index 64e5f67a3480abaf4aa13c6cda3242434777b4aa..8adccd9e6c4a2d789a7a868c8a73e03a072076e4 100644 (file)
@@ -49,6 +49,7 @@
 void node_operatortypes(void)
 {
        WM_operatortype_append(NODE_OT_properties);
+       WM_operatortype_append(NODE_OT_toolbar);
        
        WM_operatortype_append(NODE_OT_select);
        WM_operatortype_append(NODE_OT_select_all);
@@ -204,6 +205,7 @@ void node_keymap(struct wmKeyConfig *keyconf)
        keymap = WM_keymap_find(keyconf, "Node Generic", SPACE_NODE, 0);
        
        WM_keymap_add_item(keymap, "NODE_OT_properties", NKEY, KM_PRESS, 0, 0);
+       WM_keymap_add_item(keymap, "NODE_OT_toolbar", TKEY, KM_PRESS, 0, 0);
        
        /* Main Area only ----------------- */
        keymap = WM_keymap_find(keyconf, "Node Editor", SPACE_NODE, 0);
diff --git a/source/blender/editors/space_node/node_toolbar.c b/source/blender/editors/space_node/node_toolbar.c
new file mode 100644 (file)
index 0000000..86da400
--- /dev/null
@@ -0,0 +1,92 @@
+/*
+ * ***** BEGIN GPL LICENSE BLOCK *****
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version. 
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ *
+ * The Original Code is Copyright (C) 2012 Blender Foundation.
+ * All rights reserved.
+ *
+ * 
+ * Contributor(s): Lukas Toenne
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+/** \file blender/editors/space_node/node_toolbar.c
+ *  \ingroup nodes
+ */
+
+
+#include "MEM_guardedalloc.h"
+
+#include "BLI_utildefines.h"
+
+#include "DNA_node_types.h"
+
+#include "BKE_context.h"
+#include "BKE_node.h"
+#include "BKE_screen.h"
+
+#include "WM_api.h"
+#include "WM_types.h"
+
+#include "RNA_access.h"
+
+#include "ED_screen.h"
+
+#include "UI_interface.h"
+#include "UI_resources.h"
+
+#include "node_intern.h"  /* own include */
+
+
+/* ******************* node toolbar registration ************** */
+
+void node_toolbar_register(ARegionType *UNUSED(art))
+{
+}
+
+/* ********** operator to open/close toolshelf region */
+
+static int node_toolbar(bContext *C, wmOperator *UNUSED(op))
+{
+       ScrArea *sa = CTX_wm_area(C);
+       ARegion *ar = node_has_tools_region(sa);
+       
+       if (ar)
+               ED_region_toggle_hidden(C, ar);
+
+       return OPERATOR_FINISHED;
+}
+
+/* non-standard poll operator which doesn't care if there are any nodes */
+static int node_toolbar_poll(bContext *C)
+{
+       ScrArea *sa = CTX_wm_area(C);
+       return (sa && (sa->spacetype == SPACE_NODE));
+}
+
+void NODE_OT_toolbar(wmOperatorType *ot)
+{
+       ot->name = "Tool Shelf";
+       ot->description = "Toggles tool shelf display";
+       ot->idname = "NODE_OT_toolbar";
+       
+       ot->exec = node_toolbar;
+       ot->poll = node_toolbar_poll;
+       
+       /* flags */
+       ot->flag = 0;
+}
index f7e0d51ea03d828215eb39a288f5462fcab22e70..0e015a4477c348b69d45f118cec5bde8201e652e 100644 (file)
@@ -85,6 +85,30 @@ ARegion *node_has_buttons_region(ScrArea *sa)
        return arnew;
 }
 
+ARegion *node_has_tools_region(ScrArea *sa)
+{
+       ARegion *ar, *arnew;
+       
+       ar = BKE_area_find_region_type(sa, RGN_TYPE_TOOLS);
+       if (ar) return ar;
+       
+       /* add subdiv level; after header */
+       ar = BKE_area_find_region_type(sa, RGN_TYPE_HEADER);
+       
+       /* is error! */
+       if (ar == NULL) return NULL;
+       
+       arnew = MEM_callocN(sizeof(ARegion), "node tools");
+       
+       BLI_insertlinkafter(&sa->regionbase, ar, arnew);
+       arnew->regiontype = RGN_TYPE_TOOLS;
+       arnew->alignment = RGN_ALIGN_LEFT;
+       
+       arnew->flag = RGN_FLAG_HIDDEN;
+       
+       return arnew;
+}
+
 /* ******************** default callbacks for node space ***************** */
 
 static SpaceLink *node_new(const bContext *UNUSED(C))
@@ -342,6 +366,22 @@ static void node_buttons_area_draw(const bContext *C, ARegion *ar)
        ED_region_panels(C, ar, 1, NULL, -1);
 }
 
+/* add handlers, stuff you only do once or on area/region changes */
+static void node_toolbar_area_init(wmWindowManager *wm, ARegion *ar)
+{
+       wmKeyMap *keymap;
+
+       ED_region_panels_init(wm, ar);
+
+       keymap = WM_keymap_find(wm->defaultconf, "Node Generic", SPACE_NODE, 0);
+       WM_event_add_keymap_handler(&ar->handlers, keymap);
+}
+
+static void node_toolbar_area_draw(const bContext *C, ARegion *ar)
+{
+       ED_region_panels(C, ar, 1, NULL, -1);
+}
+
 static void node_cursor(wmWindow *win, ScrArea *sa, ARegion *ar)
 {
        SpaceNode *snode = sa->spacedata.first;
@@ -570,6 +610,19 @@ void ED_spacetype_node(void)
 
        node_buttons_register(art);
 
+       /* regions: toolbar */
+       art = MEM_callocN(sizeof(ARegionType), "spacetype view3d tools region");
+       art->regionid = RGN_TYPE_TOOLS;
+       art->prefsizex = 160; /* XXX */
+       art->prefsizey = 50; /* XXX */
+       art->keymapflag = ED_KEYMAP_UI | ED_KEYMAP_FRAMES;
+       art->listener = node_region_listener;
+       art->init = node_toolbar_area_init;
+       art->draw = node_toolbar_area_draw;
+       BLI_addhead(&st->regiontypes, art);
+       
+       node_toolbar_register(art);
+
        BKE_spacetype_register(st);
 }