-
Notifications
You must be signed in to change notification settings - Fork 0
/
plotCameraFrustum.m
31 lines (26 loc) · 1.29 KB
/
plotCameraFrustum.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
function [] = plotCameraFrustum(R, camLoc, color)
% PLOTCAMERAFRUSTUM Plots the frustum of a camera that is rotated by R and
% translated by t with respect to the world coordinate frame.
% R describes the rotation matrix that takes the world coordinate frame to
% the camera coordinate frame. camLoc denotes the location of the camera
% centre in the world frame.
% Size unit of the frustum
frustumSize = 1;
% Vertices of the frustum. The first vertex is the camera center. Vertices
% 2, 3, 4, 5 are the top-left, top-right, bottom-right, and bottom-left
% corners of the image respectively.
frustumVertices = [0, 0, 0; -frustumSize, -0.5*frustumSize, frustumSize; ...
frustumSize, -0.5*frustumSize, frustumSize; ...
frustumSize, 0.5*frustumSize, frustumSize; ...
-1*frustumSize, 0.5*frustumSize, frustumSize]';
% Convert the frustum to world coordinates
frustumVertices = R*frustumVertices + repmat(camLoc, 1, 5);
frustumVertices = double(-frustumVertices);
% Plot the frustum
frustumEdges = [1,2; 1,3; 1,4; 1,5; 2,3; 3,4; 4,5; 5,2];
for i = 1:size(frustumEdges,1)
plot3(frustumVertices(1,[frustumEdges(i,1), frustumEdges(i,2)]), ...
frustumVertices(2,[frustumEdges(i,1), frustumEdges(i,2)]), ...
frustumVertices(3,([frustumEdges(i,1), frustumEdges(i,2)])), color);
end
end