This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/editors/transform/transform_ops.c

211 lines
5.2 KiB
C
Raw Normal View History

2008-12-29 04:14:27 +00:00
/**
* $Id: transform_ops.c 17542 2008-11-23 15:27:53Z theeth $
*
* ***** 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*
* Contributor(s): none yet.
*
* ***** END GPL LICENSE BLOCK *****
*/
#include "MEM_guardedalloc.h"
#include "DNA_space_types.h"
#include "DNA_windowmanager_types.h"
2008-12-29 04:14:27 +00:00
#include "RNA_access.h"
#include "RNA_define.h"
#include "BLI_arithb.h"
#include "BKE_utildefines.h"
#include "BKE_context.h"
#include "WM_api.h"
#include "WM_types.h"
#include "ED_screen.h"
#include "transform.h"
static void transformops_exit(bContext *C, wmOperator *op)
{
saveTransform(C, op->customdata, op);
2008-12-29 04:14:27 +00:00
MEM_freeN(op->customdata);
op->customdata = NULL;
}
static void transformops_data(bContext *C, wmOperator *op, wmEvent *event)
{
if (op->customdata == NULL)
{
TransInfo *t = MEM_callocN(sizeof(TransInfo), "TransInfo data");
initTransform(C, t, op, event);
2008-12-29 04:14:27 +00:00
/* store data */
op->customdata = t;
}
2008-12-29 04:14:27 +00:00
}
static int transform_modal(bContext *C, wmOperator *op, wmEvent *event)
{
int exit_code;
2008-12-29 04:14:27 +00:00
TransInfo *t = op->customdata;
2008-12-29 04:14:27 +00:00
transformEvent(t, event);
transformApply(t);
exit_code = transformEnd(C, t);
if (exit_code != OPERATOR_RUNNING_MODAL)
2008-12-29 04:14:27 +00:00
{
transformops_exit(C, op);
}
return exit_code;
2008-12-29 04:14:27 +00:00
}
static int transform_cancel(bContext *C, wmOperator *op)
2008-12-29 04:14:27 +00:00
{
TransInfo *t = op->customdata;
t->state = TRANS_CANCEL;
transformEnd(C, t);
transformops_exit(C, op);
return OPERATOR_FINISHED;
}
static int transform_exec(bContext *C, wmOperator *op)
{
TransInfo *t;
transformops_data(C, op, NULL);
t = op->customdata;
t->options |= CTX_AUTOCONFIRM;
2008-12-29 04:14:27 +00:00
transformApply(t);
transformEnd(C, t);
2008-12-29 04:14:27 +00:00
//ED_region_tag_redraw(CTX_wm_region(C));
2008-12-29 04:14:27 +00:00
transformops_exit(C, op);
return OPERATOR_FINISHED;
}
static int transform_invoke(bContext *C, wmOperator *op, wmEvent *event)
{
float values[4];
2008-12-29 04:14:27 +00:00
RNA_float_get_array(op->ptr, "values", values);
2008-12-29 04:14:27 +00:00
transformops_data(C, op, event);
if(!QuatIsNul(values)) {
2008-12-29 04:14:27 +00:00
return transform_exec(C, op);
}
else {
/* add temp handler */
WM_event_add_modal_handler(C, &CTX_wm_window(C)->handlers, op);
return OPERATOR_RUNNING_MODAL;
}
}
void TFM_OT_transform(struct wmOperatorType *ot)
{
PropertyRNA *prop;
static float value[4] = {0, 0, 0};
/* identifiers */
ot->name = "Transform";
ot->idname = "TFM_OT_transform";
ot->flag= OPTYPE_REGISTER;
2008-12-29 04:14:27 +00:00
/* api callbacks */
ot->invoke = transform_invoke;
ot->exec = transform_exec;
ot->modal = transform_modal;
ot->cancel = transform_cancel;
2008-12-29 04:14:27 +00:00
ot->poll = ED_operator_areaactive;
RNA_def_property(ot->srna, "mode", PROP_INT, PROP_NONE);
RNA_def_property(ot->srna, "options", PROP_INT, PROP_NONE);
2008-12-29 04:14:27 +00:00
prop = RNA_def_property(ot->srna, "values", PROP_FLOAT, PROP_VECTOR);
2008-12-29 04:14:27 +00:00
RNA_def_property_array(prop, 4);
RNA_def_property_float_array_default(prop, value);
}
void transform_operatortypes(void)
{
WM_operatortype_append(TFM_OT_transform);
}
void transform_keymap_for_space(struct wmWindowManager *wm, struct ListBase *keymap, int spaceid)
{
wmKeymapItem *km;
switch(spaceid)
{
case SPACE_VIEW3D:
km = WM_keymap_add_item(keymap, "TFM_OT_transform", GKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_TRANSLATION);
km = WM_keymap_add_item(keymap, "TFM_OT_transform", RKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_ROTATION);
km = WM_keymap_add_item(keymap, "TFM_OT_transform", SKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_RESIZE);
km = WM_keymap_add_item(keymap, "TFM_OT_transform", WKEY, KM_PRESS, KM_SHIFT, 0);
RNA_int_set(km->ptr, "mode", TFM_WARP);
km = WM_keymap_add_item(keymap, "TFM_OT_transform", SKEY, KM_PRESS, KM_CTRL|KM_SHIFT, 0);
RNA_int_set(km->ptr, "mode", TFM_TOSPHERE);
km = WM_keymap_add_item(keymap, "TFM_OT_transform", SKEY, KM_PRESS, KM_ALT|KM_CTRL|KM_SHIFT, 0);
RNA_int_set(km->ptr, "mode", TFM_SHEAR);
break;
case SPACE_ACTION:
km= WM_keymap_add_item(keymap, "TFM_OT_transform", GKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_TIME_TRANSLATE);
km= WM_keymap_add_item(keymap, "TFM_OT_transform", EKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_TIME_EXTEND);
km= WM_keymap_add_item(keymap, "TFM_OT_transform", SKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_TIME_SCALE);
km= WM_keymap_add_item(keymap, "TFM_OT_transform", TKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_TIME_SLIDE);
case SPACE_NODE:
km= WM_keymap_add_item(keymap, "TFM_OT_transform", GKEY, KM_PRESS, 0, 0);
RNA_int_set(km->ptr, "mode", TFM_NODE_TRANSLATE);
2008-12-29 04:14:27 +00:00
default:
break;
}
}