[Bf-blender-cvs] [5296c2e099e] master: Experiment with adding output file meta data from render engine

Sergey Sharybin noreply at git.blender.org
Tue Oct 31 15:06:01 CET 2017


Commit: 5296c2e099e92e30478a454049e72f170f71a624
Author: Sergey Sharybin
Date:   Mon Feb 6 17:24:28 2017 +0100
Branches: master
https://developer.blender.org/rB5296c2e099e92e30478a454049e72f170f71a624

Experiment with adding output file meta data from render engine

The idea is to make it possible to report extra meta data from
render engine to the file writing. This way we can provide
additional information such as number of samples rendered by
resumable Cycles rendering so we can easily combine files back.

Currently only report number of samples from Cycles when rendering
a single render-layer scene. This is something what was required
here at the studio. We can easily extend that further.

Ideally we would also need to support non-string metadata, but
that's for later.

Reviewers: mont29, campbellbarton

Reviewed By: mont29, campbellbarton

Subscribers: sybren, candreacchio

Differential Revision: https://developer.blender.org/D2502

===================================================================

M	intern/cycles/blender/blender_session.cpp

===================================================================

diff --git a/intern/cycles/blender/blender_session.cpp b/intern/cycles/blender/blender_session.cpp
index 5b71e11d61d..2377c987b38 100644
--- a/intern/cycles/blender/blender_session.cpp
+++ b/intern/cycles/blender/blender_session.cpp
@@ -380,7 +380,10 @@ void BlenderSession::render()
 	BL::RenderSettings r = b_scene.render();
 	BL::RenderSettings::layers_iterator b_layer_iter;
 	BL::RenderResult::views_iterator b_view_iter;
-	
+
+	/* We do some special meta attributes when we only have single layer. */
+	const bool is_single_layer = (r.layers.length() == 1);
+
 	for(r.layers.begin(b_layer_iter); b_layer_iter != r.layers.end(); ++b_layer_iter) {
 		b_rlay_name = b_layer_iter->name();
 
@@ -475,6 +478,15 @@ void BlenderSession::render()
 				break;
 		}
 
+		if(is_single_layer) {
+			BL::RenderResult b_rr = b_engine.get_result();
+			string num_aa_samples = string_printf("%d", session->params.samples);
+			b_rr.stamp_data_add_field("Cycles Samples", num_aa_samples.c_str());
+			/* TODO(sergey): Report whether we're doing resumable render
+			 * and also start/end sample if so.
+			 */
+		}
+
 		/* free result without merging */
 		end_render_result(b_engine, b_rr, true, true, false);



More information about the Bf-blender-cvs mailing list