Simple, lightweight bullet handler for Defold.
- 
Central Bullet handler module. 
- 
Per Bullet ray casting and Collision Groups. 
- 
Per Bullet hit response functions and hit marker functions. 
- 
Per Bullet update behaviour. 
- 
Two Bullet movement types: handled by [go.animate()] or updated using [go.set()] (significantly slower). 
TO DO...
TO DO...
Please see the quick_start.script_snippet for a basic implementation.
- 
Bullets: Create a GameObject named "bullets" and create a Factory component named "factory" within the GameObject. 
- 
Hit Markers: Create a GameObject named "hit_markers" and create a Factory component named "factory" within the GameObject. 
local bulletfold = require "bulletfold_directory.bulletfold"- 
Default Bullet Factory: bulletfold.factory = "/bullets#factory" 
- 
Default Ray Cast Collsion Groups: bulletfold.raycast_groups = { hash("collision_group1"), hash("collision_group2") } 
- 
(Optional) Default Hit Marker Function. If not initialized, spawns a default hit marker: bulletfold.hitmarker = function(position, bullet_id, object_id) factory.create("/hit_markers#factory", position) end Parameters - 
[position] vmath.vector3The Bullet collision position.
- 
[bullet_id] hashThe Bullet GameObject ID.
- 
[object_id] hashThe ID of the GameObject the Bullet collided with.
 
- 
- 
Spawn a Bullet updated using [go.animate()] (Best Performance): bullet_id = bulletfold.spawn(speed, time, position, direction, accuracy, [raycast_groups], [factory], [hit_response]) 
- 
Spawn a Bullet updated using [go.set()] (Slower, Full Control Over Movement): bullet_id = bulletfold.spawn_update(speed, time, position, direction, accuracy, [raycast_groups], [factory], [hit_response]) 
- 
Custom Bullet hit response function: hit_response = function(bullet_id, result) hitmarker(result.position) ; bulletfold.delete(bullet_id) end 
- 
Update the BulletFold buffer: function update(self, dt) bulletfold.update(dt) end 
- 
The Bullet buffer. Contains all active bullets. Bullet GameObject ID hashes are used as table keys. Bullet Parameters - 
[time] doubleThe time remaining before the Bullet is deleted.
- 
[speed] doubleThe Bullet speed.
- 
[position] vmath.vector3The current Bullet position. If spawned usingbulletfold.spawn()and is not ray casting, the position is not updated after spawning (improves performance).
- 
[direction] vmath.vector3The current Bullet travel direction. Can only be changed if the Bullet was spawned usingbulletfold.spawn_update().
- 
[raycast_groups] hash tableThe Collision Groups the Bullet ray cast can collide with.nilto disable ray casting.
- 
[hit] functionThe function called when the Bullet hits an object. Default calls the Bullet Hit Marker function and deletes the Bullet.
- 
[hitmark] functionThe function called when the Bullet hits an object, if a custom hit response function was not provided.
 
- 
- The number of Bullets in the bulletfold.bulletsbuffer.
- 
Default Bullet Factory. Used if no Factory is provided during spawning. bulletfold.factory = "/game_object#factory_component" 
- 
Default Ray Cast Collsion Groups. Used if no table of Collision Groups is provided during spawning. bulletfold.raycast_groups = { hash("collision_group1"), hash("collision_group2") } 
- 
(Optional) Default Hit Marker function, called if no hit response function is provided during spawning. If not initialized, spawns a default hit marker using the function below. Parameters - 
[position] vmath.vector3The Bullet collision position.
- 
[bullet_id] hashThe Bullet GameObject ID.
- 
[object_id] hashThe ID of the GameObject the Bullet collided with.
 bulletfold.hitmarker = function(position, bullet_id, object_id) local hitmark_id = factory.create("/hit_markers#factory", position) go.animate(msg.url(nil, hitmark_id, "sprite"), "tint.w", go.PLAYBACK_ONCE_FORWARD, 0, go.EASING_LINEAR, 1, 0, function() go.delete(hitmark_id) end) end 
- 
bulletfold.spawn(speed, time, position, direction, accuracy, [raycast_groups], [factory], [hit_response])
- 
Spawn a Bullet updated using [go.animate()] (Best Performance): Parameters - 
[speed] doubleThe Bullet speed.
- 
[time] doubleThe Bullet life time, in seconds.
- 
[position] vmath.vector3The Bullet spawn position.
- 
[direction] vmath.vector3The Bullet travel direction.
- 
[accuracy] doubleThe Bullet accuracy, used to randomize the direction. 0 for perfect accuracy.
- 
[raycast_groups] hash table(Optional) The Collision Groups the Bullet ray cast can collide with.nilto disable ray casting.
- 
[factory] string(Optional) The URL string of the Factory component used to spawn the Bullet GameObject. Default is the BulletFold Factory.
- 
[hit_response] function(Optional) The function called when the Bullet hits an object. Default calls the Bullet Hit Marker function and deletes the Bullet.Parameters - 
[bullet_id] hashThe Bullet GameObject ID.
- 
[result] tableThe result of the Bullet ray cast collision.- 
[normal] vmath.vector3The surface normal of the Collision Object the Bullet collided with.
- 
[fraction] doubleThe fraction along the ray cast where the collision occured. 0 is the start, 1 is the end.
- 
[position] vmath.vector3The collision position.
- 
[group] hashThe Collision Group ID of the Collision Object.
- 
[id] hashThe ID of the GameObject the Bullet collided with.
 
- 
 
- 
 Returns - [bullet_id] hashThe Bullet GameObject ID.
 bullet_id = bulletfold.spawn(speed, time, position, direction, accuracy, [raycast_groups], [factory], [hit_response]) 
- 
bulletfold.spawn_update(speed, time, position, direction, accuracy, [raycast_groups], [factory], [hit_response])
- 
Spawn a Bullet updated using [go.set()] (Slower, Full Control Over Movement): Parameters - 
[speed] doubleThe Bullet speed.
- 
[time] doubleThe Bullet life time, in seconds.
- 
[position] vmath.vector3The Bullet spawn position.
- 
[direction] vmath.vector3The Bullet travel direction.
- 
[accuracy] doubleThe Bullet accuracy, used to randomize the direction. 0 for perfect accuracy.
- 
[raycast_groups] hash table(Optional) The Collision Groups the Bullet ray cast can collide with.nilto disable ray casting.
- 
[factory] string(Optional) The URL string of the Factory component used to spawn the Bullet GameObject. Default is the BulletFold Factory.
- 
[hit_response] function(Optional) The function called when the Bullet hits an object. Default calls the Bullet Hit Marker function and deletes the Bullet.Parameters - 
[bullet_id] hashThe Bullet GameObject ID.
- 
[result] tableThe result of the Bullet ray cast collision.- 
[normal] vmath.vector3The surface normal of the Collision Object the Bullet collided with.
- 
[fraction] doubleThe fraction along the ray cast where the collision occured. 0 is the start, 1 is the end.
- 
[position] vmath.vector3The collision position.
- 
[group] hashThe Collision Group ID of the Collision Object.
- 
[id] hashThe ID of the GameObject the Bullet collided with.
 
- 
 
- 
 Returns - [bullet_id] hashThe Bullet GameObject ID.
 bullet_id = bulletfold.spawn_update(speed, time, position, direction, accuracy, [raycast_groups], [factory], [hit_response]) 
- 
- 
Updates the BulletFold buffer. Parameters - [dt] doubleThe time elapsed since the previous frame.
 
- [dt] 
- 
Deletes a Bullet and removes it from the BulletFold buffer. Parameters - [bullet_id] hashThe Bullet GameObject ID.
 
- [bullet_id] 
- Deletes every Bullet from the BulletFold buffer.

