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
diff options
context:
space:
mode:
authorThomas Dinges <blender@dingto.org>2014-02-15 00:40:51 +0400
committerThomas Dinges <blender@dingto.org>2014-02-15 00:40:51 +0400
commit8a1f3238be98b99216dd7b57d814f3c7c2c1a696 (patch)
tree7bad9834077a0a6605fa42fcf754d1a665d944e3 /intern/cycles/app/cycles_standalone.cpp
parent8cc925a21664698fd88bdd58db93ae5bd922cec3 (diff)
Cycles Standalone: Add more controls and options
* P key, pauses the render * W/A/S/D for camera movement
Diffstat (limited to 'intern/cycles/app/cycles_standalone.cpp')
-rw-r--r--intern/cycles/app/cycles_standalone.cpp49
1 files changed, 43 insertions, 6 deletions
diff --git a/intern/cycles/app/cycles_standalone.cpp b/intern/cycles/app/cycles_standalone.cpp
index 3ec92a2aa00..fdee92a5eb0 100644
--- a/intern/cycles/app/cycles_standalone.cpp
+++ b/intern/cycles/app/cycles_standalone.cpp
@@ -46,7 +46,8 @@ struct Options {
int width, height;
SceneParams scene_params;
SessionParams session_params;
- bool quiet, show_help, interactive;
+ bool quiet;
+ bool show_help, interactive, pause;
} options;
static void session_print(const string& str)
@@ -240,14 +241,50 @@ static void resize(int width, int height)
static void keyboard(unsigned char key)
{
- if(key == 'r')
- options.session->reset(session_buffer_params(), options.session_params.samples);
- else if(key == 'h')
+ /* Toggle help */
+ if(key == 'h')
options.show_help = !(options.show_help);
- else if(key == 'i')
- options.interactive = !(options.interactive);
+
+ /* Reset */
+ else if(key == 'r')
+ options.session->reset(session_buffer_params(), options.session_params.samples);
+
+ /* Cancel */
else if(key == 27) // escape
options.session->progress.set_cancel("Canceled");
+
+ /* Pause */
+ else if(key == 'p') {
+ options.pause = !options.pause;
+ options.session->set_pause(options.pause);
+ }
+
+ /* Interactive Mode */
+ else if(key == 'i')
+ options.interactive = !(options.interactive);
+
+ else if(options.interactive && (key == 'w' || key == 'a' || key == 's' || key == 'd')) {
+ Transform matrix = options.session->scene->camera->matrix;
+ float3 translate;
+
+ if(key == 'w')
+ translate = make_float3(0.0f, 0.0f, 0.1f);
+ else if(key == 's')
+ translate = make_float3(0.0f, 0.0f, -0.1f);
+ else if(key == 'a')
+ translate = make_float3(-0.1f, 0.0f, 0.0f);
+ else if(key == 'd')
+ translate = make_float3(0.1f, 0.0f, 0.0f);
+
+ matrix = matrix * transform_translate(translate);
+
+ /* Update and Reset */
+ options.session->scene->camera->matrix = matrix;
+ options.session->scene->camera->need_update = true;
+ options.session->scene->camera->need_device_update = true;
+
+ options.session->reset(session_buffer_params(), options.session_params.samples);
+ }
}
#endif