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

git.blender.org/blender-addons.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'system_demo_mode/__init__.py')
-rw-r--r--system_demo_mode/__init__.py206
1 files changed, 206 insertions, 0 deletions
diff --git a/system_demo_mode/__init__.py b/system_demo_mode/__init__.py
new file mode 100644
index 00000000..cc568c11
--- /dev/null
+++ b/system_demo_mode/__init__.py
@@ -0,0 +1,206 @@
+# ##### 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.
+#
+# ##### END GPL LICENSE BLOCK #####
+
+# <pep8 compliant>
+
+bl_info = {
+ "name": "Demo Mode",
+ "author": "Campbell Barton",
+ "blender": (2, 5, 7),
+ "api": 35622,
+ "location": "Demo Menu",
+ "description": "Demo mode lets you select multiple blend files and loop over them.",
+ "warning": "",
+ "wiki_url": "http://wiki.blender.org/index.php/Extensions:2.5/Py/"\
+ "Scripts/System/Demo_Mode#Running_Demo_Mode",
+ "tracker_url": "",
+ "support": 'OFFICIAL',
+ "category": "System"}
+
+# To support reload properly, try to access a package var, if it's there, reload everything
+if "bpy" in locals():
+ import imp
+ if "config" in locals():
+ imp.reload(config)
+
+
+import bpy
+from bpy.props import StringProperty, BoolProperty, IntProperty, FloatProperty, EnumProperty
+from io_utils import ImportHelper
+
+
+class DemoModeSetup(bpy.types.Operator):
+ '''Creates a demo script and optionally executes'''
+ bl_idname = "wm.demo_mode_setup"
+ bl_label = "Demo Mode (Setup)"
+ bl_options = {'PRESET'}
+
+ # List of operator properties, the attributes will be assigned
+ # to the class instance from the operator settings before calling.
+
+ # these are used to create the file list.
+ filepath = StringProperty(name="File Path", description="Filepath used for importing the file", maxlen=1024, default="", subtype='FILE_PATH')
+ random_order = BoolProperty(name="Random Order", description="Select files randomly", default=False)
+ mode = EnumProperty(items=(
+ ('AUTO', "Auto", ""),
+ ('PLAY', "Play", ""),
+ ('RENDER', "Render", ""),
+ ),
+ name="Method")
+
+ run = BoolProperty(name="Run Immediately!", description="Run demo immediately", default=True)
+
+ # these are mapped directly to the config!
+ #
+ # anim
+ # ====
+ anim_cycles = IntProperty(name="Cycles", description="Number of times to play the animation", min=1, max=1000, default=2)
+ anim_time_min = FloatProperty(name="Time Min", description="Minimum number of seconds to show the animation for (for small loops)", min=0.0, max=1000.0, soft_min=1.0, soft_max=1000.0, default=4.0)
+ anim_time_max = FloatProperty(name="Time Max", description="Maximum number of seconds to show the animation for (incase the end frame is very high for no reason)", min=0.0, max=100000000.0, soft_min=1.0, soft_max=100000000.0, default=8.0)
+ anim_screen_switch = FloatProperty(name="Screen Switch", description="Time between switching screens (in seconds) or 0 to disable", min=0.0, max=100000000.0, soft_min=1.0, soft_max=60.0, default=0.0)
+ #
+ # render
+ # ======
+ display_render = FloatProperty(name="Render Delay", description="Time to display the rendered image before moving on (in seconds)", min=0.0, max=60.0, default=4.0)
+ anim_render = BoolProperty(name="Render Anim", description="Render entire animation (render mode only)", default=False)
+
+ def execute(self, context):
+ from . import config
+
+ keywords = self.as_keywords(ignore=("filepath", "random_order", "run"))
+
+ from . import config
+ cfg_str, dirpath = config.as_string(self.filepath, self.random_order, **keywords)
+ text = bpy.data.texts.get("demo.py")
+ if text:
+ text.name += ".back"
+
+ text = bpy.data.texts.new("demo.py")
+ text.from_string(cfg_str)
+
+ if self.run:
+ extern_demo_mode_run()
+
+ return {'FINISHED'}
+
+ def invoke(self, context, event):
+ context.window_manager.fileselect_add(self)
+ return {'RUNNING_MODAL'}
+
+ def check(self, context):
+ return True # lazy
+
+ def draw(self, context):
+ layout = self.layout
+
+ box = layout.box()
+ box.label("Search *.blend recursively")
+ box.label("Writes: demo.py config text.")
+
+ col = layout.column()
+ col.prop(self, "run")
+
+ col.label("Generate Settings:")
+ row = col.row()
+ row.prop(self, "mode", expand=True)
+ col.prop(self, "random_order")
+
+ mode = self.mode
+
+ col.separator()
+ colsub = col.column()
+ colsub.active = (mode in ('AUTO', 'PLAY'))
+ colsub.label("Animate Settings:")
+ colsub.prop(self, "anim_cycles")
+ colsub.prop(self, "anim_time_min")
+ colsub.prop(self, "anim_time_max")
+ colsub.prop(self, "anim_screen_switch")
+
+ col.separator()
+ colsub = col.column()
+ colsub.active = (mode in ('AUTO', 'RENDER'))
+ colsub.label("Render Settings:")
+ colsub.prop(self, "display_render")
+
+
+class DemoModeRun(bpy.types.Operator):
+ bl_idname = "wm.demo_mode_run"
+ bl_label = "Demo Mode (Start)"
+
+ def execute(self, context):
+ if extern_demo_mode_run():
+ return {'FINISHED'}
+ else:
+ self.report({'ERROR'}, "Cant load demo.py config, run: File -> Demo Mode (Setup)")
+ return {'CANCELLED'}
+
+
+# --- call demo_mode.py funcs
+def extern_demo_mode_run():
+ # this accesses demo_mode.py which is kept standalone
+ # and can be run direct.
+ from . import demo_mode
+ if demo_mode.load_config():
+ demo_mode.demo_mode_load_file() # kick starts the modal operator
+ return True
+ else:
+ return False
+
+
+def extern_demo_mode_register():
+ # this accesses demo_mode.py which is kept standalone
+ # and can be run direct.
+ from . import demo_mode
+ demo_mode.register()
+
+
+def extern_demo_mode_unregister():
+ # this accesses demo_mode.py which is kept standalone
+ # and can be run direct.
+ from . import demo_mode
+ demo_mode.unregister()
+
+# --- intergration
+
+
+def menu_func(self, context):
+ layout = self.layout
+ layout.operator(DemoModeSetup.bl_idname, icon='PREFERENCES')
+ layout.operator(DemoModeRun.bl_idname, icon='PLAY')
+ layout.separator()
+
+
+def register():
+ bpy.utils.register_class(DemoModeSetup)
+ bpy.utils.register_class(DemoModeRun)
+
+ bpy.types.INFO_MT_file.prepend(menu_func)
+
+ extern_demo_mode_register()
+
+
+def unregister():
+ bpy.utils.unregister_class(DemoModeSetup)
+ bpy.utils.unregister_class(DemoModeRun)
+
+ bpy.types.INFO_MT_file.remove(menu_func)
+
+ extern_demo_mode_unregister()
+
+if __name__ == "__main__":
+ register()