[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [23723] trunk/blender: Key Configuration

Brecht Van Lommel brecht at blender.org
Thu Oct 8 20:40:06 CEST 2009


Revision: 23723
          http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=23723
Author:   blendix
Date:     2009-10-08 20:40:03 +0200 (Thu, 08 Oct 2009)

Log Message:
-----------
Key Configuration

Keymaps are now saveable and configurable from the user preferences, note
that editing one item in a keymap means the whole keymap is now defined by
the user and will not be updated by Blender, an option for syncing might be
added later. The outliner interface is still there, but I will probably
remove it.

There's actually 3 levels now:

* Default builtin key configuration.
* Key configuration loaded from .py file, for configs like Blender 2.4x
  or other 3D applications.
* Keymaps edited by the user and saved in .B.blend. These can be saved
  to .py files as well to make creating distributable configurations
  easier.

Also, user preferences sections were reorganized a bit, now there is:
Interface, Editing, Input, Files and System.


Implementation notes:
* wmKeyConfig was added which represents a key configuration containing
  keymaps.
* wmKeymapItem was renamed to wmKeyMapItem for consistency with wmKeyMap.
* Modal maps are not wrapped yet.
* User preferences DNA file reading did not support newdataadr() yet,
  added this now for reading keymaps.
* Key configuration related settings are now RNA wrapped.
* is_property_set and is_property_hidden python methods were added.

Modified Paths:
--------------
    trunk/blender/release/scripts/ui/space_userpref.py
    trunk/blender/source/blender/blenkernel/BKE_screen.h
    trunk/blender/source/blender/blenkernel/intern/blender.c
    trunk/blender/source/blender/blenloader/intern/readfile.c
    trunk/blender/source/blender/blenloader/intern/writefile.c
    trunk/blender/source/blender/editors/animation/anim_channels_edit.c
    trunk/blender/source/blender/editors/animation/anim_markers.c
    trunk/blender/source/blender/editors/animation/anim_ops.c
    trunk/blender/source/blender/editors/armature/armature_ops.c
    trunk/blender/source/blender/editors/curve/curve_ops.c
    trunk/blender/source/blender/editors/gpencil/gpencil_ops.c
    trunk/blender/source/blender/editors/include/ED_anim_api.h
    trunk/blender/source/blender/editors/include/ED_armature.h
    trunk/blender/source/blender/editors/include/ED_curve.h
    trunk/blender/source/blender/editors/include/ED_gpencil.h
    trunk/blender/source/blender/editors/include/ED_markers.h
    trunk/blender/source/blender/editors/include/ED_mball.h
    trunk/blender/source/blender/editors/include/ED_mesh.h
    trunk/blender/source/blender/editors/include/ED_object.h
    trunk/blender/source/blender/editors/include/ED_particle.h
    trunk/blender/source/blender/editors/include/ED_physics.h
    trunk/blender/source/blender/editors/include/ED_screen.h
    trunk/blender/source/blender/editors/include/ED_sculpt.h
    trunk/blender/source/blender/editors/include/ED_transform.h
    trunk/blender/source/blender/editors/include/ED_uvedit.h
    trunk/blender/source/blender/editors/include/UI_interface.h
    trunk/blender/source/blender/editors/include/UI_view2d.h
    trunk/blender/source/blender/editors/interface/interface.c
    trunk/blender/source/blender/editors/interface/interface_handlers.c
    trunk/blender/source/blender/editors/interface/interface_layout.c
    trunk/blender/source/blender/editors/interface/interface_utils.c
    trunk/blender/source/blender/editors/interface/view2d_ops.c
    trunk/blender/source/blender/editors/mesh/editmesh_mods.c
    trunk/blender/source/blender/editors/mesh/mesh_ops.c
    trunk/blender/source/blender/editors/metaball/mball_ops.c
    trunk/blender/source/blender/editors/object/object_ops.c
    trunk/blender/source/blender/editors/physics/physics_ops.c
    trunk/blender/source/blender/editors/screen/area.c
    trunk/blender/source/blender/editors/screen/screen_ops.c
    trunk/blender/source/blender/editors/sculpt_paint/paint_ops.c
    trunk/blender/source/blender/editors/space_action/action_intern.h
    trunk/blender/source/blender/editors/space_action/action_ops.c
    trunk/blender/source/blender/editors/space_action/space_action.c
    trunk/blender/source/blender/editors/space_api/spacetypes.c
    trunk/blender/source/blender/editors/space_buttons/space_buttons.c
    trunk/blender/source/blender/editors/space_console/space_console.c
    trunk/blender/source/blender/editors/space_file/file_panels.c
    trunk/blender/source/blender/editors/space_file/filelist.c
    trunk/blender/source/blender/editors/space_file/filesel.c
    trunk/blender/source/blender/editors/space_file/space_file.c
    trunk/blender/source/blender/editors/space_graph/graph_intern.h
    trunk/blender/source/blender/editors/space_graph/graph_ops.c
    trunk/blender/source/blender/editors/space_graph/space_graph.c
    trunk/blender/source/blender/editors/space_image/space_image.c
    trunk/blender/source/blender/editors/space_info/space_info.c
    trunk/blender/source/blender/editors/space_logic/space_logic.c
    trunk/blender/source/blender/editors/space_nla/nla_intern.h
    trunk/blender/source/blender/editors/space_nla/nla_ops.c
    trunk/blender/source/blender/editors/space_nla/space_nla.c
    trunk/blender/source/blender/editors/space_node/node_intern.h
    trunk/blender/source/blender/editors/space_node/node_ops.c
    trunk/blender/source/blender/editors/space_node/space_node.c
    trunk/blender/source/blender/editors/space_outliner/outliner.c
    trunk/blender/source/blender/editors/space_outliner/outliner_intern.h
    trunk/blender/source/blender/editors/space_outliner/outliner_ops.c
    trunk/blender/source/blender/editors/space_outliner/space_outliner.c
    trunk/blender/source/blender/editors/space_script/script_intern.h
    trunk/blender/source/blender/editors/space_script/script_ops.c
    trunk/blender/source/blender/editors/space_script/space_script.c
    trunk/blender/source/blender/editors/space_sequencer/sequencer_intern.h
    trunk/blender/source/blender/editors/space_sequencer/sequencer_ops.c
    trunk/blender/source/blender/editors/space_sequencer/space_sequencer.c
    trunk/blender/source/blender/editors/space_sound/space_sound.c
    trunk/blender/source/blender/editors/space_text/space_text.c
    trunk/blender/source/blender/editors/space_time/space_time.c
    trunk/blender/source/blender/editors/space_time/time_intern.h
    trunk/blender/source/blender/editors/space_time/time_ops.c
    trunk/blender/source/blender/editors/space_userpref/space_userpref.c
    trunk/blender/source/blender/editors/space_view3d/space_view3d.c
    trunk/blender/source/blender/editors/space_view3d/view3d_edit.c
    trunk/blender/source/blender/editors/space_view3d/view3d_intern.h
    trunk/blender/source/blender/editors/space_view3d/view3d_ops.c
    trunk/blender/source/blender/editors/space_view3d/view3d_view.c
    trunk/blender/source/blender/editors/transform/transform.c
    trunk/blender/source/blender/editors/transform/transform.h
    trunk/blender/source/blender/editors/transform/transform_ops.c
    trunk/blender/source/blender/editors/uvedit/uvedit_ops.c
    trunk/blender/source/blender/makesdna/DNA_userdef_types.h
    trunk/blender/source/blender/makesdna/DNA_windowmanager_types.h
    trunk/blender/source/blender/makesrna/RNA_access.h
    trunk/blender/source/blender/makesrna/RNA_types.h
    trunk/blender/source/blender/makesrna/intern/rna_access.c
    trunk/blender/source/blender/makesrna/intern/rna_define.c
    trunk/blender/source/blender/makesrna/intern/rna_internal.h
    trunk/blender/source/blender/makesrna/intern/rna_ui_api.c
    trunk/blender/source/blender/makesrna/intern/rna_userdef.c
    trunk/blender/source/blender/makesrna/intern/rna_wm.c
    trunk/blender/source/blender/makesrna/intern/rna_wm_api.c
    trunk/blender/source/blender/python/intern/bpy_rna.c
    trunk/blender/source/blender/windowmanager/WM_api.h
    trunk/blender/source/blender/windowmanager/intern/wm.c
    trunk/blender/source/blender/windowmanager/intern/wm_event_system.c
    trunk/blender/source/blender/windowmanager/intern/wm_keymap.c
    trunk/blender/source/blender/windowmanager/intern/wm_operators.c
    trunk/blender/source/blender/windowmanager/intern/wm_window.c
    trunk/blender/source/blender/windowmanager/wm.h
    trunk/blender/source/blender/windowmanager/wm_event_system.h
    trunk/blender/source/blender/windowmanager/wm_event_types.h

Modified: trunk/blender/release/scripts/ui/space_userpref.py
===================================================================
--- trunk/blender/release/scripts/ui/space_userpref.py	2009-10-08 17:32:51 UTC (rev 23722)
+++ trunk/blender/release/scripts/ui/space_userpref.py	2009-10-08 18:40:03 UTC (rev 23723)
@@ -12,6 +12,10 @@
 	
 		layout.operator_context = "EXEC_AREA"
 		layout.itemO("wm.save_homefile", text="Save As Default")
+
+		if userpref.active_section == 'INPUT':
+			layout.operator_context = "INVOKE_DEFAULT"
+			layout.itemO("wm.keyconfig_save", "Save Key Configuration...")
 			
 class USERPREF_MT_view(bpy.types.Menu):
 	__space_type__ = 'USER_PREFERENCES'
@@ -31,14 +35,14 @@
 
 		layout.itemR(userpref, "active_section", expand=True)
 
-class USERPREF_PT_view(bpy.types.Panel):
+class USERPREF_PT_interface(bpy.types.Panel):
 	__space_type__ = 'USER_PREFERENCES'
-	__label__ = "View"
+	__label__ = "Interface"
 	__show_header__ = False
 
 	def poll(self, context):
 		userpref = context.user_preferences
-		return (userpref.active_section == 'VIEW_CONTROLS')
+		return (userpref.active_section == 'INTERFACE')
 
 	def draw(self, context):
 		layout = self.layout
@@ -87,37 +91,27 @@
 		sub1.itemR(view, "perspective_orthographic_switch")
 		sub1.itemR(view, "smooth_view")
 		sub1.itemR(view, "rotation_angle")
-		sub1.itemS()
-		sub1.itemL(text="NDOF Device:")
-		sub1.itemR(view, "ndof_pan_speed", text="Pan Speed")
-		sub1.itemR(view, "ndof_rotate_speed", text="Orbit Speed")
 		
 		col = split.column()
 		sub = col.split(percentage=0.85)
 		
 		sub1 = sub.column()
-		sub1.itemL(text="Mouse Buttons:")
-		
-		sub2 = sub1.column()
-		sub2.enabled = (view.select_mouse == 'RIGHT')
-		sub2.itemR(view, "emulate_3_button_mouse")
-		sub1.itemL(text="Select With:")
-		sub1.row().itemR(view, "select_mouse", expand=True)
-		sub1.itemL(text="Middle Mouse:")
-		sub1.row().itemR(view, "middle_mouse", expand=True)
-		sub1.itemR(view, "use_middle_mouse_paste")
-		sub1.itemL(text="Mouse Wheel:")
-		sub1.itemR(view, "wheel_invert_zoom", text="Invert Zoom")
-		sub1.itemR(view, "wheel_scroll_lines", text="Scroll Lines")
-		sub1.itemL(text="Mouse Motion:")
-		sub1.itemR(view, "continuous_mouse", text="Continuous Grab")
-		sub1.itemS()
 		sub1.itemL(text="Menus:")
 		sub1.itemR(view, "open_mouse_over")
 		sub1.itemL(text="Menu Open Delay:")
 		sub1.itemR(view, "open_toplevel_delay", text="Top Level")
 		sub1.itemR(view, "open_sublevel_delay", text="Sub Level")
 
+		sub1.itemS()
+		sub1.itemS()
+		sub1.itemS()			
+
+		sub1.itemL(text="Toolbox:")
+		sub1.itemR(view, "use_column_layout")
+		sub1.itemL(text="Open Toolbox Delay:")
+		sub1.itemR(view, "open_left_mouse_delay", text="Hold LMB")
+		sub1.itemR(view, "open_right_mouse_delay", text="Hold RMB")
+
 		col = split.column()
 		sub = col.split(percentage=0.85)
 		
@@ -129,14 +123,6 @@
 		sub2.itemR(view, "manipulator_size", text="Size")
 		sub2.itemR(view, "manipulator_handle_size", text="Handle Size")
 		sub2.itemR(view, "manipulator_hotspot", text="Hotspot")	
-		sub1.itemS()
-		sub1.itemS()
-		sub1.itemS()			
-		sub1.itemL(text="Toolbox:")
-		sub1.itemR(view, "use_column_layout")
-		sub1.itemL(text="Open Toolbox Delay:")
-		sub1.itemR(view, "open_left_mouse_delay", text="Hold LMB")
-		sub1.itemR(view, "open_right_mouse_delay", text="Hold RMB")
 
 class USERPREF_PT_edit(bpy.types.Panel):
 	__space_type__ = 'USER_PREFERENCES'
@@ -145,7 +131,7 @@
 
 	def poll(self, context):
 		userpref = context.user_preferences
-		return (userpref.active_section == 'EDIT_METHODS')
+		return (userpref.active_section == 'EDITING')
 
 	def draw(self, context):
 		layout = self.layout
@@ -248,7 +234,7 @@
 
 	def poll(self, context):
 		userpref = context.user_preferences
-		return (userpref.active_section == 'SYSTEM_OPENGL')
+		return (userpref.active_section == 'SYSTEM')
 
 	def draw(self, context):
 		layout = self.layout
@@ -276,7 +262,7 @@
 		sub1.itemL(text="Sound:")
 		sub1.row().itemR(system, "audio_device", expand=True)
 		sub2 = sub1.column()
-		sub2.active = system.audio_device != 'AUDIO_DEVICE_NULL'
+		sub2.active = system.audio_device != 'NONE'
 		sub2.itemR(system, "enable_all_codecs")
 		sub2.itemR(system, "game_sound")
 		sub2.itemR(system, "audio_channels", text="Channels")
@@ -332,14 +318,14 @@
 		sub1.itemR(system, "prefetch_frames")
 		sub1.itemR(system, "memory_cache_limit")
 		
-class USERPREF_PT_filepaths(bpy.types.Panel):
+class USERPREF_PT_file(bpy.types.Panel):
 	__space_type__ = 'USER_PREFERENCES'
-	__label__ = "File Paths"
+	__label__ = "Files"
 	__show_header__ = False
 
 	def poll(self, context):
 		userpref = context.user_preferences
-		return (userpref.active_section == 'FILE_PATHS')
+		return (userpref.active_section == 'FILES')
 
 	def draw(self, context):
 		layout = self.layout
@@ -398,11 +384,314 @@
 		sub3.enabled = paths.auto_save_temporary_files
 		sub3.itemR(paths, "auto_save_time", text="Timer (mins)")
 
+class USERPREF_PT_input(bpy.types.Panel):
+	__space_type__ = 'USER_PREFERENCES'
+	__label__ = "Input"
+	__show_header__ = False
+
+	def poll(self, context):
+		userpref = context.user_preferences
+		return (userpref.active_section == 'INPUT')
+
+	def draw(self, context):
+		layout = self.layout
+		
+		userpref = context.user_preferences
+		wm = context.manager
+		#input = userpref.input
+		input = userpref
+		view = userpref.view
+
+		split = layout.split(percentage=0.25)
+
+		# General settings
+		row = split.row()
+		col = row.column()
+
+		sub = col.column()
+		sub.itemL(text="Configuration:")
+		sub.item_pointerR(wm, "active_keyconfig", wm, "keyconfigs", text="")
+
+		col.itemS()
+
+		sub = col.column()
+		sub.itemL(text="Mouse:")
+		sub1 = sub.column()
+		sub1.enabled = (view.select_mouse == 'RIGHT')
+		sub1.itemR(view, "emulate_3_button_mouse")
+		sub.itemR(view, "continuous_mouse", text="Continuous Grab")
+
+		sub.itemL(text="Select With:")
+		sub.row().itemR(view, "select_mouse", expand=True)
+		#sub.itemL(text="Middle Mouse:")
+		#sub.row().itemR(view, "middle_mouse", expand=True)
+		#sub.itemR(view, "use_middle_mouse_paste")
+
+		#col.itemS()
+
+		#sub = col.column()
+		#sub.itemL(text="Mouse Wheel:")
+		#sub.itemR(view, "wheel_invert_zoom", text="Invert Zoom")
+		#sub.itemR(view, "wheel_scroll_lines", text="Scroll Lines")
+
+		col.itemS()
+
+		sub = col.column()
+		sub.itemL(text="NDOF Device:")
+		sub.itemR(view, "ndof_pan_speed", text="Pan Speed")
+		sub.itemR(view, "ndof_rotate_speed", text="Orbit Speed")
+
+		row.itemS()
+
+		# Keymap Settings
+		col = split.column()
+
+		kc = wm.active_keyconfig
+		defkc = wm.default_keyconfig
+		km = wm.active_keymap
+
+		subsplit = col.split()
+		subsplit.item_pointerR(wm, "active_keymap", defkc, "keymaps", text="Map:")
+		if km.user_defined:
+			row = subsplit.row()
+			row.itemO("WM_OT_keymap_restore", text="Restore")
+			row.item_booleanO("WM_OT_keymap_restore", "all", True, text="Restore All")
+		else:
+			row = subsplit.row()
+			row.itemO("WM_OT_keymap_edit", text="Edit")
+			row.itemL()
+
+		col.itemS()
+		
+		for kmi in km.items:
+			subcol = col.column()
+			subcol.set_context_pointer("keyitem", kmi)
+
+			row = subcol.row()
+
+			if kmi.expanded:
+				row.itemR(kmi, "expanded", text="", icon="ICON_TRIA_DOWN")
+			else:
+				row.itemR(kmi, "expanded", text="", icon="ICON_TRIA_RIGHT")
+
+			itemrow = row.row()
+			itemrow.enabled = km.user_defined
+			itemrow.itemR(kmi, "active", text="", icon="ICON_DOT")
+
+			itemcol = itemrow.column()
+			itemcol.active = kmi.active
+			row = itemcol.row()
+			row.itemR(kmi, "idname", text="")
+
+			sub = row.row()
+			sub.scale_x = 0.6
+			sub.itemR(kmi, "map_type", text="")
+
+			sub = row.row(align=True)
+			if kmi.map_type == 'KEYBOARD':
+				sub.itemR(kmi, "type", text="", full_event=True)
+			elif kmi.map_type == 'MOUSE':
+				sub.itemR(kmi, "type", text="", full_event=True)
+			elif kmi.map_type == 'TWEAK':
+				sub.scale_x = 0.5
+				sub.itemR(kmi, "type", text="")
+				sub.itemR(kmi, "value", text="")
+			elif kmi.map_type == 'TIMER':
+				sub.itemR(kmi, "type", text="")
+			else:
+				sub.itemL()
+
+			if kmi.expanded:
+				if kmi.map_type not in ('TEXTINPUT', 'TIMER'):
+					sub = itemcol.row(align=True)
+
+					if kmi.map_type == 'KEYBOARD':
+						sub.itemR(kmi, "type", text="", event=True)
+						sub.itemR(kmi, "value", text="")
+					elif kmi.map_type == 'MOUSE':
+						sub.itemR(kmi, "type", text="")
+						sub.itemR(kmi, "value", text="")
+					else:
+						sub.itemL()
+						sub.itemL()
+
+					subrow = sub.row()
+					subrow.scale_x = 0.75
+					subrow.itemR(kmi, "shift")
+					subrow.itemR(kmi, "ctrl")
+					subrow.itemR(kmi, "alt")
+					subrow.itemR(kmi, "oskey")
+					sub.itemR(kmi, "key_modifier", text="", event=True)
+
+				flow = itemcol.column_flow(columns=2)
+				props = kmi.properties
+
+				if props != None:
+					for pname in dir(props):
+						if not props.is_property_hidden(pname):
+							flow.itemR(props, pname)
+
+				itemcol.itemS()
+
+			itemrow.itemO("wm.keyitem_remove", text="", icon="ICON_ZOOMOUT")
+
+		itemrow = col.row()
+		itemrow.itemL()
+		itemrow.itemO("wm.keyitem_add", text="", icon="ICON_ZOOMIN")
+		itemrow.enabled = km.user_defined
+
 bpy.types.register(USERPREF_HT_header)
 bpy.types.register(USERPREF_MT_view)
 bpy.types.register(USERPREF_PT_tabs)
-bpy.types.register(USERPREF_PT_view)
+bpy.types.register(USERPREF_PT_interface)
 bpy.types.register(USERPREF_PT_edit)
 bpy.types.register(USERPREF_PT_system)
-bpy.types.register(USERPREF_PT_filepaths)
+bpy.types.register(USERPREF_PT_file)
+bpy.types.register(USERPREF_PT_input)
 
+class WM_OT_keyconfig_save(bpy.types.Operator):
+	"Save key configuration to a python script."
+	__idname__ = "wm.keyconfig_save"
+	__label__ = "Save Key Configuration..."
+	__props__ = [
+		bpy.props.StringProperty(attr="path", name="File Path", description="File path to write file to.")]
+
+	def _string_value(self, value):
+		result = ""
+		if isinstance(value, str):
+			if value != "":
+				result = "\'%s\'" % value
+		elif isinstance(value, bool):
+			if value:
+				result = "True"
+			else:
+				result = "False"
+		elif isinstance(value, float):
+			result = "%.10f" % value
+		elif isinstance(value, int):
+			result = "%d" % value
+		elif getattr(value, '__len__', False):
+			if len(value):
+				result = "["
+				for i in range(0, len(value)):
+					result += self._string_value(value[i])
+					if i != len(value)-1:
+						result += ", "
+				result += "]"
+		else:
+			print("Save key configuration: can't write ", value)
+
+		return result
+

@@ Diff output truncated at 10240 characters. @@




More information about the Bf-blender-cvs mailing list