Add a target look option for camera (Give a way to make beautiful travellings)
Make movement of camera independant from velocity (the way of velocity is fixed when /camera is started)
This commit is contained in:
parent
194ce63d73
commit
9aa8c2436f
104
init.lua
104
init.lua
@ -89,6 +89,9 @@ local camera = {
|
|||||||
end,
|
end,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local player_look_dir = nil
|
||||||
|
local target_look_position = nil
|
||||||
|
--local target_look_position = {x=-265, y=9.5, z=-126}
|
||||||
|
|
||||||
-- [event] On step
|
-- [event] On step
|
||||||
function camera:on_step(dtime)
|
function camera:on_step(dtime)
|
||||||
@ -104,6 +107,81 @@ function camera:on_step(dtime)
|
|||||||
|
|
||||||
-- if record mode
|
-- if record mode
|
||||||
if self.mode == 0 then
|
if self.mode == 0 then
|
||||||
|
-- Calculate pitch and yaw if target_look_position defined
|
||||||
|
if target_look_position then
|
||||||
|
local vec_pos = vector.subtract(target_look_position, pos)
|
||||||
|
print("vec_pos "..dump(vec_pos))
|
||||||
|
|
||||||
|
-- Pitch
|
||||||
|
local opp = vec_pos.y
|
||||||
|
local adj = vec_pos.x
|
||||||
|
|
||||||
|
if math.abs(vec_pos.z) > math.abs(vec_pos.x) then
|
||||||
|
adj = vec_pos.z
|
||||||
|
end
|
||||||
|
|
||||||
|
if adj ~= 0 then
|
||||||
|
if adj > 0 then opp = opp * -1 end
|
||||||
|
self.driver:set_look_pitch(opp/adj)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Yaw
|
||||||
|
opp = vec_pos.x
|
||||||
|
adj = vec_pos.z
|
||||||
|
|
||||||
|
local yaw = opp/adj
|
||||||
|
|
||||||
|
if math.abs(vec_pos.x) > math.abs(vec_pos.z) then
|
||||||
|
print("INVINVINVINVINVINVINVINVINVINV")
|
||||||
|
yaw = adj/opp
|
||||||
|
if adj < 0 and opp < 0 then
|
||||||
|
print("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA!!!!!!")
|
||||||
|
yaw = yaw + math.pi/2
|
||||||
|
end
|
||||||
|
|
||||||
|
if adj > 0 and opp > 0 then
|
||||||
|
print("++++++++++++++++++++++++++++++!!!!!!")
|
||||||
|
yaw = yaw + math.pi + math.pi/2
|
||||||
|
end
|
||||||
|
|
||||||
|
if yaw < 0 then
|
||||||
|
print("BBBBBBBBBBBBBBBBBBBBBBBBBBBBBB!!!!!!")
|
||||||
|
if opp > 0 then
|
||||||
|
print("OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0")
|
||||||
|
yaw = math.pi + math.pi/2 + yaw
|
||||||
|
else
|
||||||
|
print("OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 ")
|
||||||
|
yaw = math.pi/2 + yaw
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
else
|
||||||
|
print("NORMNORMNORMNORMNORMNORMNORMNORMNORM!!!!!!")
|
||||||
|
if adj < 0 and opp < 0 then
|
||||||
|
print("AAAAAAAAAAAAAAAAAAAAAAAAAAAAAA!!!!!!")
|
||||||
|
yaw = yaw - math.pi
|
||||||
|
end
|
||||||
|
|
||||||
|
if adj > 0 and opp > 0 then
|
||||||
|
print("++++++++++++++++++++++++++++++!!!!!!")
|
||||||
|
yaw = math.pi*2 - yaw
|
||||||
|
end
|
||||||
|
|
||||||
|
if yaw < 0 then
|
||||||
|
print("BBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBBB!!!!!!")
|
||||||
|
if opp > 0 then
|
||||||
|
print("OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0 OPP>0")
|
||||||
|
yaw = math.pi - yaw
|
||||||
|
else
|
||||||
|
print("OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 OPP<0 ")
|
||||||
|
yaw = math.pi*2 - yaw
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
self.driver:set_look_yaw(yaw)
|
||||||
|
end
|
||||||
|
|
||||||
-- Update path
|
-- Update path
|
||||||
self.path[#self.path + 1] = {
|
self.path[#self.path + 1] = {
|
||||||
pos = pos,
|
pos = pos,
|
||||||
@ -115,6 +193,12 @@ function camera:on_step(dtime)
|
|||||||
-- Modify yaw and pitch to match driver (player)
|
-- Modify yaw and pitch to match driver (player)
|
||||||
self.object:set_look_pitch(self.driver:get_look_pitch())
|
self.object:set_look_pitch(self.driver:get_look_pitch())
|
||||||
self.object:set_look_yaw(self.driver:get_look_yaw())
|
self.object:set_look_yaw(self.driver:get_look_yaw())
|
||||||
|
print("look pitch "..dump(self.driver:get_look_pitch()))
|
||||||
|
print("look vertical "..dump(self.driver:get_look_vertical()))
|
||||||
|
print("look yaw "..dump(self.driver:get_look_yaw()))
|
||||||
|
print("look horizontal "..dump(self.driver:get_look_horizontal()))
|
||||||
|
print("velocity "..dump(self.object:getvelocity()))
|
||||||
|
print("look dir "..dump(dir))
|
||||||
|
|
||||||
-- Get controls
|
-- Get controls
|
||||||
local ctrl = self.driver:get_player_control()
|
local ctrl = self.driver:get_player_control()
|
||||||
@ -147,7 +231,8 @@ function camera:on_step(dtime)
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- Set updated velocity
|
-- Set updated velocity
|
||||||
self.object:setvelocity(vector.multiply(self.driver:get_look_dir(), speed))
|
--self.object:setvelocity(vector.multiply(self.driver:get_look_dir(), speed))
|
||||||
|
self.object:setvelocity(vector.multiply(player_look_dir, speed))
|
||||||
elseif self.mode == 1 then -- elseif playback mode
|
elseif self.mode == 1 then -- elseif playback mode
|
||||||
-- Get controls
|
-- Get controls
|
||||||
local ctrl = self.driver:get_player_control()
|
local ctrl = self.driver:get_player_control()
|
||||||
@ -225,7 +310,24 @@ minetest.register_chatcommand("camera", {
|
|||||||
end
|
end
|
||||||
elseif param1 == "list" then -- elseif list, list recordings
|
elseif param1 == "list" then -- elseif list, list recordings
|
||||||
return true, "Recordings: "..get_recordings(name)
|
return true, "Recordings: "..get_recordings(name)
|
||||||
|
elseif param1 == "look_target" then
|
||||||
|
if param2 and param2 ~= "" then
|
||||||
|
if param2 == "nil" then
|
||||||
|
target_look_position = nil
|
||||||
|
return true, "Target look deleted"
|
||||||
|
end
|
||||||
|
local coord = string.split(param2, ",")
|
||||||
|
if #coord == 3 then
|
||||||
|
target_look_position = {x=tonumber(coord[1]), y=tonumber(coord[2]), z=tonumber(coord[3])}
|
||||||
|
return true, "Target look fixed"
|
||||||
|
else
|
||||||
|
return false, "Wrong formated coords (/camera look_target <x,y,z>)"
|
||||||
|
end
|
||||||
|
else
|
||||||
|
return false, "Missing coords (/camera look_target <x,y,z>)"
|
||||||
|
end
|
||||||
else -- else, begin recording
|
else -- else, begin recording
|
||||||
|
player_look_dir = player:get_look_dir()
|
||||||
local object = minetest.add_entity(player:getpos(), "camera:camera")
|
local object = minetest.add_entity(player:getpos(), "camera:camera")
|
||||||
object:get_luaentity():init(player, 0)
|
object:get_luaentity():init(player, 0)
|
||||||
object:setyaw(player:get_look_yaw())
|
object:setyaw(player:get_look_yaw())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user