Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/windowmanager/manipulators/intern/manipulator_library/primitive_manipulator.c')
-rw-r--r--source/blender/windowmanager/manipulators/intern/manipulator_library/primitive_manipulator.c28
1 files changed, 21 insertions, 7 deletions
diff --git a/source/blender/windowmanager/manipulators/intern/manipulator_library/primitive_manipulator.c b/source/blender/windowmanager/manipulators/intern/manipulator_library/primitive_manipulator.c
index 0c27e739fe7..c67aeace8d9 100644
--- a/source/blender/windowmanager/manipulators/intern/manipulator_library/primitive_manipulator.c
+++ b/source/blender/windowmanager/manipulators/intern/manipulator_library/primitive_manipulator.c
@@ -193,21 +193,17 @@ static void manipulator_primitive_invoke(
wmManipulator *MANIPULATOR_primitive_new(wmManipulatorGroup *mgroup, const char *name, const int style)
{
- PrimitiveManipulator *prim = MEM_callocN(sizeof(PrimitiveManipulator), name);
+ const wmManipulatorType *mpt = WM_manipulatortype_find("MANIPULATOR_WT_primitive", false);
+ PrimitiveManipulator *prim = (PrimitiveManipulator *)WM_manipulator_new(mpt, mgroup, name);
+
const float dir_default[3] = {0.0f, 0.0f, 1.0f};
- prim->manipulator.type.draw = manipulator_primitive_draw;
- prim->manipulator.type.draw_select = manipulator_primitive_render_3d_intersect;
- prim->manipulator.type.invoke = manipulator_primitive_invoke;
- prim->manipulator.type.intersect = NULL;
prim->manipulator.flag |= WM_MANIPULATOR_DRAW_ACTIVE;
prim->style = style;
/* defaults */
copy_v3_v3(prim->direction, dir_default);
- wm_manipulator_register(mgroup, &prim->manipulator, name);
-
return (wmManipulator *)prim;
}
@@ -237,6 +233,24 @@ void MANIPULATOR_primitive_set_up_vector(wmManipulator *manipulator, const float
}
}
+static void MANIPULATOR_WT_primitive(wmManipulatorType *wt)
+{
+ /* identifiers */
+ wt->idname = "MANIPULATOR_WT_primitive";
+
+ /* api callbacks */
+ wt->draw = manipulator_primitive_draw;
+ wt->draw_select = manipulator_primitive_render_3d_intersect;
+ wt->invoke = manipulator_primitive_invoke;
+
+ wt->size = sizeof(PrimitiveManipulator);
+}
+
+void ED_manipulatortypes_primitive(void)
+{
+ WM_manipulatortype_append(MANIPULATOR_WT_primitive);
+}
+
/** \} */ // Primitive Manipulator API