-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathcamera.py
109 lines (92 loc) · 3.74 KB
/
camera.py
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
import numpy as np
import math
class Camera(object):
def __init__(self, pos=np.array([0.0,0.0,5.0]), fov=45):
self.pos = pos
self.focus = np.array([0.0,0.0,0.0])
self.camFocus = self.pos - self.focus
self.normCamFocus = self.camFocus / np.linalg.norm(self.camFocus)
worldUp = np.array([0.0,1.0,0.0])
self.right = np.cross(self.normCamFocus, worldUp)
self.up = np.cross(self.right, self.normCamFocus)
self.fov = fov
def translate(self, delta, delta2):
#delta: left and right translation
#delta2: foward/back translation
worldUp = np.array([0.0,1.0,0.0])
self.focus += delta
self.pos += delta + delta2
self.camFocus = self.pos - self.focus
self.normCamFocus = self.camFocus /np.linalg.norm(self.camFocus)
self.right = np.cross(self.normCamFocus, worldUp)
self = np.cross(self.right, self.normCamFocus)
#The follwoing matrix methods derived from glm library by Mack Stone
#See https://github.com/mackst/glm/tree/master/glm
#Copyright notice below:
# -*- coding: utf-8 -*-
# The MIT License (MIT)
#
# Copyright (c) 2014 mack stone
# Modified by Jai Chauhan 2018
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in all
# copies or substantial portions of the Software.
@staticmethod
def rotationMatrix(angle, axis):
rmat = np.zeros((4,4))
a = math.radians(angle)
c = math.cos(a)
s = math.sin(a)
axis = axis / np.linalg.norm(axis)
temp = (1. - c) * axis
rmat[0][0] = c + temp[0] * axis[0]
rmat[0][1] = 0 + temp[0] * axis[1] + s * axis[2]
rmat[0][2] = 0 + temp[0] * axis[2] - s * axis[1]
rmat[1][0] = 0 + temp[1] * axis[0] - s * axis[2]
rmat[1][1] = c + temp[1] * axis[1]
rmat[1][2] = 0 + temp[1] * axis[2] + s * axis[0]
rmat[2][0] = 0 + temp[2] * axis[0] + s * axis[1]
rmat[2][1] = 0 + temp[2] * axis[1] - s * axis[0]
rmat[2][2] = c + temp[2] * axis[2]
return rmat
@staticmethod
def lookatMatrix(eye, center, up):
f = (center - eye) / np.linalg.norm((center - eye))
cp = np.cross(f, up)
s = cp / np.linalg.norm(cp)
u = np.cross(s, f)
Result = np.diag([1.0,1.0,1.0,1.0])
Result[0][0] = s[0]
Result[1][0] = s[1]
Result[2][0] = s[2]
Result[0][1] = u[0]
Result[1][1] = u[1]
Result[2][1] = u[2]
Result[0][2] =-f[0]
Result[1][2] = -f[1]
Result[2][2] =-f[2]
Result[3][0] = -1 * np.dot(s, eye)
Result[3][1] = -1 * np.dot(u, eye)
Result[3][2] = np.dot(f, eye)
return Result
@staticmethod
def perspectiveMatrix(fovy, aspect, zNear, zFar):
assert(aspect != 0)
assert(zFar != zNear)
rad = math.radians(fovy)
tanHalfFovy = math.tan((rad / 2))
result = np.zeros((4,4))
result[0][0] = 1. / (aspect * tanHalfFovy)
result[1][1] = 1. / tanHalfFovy
result[2][2] = -(zFar + zNear) / (zFar - zNear)
result[2][3] = -1.
result[3][2] = -(2. * zFar * zNear) / (zFar - zNear)
return result
if __name__ == "__main__":
print("Trying to run Camera class definition?!")