17 KiB
[MOD] Simple Mobs [mobs] for MINETEST-C55
This mod, Forked from PilzAdam's Simple Mobs, adds some basic hostile and friendly mobs to the game. It includes additional mobs and rotton meat, which were originally provided in another mod called my_mobs. However my_mobs cages has not been included.
Since the original mod is no longer maintained and the author of my_mobs wished to continue it's development, the two have been merged.
Upstream contributions have been included from:
Settings Options
- Notify of Spawns for debugging, disabled by default
- Spawn Interval will determine how often the spawning ABM is executed, 30 seconds by default
- Drop Litter if mobs should drop dropps when dying naturally, disabled by default
- Meat Rots if raw meat should rot periodically, disabled by default
- Rats, Sheep, and monsters can be drawn with a default 3D mesh, a 2D sprite, or be disabled.
The Mobs
Animals
- Cows are large beasts that can be milked--until they go dry. They are tasty when killed and cooked. They like grass.
- Rabbits are cute little critters that you can pick up. They are tasty when cooked. They like berries and carrots, but are shy and get spooked easy. They can be white, grey, or brown.
- Racoons are cute little beasts. They will take whatever you give them, but only appreciate things that are eatable.
- Rats are cute little critters that you can pick up. They are tasty when cooked.
- Sheep produce wool--when well fed--that can be harvested. They are tasty when killed and cooked. They like wheat.
Monsters
- Dirt Monster
- Dungeon Master
- Oerkki
- Sand Monster
- Stone Monster
- Tree Monster
Combat Table [Spoiler Alert]
Mob Name | HP/2 (Hearts) | Crumbly (Shovel) | Cracky (Pickaxe) | Choppy (Axe) | Fleshy (Sword) |
---|---|---|---|---|---|
Cow | 9 | 15% | 25% | 80% | 90% |
Rabbit | 6 | 25% | 25% | 90% | 100% |
Racoon | 7 | 25% | 25% | 70% | 80% |
Rat | 5 | 100% | 100% | 100% | 100% |
Sheep | 8 | 25% | 25% | 80% | 90% |
Dirt Monster | 7 | 85% | 50% | 40% | 50% |
DM | 10 | 1% | 15% | 40% | 50% |
Oerkki | 9 | 15% | 25% | 50% | 60% |
Sand Monster | 7 | 90% | 30% | 10% | 25% |
Stone Monster | 8 | 1% | 90% | 10% | 25% |
Tree Monster | 8 | 0% | 10% | 80% | 70% |
Miscellaneous
- Raw and Cooked Meat
- Meat spoilage if it remains uncooked (untested) -- [X] Raw meet can be preserved through "cheating" or using a refridgerator provided by VanessaE's Home Decor Mod
- Overcooking and using the result to make dye
- Cages for Pet Rodents (TODO: move into separate mod) -- They must be fed apples and have a bucket of water available to survive
API
Mobs are added using the mobs:register_mob(name, def) function, where name
is the name of the mob. The entity should then be referenced as "mob:name"
. Thedef
parameter is a table with all the defining attributes of the mob. For the most part, these are the same as in minetest.register_entity()
. Other attributes are described below:
Mob Attributes
-
type = "animal" or "monster",
-
armor = the armor group table for percentages of damage caused by:
- crumbly = shovels,
- cracky = pickaxes,
- choppy = axes,
- fleshy = swords,
-
view_range = integer indicating how far away the mob can see a player,
-
walk_velocity = the velocity when the mob is walking around,
-
run_velocity = the velocity when the mob is running,
-
spawning_nodes = a table of nodes upon which the mob may spawn,
-
max_spawn_light = the maximum amount of light present for the mob to spawn,
-
min_spawn_light = the minimum amount of light present for the mob to spawn,
-
spawn_chance = the inverted chance for the mob to spawn per 30 second,
-
max_spawn_count = the maximum quantity of active mobs in the spawning node's vicinity,
-
max_spawn_height = the highest altitude that the mob may spawn,
-
damage = a table of damage per second done to the mob if it is in: water, lava, or light
-
drawtype = "front" or "side" to orient the mob's directional heading,
-
animation = a table with the animation ranges and speed of a model:
- stand_start
- stand_end
- walk_start
- walk_end
- run_start
- run_end
- punch_start
- punch_end
- speed_normal
- speed_run
-
sounds = an optional table of sounds for the mob:
- random = a sound that is played randomly,
- attack = a sound that is played when the mob attacks,
- punch = a sound that is played when the mob is hit,
- death_fall = a sound that is played when a mob falls to death,
- death_light = a sound that is played when a mob dies in light,
- death_lava = a sound that is played when a mob dies in lava,
-
drops = a list of tables indicating what the mob drops when dying:
- name = itemname,
- chance = the inverted chance to get the item,
- min = the minimum quantity of items,
- max = the maximum quantity of items,
States
Mobs start out in the standing state. They will then start walking around randomly, ocasionally stopping to stand around again. If a monster
type notices a player--and damage is enabled--the mob will give chase! If the player is holding something that a mob likes to follow, it will do so in the chase state. Once in range, mobs in the chase state will attack (if they have an attack). There is also a flee state in which mobs will run away from a target. When the target a mob is attacking or fleeing from dies, or otherwise is out of view, they will stop and stand again. If a player stops wielding an item that a mob follows, then it will stop chaseing--unless, of course, it still wants to attack.
Callbacks
Besides the regular entity callbacks, the mobs api adds some more that you may take advantage of. Additionally, there are helper functions availabe for assisting in the implementation of these callbacks.
attack( self, target )
Monsters should provide an attack method in order to inflict damage on players. The function receives two parameters, the self
entity which is performing the attack and the target
of the attack. The target will be a table with player, position, and distance attributes. Return true if the attack was performed, or else false.
The mob entity has a a self.timer
which should be checked to control how often the attack will take place. This is handled automatically if you use the provided mobs:slap
method. However, if you wish for your mob to shoot: you will need to register the projectile via mobs:register_arrow
, and verify/update the timing yourself as is done by the Dungeon Master mob.
follow( item )
The mob's optional follow
callback is used to check if a player is wielding something the mob likes. The input item
will be the wielded item's name. The function should return true
if the mob is attracted to the item.
try_jump( self )
You don't need to provide a callback to handle mobs jumping. However, you may. Or if you simply want to prevent a mob from jumping, use something like the following for your mob:
try_jump = function(self) return end
Helper Functions
mobs:orient(self, pos, target)
Returns a heading, in radians, which can be used with set_yaw
to orient self
in the direction from pos
to target
.
mobs:register_arrow(name, def)
Projectiles can be registered with this function, and then be launched using the mobs:shoot
function. They are referened by name
such as the Dungeon Master's mobs:fireball
. The def
inition is a table with attributes with the following values:
visual
= "cube" or "sprite" or "upright_sprite", [TODO: "mesh"]visual_size
= {x,y},textures
= a table of textures, the quantity of which depend on visual,velocity
= the speed with which the projectile witll travel on its trajectory,hit_player
= a callback function(self, player) to be called when the projectile hits a player,hit_node
= a callback function(self, pos, node) to be called when the projectile hits a node
mobs:slap(self, target, damage)
Punch the target
with damage
damage groups for use as an attack
callback. This is what most mobs use. For example:
attack = function(self, target)
return mobs:slap(self, target.player, {fleshy=2})
end
mobs:shoot(name, pos, target)
Launch projectiles at a target. name
is the name of the projectile. pos
and target
are the positions of the shooter and the target respectively.
Issues
- If you drink milk from a stack of vessels, you will not recieve the empty vessel.
- When an entity is slain both the
on_punch
andon_death
callbacks are triggered. So, if you have sounds for punch and death both will be heard. Take this into account while creating your sounds.
ETHICAL DISCLOSURE
The sourcecode (by PilzAdam), models (by Pavel_S), and other graphics (unless otherwise noted) were originally released under the WTFPL (see below).
Cow Assets
The cow texture was created by rinoux. It was retrieved from the mobf mod by sapier. The cow's dry-up sound came from there too, which reports that the graphic is under WTFPL and the sound was created by Secretlondon.
Rodent Assets
The rabbit and rat textures were acquired from cornernote's critters modpack. It's README.txt reports:
Artist: Martin Berube (Available for custom work)
Iconset Homepage: [http://www.graphics-and-desktop-icons.com/animal-icons.html](http://www.graphics-and-desktop-icons.com/animal-icons.html)
License: Freeware
Commercial usage: Allowed
Readme file: textures/terms-of-use.txt (see below)
The current rat-in-cage image is also adapted from one of the critters from the same source as the rabbit.
Rodent Terms-of-use.txt
Terms of use
1. Terms
By accessing this folder, you are agreeing to be bound by these folder Terms and Conditions of Use, all applicable laws and regulations, and agree that you are responsible for compliance with any applicable local laws. If you do not agree with any of these terms, you are prohibited from using or accessing this folder. The materials contained in this folder are protected by applicable copyright and trade mark law.
2. Use License
General use of the icons:
Permission is granted to temporarily download one copy of the materials (icons) on Graphics-and-desktop-icons.com for personal or commercial use. This is the grant of a license, not a transfer of title, and under this license you may not:
- claim to be the author of the images;
- sell the images (clipart resale);
- transfer the materials to another person or "mirror" the materials on any other server unless a static link is provide to Graphics-and-desktop-icons.com's homepage.
This license shall automatically terminate if you violate any of these restrictions and may be terminated by Graphics-and-desktop-icons.com at any time. Upon terminating your viewing of these materials or upon the termination of this license, you must destroy any downloaded materials in your possession whether in electronic or printed format.
Services:
The materials provided through services by Graphics-and-desktop-icons.com or its owner are provided "as is". Graphics-and-desktop-icons.com and its owner makes no warranties, expressed or implied, and hereby disclaims and negates all other warranties, including without limitation, implied warranties or conditions of merchantability, fitness for a particular purpose, or non-infringement of intellectual property or other violation of rights. Further, Graphics-and-desktop-icons.com and its owner does not warrant or make any representations concerning the accuracy, likely results, or reliability of the use of the materials provided by Graphics-and-desktop-icons.com and its owner or otherwise relating to such materials.
In no event shall Graphics-and-desktop-icons.com, its owner or its suppliers be liable for any damages (including, without limitation, damages for loss of data or profit, or due to business interruption,) arising out of the use or inability to use the materials provided by Graphics-and-desktop-icons.com or its owner, even if Graphics-and-desktop-icons.com or its owner has been notified orally or in writing of the possibility of such damage. Because some jurisdictions do not allow limitations on implied warranties, or limitations of liability for consequential or incidental damages, these limitations may not apply to you.
Any claim relating to Graphics-and-desktop-icons.com or its owner shall be governed by the laws of the State of Graphics-and-desktop-icons.com or its owner without regard to its conflict of law provisions.
3. Disclaimer
The materials on Graphics-and-desktop-icons.com are provided "as is". Graphics-and-desktop-icons.com makes no warranties, expressed or implied, and hereby disclaims and negates all other warranties, including without limitation, implied warranties or conditions of merchantability, fitness for a particular purpose, or non-infringement of intellectual property or other violation of rights. Further, Graphics-and-desktop-icons.com does not warrant or make any representations concerning the accuracy, likely results, or reliability of the use of the materials on its Internet web site or otherwise relating to such materials or on any sites linked to this site.
4. Limitations
In no event shall Graphics-and-desktop-icons.com or its suppliers be liable for any damages (including, without limitation, damages for loss of data or profit, or due to business interruption,) arising out of the use or inability to use the materials on Graphics-and-desktop-icons.com Internet site, even if Graphics-and-desktop-icons.com or a Graphics-and-desktop-icons.com authorized representative has been notified orally or in writing of the possibility of such damage. Because some jurisdictions do not allow limitations on implied warranties, or limitations of liability for consequential or incidental damages, these limitations may not apply to you.
5. Revisions and Errata
The materials appearing on Graphics-and-desktop-icons.com could include technical, typographical, or photographic errors. Graphics-and-desktop-icons.com does not warrant that any of the materials on its web site are accurate, complete, or current. Graphics-and-desktop-icons.com may make changes to the materials contained on its web site at any time without notice.
6. Links
Graphics-and-desktop-icons.com has not reviewed all of the sites linked to its Internet web site and is not responsible for the contents of any such linked site. The inclusion of any link does not imply endorsement by Graphics-and-desktop-icons.com of the site. Use of any such linked web site is at the user's own risk.
7. Site Terms of Use Modifications
Graphics-and-desktop-icons.com may revise these terms of use for its web site at any time without notice. By using this web site you are agreeing to be bound by the then current version of these Terms and Conditions of Use.
8. Governing Law
Any claim relating to Graphics-and-desktop-icons.com shall be governed by the laws of the State of Graphics-and-desktop-icons.com without regard to its conflict of law provisions.
Sound Assets
The rest of the sounds were found at various locations that I don't recall, unless otherwise acknowledged in changes.txt. If you own one of them, I will remove it and delete all copies of it, at you're request.
Other Assets
The unused images were created by me using THE GIMP
WTFPL
DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
Version 2, December 2004
Copyright (C) 2004 Sam Hocevar <sam@hocevar.net>
Everyone is permitted to copy and distribute verbatim or modified
copies of this license document, and changing it is allowed as long
as the name is changed.
DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
0. You just DO WHAT THE FUCK YOU WANT TO.