summaryrefslogtreecommitdiff
path: root/meta/3rd/Defold/library/collision_object.lua
blob: 41a6ac6a3ee517fa4fc6af8922d6388741b527c4 (plain)
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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
---Collision object physics API documentation
---Collision object physics API documentation
---@class physics
physics = {}
---fixed joint type
physics.JOINT_TYPE_FIXED = nil
---hinge joint type
physics.JOINT_TYPE_HINGE = nil
---slider joint type
physics.JOINT_TYPE_SLIDER = nil
---spring joint type
physics.JOINT_TYPE_SPRING = nil
---weld joint type
physics.JOINT_TYPE_WELD = nil
---Create a physics joint between two collision object components.
---Note: Currently only supported in 2D physics.
---@param joint_type number # the joint type
---@param collisionobject_a string|hash|url # first collision object
---@param joint_id string|hash # id of the joint
---@param position_a vector3 # local position where to attach the joint on the first collision object
---@param collisionobject_b string|hash|url # second collision object
---@param position_b vector3 # local position where to attach the joint on the second collision object
---@param properties table? # optional joint specific properties table See each joint type for possible properties field. The one field that is accepted for all joint types is: - boolean collide_connected: Set this flag to true if the attached bodies should collide.
function physics.create_joint(joint_type, collisionobject_a, joint_id, position_a, collisionobject_b, position_b, properties) end

---Destroy an already physics joint. The joint has to be created before a
---destroy can be issued.
---Note: Currently only supported in 2D physics.
---@param collisionobject string|hash|url # collision object where the joint exist
---@param joint_id string|hash # id of the joint
function physics.destroy_joint(collisionobject, joint_id) end

---Get the gravity in runtime. The gravity returned is not global, it will return
---the gravity for the collection that the function is called from.
---Note: For 2D physics the z component will always be zero.
---@return vector3 # gravity vector of collection
function physics.get_gravity() end

---Returns the group name of a collision object as a hash.
---@param url string|hash|url # the collision object to return the group of.
---@return hash # hash value of the group. local function check_is_enemy()     local group = physics.get_group("#collisionobject")     return group == hash("enemy") end
function physics.get_group(url) end

---Get a table for properties for a connected joint. The joint has to be created before
---properties can be retrieved.
---Note: Currently only supported in 2D physics.
---@param collisionobject string|hash|url # collision object where the joint exist
---@param joint_id string|hash # id of the joint
---@return table # properties table. See the joint types for what fields are available, the only field available for all types is:
function physics.get_joint_properties(collisionobject, joint_id) end

---Get the reaction force for a joint. The joint has to be created before
---the reaction force can be calculated.
---Note: Currently only supported in 2D physics.
---@param collisionobject string|hash|url # collision object where the joint exist
---@param joint_id string|hash # id of the joint
---@return vector3 # reaction force for the joint
function physics.get_joint_reaction_force(collisionobject, joint_id) end

---Get the reaction torque for a joint. The joint has to be created before
---the reaction torque can be calculated.
---Note: Currently only supported in 2D physics.
---@param collisionobject string|hash|url # collision object where the joint exist
---@param joint_id string|hash # id of the joint
---@return float # the reaction torque on bodyB in N*m.
function physics.get_joint_reaction_torque(collisionobject, joint_id) end

---Returns true if the specified group is set in the mask of a collision
---object, false otherwise.
---@param url string|hash|url # the collision object to check the mask of.
---@param group string # the name of the group to check for.
---@return boolean # boolean value of the maskbit. 'true' if present, 'false' otherwise. local function is_invincible()     -- check if the collisionobject would collide with the "bullet" group     local invincible = physics.get_maskbit("#collisionobject", "bullet")     return invincible end
function physics.get_maskbit(url, group) end

---Ray casts are used to test for intersections against collision objects in the physics world.
---Collision objects of types kinematic, dynamic and static are tested against. Trigger objects
---do not intersect with ray casts.
---Which collision objects to hit is filtered by their collision groups and can be configured
---through groups.
---@param from vector3 # the world position of the start of the ray
---@param to vector3 # the world position of the end of the ray
---@param groups table # a lua table containing the hashed groups for which to test collisions against
---@param options table # a lua table containing options for the raycast.
---@return table # It returns a list. If missed it returns nil. See ray_cast_response for details on the returned values.
function physics.raycast(from, to, groups, options) end

---Ray casts are used to test for intersections against collision objects in the physics world.
---Collision objects of types kinematic, dynamic and static are tested against. Trigger objects
---do not intersect with ray casts.
---Which collision objects to hit is filtered by their collision groups and can be configured
---through groups.
---The actual ray cast will be performed during the physics-update.
---
---
--- * If an object is hit, the result will be reported via a ray_cast_response message.
---
--- * If there is no object hit, the result will be reported via a ray_cast_missed message.
---@param from vector3 # the world position of the start of the ray
---@param to vector3 # the world position of the end of the ray
---@param groups table # a lua table containing the hashed groups for which to test collisions against
---@param request_id number] a number between [0,-255? # . It will be sent back in the response for identification, 0 by default
function physics.raycast_async(from, to, groups, request_id) end

---Set the gravity in runtime. The gravity change is not global, it will only affect
---the collection that the function is called from.
---Note: For 2D physics the z component of the gravity vector will be ignored.
---@param gravity vector3 # the new gravity vector
function physics.set_gravity(gravity) end

---Updates the group property of a collision object to the specified
---string value. The group name should exist i.e. have been used in
---a collision object in the editor.
---@param url string|hash|url # the collision object affected.
---@param group string # the new group name to be assigned. local function change_collision_group()      physics.set_group("#collisionobject", "enemy") end
function physics.set_group(url, group) end

---Flips the collision shapes horizontally for a collision object
---@param url string|hash|url # the collision object that should flip its shapes
---@param flip boolean # true if the collision object should flip its shapes, false if not
function physics.set_hflip(url, flip) end

---Updates the properties for an already connected joint. The joint has to be created before
---properties can be changed.
---Note: Currently only supported in 2D physics.
---@param collisionobject string|hash|url # collision object where the joint exist
---@param joint_id string|hash # id of the joint
---@param properties table # joint specific properties table Note: The collide_connected field cannot be updated/changed after a connection has been made.
function physics.set_joint_properties(collisionobject, joint_id, properties) end

---Sets or clears the masking of a group (maskbit) in a collision object.
---@param url string|hash|url # the collision object to change the mask of.
---@param group string # the name of the group (maskbit) to modify in the mask.
---@param maskbit boolean # boolean value of the new maskbit. 'true' to enable, 'false' to disable. local function make_invincible()     -- no longer collide with the "bullet" group     physics.set_maskbit("#collisionobject", "bullet", false) end
function physics.set_maskbit(url, group, maskbit) end

---Flips the collision shapes vertically for a collision object
---@param url string|hash|url # the collision object that should flip its shapes
---@param flip boolean # true if the collision object should flip its shapes, false if not
function physics.set_vflip(url, flip) end

---Collision objects tend to fall asleep when inactive for a small period of time for
---efficiency reasons. This function wakes them up.
---@param url string|hash|url # the collision object to wake. function on_input(self, action_id, action)     if action_id == hash("test") and action.pressed then         physics.wakeup("#collisionobject")     end end
function physics.wakeup(url) end




return physics