Cycles: svn merge -r40266:40358 https://svn.blender.org/svnroot/bf-blender/trunk...
[blender-staging.git] / source / blender / makesrna / intern / rna_scene_api.c
index fa21257be29fe80954eb8aed06ec1d97d4a146a9..124fa9037e342af85e43417b9622e3439a5ff93e 100644 (file)
@@ -1,4 +1,4 @@
-/**
+/*
  * $Id$
  *
  * ***** BEGIN GPL LICENSE BLOCK *****
  *
  * 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.
+ * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  *
  * The Original Code is Copyright (C) 2009 Blender Foundation.
  * All rights reserved.
  *
  * 
- * Contributor(s): Arystanbek Dyussenov, Joshua Leung
+ * Contributor(s): Joshua Leung, Arystanbek Dyussenov
  *
  * ***** END GPL LICENSE BLOCK *****
  */
 
+/** \file blender/makesrna/intern/rna_scene_api.c
+ *  \ingroup RNA
+ */
+
+
 #include <stdlib.h>
 #include <stdio.h>
 
 #include "RNA_define.h"
-#include "RNA_enum_types.h"
-#include "RNA_types.h"
 
 #include "DNA_anim_types.h"
 #include "DNA_object_types.h"
 #include "DNA_scene_types.h"
+#include "BKE_utildefines.h"
 
 #ifdef RNA_RUNTIME
 
 #include "BKE_animsys.h"
-#include "BKE_scene.h"
 #include "BKE_depsgraph.h"
+#include "BKE_global.h"
+#include "BKE_image.h"
+#include "BKE_scene.h"
+#include "BKE_writeavi.h"
 
-#include "ED_object.h"
 
-#include "WM_api.h"
 
-static void rna_Scene_add_object(Scene *sce, ReportList *reports, Object *ob)
+static void rna_Scene_frame_set(Scene *scene, int frame, float subframe)
 {
-       Base *base= object_in_scene(ob, sce);
-       if (base) {
-               BKE_report(reports, RPT_ERROR, "Object is already in this scene.");
-               return;
-       }
-       base= scene_add_base(sce, ob);
-       ob->id.us++;
-
-       /* this is similar to what object_add_type and add_object do */
-       ob->lay= base->lay= sce->lay;
-       ob->recalc |= OB_RECALC;
-
-       DAG_scene_sort(sce);
+       scene->r.cfra= frame;
+       scene->r.subframe= subframe;
+       
+       CLAMP(scene->r.cfra, MINAFRAME, MAXFRAME);
+       scene_update_for_newframe(G.main, scene, (1<<20) - 1);
+
+       /* cant use NC_SCENE|ND_FRAME because this casues wm_event_do_notifiers to call 
+        * scene_update_for_newframe which will loose any un-keyed changes [#24690] */
+       /* WM_main_add_notifier(NC_SCENE|ND_FRAME, scene); */
+       
+       /* instead just redraw the views */
+       WM_main_add_notifier(NC_WINDOW, NULL);
 }
 
-static void rna_Scene_remove_object(Scene *sce, ReportList *reports, Object *ob)
+static void rna_Scene_update_tagged(Scene *scene)
 {
-       Base *base= object_in_scene(ob, sce);
-       if (!base) {
-               BKE_report(reports, RPT_ERROR, "Object is not in this scene.");
-               return;
-       }
-       /* as long as ED_base_object_free_and_unlink calls free_libblock_us, we don't have to decrement ob->id.us */
-       ED_base_object_free_and_unlink(sce, base);
+       scene_update_tagged(G.main, scene);
+       scene_clear_tagged(G.main, scene);
 }
 
-static void rna_Scene_set_frame(Scene *sce, bContext *C, int frame)
+static void rna_SceneRender_get_frame_path(RenderData *rd, int frame, char *name)
 {
-       sce->r.cfra= frame;
-       CLAMP(sce->r.cfra, MINAFRAME, MAXFRAME);
-       scene_update_for_newframe(sce, (1<<20) - 1);
-
-       WM_event_add_notifier(C, NC_SCENE|ND_FRAME, sce);
+       if(BKE_imtype_is_movie(rd->imtype))
+               BKE_makeanimstring(name, rd);
+       else
+               BKE_makepicstring(name, rd->pic, (frame==INT_MIN) ? rd->cfra : frame, rd->imtype, rd->scemode & R_EXTENSION, TRUE);
 }
 
-static KeyingSet *rna_Scene_add_keying_set(Scene *sce, ReportList *reports, 
-               char name[], int absolute, int insertkey_needed, int insertkey_visual)
+#ifdef WITH_COLLADA
+/* don't remove this, as COLLADA exporting cannot be done through operators in render() callback. */
+#include "../../collada/collada.h"
+
+static void rna_Scene_collada_export(Scene *scene, const char *filepath, int selected)
 {
-       KeyingSet *ks= NULL;
-       short flag=0, keyingflag=0;
-       
-       /* validate flags */
-       if (absolute)
-               flag |= KEYINGSET_ABSOLUTE;
-       if (insertkey_needed)
-               keyingflag |= INSERTKEY_NEEDED;
-       if (insertkey_visual)
-               keyingflag |= INSERTKEY_MATRIX;
-               
-       /* call the API func, and set the active keyingset index */
-       ks= BKE_keyingset_add(&sce->keyingsets, name, flag, keyingflag);
-       
-       if (ks) {
-               sce->active_keyingset= BLI_countlist(&sce->keyingsets);
-               return ks;
-       }
-       else {
-               BKE_report(reports, RPT_ERROR, "Keying Set could not be added.");
-               return NULL;
-       }
+       collada_export(scene, filepath, selected);
 }
 
+#endif
+
 #else
 
 void RNA_api_scene(StructRNA *srna)
@@ -118,38 +100,41 @@ void RNA_api_scene(StructRNA *srna)
        FunctionRNA *func;
        PropertyRNA *parm;
 
-       func= RNA_def_function(srna, "add_object", "rna_Scene_add_object");
-       RNA_def_function_ui_description(func, "Add object to scene.");
-       RNA_def_function_flag(func, FUNC_USE_REPORTS);
-       parm= RNA_def_pointer(func, "object", "Object", "", "Object to add to scene.");
+       func= RNA_def_function(srna, "frame_set", "rna_Scene_frame_set");
+       RNA_def_function_ui_description(func, "Set scene frame updating all objects immediately");
+       parm= RNA_def_int(func, "frame", 0, MINAFRAME, MAXFRAME, "", "Frame number to set", MINAFRAME, MAXFRAME);
        RNA_def_property_flag(parm, PROP_REQUIRED);
+       RNA_def_float(func, "subframe", 0.0, 0.0, 1.0, "", "Sub-frame time, between 0.0 and 1.0", 0.0, 1.0);
 
-       func= RNA_def_function(srna, "remove_object", "rna_Scene_remove_object");
-       RNA_def_function_ui_description(func, "Remove object from scene.");
-       RNA_def_function_flag(func, FUNC_USE_REPORTS);
-       parm= RNA_def_pointer(func, "object", "Object", "", "Object to remove from scene.");
-       RNA_def_property_flag(parm, PROP_REQUIRED);
+       func= RNA_def_function(srna, "update", "rna_Scene_update_tagged");
+       RNA_def_function_ui_description(func, "Update data tagged to be updated from previous access to data or operators");
 
-       func= RNA_def_function(srna, "set_frame", "rna_Scene_set_frame");
-       RNA_def_function_flag(func, FUNC_USE_CONTEXT);
-       RNA_def_function_ui_description(func, "Set scene frame updating all objects immediately.");
-       parm= RNA_def_int(func, "frame", 0, MINAFRAME, MAXFRAME, "", "Frame number to set.", MINAFRAME, MAXFRAME);
+#ifdef WITH_COLLADA
+       /* don't remove this, as COLLADA exporting cannot be done through operators in render() callback. */
+       func= RNA_def_function(srna, "collada_export", "rna_Scene_collada_export");
+       RNA_def_string(func, "filepath", "", FILE_MAX, "File Path", "File path to write Collada file");
+       parm= RNA_def_boolean(func, "selected", 0, "Export only selected", "Export only selected elements");
        RNA_def_property_flag(parm, PROP_REQUIRED);
+       RNA_def_property_subtype(parm, PROP_FILEPATH); /* allow non utf8 */
+       RNA_def_function_ui_description(func, "Export to collada file");
+#endif
+}
+
 
-       /* Add Keying Set */
-       func= RNA_def_function(srna, "add_keying_set", "rna_Scene_add_keying_set");
-       RNA_def_function_ui_description(func, "Add a new Keying Set to Scene.");
-       RNA_def_function_flag(func, FUNC_USE_REPORTS);
-       /* returns the new KeyingSet */
-       parm= RNA_def_pointer(func, "keyingset", "KeyingSet", "", "Newly created Keying Set.");
-       RNA_def_function_return(func, parm);
-       /* name */
-       RNA_def_string(func, "name", "KeyingSet", 64, "Name", "Name of Keying Set");
-       /* flags */
-       RNA_def_boolean(func, "absolute", 1, "Absolute", "Keying Set defines specific paths/settings to be keyframed (i.e. is not reliant on context info)");
-       /* keying flags */
-       RNA_def_boolean(func, "insertkey_needed", 0, "Insert Keyframes - Only Needed", "Only insert keyframes where they're needed in the relevant F-Curves.");
-       RNA_def_boolean(func, "insertkey_visual", 0, "Insert Keyframes - Visual", "Insert keyframes based on 'visual transforms'.");
+void RNA_api_scene_render(StructRNA *srna)
+{
+       FunctionRNA *func;
+       PropertyRNA *parm;
+
+       func= RNA_def_function(srna, "frame_path", "rna_SceneRender_get_frame_path");
+       RNA_def_function_ui_description(func, "Return the absolute path to the filename to be written for a given frame");
+       RNA_def_int(func, "frame", INT_MIN, INT_MIN, INT_MAX, "",
+                   "Frame number to use, if unset the current frame will be used", MINAFRAME, MAXFRAME);
+       parm= RNA_def_string_file_path(func, "filepath", "", FILE_MAX, "File Path",
+                                      "The resulting filepath from the scenes render settings");
+       RNA_def_property_flag(parm, PROP_THICK_WRAP); /* needed for string return value */
+       RNA_def_function_output(func, parm);
 }
 
 #endif
+