forked from Courseplay/courseplay
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBaleToCollect.lua
111 lines (92 loc) · 3.86 KB
/
BaleToCollect.lua
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
110
111
--[[
This file is part of Courseplay (https://github.com/Courseplay/courseplay)
Copyright (C) 2021 Peter Vaiko
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 3 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, see <http://www.gnu.org/licenses/>.
]]
--[[
A wrapper :) for the standard Bale object
--]]
---@class BaleToCollect
BaleToCollect = CpObject()
---@param baleObject : Bale
function BaleToCollect:init(baleObject)
self.bale = baleObject
local x, _, z = getWorldTranslation(self.bale.nodeId)
-- this finds bales on merged fields too, but the bale must be on the field
self.fieldId = courseplay.fields:getFieldNumForPosition(x, z)
if self.fieldId == 0 then
-- this does not find bales on merged fields, but finds them if they are on the
-- field border too (just off the field)
self.fieldId = PathfinderUtil.getFieldIdAtWorldPosition(x, z)
end
end
--- Call this before attempting to construct a BaleToCollect to check the validity of the object
---@param baleWrapper table bale wrapper, if exists
function BaleToCollect.isValidBale(object, baleWrapper)
-- nodeId is sometimes 0, causing issues for the BaleToCollect constructor
if object.isa and object:isa(Bale) and object.nodeId and entityExists(object.nodeId) then
if baleWrapper then
-- if there is a bale wrapper, the bale must be wrappable and the wrapper does not want to skip this fill type
-- (and yes, this is another typo in Giants code
local wrappedBaleType = baleWrapper:getWrapperBaleType(object)
courseplay.debugFormat(courseplay.DBG_MODE_7, ' bale %d wrapping state: %d, wrapped bale type: %s',
object.id, tostring(object.wrappingState), tostring(wrappedBaleType))
return wrappedBaleType and object.wrappingState < 0.99
else
return true
end
end
end
function BaleToCollect:isStillValid()
return BaleToCollect.isValidBale(self.bale)
end
function BaleToCollect:isLoaded()
return self.bale.mountObject
end
function BaleToCollect:getFieldId()
return self.fieldId
end
function BaleToCollect:getId()
return self.bale.id
end
function BaleToCollect:getBaleObjectId()
return NetworkUtil.getObjectId(self.bale)
end
function BaleToCollect:getBaleObject()
return self.bale
end
function BaleToCollect:getPosition()
return getWorldTranslation(self.bale.nodeId)
end
---@return number, number, number, number x, z, direction from node, distance from node
function BaleToCollect:getPositionInfoFromNode(node)
local xb, _, zb = self:getPosition()
local x, _, z = getWorldTranslation(node)
local dx, dz = xb - x, zb - z
local yRot = MathUtil.getYRotationFromDirection(dx, dz)
return xb, zb, yRot, math.sqrt(dx * dx + dz * dz)
end
function BaleToCollect:getPositionAsState3D()
local xb, _, zb = self:getPosition()
local _, yRot, _ = getWorldRotation(self.bale.nodeId)
return State3D(xb, -zb, courseGenerator.fromCpAngle(yRot))
end
--- Minimum distance from the bale's center (node) to avoid hitting the bale
--- when driving by in any direction
function BaleToCollect:getSafeDistance()
-- round bales don't have length, just diameter
local length = self.bale.baleDiameter and self.bale.baleDiameter or self.bale.baleLength
-- no matter what kind of bale, the footprint is a rectangle, get the diagonal (which, is BTW, not
-- exact math as it depends on the angle we are approaching the bale, so add a little buffer instead of
-- thinking about the math...
return math.sqrt(length * length + self.bale.baleWidth * self.bale.baleWidth) / 2 + 0.2
end