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
path: root/source
diff options
context:
space:
mode:
authorCampbell Barton <ideasman42@gmail.com>2014-02-12 08:31:23 +0400
committerCampbell Barton <ideasman42@gmail.com>2014-02-12 14:05:24 +0400
commitbd89528a5e159349003b90ec9f9a2460d0b45227 (patch)
treef7a5cbeddcd7324b0cd0ed6e5a3a5324c527b673 /source
parent054094f5827f3b6c0c1a6316c2e624f197244ec8 (diff)
Code cleanup: replace WM_OT_ndof_sensitivity_change -> WM_OT_context_scale_float
also increase maximum sensitivity
Diffstat (limited to 'source')
-rw-r--r--source/blender/makesrna/intern/rna_userdef.c4
-rw-r--r--source/blender/windowmanager/intern/wm_operators.c72
2 files changed, 19 insertions, 57 deletions
diff --git a/source/blender/makesrna/intern/rna_userdef.c b/source/blender/makesrna/intern/rna_userdef.c
index f73c285ada8..704aff21c4d 100644
--- a/source/blender/makesrna/intern/rna_userdef.c
+++ b/source/blender/makesrna/intern/rna_userdef.c
@@ -4039,11 +4039,11 @@ static void rna_def_userdef_input(BlenderRNA *brna)
/* 3D mouse settings */
/* global options */
prop = RNA_def_property(srna, "ndof_sensitivity", PROP_FLOAT, PROP_NONE);
- RNA_def_property_range(prop, 0.25f, 4.0f);
+ RNA_def_property_range(prop, 0.25f, 40.0f);
RNA_def_property_ui_text(prop, "Sensitivity", "Overall sensitivity of the 3D Mouse for panning");
prop = RNA_def_property(srna, "ndof_orbit_sensitivity", PROP_FLOAT, PROP_NONE);
- RNA_def_property_range(prop, 0.25f, 4.0f);
+ RNA_def_property_range(prop, 0.25f, 40.0f);
RNA_def_property_ui_text(prop, "Orbit Sensitivity", "Overall sensitivity of the 3D Mouse for orbiting");
prop = RNA_def_property(srna, "ndof_zoom_updown", PROP_BOOLEAN, PROP_NONE);
diff --git a/source/blender/windowmanager/intern/wm_operators.c b/source/blender/windowmanager/intern/wm_operators.c
index add726e53e8..c02cc456a46 100644
--- a/source/blender/windowmanager/intern/wm_operators.c
+++ b/source/blender/windowmanager/intern/wm_operators.c
@@ -4321,48 +4321,6 @@ static void WM_OT_dependency_relations(wmOperatorType *ot)
/* ******************************************************* */
-static int wm_ndof_sensitivity_exec(bContext *UNUSED(C), wmOperator *op)
-{
- const float min = 0.25f, max = 4.0f; /* TODO: get these from RNA property */
- float change;
- float sensitivity = U.ndof_sensitivity;
-
- if (RNA_boolean_get(op->ptr, "fast"))
- change = 0.5f; /* 50% change */
- else
- change = 0.1f; /* 10% */
-
- if (RNA_boolean_get(op->ptr, "decrease")) {
- sensitivity -= sensitivity * change;
- if (sensitivity < min)
- sensitivity = min;
- }
- else {
- sensitivity += sensitivity * change;
- if (sensitivity > max)
- sensitivity = max;
- }
-
- if (sensitivity != U.ndof_sensitivity) {
- U.ndof_sensitivity = sensitivity;
- }
-
- return OPERATOR_FINISHED;
-}
-
-static void WM_OT_ndof_sensitivity_change(wmOperatorType *ot)
-{
- ot->name = "Change NDOF Sensitivity";
- ot->idname = "WM_OT_ndof_sensitivity_change";
- ot->description = "Change NDOF sensitivity";
-
- ot->exec = wm_ndof_sensitivity_exec;
-
- RNA_def_boolean(ot->srna, "decrease", 1, "Decrease NDOF sensitivity", "If true then action decreases NDOF sensitivity instead of increasing");
- RNA_def_boolean(ot->srna, "fast", 0, "Fast NDOF sensitivity change", "If true then sensitivity changes 50%, otherwise 10%");
-}
-
-
static void operatortype_ghash_free_cb(wmOperatorType *ot)
{
if (ot->last_properties) {
@@ -4419,7 +4377,6 @@ void wm_operatortype_init(void)
WM_operatortype_append(WM_OT_search_menu);
WM_operatortype_append(WM_OT_call_menu);
WM_operatortype_append(WM_OT_radial_control);
- WM_operatortype_append(WM_OT_ndof_sensitivity_change);
#if defined(WIN32)
WM_operatortype_append(WM_OT_console_toggle);
#endif
@@ -4615,6 +4572,7 @@ void wm_window_keymap(wmKeyConfig *keyconf)
{
wmKeyMap *keymap = WM_keymap_find(keyconf, "Window", 0, 0);
wmKeyMapItem *kmi;
+ const char *data_path;
/* note, this doesn't replace existing keymap items */
WM_keymap_verify_item(keymap, "WM_OT_window_duplicate", WKEY, KM_PRESS, KM_CTRL | KM_ALT, 0);
@@ -4700,21 +4658,25 @@ void wm_window_keymap(wmKeyConfig *keyconf)
RNA_string_set(kmi->ptr, "value", "DOPESHEET_EDITOR");
/* ndof speed */
- kmi = WM_keymap_add_item(keymap, "WM_OT_ndof_sensitivity_change", NDOF_BUTTON_PLUS, KM_PRESS, 0, 0);
- RNA_boolean_set(kmi->ptr, "decrease", FALSE);
- RNA_boolean_set(kmi->ptr, "fast", FALSE);
+ data_path = "user_preferences.inputs.ndof_sensitivity";
+ kmi = WM_keymap_add_item(keymap, "WM_OT_context_scale_float", NDOF_BUTTON_PLUS, KM_PRESS, 0, 0);
+ RNA_string_set(kmi->ptr, "data_path", data_path);
+ RNA_float_set(kmi->ptr, "value", 1.1f);
+
+ kmi = WM_keymap_add_item(keymap, "WM_OT_context_scale_float", NDOF_BUTTON_MINUS, KM_PRESS, 0, 0);
+ RNA_string_set(kmi->ptr, "data_path", data_path);
+ RNA_float_set(kmi->ptr, "value", 1.0f / 1.1f);
- kmi = WM_keymap_add_item(keymap, "WM_OT_ndof_sensitivity_change", NDOF_BUTTON_MINUS, KM_PRESS, 0, 0);
- RNA_boolean_set(kmi->ptr, "decrease", TRUE);
- RNA_boolean_set(kmi->ptr, "fast", FALSE);
+ kmi = WM_keymap_add_item(keymap, "WM_OT_context_scale_float", NDOF_BUTTON_PLUS, KM_PRESS, KM_SHIFT, 0);
+ RNA_string_set(kmi->ptr, "data_path", data_path);
+ RNA_float_set(kmi->ptr, "value", 1.5f);
- kmi = WM_keymap_add_item(keymap, "WM_OT_ndof_sensitivity_change", NDOF_BUTTON_PLUS, KM_PRESS, KM_SHIFT, 0);
- RNA_boolean_set(kmi->ptr, "decrease", FALSE);
- RNA_boolean_set(kmi->ptr, "fast", TRUE);
+ kmi = WM_keymap_add_item(keymap, "WM_OT_context_scale_float", NDOF_BUTTON_MINUS, KM_PRESS, KM_SHIFT, 0);
+ RNA_string_set(kmi->ptr, "data_path", data_path);
+ RNA_float_set(kmi->ptr, "value", 1.0f / 1.5f);
+ data_path = NULL;
+ (void)data_path;
- kmi = WM_keymap_add_item(keymap, "WM_OT_ndof_sensitivity_change", NDOF_BUTTON_MINUS, KM_PRESS, KM_SHIFT, 0);
- RNA_boolean_set(kmi->ptr, "decrease", TRUE);
- RNA_boolean_set(kmi->ptr, "fast", TRUE);
gesture_circle_modal_keymap(keyconf);
gesture_border_modal_keymap(keyconf);