| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright 2011, Blender Foundation. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "camera.h"
 | 
					
						
							|  |  |  | #include "scene.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "blender_sync.h"
 | 
					
						
							|  |  |  | #include "blender_util.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | CCL_NAMESPACE_BEGIN | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Blender Camera Intermediate: we first convert both the offline and 3d view
 | 
					
						
							|  |  |  |  * render camera to this, and from there convert to our native camera format. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct BlenderCamera { | 
					
						
							|  |  |  | 	float nearclip; | 
					
						
							|  |  |  | 	float farclip; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 	CameraType type; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	float ortho_scale; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	float lens; | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 	float shuttertime; | 
					
						
							| 
									
										
										
										
											2011-09-16 13:14:02 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	float aperturesize; | 
					
						
							|  |  |  | 	uint apertureblades; | 
					
						
							|  |  |  | 	float aperturerotation; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	float focaldistance; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	float2 shift; | 
					
						
							|  |  |  | 	float2 offset; | 
					
						
							|  |  |  | 	float zoom; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	float2 pixelaspect; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-04 16:20:51 +00:00
										 |  |  | 	PanoramaType panorama_type; | 
					
						
							|  |  |  | 	float fisheye_fov; | 
					
						
							|  |  |  | 	float fisheye_lens; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 	enum { AUTO, HORIZONTAL, VERTICAL } sensor_fit; | 
					
						
							|  |  |  | 	float sensor_width; | 
					
						
							|  |  |  | 	float sensor_height; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	float border_left; | 
					
						
							|  |  |  | 	float border_right; | 
					
						
							|  |  |  | 	float border_bottom; | 
					
						
							|  |  |  | 	float border_top; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	Transform matrix; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void blender_camera_init(BlenderCamera *bcam) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	memset(bcam, 0, sizeof(BlenderCamera)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 	bcam->type = CAMERA_PERSPECTIVE; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	bcam->zoom = 1.0f; | 
					
						
							|  |  |  | 	bcam->pixelaspect = make_float2(1.0f, 1.0f); | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 	bcam->sensor_width = 32.0f; | 
					
						
							|  |  |  | 	bcam->sensor_height = 18.0f; | 
					
						
							|  |  |  | 	bcam->sensor_fit = BlenderCamera::AUTO; | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 	bcam->shuttertime = 1.0f; | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	bcam->border_right = 1.0f; | 
					
						
							|  |  |  | 	bcam->border_top = 1.0f; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static float blender_camera_focal_distance(BL::Object b_ob, BL::Camera b_camera) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BL::Object b_dof_object = b_camera.dof_object(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(!b_dof_object) | 
					
						
							|  |  |  | 		return b_camera.dof_distance(); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2011-12-29 23:34:25 +00:00
										 |  |  | 	/* for dof object, return distance along camera Z direction */ | 
					
						
							|  |  |  | 	Transform obmat = transform_clear_scale(get_transform(b_ob.matrix_world())); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	Transform dofmat = get_transform(b_dof_object.matrix_world()); | 
					
						
							| 
									
										
										
										
											2011-12-29 23:34:25 +00:00
										 |  |  | 	Transform mat = transform_inverse(obmat) * dofmat; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-29 23:34:25 +00:00
										 |  |  | 	return fabsf(transform_get_column(&mat, 3).z); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void blender_camera_from_object(BlenderCamera *bcam, BL::Object b_ob) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BL::ID b_ob_data = b_ob.data(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(b_ob_data.is_a(&RNA_Camera)) { | 
					
						
							|  |  |  | 		BL::Camera b_camera(b_ob_data); | 
					
						
							|  |  |  | 		PointerRNA ccamera = RNA_pointer_get(&b_camera.ptr, "cycles"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bcam->nearclip = b_camera.clip_start(); | 
					
						
							|  |  |  | 		bcam->farclip = b_camera.clip_end(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-04 16:20:51 +00:00
										 |  |  | 		switch(b_camera.type()) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			case BL::Camera::type_ORTHO: | 
					
						
							|  |  |  | 				bcam->type = CAMERA_ORTHOGRAPHIC; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case BL::Camera::type_PANO: | 
					
						
							|  |  |  | 				bcam->type = CAMERA_PANORAMA; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case BL::Camera::type_PERSP: | 
					
						
							|  |  |  | 			default: | 
					
						
							|  |  |  | 				bcam->type = CAMERA_PERSPECTIVE; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		}	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		switch(RNA_enum_get(&ccamera, "panorama_type")) | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			case 1: | 
					
						
							|  |  |  | 				bcam->panorama_type = PANORAMA_FISHEYE_EQUIDISTANT; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case 2: | 
					
						
							|  |  |  | 				bcam->panorama_type = PANORAMA_FISHEYE_EQUISOLID; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case 0: | 
					
						
							|  |  |  | 			default: | 
					
						
							|  |  |  | 				bcam->panorama_type = PANORAMA_EQUIRECTANGULAR; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		}	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bcam->fisheye_fov = RNA_float_get(&ccamera, "fisheye_fov"); | 
					
						
							|  |  |  | 		bcam->fisheye_lens = RNA_float_get(&ccamera, "fisheye_lens"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		bcam->ortho_scale = b_camera.ortho_scale(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bcam->lens = b_camera.lens(); | 
					
						
							| 
									
										
										
										
											2012-03-07 13:01:30 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* allow f/stop number to change aperture_size but still
 | 
					
						
							| 
									
										
										
										
											2012-06-09 17:22:52 +00:00
										 |  |  | 		 * give manual control over aperture radius */ | 
					
						
							| 
									
										
										
										
											2012-03-07 13:01:30 +00:00
										 |  |  | 		int aperture_type = RNA_enum_get(&ccamera, "aperture_type"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(aperture_type == 1) { | 
					
						
							|  |  |  | 			float fstop = RNA_float_get(&ccamera, "aperture_fstop"); | 
					
						
							|  |  |  | 			bcam->aperturesize = (bcam->lens*1e-3f)/(2.0f*max(fstop, 1e-5f)); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			bcam->aperturesize = RNA_float_get(&ccamera, "aperture_size"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-09-16 13:14:02 +00:00
										 |  |  | 		bcam->apertureblades = RNA_int_get(&ccamera, "aperture_blades"); | 
					
						
							|  |  |  | 		bcam->aperturerotation = RNA_float_get(&ccamera, "aperture_rotation"); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		bcam->focaldistance = blender_camera_focal_distance(b_ob, b_camera); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		bcam->shift.x = b_camera.shift_x(); | 
					
						
							|  |  |  | 		bcam->shift.y = b_camera.shift_y(); | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		bcam->sensor_width = b_camera.sensor_width(); | 
					
						
							|  |  |  | 		bcam->sensor_height = b_camera.sensor_height(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if(b_camera.sensor_fit() == BL::Camera::sensor_fit_AUTO) | 
					
						
							|  |  |  | 			bcam->sensor_fit = BlenderCamera::AUTO; | 
					
						
							|  |  |  | 		else if(b_camera.sensor_fit() == BL::Camera::sensor_fit_HORIZONTAL) | 
					
						
							|  |  |  | 			bcam->sensor_fit = BlenderCamera::HORIZONTAL; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			bcam->sensor_fit = BlenderCamera::VERTICAL; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* from lamp not implemented yet */ | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | static Transform blender_camera_matrix(const Transform& tfm, CameraType type) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Transform result; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-04 16:20:51 +00:00
										 |  |  | 	if(type == CAMERA_PANORAMA) { | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 		/* make it so environment camera needs to be pointed in the direction
 | 
					
						
							| 
									
										
										
										
											2012-06-09 17:22:52 +00:00
										 |  |  | 		 * of the positive x-axis to match an environment texture, this way | 
					
						
							|  |  |  | 		 * it is looking at the center of the texture */ | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 		result = tfm * | 
					
						
							|  |  |  | 			make_transform( 0.0f, -1.0f, 0.0f, 0.0f, | 
					
						
							|  |  |  | 			                0.0f,  0.0f, 1.0f, 0.0f, | 
					
						
							|  |  |  | 			               -1.0f,  0.0f, 0.0f, 0.0f, | 
					
						
							|  |  |  | 			                0.0f,  0.0f, 0.0f, 1.0f); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* note the blender camera points along the negative z-axis */ | 
					
						
							|  |  |  | 		result = tfm * transform_scale(1.0f, 1.0f, -1.0f); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return transform_clear_scale(result); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | static void blender_camera_viewplane(BlenderCamera *bcam, int width, int height, | 
					
						
							|  |  |  | 	float *left, float *right, float *bottom, float *top, float *aspectratio, float *sensor_size) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* dimensions */ | 
					
						
							|  |  |  | 	float xratio = width*bcam->pixelaspect.x; | 
					
						
							|  |  |  | 	float yratio = height*bcam->pixelaspect.y; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* compute x/y aspect and ratio */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	float xaspect, yaspect; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 	/* sensor fitting */ | 
					
						
							|  |  |  | 	bool horizontal_fit; | 
					
						
							| 
									
										
										
										
											2012-05-04 16:20:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 	if(bcam->sensor_fit == BlenderCamera::AUTO) { | 
					
						
							|  |  |  | 		horizontal_fit = (xratio > yratio); | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		*sensor_size = bcam->sensor_width; | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else if(bcam->sensor_fit == BlenderCamera::HORIZONTAL) { | 
					
						
							|  |  |  | 		horizontal_fit = true; | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		*sensor_size = bcam->sensor_width; | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		horizontal_fit = false; | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		*sensor_size = bcam->sensor_height; | 
					
						
							| 
									
										
										
										
											2011-11-05 11:11:06 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(horizontal_fit) { | 
					
						
							| 
									
										
										
										
											2012-06-09 18:56:12 +00:00
										 |  |  | 		*aspectratio = xratio/yratio; | 
					
						
							|  |  |  | 		xaspect = *aspectratio; | 
					
						
							|  |  |  | 		yaspect = 1.0f; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-06-09 18:56:12 +00:00
										 |  |  | 		*aspectratio = yratio/xratio; | 
					
						
							|  |  |  | 		xaspect = 1.0f; | 
					
						
							|  |  |  | 		yaspect = *aspectratio; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* modify aspect for orthographic scale */ | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 	if(bcam->type == CAMERA_ORTHOGRAPHIC) { | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		xaspect = xaspect*bcam->ortho_scale/(*aspectratio*2.0f); | 
					
						
							|  |  |  | 		yaspect = yaspect*bcam->ortho_scale/(*aspectratio*2.0f); | 
					
						
							|  |  |  | 		*aspectratio = bcam->ortho_scale/2.0f; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-04 16:20:51 +00:00
										 |  |  | 	if(bcam->type == CAMERA_PANORAMA) { | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 		/* set viewplane */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		*left = 0.0f; | 
					
						
							|  |  |  | 		*right = 1.0f; | 
					
						
							|  |  |  | 		*bottom = 0.0f; | 
					
						
							|  |  |  | 		*top = 1.0f; | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* set viewplane */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		*left = -xaspect; | 
					
						
							|  |  |  | 		*right = xaspect; | 
					
						
							|  |  |  | 		*bottom = -yaspect; | 
					
						
							|  |  |  | 		*top = yaspect; | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* zoom for 3d camera view */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		*left *= bcam->zoom; | 
					
						
							|  |  |  | 		*right *= bcam->zoom; | 
					
						
							|  |  |  | 		*bottom *= bcam->zoom; | 
					
						
							|  |  |  | 		*top *= bcam->zoom; | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* modify viewplane with camera shift and 3d camera view offset */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		float dx = 2.0f*(*aspectratio*bcam->shift.x + bcam->offset.x*xaspect*2.0f); | 
					
						
							|  |  |  | 		float dy = 2.0f*(*aspectratio*bcam->shift.y + bcam->offset.y*yaspect*2.0f); | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		*left += dx; | 
					
						
							|  |  |  | 		*right += dx; | 
					
						
							|  |  |  | 		*bottom += dy; | 
					
						
							|  |  |  | 		*top += dy; | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void blender_camera_sync(Camera *cam, BlenderCamera *bcam, int width, int height) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* copy camera to compare later */ | 
					
						
							|  |  |  | 	Camera prevcam = *cam; | 
					
						
							|  |  |  | 	float aspectratio, sensor_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* viewplane */ | 
					
						
							|  |  |  | 	blender_camera_viewplane(bcam, width, height, | 
					
						
							|  |  |  | 		&cam->left, &cam->right, &cam->bottom, &cam->top, &aspectratio, &sensor_size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* sensor */ | 
					
						
							|  |  |  | 	cam->sensorwidth = bcam->sensor_width; | 
					
						
							|  |  |  | 	cam->sensorheight = bcam->sensor_height; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* clipping distances */ | 
					
						
							|  |  |  | 	cam->nearclip = bcam->nearclip; | 
					
						
							|  |  |  | 	cam->farclip = bcam->farclip; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 	/* type */ | 
					
						
							|  |  |  | 	cam->type = bcam->type; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-04 16:20:51 +00:00
										 |  |  | 	/* panorama */ | 
					
						
							|  |  |  | 	cam->panorama_type = bcam->panorama_type; | 
					
						
							|  |  |  | 	cam->fisheye_fov = bcam->fisheye_fov; | 
					
						
							|  |  |  | 	cam->fisheye_lens = bcam->fisheye_lens; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	/* perspective */ | 
					
						
							| 
									
										
										
										
											2012-06-09 17:45:22 +00:00
										 |  |  | 	cam->fov = 2.0f * atanf((0.5f * sensor_size) / bcam->lens / aspectratio); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	cam->focaldistance = bcam->focaldistance; | 
					
						
							| 
									
										
										
										
											2011-09-16 13:14:02 +00:00
										 |  |  | 	cam->aperturesize = bcam->aperturesize; | 
					
						
							|  |  |  | 	cam->blades = bcam->apertureblades; | 
					
						
							|  |  |  | 	cam->bladesrotation = bcam->aperturerotation; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-28 16:44:54 +00:00
										 |  |  | 	/* transform */ | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 	cam->matrix = blender_camera_matrix(bcam->matrix, bcam->type); | 
					
						
							|  |  |  | 	cam->motion.pre = cam->matrix; | 
					
						
							|  |  |  | 	cam->motion.post = cam->matrix; | 
					
						
							|  |  |  | 	cam->use_motion = false; | 
					
						
							|  |  |  | 	cam->shuttertime = bcam->shuttertime; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	/* border */ | 
					
						
							|  |  |  | 	cam->border_left = bcam->border_left; | 
					
						
							|  |  |  | 	cam->border_right = bcam->border_right; | 
					
						
							|  |  |  | 	cam->border_bottom = bcam->border_bottom; | 
					
						
							|  |  |  | 	cam->border_top = bcam->border_top; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	/* set update flag */ | 
					
						
							|  |  |  | 	if(cam->modified(prevcam)) | 
					
						
							|  |  |  | 		cam->tag_update(); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Sync Render Camera */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-13 17:42:03 +00:00
										 |  |  | void BlenderSync::sync_camera(BL::Object b_override, int width, int height) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	BlenderCamera bcam; | 
					
						
							|  |  |  | 	blender_camera_init(&bcam); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* pixel aspect */ | 
					
						
							|  |  |  | 	BL::RenderSettings r = b_scene.render(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bcam.pixelaspect.x = r.pixel_aspect_x(); | 
					
						
							|  |  |  | 	bcam.pixelaspect.y = r.pixel_aspect_y(); | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | 	bcam.shuttertime = r.motion_blur_shutter(); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	/* border */ | 
					
						
							|  |  |  | 	if(r.use_border()) { | 
					
						
							|  |  |  | 		bcam.border_left = r.border_min_x(); | 
					
						
							|  |  |  | 		bcam.border_right = r.border_max_x(); | 
					
						
							|  |  |  | 		bcam.border_bottom = r.border_min_y(); | 
					
						
							|  |  |  | 		bcam.border_top = r.border_max_y(); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	/* camera object */ | 
					
						
							|  |  |  | 	BL::Object b_ob = b_scene.camera(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-13 17:42:03 +00:00
										 |  |  | 	if(b_override) | 
					
						
							|  |  |  | 		b_ob = b_override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	if(b_ob) { | 
					
						
							|  |  |  | 		blender_camera_from_object(&bcam, b_ob); | 
					
						
							|  |  |  | 		bcam.matrix = get_transform(b_ob.matrix_world()); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* sync */ | 
					
						
							|  |  |  | 	Camera *cam = scene->camera; | 
					
						
							|  |  |  | 	blender_camera_sync(cam, &bcam, width, height); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-30 12:49:26 +00:00
										 |  |  | void BlenderSync::sync_camera_motion(BL::Object b_ob, int motion) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Camera *cam = scene->camera; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Transform tfm = get_transform(b_ob.matrix_world()); | 
					
						
							|  |  |  | 	tfm = blender_camera_matrix(tfm, cam->type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(tfm != cam->matrix) { | 
					
						
							|  |  |  | 		if(motion == -1) | 
					
						
							|  |  |  | 			cam->motion.pre = tfm; | 
					
						
							|  |  |  | 		else | 
					
						
							|  |  |  | 			cam->motion.post = tfm; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		cam->use_motion = true; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | /* Sync 3D View Camera */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | static void blender_camera_from_view(BlenderCamera *bcam, BL::Scene b_scene, BL::SpaceView3D b_v3d, BL::RegionView3D b_rv3d, int width, int height) | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* 3d view parameters */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	bcam->nearclip = b_v3d.clip_start(); | 
					
						
							|  |  |  | 	bcam->farclip = b_v3d.clip_end(); | 
					
						
							|  |  |  | 	bcam->lens = b_v3d.lens(); | 
					
						
							|  |  |  | 	bcam->shuttertime = b_scene.render().motion_blur_shutter(); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if(b_rv3d.view_perspective() == BL::RegionView3D::view_perspective_CAMERA) { | 
					
						
							|  |  |  | 		/* camera view */ | 
					
						
							| 
									
										
										
										
											2012-04-12 11:42:18 +00:00
										 |  |  | 		BL::Object b_ob = (b_v3d.lock_camera_and_layers())? b_scene.camera(): b_v3d.camera(); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if(b_ob) { | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 			blender_camera_from_object(bcam, b_ob); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* magic zoom formula */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 			bcam->zoom = (float)b_rv3d.view_camera_zoom(); | 
					
						
							|  |  |  | 			bcam->zoom = (1.41421f + bcam->zoom/50.0f); | 
					
						
							|  |  |  | 			bcam->zoom *= bcam->zoom; | 
					
						
							|  |  |  | 			bcam->zoom = 2.0f/bcam->zoom; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* offset */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 			bcam->offset = get_float2(b_rv3d.view_camera_offset()); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else if(b_rv3d.view_perspective() == BL::RegionView3D::view_perspective_ORTHO) { | 
					
						
							|  |  |  | 		/* orthographic view */ | 
					
						
							| 
									
										
										
										
											2012-06-09 17:45:22 +00:00
										 |  |  | 		bcam->farclip *= 0.5f; | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		bcam->nearclip = -bcam->farclip; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 		bcam->type = CAMERA_ORTHOGRAPHIC; | 
					
						
							|  |  |  | 		bcam->ortho_scale = b_rv3d.view_distance(); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	bcam->zoom *= 2.0f; | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* 3d view transform */ | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	bcam->matrix = transform_inverse(get_transform(b_rv3d.view_matrix())); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void blender_camera_border(BlenderCamera *bcam, BL::Scene b_scene, BL::SpaceView3D b_v3d, | 
					
						
							|  |  |  | 	BL::RegionView3D b_rv3d, int width, int height) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BL::RenderSettings r = b_scene.render(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(!r.use_border()) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* camera view? */ | 
					
						
							|  |  |  | 	if(!(b_rv3d && b_rv3d.view_perspective() == BL::RegionView3D::view_perspective_CAMERA)) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	BL::Object b_ob = (b_v3d.lock_camera_and_layers())? b_scene.camera(): b_v3d.camera(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(!b_ob) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bcam->border_left = r.border_min_x(); | 
					
						
							|  |  |  | 	bcam->border_right = r.border_max_x(); | 
					
						
							|  |  |  | 	bcam->border_bottom = r.border_min_y(); | 
					
						
							|  |  |  | 	bcam->border_top = r.border_max_y(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	float cam_left, cam_right, cam_bottom, cam_top; | 
					
						
							|  |  |  | 	float view_left, view_right, view_bottom, view_top; | 
					
						
							|  |  |  | 	float view_aspect, cam_aspect, sensor_size; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* get viewport viewplane */ | 
					
						
							|  |  |  | 	BlenderCamera view_bcam; | 
					
						
							|  |  |  | 	blender_camera_init(&view_bcam); | 
					
						
							|  |  |  | 	blender_camera_from_view(&view_bcam, b_scene, b_v3d, b_rv3d, width, height); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	blender_camera_viewplane(&view_bcam, width, height, | 
					
						
							|  |  |  | 		&view_left, &view_right, &view_bottom, &view_top, &view_aspect, &sensor_size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	view_left /= view_aspect; | 
					
						
							|  |  |  | 	view_right /= view_aspect; | 
					
						
							|  |  |  | 	view_bottom /= view_aspect; | 
					
						
							|  |  |  | 	view_top /= view_aspect; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* get camera viewplane */ | 
					
						
							|  |  |  | 	BlenderCamera cam_bcam; | 
					
						
							|  |  |  | 	blender_camera_init(&cam_bcam); | 
					
						
							|  |  |  | 	blender_camera_from_object(&cam_bcam, b_ob); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	width = (int)(r.resolution_x()*r.resolution_percentage()/100); | 
					
						
							|  |  |  | 	height = (int)(r.resolution_y()*r.resolution_percentage()/100); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	blender_camera_viewplane(&cam_bcam, width, height, | 
					
						
							|  |  |  | 		&cam_left, &cam_right, &cam_bottom, &cam_top, &cam_aspect, &sensor_size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	cam_left /= cam_aspect; | 
					
						
							|  |  |  | 	cam_right /= cam_aspect; | 
					
						
							|  |  |  | 	cam_bottom /= cam_aspect; | 
					
						
							|  |  |  | 	cam_top /= cam_aspect; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* determine viewport subset matching camera border */ | 
					
						
							|  |  |  | 	float tmp_left = ((cam_left - view_left) / (view_right - view_left)); | 
					
						
							|  |  |  | 	float tmp_right = ((cam_right - view_left) / (view_right - view_left)); | 
					
						
							|  |  |  | 	float tmp_bottom = ((cam_bottom - view_bottom) / (view_top - view_bottom)); | 
					
						
							|  |  |  | 	float tmp_top = ((cam_top - view_bottom) / (view_top - view_bottom)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bcam->border_left = tmp_left + bcam->border_left*(tmp_right - tmp_left); | 
					
						
							|  |  |  | 	bcam->border_right = tmp_left + bcam->border_right*(tmp_right - tmp_left); | 
					
						
							|  |  |  | 	bcam->border_bottom = tmp_bottom + bcam->border_bottom*(tmp_top - tmp_bottom); | 
					
						
							|  |  |  | 	bcam->border_top = tmp_bottom + bcam->border_top*(tmp_top - tmp_bottom); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* clamp */ | 
					
						
							| 
									
										
										
										
											2012-06-13 11:25:36 +00:00
										 |  |  | 	bcam->border_left = clamp(bcam->border_left, 0.0f, 1.0f); | 
					
						
							|  |  |  | 	bcam->border_right = clamp(bcam->border_right, 0.0f, 1.0f); | 
					
						
							|  |  |  | 	bcam->border_bottom = clamp(bcam->border_bottom, 0.0f, 1.0f); | 
					
						
							|  |  |  | 	bcam->border_top = clamp(bcam->border_top, 0.0f, 1.0f); | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void BlenderSync::sync_view(BL::SpaceView3D b_v3d, BL::RegionView3D b_rv3d, int width, int height) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BlenderCamera bcam; | 
					
						
							|  |  |  | 	blender_camera_init(&bcam); | 
					
						
							|  |  |  | 	blender_camera_from_view(&bcam, b_scene, b_v3d, b_rv3d, width, height); | 
					
						
							|  |  |  | 	blender_camera_border(&bcam, b_scene, b_v3d, b_rv3d, width, height); | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	blender_camera_sync(scene->camera, &bcam, width, height); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | BufferParams BlenderSync::get_buffer_params(BL::Scene b_scene, Camera *cam, int width, int height) | 
					
						
							| 
									
										
										
										
											2011-12-20 12:25:37 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	BufferParams params; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	params.full_width = width; | 
					
						
							|  |  |  | 	params.full_height = height; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-06 23:27:43 +00:00
										 |  |  | 	if(b_scene.render().use_border()) { | 
					
						
							|  |  |  | 		/* border render */ | 
					
						
							|  |  |  | 		params.full_x = cam->border_left*width; | 
					
						
							|  |  |  | 		params.full_y = cam->border_bottom*height; | 
					
						
							|  |  |  | 		params.width = (int)(cam->border_right*width) - params.full_x; | 
					
						
							|  |  |  | 		params.height = (int)(cam->border_top*height) - params.full_y; | 
					
						
							| 
									
										
										
										
											2012-06-13 11:25:36 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* survive in case border goes out of view or becomes too small */ | 
					
						
							|  |  |  | 		params.width = max(params.width, 1); | 
					
						
							|  |  |  | 		params.height = max(params.height, 1); | 
					
						
							| 
									
										
										
										
											2011-12-20 12:25:37 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		params.width = width; | 
					
						
							|  |  |  | 		params.height = height; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return params; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-27 11:58:34 +00:00
										 |  |  | CCL_NAMESPACE_END | 
					
						
							|  |  |  | 
 |