commit 5fb9897a36992e6560c87ea195dbd6e2c47358c3 Author: MCLx86 Date: Tue Dec 21 18:09:12 2021 -0500 Initial commit diff --git a/CHANGELOG.TXT b/CHANGELOG.TXT new file mode 100644 index 0000000..befea37 --- /dev/null +++ b/CHANGELOG.TXT @@ -0,0 +1,28 @@ +==================== +==================== +==ADSURV CHANGELOG== +==================== +==================== + + +------------------------------- +Adsurv 0.5.2137 (March 7, 2021) +------------------------------- +- Added some new crafting recipes. +- Added planks. +- Changed the texture for dirt. + +-------------------------- +Adsurv 0.5 (March 4, 2021) +-------------------------- +- Added blocks from every type of metal currently in the game. +- Added lumps. +- Added axes and knives from steel, stone, and refined stone. +- Completely changed textures of obsidian, cobble, apple tree log, leaves, and more. + + +----------------------------- +Adsurv 0.4 (February 2, 2019) +----------------------------- +- Changed selected slot hotbar texture. +- Made a few minor changes to the textures diff --git a/LICENSE.TXT b/LICENSE.TXT new file mode 100644 index 0000000..6b67a9f --- /dev/null +++ b/LICENSE.TXT @@ -0,0 +1,106 @@ +Source code license: MIT License (see below) +------------------- +Copyright 2019-2021 MCL + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + +Textures and sounds license: Creative Commons Attribution 4.0 International +--------------------------- +By exercising the Licensed Rights (defined below), You accept and agree to be bound by the terms and conditions of this Creative Commons Attribution 4.0 International Public License ("Public License"). To the extent this Public License may be interpreted as a contract, You are granted the Licensed Rights in consideration of Your acceptance of these terms and conditions, and the Licensor grants You such rights in consideration of benefits the Licensor receives from making the Licensed Material available under these terms and conditions. + +Section 1 – Definitions. + + Adapted Material means material subject to Copyright and Similar Rights that is derived from or based upon the Licensed Material and in which the Licensed Material is translated, altered, arranged, transformed, or otherwise modified in a manner requiring permission under the Copyright and Similar Rights held by the Licensor. For purposes of this Public License, where the Licensed Material is a musical work, performance, or sound recording, Adapted Material is always produced where the Licensed Material is synched in timed relation with a moving image. + Adapter's License means the license You apply to Your Copyright and Similar Rights in Your contributions to Adapted Material in accordance with the terms and conditions of this Public License. + Copyright and Similar Rights means copyright and/or similar rights closely related to copyright including, without limitation, performance, broadcast, sound recording, and Sui Generis Database Rights, without regard to how the rights are labeled or categorized. For purposes of this Public License, the rights specified in Section 2(b)(1)-(2) are not Copyright and Similar Rights. + Effective Technological Measures means those measures that, in the absence of proper authority, may not be circumvented under laws fulfilling obligations under Article 11 of the WIPO Copyright Treaty adopted on December 20, 1996, and/or similar international agreements. + Exceptions and Limitations means fair use, fair dealing, and/or any other exception or limitation to Copyright and Similar Rights that applies to Your use of the Licensed Material. + Licensed Material means the artistic or literary work, database, or other material to which the Licensor applied this Public License. + Licensed Rights means the rights granted to You subject to the terms and conditions of this Public License, which are limited to all Copyright and Similar Rights that apply to Your use of the Licensed Material and that the Licensor has authority to license. + Licensor means the individual(s) or entity(ies) granting rights under this Public License. + Share means to provide material to the public by any means or process that requires permission under the Licensed Rights, such as reproduction, public display, public performance, distribution, dissemination, communication, or importation, and to make material available to the public including in ways that members of the public may access the material from a place and at a time individually chosen by them. + Sui Generis Database Rights means rights other than copyright resulting from Directive 96/9/EC of the European Parliament and of the Council of 11 March 1996 on the legal protection of databases, as amended and/or succeeded, as well as other essentially equivalent rights anywhere in the world. + You means the individual or entity exercising the Licensed Rights under this Public License. Your has a corresponding meaning. + +Section 2 – Scope. + + License grant. + Subject to the terms and conditions of this Public License, the Licensor hereby grants You a worldwide, royalty-free, non-sublicensable, non-exclusive, irrevocable license to exercise the Licensed Rights in the Licensed Material to: + reproduce and Share the Licensed Material, in whole or in part; and + produce, reproduce, and Share Adapted Material. + Exceptions and Limitations. For the avoidance of doubt, where Exceptions and Limitations apply to Your use, this Public License does not apply, and You do not need to comply with its terms and conditions. + Term. The term of this Public License is specified in Section 6(a). + Media and formats; technical modifications allowed. The Licensor authorizes You to exercise the Licensed Rights in all media and formats whether now known or hereafter created, and to make technical modifications necessary to do so. The Licensor waives and/or agrees not to assert any right or authority to forbid You from making technical modifications necessary to exercise the Licensed Rights, including technical modifications necessary to circumvent Effective Technological Measures. For purposes of this Public License, simply making modifications authorized by this Section 2(a)(4) never produces Adapted Material. + Downstream recipients. + Offer from the Licensor – Licensed Material. Every recipient of the Licensed Material automatically receives an offer from the Licensor to exercise the Licensed Rights under the terms and conditions of this Public License. + No downstream restrictions. You may not offer or impose any additional or different terms or conditions on, or apply any Effective Technological Measures to, the Licensed Material if doing so restricts exercise of the Licensed Rights by any recipient of the Licensed Material. + No endorsement. Nothing in this Public License constitutes or may be construed as permission to assert or imply that You are, or that Your use of the Licensed Material is, connected with, or sponsored, endorsed, or granted official status by, the Licensor or others designated to receive attribution as provided in Section 3(a)(1)(A)(i). + + Other rights. + Moral rights, such as the right of integrity, are not licensed under this Public License, nor are publicity, privacy, and/or other similar personality rights; however, to the extent possible, the Licensor waives and/or agrees not to assert any such rights held by the Licensor to the limited extent necessary to allow You to exercise the Licensed Rights, but not otherwise. + Patent and trademark rights are not licensed under this Public License. + To the extent possible, the Licensor waives any right to collect royalties from You for the exercise of the Licensed Rights, whether directly or through a collecting society under any voluntary or waivable statutory or compulsory licensing scheme. In all other cases the Licensor expressly reserves any right to collect such royalties. + +Section 3 – License Conditions. + +Your exercise of the Licensed Rights is expressly made subject to the following conditions. + + Attribution. + + If You Share the Licensed Material (including in modified form), You must: + retain the following if it is supplied by the Licensor with the Licensed Material: + identification of the creator(s) of the Licensed Material and any others designated to receive attribution, in any reasonable manner requested by the Licensor (including by pseudonym if designated); + a copyright notice; + a notice that refers to this Public License; + a notice that refers to the disclaimer of warranties; + a URI or hyperlink to the Licensed Material to the extent reasonably practicable; + indicate if You modified the Licensed Material and retain an indication of any previous modifications; and + indicate the Licensed Material is licensed under this Public License, and include the text of, or the URI or hyperlink to, this Public License. + You may satisfy the conditions in Section 3(a)(1) in any reasonable manner based on the medium, means, and context in which You Share the Licensed Material. For example, it may be reasonable to satisfy the conditions by providing a URI or hyperlink to a resource that includes the required information. + If requested by the Licensor, You must remove any of the information required by Section 3(a)(1)(A) to the extent reasonably practicable. + If You Share Adapted Material You produce, the Adapter's License You apply must not prevent recipients of the Adapted Material from complying with this Public License. + +Section 4 – Sui Generis Database Rights. + +Where the Licensed Rights include Sui Generis Database Rights that apply to Your use of the Licensed Material: + + for the avoidance of doubt, Section 2(a)(1) grants You the right to extract, reuse, reproduce, and Share all or a substantial portion of the contents of the database; + if You include all or a substantial portion of the database contents in a database in which You have Sui Generis Database Rights, then the database in which You have Sui Generis Database Rights (but not its individual contents) is Adapted Material; and + You must comply with the conditions in Section 3(a) if You Share all or a substantial portion of the contents of the database. + +For the avoidance of doubt, this Section 4 supplements and does not replace Your obligations under this Public License where the Licensed Rights include other Copyright and Similar Rights. + +Section 5 – Disclaimer of Warranties and Limitation of Liability. + + Unless otherwise separately undertaken by the Licensor, to the extent possible, the Licensor offers the Licensed Material as-is and as-available, and makes no representations or warranties of any kind concerning the Licensed Material, whether express, implied, statutory, or other. This includes, without limitation, warranties of title, merchantability, fitness for a particular purpose, non-infringement, absence of latent or other defects, accuracy, or the presence or absence of errors, whether or not known or discoverable. Where disclaimers of warranties are not allowed in full or in part, this disclaimer may not apply to You. + To the extent possible, in no event will the Licensor be liable to You on any legal theory (including, without limitation, negligence) or otherwise for any direct, special, indirect, incidental, consequential, punitive, exemplary, or other losses, costs, expenses, or damages arising out of this Public License or use of the Licensed Material, even if the Licensor has been advised of the possibility of such losses, costs, expenses, or damages. Where a limitation of liability is not allowed in full or in part, this limitation may not apply to You. + + The disclaimer of warranties and limitation of liability provided above shall be interpreted in a manner that, to the extent possible, most closely approximates an absolute disclaimer and waiver of all liability. + +Section 6 – Term and Termination. + + This Public License applies for the term of the Copyright and Similar Rights licensed here. However, if You fail to comply with this Public License, then Your rights under this Public License terminate automatically. + + Where Your right to use the Licensed Material has terminated under Section 6(a), it reinstates: + automatically as of the date the violation is cured, provided it is cured within 30 days of Your discovery of the violation; or + upon express reinstatement by the Licensor. + For the avoidance of doubt, this Section 6(b) does not affect any right the Licensor may have to seek remedies for Your violations of this Public License. + For the avoidance of doubt, the Licensor may also offer the Licensed Material under separate terms or conditions or stop distributing the Licensed Material at any time; however, doing so will not terminate this Public License. + Sections 1, 5, 6, 7, and 8 survive termination of this Public License. + +Section 7 – Other Terms and Conditions. + + The Licensor shall not be bound by any additional or different terms or conditions communicated by You unless expressly agreed. + Any arrangements, understandings, or agreements regarding the Licensed Material not stated herein are separate from and independent of the terms and conditions of this Public License. + +Section 8 – Interpretation. + + For the avoidance of doubt, this Public License does not, and shall not be interpreted to, reduce, limit, restrict, or impose conditions on any use of the Licensed Material that could lawfully be made without permission under this Public License. + To the extent possible, if any provision of this Public License is deemed unenforceable, it shall be automatically reformed to the minimum extent necessary to make it enforceable. If the provision cannot be reformed, it shall be severed from this Public License without affecting the enforceability of the remaining terms and conditions. + No term or condition of this Public License will be waived and no failure to comply consented to unless expressly agreed to by the Licensor. + Nothing in this Public License constitutes or may be interpreted as a limitation upon, or waiver of, any privileges and immunities that apply to the Licensor or You, including from the legal processes of any jurisdiction or authority. diff --git a/README.TXT b/README.TXT new file mode 100644 index 0000000..40d920a --- /dev/null +++ b/README.TXT @@ -0,0 +1,19 @@ +FortTest - Version 0.1-dev + + +TODO: +Death detection +Add all guns +Loot chest generation +Game start +Building + + + + +-------- +LICENSES +-------- + +Liccense of code: X11 License (see LICENSE.TXT) +Licecnse of textures, sounds, and schematics: CC BY 4.0 International (see LICENSE.TXT) diff --git a/game.conf b/game.conf new file mode 100644 index 0000000..902e63b --- /dev/null +++ b/game.conf @@ -0,0 +1 @@ +name = Coconut Collection (a.k.a. Coconut Hut) diff --git a/menu/header.png b/menu/header.png new file mode 100644 index 0000000..a23b7ae Binary files /dev/null and b/menu/header.png differ diff --git a/menu/icon.png b/menu/icon.png new file mode 100644 index 0000000..cfc767d Binary files /dev/null and b/menu/icon.png differ diff --git a/mods/coconut/init.lua b/mods/coconut/init.lua new file mode 100644 index 0000000..a12892c --- /dev/null +++ b/mods/coconut/init.lua @@ -0,0 +1,60 @@ +coconut = {} + +minetest.register_node("coconut:nut", { + tiles = + { + "main_cobble.png", + "main_cobble.png", + "main_cobble.png", + "main_cobble.png", + "main_cobble.png", + "main_cobble.png" + }, + drawtype = "nodebox", + paramtype = "light", + node_box = + { + type = "fixed", + fixed = + { + {-0.25, -0.5, -0.25, 0.25, 0, 0.25}, + } + } +}) + +function coconut.init() + local players = minetest.get_connected_players() + for i=1, #players do + coconut.add_huds(players[i]) + minetest.chat_send_all(players[i]) + end + +end + +function coconut.add_hud(player) + + +local meta = player:get_meta() +local digs_text = "You: " .. meta:get_int("score:digs") +local places_text = "Ami: " .. meta:get_int("score:places") + +player:hud_add({ + hud_elem_type = "text", + position = {x = 1, y = 0.5}, + offset = {x = -120, y = -25}, + text = "Stats", + alignment = 0, + scale = { x = 100, y = 30}, + number = 0xFFFFFF, +}) + +player:hud_add({ + hud_elem_type = "text", + position = {x = 1, y = 0.5}, + offset = {x = -180, y = 0}, + text = digs_text, + alignment = -1, + scale = { x = 50, y = 10}, + number = 0xFFFFFF, +}) +end diff --git a/mods/industrial_decor/LICENSE.TXT b/mods/industrial_decor/LICENSE.TXT new file mode 100644 index 0000000..e3e2290 --- /dev/null +++ b/mods/industrial_decor/LICENSE.TXT @@ -0,0 +1,113 @@ +SOURCE CODE LICENSE: MIT License (see below) + +Copyright 2018-2021 MCL + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + + + + + + +=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-= +TEXTURES AND SOUNDS LICENSE: Creative Commons Attribution 4.0 International Public License (see below) + + +By exercising the Licensed Rights (defined below), You accept and agree to be bound by the terms and conditions of this Creative Commons Attribution 4.0 International Public License ("Public License"). To the extent this Public License may be interpreted as a contract, You are granted the Licensed Rights in consideration of Your acceptance of these terms and conditions, and the Licensor grants You such rights in consideration of benefits the Licensor receives from making the Licensed Material available under these terms and conditions. + +Section 1 – Definitions. + + Adapted Material means material subject to Copyright and Similar Rights that is derived from or based upon the Licensed Material and in which the Licensed Material is translated, altered, arranged, transformed, or otherwise modified in a manner requiring permission under the Copyright and Similar Rights held by the Licensor. For purposes of this Public License, where the Licensed Material is a musical work, performance, or sound recording, Adapted Material is always produced where the Licensed Material is synched in timed relation with a moving image. + Adapter's License means the license You apply to Your Copyright and Similar Rights in Your contributions to Adapted Material in accordance with the terms and conditions of this Public License. + Copyright and Similar Rights means copyright and/or similar rights closely related to copyright including, without limitation, performance, broadcast, sound recording, and Sui Generis Database Rights, without regard to how the rights are labeled or categorized. For purposes of this Public License, the rights specified in Section 2(b)(1)-(2) are not Copyright and Similar Rights. + Effective Technological Measures means those measures that, in the absence of proper authority, may not be circumvented under laws fulfilling obligations under Article 11 of the WIPO Copyright Treaty adopted on December 20, 1996, and/or similar international agreements. + Exceptions and Limitations means fair use, fair dealing, and/or any other exception or limitation to Copyright and Similar Rights that applies to Your use of the Licensed Material. + Licensed Material means the artistic or literary work, database, or other material to which the Licensor applied this Public License. + Licensed Rights means the rights granted to You subject to the terms and conditions of this Public License, which are limited to all Copyright and Similar Rights that apply to Your use of the Licensed Material and that the Licensor has authority to license. + Licensor means the individual(s) or entity(ies) granting rights under this Public License. + Share means to provide material to the public by any means or process that requires permission under the Licensed Rights, such as reproduction, public display, public performance, distribution, dissemination, communication, or importation, and to make material available to the public including in ways that members of the public may access the material from a place and at a time individually chosen by them. + Sui Generis Database Rights means rights other than copyright resulting from Directive 96/9/EC of the European Parliament and of the Council of 11 March 1996 on the legal protection of databases, as amended and/or succeeded, as well as other essentially equivalent rights anywhere in the world. + You means the individual or entity exercising the Licensed Rights under this Public License. Your has a corresponding meaning. + +Section 2 – Scope. + + License grant. + Subject to the terms and conditions of this Public License, the Licensor hereby grants You a worldwide, royalty-free, non-sublicensable, non-exclusive, irrevocable license to exercise the Licensed Rights in the Licensed Material to: + reproduce and Share the Licensed Material, in whole or in part; and + produce, reproduce, and Share Adapted Material. + Exceptions and Limitations. For the avoidance of doubt, where Exceptions and Limitations apply to Your use, this Public License does not apply, and You do not need to comply with its terms and conditions. + Term. The term of this Public License is specified in Section 6(a). + Media and formats; technical modifications allowed. The Licensor authorizes You to exercise the Licensed Rights in all media and formats whether now known or hereafter created, and to make technical modifications necessary to do so. The Licensor waives and/or agrees not to assert any right or authority to forbid You from making technical modifications necessary to exercise the Licensed Rights, including technical modifications necessary to circumvent Effective Technological Measures. For purposes of this Public License, simply making modifications authorized by this Section 2(a)(4) never produces Adapted Material. + Downstream recipients. + Offer from the Licensor – Licensed Material. Every recipient of the Licensed Material automatically receives an offer from the Licensor to exercise the Licensed Rights under the terms and conditions of this Public License. + No downstream restrictions. You may not offer or impose any additional or different terms or conditions on, or apply any Effective Technological Measures to, the Licensed Material if doing so restricts exercise of the Licensed Rights by any recipient of the Licensed Material. + No endorsement. Nothing in this Public License constitutes or may be construed as permission to assert or imply that You are, or that Your use of the Licensed Material is, connected with, or sponsored, endorsed, or granted official status by, the Licensor or others designated to receive attribution as provided in Section 3(a)(1)(A)(i). + + Other rights. + Moral rights, such as the right of integrity, are not licensed under this Public License, nor are publicity, privacy, and/or other similar personality rights; however, to the extent possible, the Licensor waives and/or agrees not to assert any such rights held by the Licensor to the limited extent necessary to allow You to exercise the Licensed Rights, but not otherwise. + Patent and trademark rights are not licensed under this Public License. + To the extent possible, the Licensor waives any right to collect royalties from You for the exercise of the Licensed Rights, whether directly or through a collecting society under any voluntary or waivable statutory or compulsory licensing scheme. In all other cases the Licensor expressly reserves any right to collect such royalties. + +Section 3 – License Conditions. + +Your exercise of the Licensed Rights is expressly made subject to the following conditions. + + Attribution. + + If You Share the Licensed Material (including in modified form), You must: + retain the following if it is supplied by the Licensor with the Licensed Material: + identification of the creator(s) of the Licensed Material and any others designated to receive attribution, in any reasonable manner requested by the Licensor (including by pseudonym if designated); + a copyright notice; + a notice that refers to this Public License; + a notice that refers to the disclaimer of warranties; + a URI or hyperlink to the Licensed Material to the extent reasonably practicable; + indicate if You modified the Licensed Material and retain an indication of any previous modifications; and + indicate the Licensed Material is licensed under this Public License, and include the text of, or the URI or hyperlink to, this Public License. + You may satisfy the conditions in Section 3(a)(1) in any reasonable manner based on the medium, means, and context in which You Share the Licensed Material. For example, it may be reasonable to satisfy the conditions by providing a URI or hyperlink to a resource that includes the required information. + If requested by the Licensor, You must remove any of the information required by Section 3(a)(1)(A) to the extent reasonably practicable. + If You Share Adapted Material You produce, the Adapter's License You apply must not prevent recipients of the Adapted Material from complying with this Public License. + +Section 4 – Sui Generis Database Rights. + +Where the Licensed Rights include Sui Generis Database Rights that apply to Your use of the Licensed Material: + + for the avoidance of doubt, Section 2(a)(1) grants You the right to extract, reuse, reproduce, and Share all or a substantial portion of the contents of the database; + if You include all or a substantial portion of the database contents in a database in which You have Sui Generis Database Rights, then the database in which You have Sui Generis Database Rights (but not its individual contents) is Adapted Material; and + You must comply with the conditions in Section 3(a) if You Share all or a substantial portion of the contents of the database. + +For the avoidance of doubt, this Section 4 supplements and does not replace Your obligations under this Public License where the Licensed Rights include other Copyright and Similar Rights. + +Section 5 – Disclaimer of Warranties and Limitation of Liability. + + Unless otherwise separately undertaken by the Licensor, to the extent possible, the Licensor offers the Licensed Material as-is and as-available, and makes no representations or warranties of any kind concerning the Licensed Material, whether express, implied, statutory, or other. This includes, without limitation, warranties of title, merchantability, fitness for a particular purpose, non-infringement, absence of latent or other defects, accuracy, or the presence or absence of errors, whether or not known or discoverable. Where disclaimers of warranties are not allowed in full or in part, this disclaimer may not apply to You. + To the extent possible, in no event will the Licensor be liable to You on any legal theory (including, without limitation, negligence) or otherwise for any direct, special, indirect, incidental, consequential, punitive, exemplary, or other losses, costs, expenses, or damages arising out of this Public License or use of the Licensed Material, even if the Licensor has been advised of the possibility of such losses, costs, expenses, or damages. Where a limitation of liability is not allowed in full or in part, this limitation may not apply to You. + + The disclaimer of warranties and limitation of liability provided above shall be interpreted in a manner that, to the extent possible, most closely approximates an absolute disclaimer and waiver of all liability. + +Section 6 – Term and Termination. + + This Public License applies for the term of the Copyright and Similar Rights licensed here. However, if You fail to comply with this Public License, then Your rights under this Public License terminate automatically. + + Where Your right to use the Licensed Material has terminated under Section 6(a), it reinstates: + automatically as of the date the violation is cured, provided it is cured within 30 days of Your discovery of the violation; or + upon express reinstatement by the Licensor. + For the avoidance of doubt, this Section 6(b) does not affect any right the Licensor may have to seek remedies for Your violations of this Public License. + For the avoidance of doubt, the Licensor may also offer the Licensed Material under separate terms or conditions or stop distributing the Licensed Material at any time; however, doing so will not terminate this Public License. + Sections 1, 5, 6, 7, and 8 survive termination of this Public License. + +Section 7 – Other Terms and Conditions. + + The Licensor shall not be bound by any additional or different terms or conditions communicated by You unless expressly agreed. + Any arrangements, understandings, or agreements regarding the Licensed Material not stated herein are separate from and independent of the terms and conditions of this Public License. + +Section 8 – Interpretation. + + For the avoidance of doubt, this Public License does not, and shall not be interpreted to, reduce, limit, restrict, or impose conditions on any use of the Licensed Material that could lawfully be made without permission under this Public License. + To the extent possible, if any provision of this Public License is deemed unenforceable, it shall be automatically reformed to the minimum extent necessary to make it enforceable. If the provision cannot be reformed, it shall be severed from this Public License without affecting the enforceability of the remaining terms and conditions. + No term or condition of this Public License will be waived and no failure to comply consented to unless expressly agreed to by the Licensor. + Nothing in this Public License constitutes or may be interpreted as a limitation upon, or waiver of, any privileges and immunities that apply to the Licensor or You, including from the legal processes of any jurisdiction or authority. + diff --git a/mods/industrial_decor/init.lua b/mods/industrial_decor/init.lua new file mode 100644 index 0000000..982de23 --- /dev/null +++ b/mods/industrial_decor/init.lua @@ -0,0 +1,384 @@ +--[[ +Copyright 2018-2021 MCL + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. + +]] + + +minetest.register_node("industrial_decor:planks",{ + description = "Planks", + drawtype = "signlike", + tiles = {"industrial_decor_planks.png"}, + inventory_image = "industrial_decor_planks.png", + wield_image = "industrial_decor_planks.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {choppy = 2}, + selection_box = { + type = "wallmounted", + }, + }) + + minetest.register_node("industrial_decor:planks_destroyed",{ + description = "Destroyed Planks", + drawtype = "signlike", + tiles = {"industrial_decor_planks_destroyed.png"}, + inventory_image = "industrial_decor_planks_destroyed.png", + wield_image = "industrial_decor_planks_destroyed.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = true, + + + groups = {choppy = 3}, + selection_box = { + type = "wallmounted", + }, + }) + +--Lamps +minetest.register_node("industrial_decor:lamp",{ + description = "Industrial Lamp", + drawtype = "plantlike", + tiles = {"industrial_decor_lamp.png"}, + inventory_image = "industrial_decor_lamp.png", + wield_image = "industrial_decor_lamp.png", + light_source = 14, + light_propagates = true, + sunlight_propagates = true, + is_ground_content = false, + walkable = false, + + groups = {cracky = 1}, + selection_box = { + type = "fixed", + fixed = {-6 / 16, -0.5, -6 / 16, 6 / 16, 0.5, 6 / 16}, + }, + + on_punch = function(pos, node, player, pointed_thing) + minetest.set_node({x = pos.x, y = pos.y, z = pos.z}, {name = "industrial_decor:lamp_damaged"}) + end + }) + +--Damaged +minetest.register_node("industrial_decor:lamp_damaged",{ + description = "Damaged Industrial Lamp", + drawtype = "plantlike", + tiles = {"industrial_decor_lamp_damaged.png"}, + inventory_image = "industrial_decor_lamp_damaged.png", + wield_image = "industrial_decor_lamp_damaged.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + is_ground_content = false, + walkable = false, + + groups = {cracky = 2}, + selection_box = { + type = "fixed", + fixed = {-6 / 16, -0.5, -6 / 16, 6 / 16, 0.5, 6 / 16}, + }, + + on_rightclick = function(pos, node, player, pointed_thing) + if player:get_wielded_item():get_name() == "electronics:light_bulb_incandescent" then + minetest.set_node({x = pos.x, y = pos.y, z = pos.z}, {name = "industrial_decor:lamp_bulb"}) + elseif player:get_wielded_item():get_name() == "tapes:ducttape_black" then + minetest.set_node({x = pos.x, y = pos.y, z = pos.z}, {name = "industrial_decor:lamp_tape"}) + end + + end + }) + +--Light Bulb Only +minetest.register_node("industrial_decor:lamp_bulb",{ + description = "Damaged Industrial Lamp with Light Bulb", + drawtype = "plantlike", + tiles = { + { + name = "industrial_decor_lamp_bulb.png", + animation = { + type = "vertical_frames", + aspect_w = 16, + aspect_h = 16, + length = 2.0, + }, + }, + }, + inventory_image = "industrial_decor_lamp_bulb_single.png", + wield_image = "industrial_decor_lamp_bulb_single.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + is_ground_content = false, + walkable = false, + + groups = {cracky = 2}, + selection_box = { + type = "fixed", + fixed = {-6 / 16, -0.5, -6 / 16, 6 / 16, 0.5, 6 / 16}, + }, + + on_rightclick = function(pos, node, player, pointed_thing) + if player:get_wielded_item():get_name() == "tapes:ducttape_black" then + minetest.set_node({x = pos.x, y = pos.y, z = pos.z}, {name = "industrial_decor:lamp_fixed"}) + end + + end + }) + +--Taped +minetest.register_node("industrial_decor:lamp_tape",{ + description = "Industrial Lamp with Duct Tape", + drawtype = "plantlike", + tiles = {"industrial_decor_lamp_tape.png"}, + inventory_image = "industrial_decor_lamp_tape.png", + wield_image = "industrial_decor_lamp_bulb_tape.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + is_ground_content = false, + walkable = false, + + groups = {cracky = 2}, + selection_box = { + type = "fixed", + fixed = {-6 / 16, -0.5, -6 / 16, 6 / 16, 0.5, 6 / 16}, + }, + + on_rightclick = function(pos, node, player, pointed_thing) + if player:get_wielded_item():get_name() == "electronics:light_bulb_incandescent" then + minetest.set_node({x = pos.x, y = pos.y, z = pos.z}, {name = "industrial_decor:lamp_fixed"}) + end + + end + }) + +--Fixed +minetest.register_node("industrial_decor:lamp_fixed",{ + description = "Fixed Industrial Lamp", + drawtype = "plantlike", + tiles = {"industrial_decor_lamp_fixed.png"}, + inventory_image = "industrial_decor_lamp_fixed.png", + wield_image = "industrial_decor_lamp_fixed.png", + light_source = 10, + light_propagates = true, + sunlight_propagates = true, + is_ground_content = false, + walkable = false, + + groups = {cracky = 1}, + selection_box = { + type = "fixed", + fixed = {-6 / 16, -0.5, -6 / 16, 6 / 16, 0.5, 6 / 16}, + }, + + on_punch = function(pos, node, player, pointed_thing) + minetest.set_node({x = pos.x, y = pos.y, z = pos.z}, {name = "industrial_decor:lamp_damaged"}) + end + }) +--End of Lamps + +minetest.register_node("industrial_decor:wires_hanging",{ + description = "Hanging Wires", + drawtype = "plantlike", + tiles = {"industrial_decor_wires_hanging.png"}, + inventory_image = "industrial_decor_wires_hanging.png", + wield_image = "industrial_decor_wires_hanging.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + is_ground_content = false, + walkable = false, + + groups = {snappy = 3}, + selection_box = { + type = "fixed", + fixed = {-6 / 16, -0.5, -6 / 16, 6 / 16, 0.5, 6 / 16}, + }, + }) + +minetest.register_node("industrial_decor:sheet_tin",{ + description = "Industrial Tin Sheet", + tiles = {"industrial_decor_sheet_tin.png"}, + + + groups = {cracky = 1}, + }) + + minetest.register_node("industrial_decor:shelf_empty",{ + paramtype = "light", + description = "Empty Metal Shelf", + tiles = {"industrial_decor_sheet_tin.png", + "industrial_decor_sheet_tin.png", + "industrial_decor_sheet_tin.png", + "industrial_decor_sheet_tin.png", + "industrial_decor_shelf_empty.png",}, + + + groups = {choppy = 2}, + }) + + minetest.register_node("industrial_decor:crate_upsidedown",{ + drawtype = "allfaces_optional", + paramtype = "light", + description = "Food Crate", + tiles = {"industrial_decor_crate_upsidedown.png"}, + + + groups = {choppy = 3}, + }) + +minetest.register_node("industrial_decor:hvdevice_pol",{ + description = "Polish High Voltage Device", + drawtype = "signlike", + tiles = {"industrial_decor_hvdevice_polish.png"}, + inventory_image = "industrial_decor_hvdevice_polish.png", + wield_image = "industrial_decor_hvdevice_polish.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {cracky = 1}, + selection_box = { + type = "wallmounted", + }, + }) + +minetest.register_node("industrial_decor:hvdevice_usa",{ + description = "American High Voltage Device", + drawtype = "signlike", + tiles = {"industrial_decor_hvdevice_american.png"}, + inventory_image = "industrial_decor_hvdevice_american.png", + wield_image = "industrial_decor_hvdevice_american.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {cracky = 1}, + selection_box = { + type = "wallmounted", + }, + }) + + --Hazard signs +minetest.register_node("industrial_decor:hazardsign_generic",{ + description = "Generic Caution Hazard Sign", + drawtype = "signlike", + tiles = {"industrial_decor_hazardsign_generic.png"}, + inventory_image = "industrial_decor_hazardsign_generic.png", + wield_image = "industrial_decor_hazardsign_generic.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {cracky = 1}, + selection_box = { + type = "wallmounted", + }, + }) + +minetest.register_node("industrial_decor:hazardsign_poison",{ + description = "Poison Hazard Sign", + drawtype = "signlike", + tiles = {"industrial_decor_hazardsign_poison.png"}, + inventory_image = "industrial_decor_hazardsign_poison.png", + wield_image = "industrial_decor_hazardsign_poison.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {cracky = 1}, + selection_box = { + type = "wallmounted", + }, + }) + +minetest.register_node("industrial_decor:hazardsign_laser",{ + description = "Laser Hazard Sign", + drawtype = "signlike", + tiles = {"industrial_decor_hazardsign_laser.png"}, + inventory_image = "industrial_decor_hazardsign_laser.png", + wield_image = "industrial_decor_hazardsign_laser.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {cracky = 1}, + selection_box = { + type = "wallmounted", + }, + }) + +minetest.register_node("industrial_decor:hazardsign_radiation_ion",{ + description = "Ionizing Radiation Hazard Sign", + drawtype = "signlike", + tiles = {"industrial_decor_hazardsign_ionradiation.png"}, + inventory_image = "industrial_decor_hazardsignion_ionradiation.png", + wield_image = "industrial_decor_hazardsign_ionradiation.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {cracky = 1}, + selection_box = { + type = "wallmounted", + }, + }) + +minetest.register_node("industrial_decor:hazardsign_radiation_nonion",{ + description = "Non-Ionizing Radiation Hazard Sign", + drawtype = "signlike", + tiles = {"industrial_decor_hazardsign_nonionradiation.png"}, + inventory_image = "industrial_decor_hazardsign_nonionradiation.png", + wield_image = "industrial_decor_hazardsign_nonionradiation.png", + light_propagates = true, + sunlight_propagates = true, + paramtype = "light", + paramtype2 = "wallmounted", + + walkable = false, + + + groups = {cracky = 1}, + selection_box = { + type = "wallmounted", + }, + }) diff --git a/mods/industrial_decor/textures/industrial_decor_crate_upsidedown.png b/mods/industrial_decor/textures/industrial_decor_crate_upsidedown.png new file mode 100644 index 0000000..2a8304b Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_crate_upsidedown.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_desk.png b/mods/industrial_decor/textures/industrial_decor_desk.png new file mode 100644 index 0000000..952778b Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_desk.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_desk_front.png b/mods/industrial_decor/textures/industrial_decor_desk_front.png new file mode 100644 index 0000000..8f47f48 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_desk_front.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_hazardsign_generic.png b/mods/industrial_decor/textures/industrial_decor_hazardsign_generic.png new file mode 100644 index 0000000..2722d60 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_hazardsign_generic.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_hazardsign_ionradiation.png b/mods/industrial_decor/textures/industrial_decor_hazardsign_ionradiation.png new file mode 100644 index 0000000..616f3a8 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_hazardsign_ionradiation.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_hazardsign_laser.png b/mods/industrial_decor/textures/industrial_decor_hazardsign_laser.png new file mode 100644 index 0000000..2dc1bbc Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_hazardsign_laser.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_hazardsign_nonionradiation.png b/mods/industrial_decor/textures/industrial_decor_hazardsign_nonionradiation.png new file mode 100644 index 0000000..0fc27e8 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_hazardsign_nonionradiation.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_hazardsign_poison.png b/mods/industrial_decor/textures/industrial_decor_hazardsign_poison.png new file mode 100644 index 0000000..a1d9c4b Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_hazardsign_poison.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_hvdevice_american.png b/mods/industrial_decor/textures/industrial_decor_hvdevice_american.png new file mode 100644 index 0000000..f4fc06e Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_hvdevice_american.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_hvdevice_polish.png b/mods/industrial_decor/textures/industrial_decor_hvdevice_polish.png new file mode 100644 index 0000000..0d23a06 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_hvdevice_polish.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_lamp.png b/mods/industrial_decor/textures/industrial_decor_lamp.png new file mode 100644 index 0000000..66d4b3b Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_lamp.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_lamp_bulb.png b/mods/industrial_decor/textures/industrial_decor_lamp_bulb.png new file mode 100644 index 0000000..8280139 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_lamp_bulb.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_lamp_bulb_single.png b/mods/industrial_decor/textures/industrial_decor_lamp_bulb_single.png new file mode 100644 index 0000000..90777f5 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_lamp_bulb_single.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_lamp_damaged.png b/mods/industrial_decor/textures/industrial_decor_lamp_damaged.png new file mode 100644 index 0000000..5d4b7a9 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_lamp_damaged.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_lamp_fixed.png b/mods/industrial_decor/textures/industrial_decor_lamp_fixed.png new file mode 100644 index 0000000..713472c Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_lamp_fixed.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_lamp_tape.png b/mods/industrial_decor/textures/industrial_decor_lamp_tape.png new file mode 100644 index 0000000..a043b13 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_lamp_tape.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_planks.png b/mods/industrial_decor/textures/industrial_decor_planks.png new file mode 100644 index 0000000..5b32563 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_planks.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_planks_destroyed.png b/mods/industrial_decor/textures/industrial_decor_planks_destroyed.png new file mode 100644 index 0000000..0c68dfe Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_planks_destroyed.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_sheet_tin.png b/mods/industrial_decor/textures/industrial_decor_sheet_tin.png new file mode 100644 index 0000000..e050ecd Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_sheet_tin.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_shelf_empty.png b/mods/industrial_decor/textures/industrial_decor_shelf_empty.png new file mode 100644 index 0000000..713e28e Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_shelf_empty.png differ diff --git a/mods/industrial_decor/textures/industrial_decor_wires_hanging.png b/mods/industrial_decor/textures/industrial_decor_wires_hanging.png new file mode 100644 index 0000000..de20143 Binary files /dev/null and b/mods/industrial_decor/textures/industrial_decor_wires_hanging.png differ diff --git a/mods/main/craftitems.lua b/mods/main/craftitems.lua new file mode 100644 index 0000000..373abc2 --- /dev/null +++ b/mods/main/craftitems.lua @@ -0,0 +1,76 @@ +--------------- +--------------- +--Craft Items-- +--------------- +--------------- + +--Stick +minetest.register_craftitem("main:stick", { + description = "Stick", + inventory_image = "main_stick.png", +}) + +--Twig +minetest.register_craftitem("main:twig", { + description = "Twig", + inventory_image = "main_twig.png", +}) + + +---------- +--Minerals +---------- + +--Salt Crystals +minetest.register_craftitem("main:salt_crystals", { + description = "Salt Crystals", + inventory_image = "main_salt_crystals.png", +}) + +--Sulfur Lump +minetest.register_craftitem("main:lump_sulfur", { + description = "Sulfur Lump", + inventory_image = "main_lump_sulfur.png", +}) + +--Coal +minetest.register_craftitem("main:coal", { + description = "Coal", + inventory_image = "main_lump_coal.png", +}) + +--Iron Lump +minetest.register_craftitem("main:lump_iron", { + description = "Iron Lump", + inventory_image = "main_lump_iron.png", +}) + +--Copper Lump +minetest.register_craftitem("main:lump_copper", { + description = "Copper Lump", + inventory_image = "main_lump_copper.png", +}) + +--Raw Diamond +minetest.register_craftitem("main:diamond_raw", { + description = "Raw Diamond", + inventory_image = "main_dirt.png", -- Dummy/placeholder texture, will be changed in the future + --inventory_image = "main_diamond_raw.png", +}) + +--Polished Diamond +minetest.register_craftitem("main:diamond_polished", { + description = "Polished Diamond", + inventory_image = "main_dirt.png", -- Dummy/placeholder, will be changed in the future + --inventory_image = "main_diamond_polished.png", +}) +--------- +--Edibles +--------- + +--Strawberry +minetest.register_craftitem("main:berry_straw", { + description = "Strawberry", + tiles = {"main_berry_straw.png"}, + on_use = minetest.item_eat(1), +}) diff --git a/mods/main/init.lua b/mods/main/init.lua new file mode 100644 index 0000000..caf8485 --- /dev/null +++ b/mods/main/init.lua @@ -0,0 +1,11 @@ +local modpath = minetest.get_modpath("main") + +dofile(modpath.."/nodes.lua") +dofile(modpath.."/craftitems.lua") +dofile(modpath.."/mapgen.lua") +dofile(modpath.."/tools.lua") + +minetest.register_on_joinplayer(function(player) + player:hud_set_hotbar_image("gui_hotbar.png") + player:hud_set_hotbar_selected_image("gui_hotbar_selected.png") +end) diff --git a/mods/main/license.txt b/mods/main/license.txt new file mode 100644 index 0000000..a848956 --- /dev/null +++ b/mods/main/license.txt @@ -0,0 +1,7 @@ +Copyright 2019-2021 MCL + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/mods/main/mapgen.lua b/mods/main/mapgen.lua new file mode 100644 index 0000000..fa514b5 --- /dev/null +++ b/mods/main/mapgen.lua @@ -0,0 +1,43 @@ +minetest.register_alias("mapgen_stone", "main:stone") +minetest.register_alias("mapgen_dirt", "main:dirt") +minetest.register_alias("mapgen_dirt_with_grass", "main:grass") +minetest.register_alias("mapgen_sand", "main:sand") +minetest.register_alias("mapgen_water_source", "main:water_source") + + + + +--Beach +minetest.register_biome( + { + name = "Beach", + + node_top = "main:sand", + node_filler = "main:sand", + + depth_top = 1, + depth_filler = 3, + + y_min = -20, + y_max = 32000, + + heat_point = 70, + humidity_point = 55, +}) + + +--Small Rock +minetest.register_decoration( + { + deco_type = "schematic", + place_on = {"main:dirt_with_grass", "main:dirt", "main:sand", "main:dirt_with_swamp_grass"}, + rotation = "random", + sidelen = 16, + fill_ratio = 0.004, + biomes = {"Grasslands", "Swamp", "Desert", "Wasteland"}, + flags = "place_center_x, place_center_z", + schematic = minetest.get_modpath("main") + .. "/schematics/main_rock_cobble_small.mts", + y_min = -32000, + y_max = 32000, +}) diff --git a/mods/main/nodes.lua b/mods/main/nodes.lua new file mode 100644 index 0000000..30cb79b --- /dev/null +++ b/mods/main/nodes.lua @@ -0,0 +1,193 @@ +--Naturally generating nodes +minetest.register_node("main:stone", { + description = "Stone", + tiles = {"main_stone.png"}, + groups = {cracky = 3, stone = 1}, + drop = 'main:cobble', + legacy_mineral = true, +}) + +minetest.register_node("main:cobble", { + description = "Cobble", + tiles = {"main_cobble.png"}, + groups = {cracky = 2, stone = 1}, + drop = 'main:cobble', + legacy_mineral = true, +}) + +minetest.register_node("main:dirt", { + description = "Dirt", + tiles = {"main_dirt.png"}, + groups = {crumbly = 3, soil = 1}, +}) + +minetest.register_node("main:grass", { + description = "Grass", + tiles = {"main_grass.png", "main_dirt.png", + {name = "main_dirt.png^main_grass_side.png", + tileable_vertical = false}}, + groups = {crumbly = 3, soil = 1, spreading_dirt_type = 1}, + drop = 'main:dirt', +}) + + +minetest.register_node("main:sand", { + description = "Sand", + tiles = {"main_sand.png"}, + groups = {crumbly = 3, sand = 1}, +}) + +--Player made nodes +minetest.register_node("main:light", { + description = "Lamp", + tiles = {"main_indsutrial_decor_lamp.png"}, + light_source = 14, + groups = {choppy = 3, oddly_breakable_by_hand = 3}, +}) + + + +--Steel Block +minetest.register_node("main:block_steel", { + description = "Steel Block", + tiles = {"main_block_iron.png"}, + groups = {cracky = 3}, + drop = 'main:block_iron', +}) + +--Gold Block +minetest.register_node("main:block_gold", { + description = "Gold Block", + tiles = {"main_block_gold.png"}, + groups = {cracky = 3}, + drop = 'main:block_gold', +}) + +--Planks +minetest.register_node("main:planks_oak", { + description = "Planks", + tiles = {"main_planks_oak.png"}, + groups = {choppy = 3}, +}) + + +-- +-- Plants and Other Living Organisms +-- + + +--Oak Log +minetest.register_node("main:log", { + description = "Log", + tiles = {"main_log.png"}, + groups = {choppy = 2, logs = 1}, +}) + +--Oak Leaves +minetest.register_node("main:leaves", { + drawtype = "plantlike", + paramtype = "light", + light_propagates = true, + sunlight_propagates = true, + walkable = false, + climbable = true, + is_ground_content = false, + description = "Leaves", + tiles = {"main_leaves.png"}, + groups = {snappy = 3}, +}) + + +-- +-- Liquids +-- + +--Fresh water +minetest.register_node("main:water_source", { + description = "Fresh Water Source", + drawtype = "liquid", + paramtype = "light", + + tiles = { + { + name = "main_water_source_animated.png", + animation = { + type = "vertical_frames", + aspect_w = 16, + aspect_h = 16, + length = 2.0, + }, + }, + }, + alpha = 180, + post_effect_color = {a = 50, r = 0, g = 50, b = 200}, + + --Behavior + walkable = false, + pointable = false, + buildable_to = true, + diggable = false, + is_ground_content = false, + + --Properties + liquid_range = 14, + liquid_viscosity = 0.1, + drowning = 1, + liquidtype = "source", + liquid_alternative_flowing = "main:water_flowing", + liquid_alternative_source = "main:water_source", + groups = {liquid = 3, water = 1}, +}) + +minetest.register_node("main:water_flowing", { + description = "Flowing Water", + drawtype = "flowingliquid", + paramtype = "light", + + tiles = { + { + name = "main_water_flowing_animated.png", + animation = { + type = "vertical_frames", + aspect_w = 16, + aspect_h = 16, + length = 2.0, + }, + }, + }, + + special_tiles = { + { + name = "main_water_flowing_animated.png", + animation = {type = "vertical_frames", aspect_w = 16, + aspect_h = 16, length = 2.0}, + backface_culling = true, + }, + + { + name = "main_water_flowing_animated.png", + animation = {type = "vertical_frames", aspect_w = 16, + aspect_h = 16, length = 2.0}, + backface_culling = false, + } + }, + + alpha = 180, + post_effect_color = {a = 50, r = 0, g = 50, b = 200}, + + --Behavior + walkable = false, + pointable = false, + buildable_to = true, + diggable = false, + is_ground_content = false, + + --Properties + liquid_range = 14, + liquid_viscosity = 0.1, + drowning = 1, + liquidtype = "flowing", + liquid_alternative_flowing = "main:water_flowing", + liquid_alternative_source = "main:water_source", + groups = {liquid = 3, water = 1}, +}) diff --git a/mods/main/schematics/main_rock_cobble_small.mts b/mods/main/schematics/main_rock_cobble_small.mts new file mode 100644 index 0000000..0044421 Binary files /dev/null and b/mods/main/schematics/main_rock_cobble_small.mts differ diff --git a/mods/main/schematics/main_tree_apple.mts b/mods/main/schematics/main_tree_apple.mts new file mode 100644 index 0000000..5f96503 Binary files /dev/null and b/mods/main/schematics/main_tree_apple.mts differ diff --git a/mods/main/schematics/main_tree_oak.mts b/mods/main/schematics/main_tree_oak.mts new file mode 100644 index 0000000..66c213f Binary files /dev/null and b/mods/main/schematics/main_tree_oak.mts differ diff --git a/mods/main/schematics/main_tree_oak_tall.mts b/mods/main/schematics/main_tree_oak_tall.mts new file mode 100644 index 0000000..4146aa4 Binary files /dev/null and b/mods/main/schematics/main_tree_oak_tall.mts differ diff --git a/mods/main/schematics/main_tree_oak_tall_dead.mts b/mods/main/schematics/main_tree_oak_tall_dead.mts new file mode 100644 index 0000000..168b292 Binary files /dev/null and b/mods/main/schematics/main_tree_oak_tall_dead.mts differ diff --git a/mods/main/textures/bubble.png b/mods/main/textures/bubble.png new file mode 100644 index 0000000..f45f3f7 Binary files /dev/null and b/mods/main/textures/bubble.png differ diff --git a/mods/main/textures/character.png b/mods/main/textures/character.png new file mode 100644 index 0000000..f853d49 Binary files /dev/null and b/mods/main/textures/character.png differ diff --git a/mods/main/textures/character_jackie.png b/mods/main/textures/character_jackie.png new file mode 100644 index 0000000..902d775 Binary files /dev/null and b/mods/main/textures/character_jackie.png differ diff --git a/mods/main/textures/crack_anylength.png b/mods/main/textures/crack_anylength.png new file mode 100644 index 0000000..ab8d5b3 Binary files /dev/null and b/mods/main/textures/crack_anylength.png differ diff --git a/mods/main/textures/gui_hotbar.png b/mods/main/textures/gui_hotbar.png new file mode 100644 index 0000000..4133e44 Binary files /dev/null and b/mods/main/textures/gui_hotbar.png differ diff --git a/mods/main/textures/gui_hotbar_selected.png b/mods/main/textures/gui_hotbar_selected.png new file mode 100644 index 0000000..0e678a6 Binary files /dev/null and b/mods/main/textures/gui_hotbar_selected.png differ diff --git a/mods/main/textures/hand.png b/mods/main/textures/hand.png new file mode 100644 index 0000000..08cba58 Binary files /dev/null and b/mods/main/textures/hand.png differ diff --git a/mods/main/textures/heart.png b/mods/main/textures/heart.png new file mode 100644 index 0000000..b2cfb21 Binary files /dev/null and b/mods/main/textures/heart.png differ diff --git a/mods/main/textures/leaves_grey.png b/mods/main/textures/leaves_grey.png new file mode 100644 index 0000000..5055ca5 Binary files /dev/null and b/mods/main/textures/leaves_grey.png differ diff --git a/mods/main/textures/main_beans.png b/mods/main/textures/main_beans.png new file mode 100644 index 0000000..41c464e Binary files /dev/null and b/mods/main/textures/main_beans.png differ diff --git a/mods/main/textures/main_block_copper.png b/mods/main/textures/main_block_copper.png new file mode 100644 index 0000000..ed6e99b Binary files /dev/null and b/mods/main/textures/main_block_copper.png differ diff --git a/mods/main/textures/main_block_gold.png b/mods/main/textures/main_block_gold.png new file mode 100644 index 0000000..ca5853b Binary files /dev/null and b/mods/main/textures/main_block_gold.png differ diff --git a/mods/main/textures/main_block_iron.png b/mods/main/textures/main_block_iron.png new file mode 100644 index 0000000..e3e6e84 Binary files /dev/null and b/mods/main/textures/main_block_iron.png differ diff --git a/mods/main/textures/main_cobble.png b/mods/main/textures/main_cobble.png new file mode 100644 index 0000000..0faee33 Binary files /dev/null and b/mods/main/textures/main_cobble.png differ diff --git a/mods/main/textures/main_dirt.png b/mods/main/textures/main_dirt.png new file mode 100644 index 0000000..add9bbe Binary files /dev/null and b/mods/main/textures/main_dirt.png differ diff --git a/mods/main/textures/main_grass.png b/mods/main/textures/main_grass.png new file mode 100644 index 0000000..e2c51af Binary files /dev/null and b/mods/main/textures/main_grass.png differ diff --git a/mods/main/textures/main_grass_side.png b/mods/main/textures/main_grass_side.png new file mode 100644 index 0000000..6932c3b Binary files /dev/null and b/mods/main/textures/main_grass_side.png differ diff --git a/mods/main/textures/main_ice_thick.png b/mods/main/textures/main_ice_thick.png new file mode 100644 index 0000000..f2db28c Binary files /dev/null and b/mods/main/textures/main_ice_thick.png differ diff --git a/mods/main/textures/main_ice_thin.png b/mods/main/textures/main_ice_thin.png new file mode 100644 index 0000000..e6b9fec Binary files /dev/null and b/mods/main/textures/main_ice_thin.png differ diff --git a/mods/main/textures/main_leaves.png b/mods/main/textures/main_leaves.png new file mode 100644 index 0000000..24452ea Binary files /dev/null and b/mods/main/textures/main_leaves.png differ diff --git a/mods/main/textures/main_log.png b/mods/main/textures/main_log.png new file mode 100644 index 0000000..3f2a2ca Binary files /dev/null and b/mods/main/textures/main_log.png differ diff --git a/mods/main/textures/main_pickaxe_steel.png b/mods/main/textures/main_pickaxe_steel.png new file mode 100644 index 0000000..adf8fae Binary files /dev/null and b/mods/main/textures/main_pickaxe_steel.png differ diff --git a/mods/main/textures/main_planks_oak.png b/mods/main/textures/main_planks_oak.png new file mode 100644 index 0000000..8639a83 Binary files /dev/null and b/mods/main/textures/main_planks_oak.png differ diff --git a/mods/main/textures/main_sand.png b/mods/main/textures/main_sand.png new file mode 100644 index 0000000..1e753f0 Binary files /dev/null and b/mods/main/textures/main_sand.png differ diff --git a/mods/main/textures/main_stone.png b/mods/main/textures/main_stone.png new file mode 100644 index 0000000..c5abe94 Binary files /dev/null and b/mods/main/textures/main_stone.png differ diff --git a/mods/main/textures/main_water.png b/mods/main/textures/main_water.png new file mode 100644 index 0000000..300b8a2 Binary files /dev/null and b/mods/main/textures/main_water.png differ diff --git a/mods/main/textures/main_water_flowing_animated.png b/mods/main/textures/main_water_flowing_animated.png new file mode 100644 index 0000000..f1c52f5 Binary files /dev/null and b/mods/main/textures/main_water_flowing_animated.png differ diff --git a/mods/main/textures/main_water_source_animated.png b/mods/main/textures/main_water_source_animated.png new file mode 100644 index 0000000..f1c52f5 Binary files /dev/null and b/mods/main/textures/main_water_source_animated.png differ diff --git a/mods/main/textures/player.png b/mods/main/textures/player.png new file mode 100644 index 0000000..39a31c1 Binary files /dev/null and b/mods/main/textures/player.png differ diff --git a/mods/main/textures/player_back.png b/mods/main/textures/player_back.png new file mode 100644 index 0000000..ea08a33 Binary files /dev/null and b/mods/main/textures/player_back.png differ diff --git a/mods/main/tools.lua b/mods/main/tools.lua new file mode 100644 index 0000000..0f47c56 --- /dev/null +++ b/mods/main/tools.lua @@ -0,0 +1,74 @@ +minetest.register_item(":", +{ + type = "none", + wield_image = "hand.png", + wield_scale = {x=1,y=1,z=3.5}, + tool_capabilities = + { + max_drop_level = 0, + full_punch_interval = 0.4, + + groupcaps = + { + oddly_breakable_by_hand = {times={[1]=3.50,[2]=2.00,[3]=0.70}, uses=0}, + snappy = {times={[3]=1.00}, uses=0, maxlevel=1}, + crumbly = {times={[2]=4.50, [3]=1.80}, uses=0, maxlevel=1}, + }, + damage_groups = {fleshy = 3, snappy = 2}, + } +}) + +minetest.register_item("main:pickaxe_steel", +{ + type = "none", + wield_image = "main_pickaxe_steel.png", + inventory_image = "main_pickaxe_steel.png", + tool_capabilities = + { + max_drop_level = 1, + full_punch_interval = 0.8, + + groupcaps = + { + cracky = {times={[1]=1.80, [2]=1.00,[3]=0.50}, uses=0, maxlevel=1}, + crumbly = {times={[2]=2.50, [3]=0.80}, uses=0, maxlevel=1}, + }, + damage_groups = {fleshy = 5, cracky = 8}, + } +}) + +minetest.register_item("main:pickaxe_stone", +{ + type = "none", + wield_image = "main_pickaxe_stone.png", + tool_capabilities = + { + max_drop_level = 1, + full_punch_interval = 0.8, + + groupcaps = + { + cracky = {times={[1]=3.80, [2]=2.00,[3]=1.50}, uses=0, maxlevel=1}, + crumbly = {times={[2]=3.50, [3]=1.80}, uses=0, maxlevel=1}, + }, + damage_groups = {fleshy = 4, cracky = 5}, + } +}) + +minetest.register_item("main:ax_steel", +{ + type = "none", + wield_image = "main_pickaxe_stone.png", + tool_capabilities = + { + max_drop_level = 1, + full_punch_interval = 0.4, + + groupcaps = + { + choppy = {times={[1]=3.80, [2]=2.00,[3]=1.50}, uses=0, maxlevel=1}, + crumbly = {times={[2]=3.50, [3]=1.80}, uses=0, maxlevel=1}, + }, + damage_groups = {fleshy = 4, cracky = 8}, + } +}) diff --git a/mods/rangedweapons/aa12.lua b/mods/rangedweapons/aa12.lua new file mode 100644 index 0000000..71b1206 --- /dev/null +++ b/mods/rangedweapons/aa12.lua @@ -0,0 +1,75 @@ + + +minetest.register_tool("rangedweapons:aa12_r", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.4}, + description = "", + rw_next_reload = "rangedweapons:aa12_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_aa12_rld.png", +}) +minetest.register_tool("rangedweapons:aa12_rr", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.4}, + description = "", + rw_next_reload = "rangedweapons:aa12_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_aa12.png", +}) +minetest.register_tool("rangedweapons:aa12_rrr", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.4}, + description = "", + rw_next_reload = "rangedweapons:aa12", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_aa12.png", +}) +------------------------------------------- + + minetest.register_tool("rangedweapons:aa12", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.4}, + description = "" ..core.colorize("#35cdff","AA-12\n") ..core.colorize("#FFFFFF", "Ranged damage: 1\n") ..core.colorize("#FFFFFF", "projectiles: 5\n") ..core.colorize("#FFFFFF", "Gun gravity: 4\n") ..core.colorize("#FFFFFF", "accuracy: 40%\n") ..core.colorize("#FFFFFF", "knockback: 5\n") ..core.colorize("#FFFFFF", "Reload delay: 1.5\n") ..core.colorize("#FFFFFF", "Clip size: 20\n") ..core.colorize("#FFFFFF", "Critical chance: 5%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shell\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.2 (full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + range = 0, + inventory_image = "rangedweapons_aa12.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=1,knockback=5}, + gun_crit = 5, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:shell",20}}, + gun_skill = {"shotgun_skill",40}, + gun_magazine = "rangedweapons:drum_mag", + gun_icon = "rangedweapons_aa12_icon.png", + gun_unloaded = "rangedweapons:aa12_r", + gun_velocity = 25, + gun_accuracy = 40, + gun_cooldown = 0.2, + gun_reload = 1.5/4, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 750, + gun_smokeSize = 8, + gun_door_breaking = 1, + gun_projectiles = 5, + gun_gravity = 4, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_shotgun_shot", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) + + + + + + diff --git a/mods/rangedweapons/ak47.lua b/mods/rangedweapons/ak47.lua new file mode 100644 index 0000000..9ee58e8 --- /dev/null +++ b/mods/rangedweapons/ak47.lua @@ -0,0 +1,76 @@ + + +minetest.register_tool("rangedweapons:ak47_r", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:ak47_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_ak47_rld.png", +}) + +minetest.register_tool("rangedweapons:ak47_rr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:ak47_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_ak47.png", +}) + +minetest.register_tool("rangedweapons:ak47_rrr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:ak47", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_ak47.png", +}) + + + minetest.register_tool("rangedweapons:ak47", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "" ..core.colorize("#35cdff","AK-47\n") ..core.colorize("#FFFFFF", "Gun damage: 7\n") ..core.colorize("#FFFFFF", "accuracy: 77%\n") ..core.colorize("#FFFFFF", "Gun knockback: 5\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 12%\n")..core.colorize("#FFFFFF", "Critical efficiency: 2.9x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.4\n") ..core.colorize("#FFFFFF", "Clip size: 30\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.10(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: assault rifle\n") ..core.colorize("#FFFFFF", "Block penetration: 5%\n") +..core.colorize("#FFFFFF", "Enemy penetration: 15%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 40"), + range = 0, + inventory_image = "rangedweapons_ak47.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=7,knockback=5}, + gun_crit = 12, + gun_critEffc = 2.9, + suitable_ammo = {{"rangedweapons:762mm",30}}, + gun_skill = {"arifle_skill",50}, + gun_magazine = "rangedweapons:assaultrifle_mag", + gun_icon = "rangedweapons_ak47_icon.png", + gun_unloaded = "rangedweapons:ak47_r", + gun_velocity = 40, + gun_accuracy = 77, + gun_cooldown = 0.1, + gun_reload = 1.4/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1200, + gun_smokeSize = 5, + gun_mob_penetration = 15, + gun_node_penetration = 5, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_ak", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + + inventory_image = "rangedweapons_ak47.png", +}) + + diff --git a/mods/rangedweapons/ammo.lua b/mods/rangedweapons/ammo.lua new file mode 100644 index 0000000..abd66ec --- /dev/null +++ b/mods/rangedweapons/ammo.lua @@ -0,0 +1,778 @@ +forbidden_ents = { +"", +} + + +minetest.register_alias("rangedweapons:726mm", "rangedweapons:762mm") + +bullet_particles = bullet_particles or "rangedweapons_bullet_fly.png" + + +minetest.register_craftitem("rangedweapons:shot_bullet_visual", { + wield_scale = {x=1.0,y=1.0,z=1.0}, + inventory_image = "rangedweapons_bulletshot.png", +}) + + +local rangedweapons_shot_bullet = { + timer = 0, +initial_properties = { + physical = true, + hp_max = 420, + glow = 100, + visual = "wielditem", + visual_size = {x=0.75, y=0.75}, + textures = {"rangedweapons:shot_bullet_visual"}, + lastpos = {}, + collide_with_objects = false, + collisionbox = {-0.0025, -0.0025, -0.0025, 0.0025, 0.0025, 0.0025}, +}, +} +rangedweapons_shot_bullet.on_step = function(self, dtime, moveresult) +---------------------------------------- +--------------------------------------- + +if self.owner == nil then +self.object:remove() +end + +local sparks = self.sparks or 0 +local ignite = self.ignite or 0 +local size = self.size or 0.0025 + +local SBP = self.bullet_particles +if SBP ~= nil then +for i=1,math.random(SBP.amount[1],SBP.amount[2]) do + minetest.add_particle({ + pos = {x=self.object:get_pos().x+(math.random(-SBP.pos_randomness,SBP.pos_randomness)/100),y=self.object:get_pos().y+(math.random(-SBP.pos_randomness,SBP.pos_randomness)/100),z=self.object:get_pos().z+(math.random(-SBP.pos_randomness,SBP.pos_randomness)/100)}, + velocity = {x=math.random(-SBP.velocity.x,SBP.velocity.x), y=math.random(-SBP.velocity.y,SBP.velocity.y), z=math.random(-SBP.velocity.z,SBP.velocity.z)}, + acceleration = {x=math.random(-SBP.acceleration.x,SBP.acceleration.x), y=math.random(-SBP.acceleration.y,SBP.acceleration.y)-SBP.gravity, z=math.random(-SBP.acceleration.z,SBP.acceleration.z)}, + expirationtime = SBP.lifetime, + size = math.random(SBP.minsize,SBP.maxsize)/10, + collisiondetection = SBP.collisiondetection, + vertical = false, + texture = SBP.texture, + animation = {type="vertical_frames", aspect_w=8, aspect_h=8, length = SBP.lifetime+0.1,}, + glow = SBP.glow, + }) +end end + + +self.timer = self.timer + dtime + +if self.timer > 0.06 then +self.object:set_properties({collide_with_objects = true}) +self.object:set_properties({collisionbox = {-size, -size, -size, size, size, size}}) +end + +if self.timer > 10 then +self.object:remove() +end + +if moveresult.collides == true then +if moveresult.collisions[1] ~= nil then + +local mobPen = self.mobPen or 0 +local nodePen = self.nodePen or 0 +local door_break = self.door_break or 0 +local glass_break = self.glass_break or 0 + +if moveresult.collisions[1].type == "node" then + +minetest.check_for_falling(moveresult.collisions[1].node_pos) + + +if minetest.registered_nodes[minetest.get_node(moveresult.collisions[1].node_pos).name] and +minetest.registered_nodes[minetest.get_node(moveresult.collisions[1].node_pos).name].tiles and +minetest.registered_nodes[minetest.get_node(moveresult.collisions[1].node_pos).name].tiles[1] +then + +local hit_texture = minetest.registered_nodes[minetest.get_node(moveresult.collisions[1].node_pos).name].tiles[1] + +if hit_texture.name ~= nil then +hit_texture = hit_texture.name +end + + minetest.add_particle({ + pos = self.object:get_pos(), + velocity = {x=0, y=0, z=0}, + acceleration = {x=0, y=0, z=0}, + expirationtime = 30, + size = math.random(10,20)/10, + collisiondetection = false, + vertical = false, + texture = "rangedweapons_bullethole.png", + glow = 0, + }) + + for i=1,math.random(4,8) do + minetest.add_particle({ + pos = self.object:get_pos(), + velocity = {x=math.random(-3.0,3.0), y=math.random(2.0,5.0), z=math.random(-3.0,3.0)}, + acceleration = {x=math.random(-3.0,3.0), y=math.random(-10.0,-15.0), z=math.random(-3.0,3.0)}, + expirationtime = 0.5, + size = math.random(10,20)/10, + collisiondetection = true, + vertical = false, + texture = ""..hit_texture.."^[resize:4x4".."", + glow = 0, + }) + end + +end + + +minetest.sound_play("default_dig_cracky", {self.object:get_pos(), gain = 1.0}) + +if ignite > 0 then + +if minetest.get_node(moveresult.collisions[1].node_pos).name == "rangedweapons:barrel" then +minetest.swap_node(moveresult.collisions[1].node_pos, {name = "air"}) +tnt.boom(moveresult.collisions[1].node_pos, {radius = 3}) +end + +if minetest.get_node(moveresult.collisions[1].node_pos).name == "tnt:tnt" then +minetest.swap_node(moveresult.collisions[1].node_pos, {name = "tnt:tnt_burning"}) + minetest.sound_play("tnt_ignite", {moveresult.collisions[1].node_pos}, true) + minetest.get_node_timer(moveresult.collisions[1].node_pos):start(3) + minetest.check_for_falling(moveresult.collisions[1].node_pos) +end + +end + + +if rweapons_door_breaking == "true" and door_break > 0 then +if string.find(minetest.get_node(moveresult.collisions[1].node_pos).name,"door_wood") then + +minetest.swap_node(moveresult.collisions[1].node_pos, {name = "air"}) +minetest.add_item(moveresult.collisions[1].node_pos, "default:wood 5") +minetest.sound_play("rangedweapons_woodbreak",{moveresult.collisions[1].node_pos}) + +end end + +if rweapons_glass_breaking == "true" and glass_break > 0 then + +local nodeName = minetest.get_node(moveresult.collisions[1].node_pos).name + + if nodeName == "default:glass" then + minetest.swap_node(moveresult.collisions[1].node_pos, {name = "rangedweapons:broken_glass"}) +minetest.sound_play("glass_break",{moveresult.collisions[1].node_pos}) + end + if nodeName == "xpanes:pane" or + nodeName == "xpanes:pane_flat" then +minetest.swap_node(moveresult.collisions[1].node_pos, {name = "air"}) +minetest.add_item(moveresult.collisions[1].node_pos, "rangedweapons:glass_shards") +minetest.sound_play("glass_break",{moveresult.collisions[1].node_pos}) + end +if string.find(nodeName,"door_glass") then +minetest.swap_node(moveresult.collisions[1].node_pos, {name = "air"}) +minetest.add_item(moveresult.collisions[1].node_pos, "vessels:glass_fragments 5") +minetest.sound_play("glass_break",{moveresult.collisions[1].node_pos}) + end +end + + +if minetest.get_item_group(minetest.get_node(moveresult.collisions[1].node_pos).name, "level") > 1 then +self.object:set_velocity(moveresult.collisions[1].old_velocity) + +if sparks > 0 then +make_sparks(self.object:get_pos()) +end + +local objVel = moveresult.collisions[1].old_velocity +local objRot = self.object:get_rotation() + +if objRot and objVel then +if moveresult.collisions[1].axis == "x" then +self.object:set_rotation({x=0,y=objRot.y,z=objRot.z+3}) +self.object:set_velocity({x=objVel.x*-1,y=objVel.y,z=objVel.z}) +end + +if moveresult.collisions[1].axis == "z" then +self.object:set_rotation({x=0,y=objRot.y,z=objRot.z+3}) +self.object:set_velocity({x=objVel.x,y=objVel.y,z=objVel.z*-1}) +end + +if moveresult.collisions[1].axis == "y" then +self.object:set_rotation({x=0,y=objRot.y+3,z=objRot.z+3}) +self.object:set_velocity({x=objVel.x,y=objVel.y*-1,z=objVel.z}) +end end + + +else + +if math.random(1,100) <= nodePen then + for i=1,10 do + minetest.add_particle({ + pos = self.object:get_pos(), + velocity = {x=1.5, y=1.5, z=1.5} , + acceleration = {x=math.random(-3.0,3.0), y=math.random(-4.0,4.0), z=math.random(-3.0,3.0)}, + expirationtime = 1.25, + size = math.random(3,6), + collisiondetection = false, + vertical = false, + texture = "tnt_smoke.png", + glow = 2, + }) + end +minetest.sound_play("default_dig_cracky", {self.object:get_pos(), gain = 1.0}) +self.object:set_properties({collisionbox = {0,0,0,0,0,0}}) +--minetest.chat_send_all("hit") +self.object:set_velocity(moveresult.collisions[1].old_velocity) +else + +if minetest.get_item_group(minetest.get_node(moveresult.collisions[1].node_pos).name, "leaves") > 0 then + +minetest.sound_play("default_dig_snappy", {self.object:get_pos(), gain = 1.5}) + +for i = 1,math.random(3,6) do + minetest.add_particle({ + pos = self.object:get_pos(), + velocity = {x=math.random(-2,2), y=math.random(3,6), z=math.random(-2,2)}, + acceleration = {x=math.random(-2,2), y=math.random(-3,-6), z=math.random(-2,2)}, + expirationtime = math.random(2,4), + size = math.random(6,9), + collisiondetection = true, + collision_removal = false, + vertical = false, + texture = "rangedweapons_leaf.png", + animation = {type="vertical_frames", aspect_w=8, aspect_h=8, length = 0.8,}, + glow = 15, + }) +end + +self.object:set_properties({collisionbox = {0,0,0,0,0,0}}) +self.object:set_velocity(moveresult.collisions[1].old_velocity) + +else +if self.OnCollision ~= nil then +self.OnCollision(self.owner,self,moveresult.collisions[1]) +end +self.object:remove() +end +end +end + +end + +if moveresult.collisions[1].type == "object" then + + +local actualDamage = self.damage or {fleshy=1} +local damage = {} +local crit = self.crit or 0 +local critEffc = self.critEffc or 1 +local owner = minetest.get_player_by_name(self.owner) +local hit_texture = "rangedweapons_hit.png" +local dps = self.dps or 0 +local skill = self.skill_value or 1 + +for _, dmg in pairs(actualDamage) do +damage[_] = actualDamage[_] +end + +if moveresult.collisions[1].object:is_player() then +for _, player_dmg in pairs(damage) do +damage[_] = damage[_] * rweapons_player_dmg_multiplier +end +if self.object:get_pos().y - moveresult.collisions[1].object:get_pos().y > 1.5 then +for _, hs_dmg in pairs(damage) do +damage[_] = damage[_] * rweapons_headshot_dmg_multiplier +end +end +knockback = damage.knockback or 0 +projectile_kb(moveresult.collisions[1].object,self.object,knockback) +else +for _, mob_dmg in pairs(damage) do +damage[_] = damage[_] * rweapons_mob_dmg_multiplier +end +end + +for _, bonus_dmg in pairs(damage) do +damage[_] = (damage[_]*skill) + (self.dps*self.timer) +end + +--minetest.chat_send_all(critEffc) +if math.random(1,100) <= crit+((skill*10)-10) then +for _, critDmg in pairs(damage) do +damage[_] = damage[_] * critEffc +end + + +entpos = self.object:get_pos() +minetest.add_particle ({ +pos = entpos, velocity = 0, acceleration = {x=0, y=5, z=0}, +expirationtime = 0.75, size = 12, collisiondetection = false, +vertical = false, texture = "rangedweapons_crit.png", glow = 30,}) +hit_texture = "rangedweapons_crithit.png" +end + +moveresult.collisions[1].object:punch(owner, 1.0, { + full_punch_interval = 1.0, + damage_groups = damage,}, nil) +owner:hud_change(hit, "text", hit_texture) + + for i=1,math.random(math.ceil(rweapons_bloodyness*0.66),math.ceil(rweapons_bloodyness*1.5)) do + minetest.add_particle({ + pos = self.object:get_pos(), + velocity = {x=math.random(-15.0,15.0)/10, y=math.random(2.0,5.0), z=math.random(-15.0,15.0)/10}, + acceleration = {x=math.random(-3.0,3.0), y=math.random(-10.0,-15.0), z=math.random(-3.0,3.0)}, + expirationtime = 0.75, + size = math.random(10,20)/10, + collisiondetection = true, + vertical = false, + texture = "rangedweapons_blood.png", + animation = {type="vertical_frames", aspect_w=8, aspect_h=8, length = 0.8,}, + glow = 0, + }) + end + + +if math.random(1,100) <= mobPen then + for i=1,10 do + minetest.add_particle({ + pos = self.object:get_pos(), + velocity = {x=1.5, y=1.5, z=1.5} , + acceleration = {x=math.random(-3.0,3.0), y=math.random(-4.0,4.0), z=math.random(-3.0,3.0)}, + expirationtime = 1.25, + size = math.random(3,6), + collisiondetection = false, + vertical = false, + texture = "tnt_smoke.png", + glow = 2, + }) + end +minetest.sound_play("default_dig_cracky", {self.object:get_pos(), gain = 1.0}) +self.object:set_properties({collisionbox = {0,0,0,0,0,0}}) +self.object:set_velocity(moveresult.collisions[1].old_velocity) +else +if self.OnCollision ~= nil then +self.OnCollision(self.owner,self,moveresult.collisions[1]) +end +self.object:remove() +end +end + + +else + +self.object:remove() + +end +end + +end + +minetest.register_entity("rangedweapons:shot_bullet", rangedweapons_shot_bullet) + + + +--- +--- actual mags +--- + +--- +--- visual drop mags +--- + +minetest.register_craftitem("rangedweapons:drum_mag", { + wield_scale = {x=1.0,y=1.0,z=1.5}, + inventory_image = "rangedweapons_drum_mag.png", +}) + +minetest.register_craftitem("rangedweapons:handgun_mag_black", { + wield_scale = {x=0.6,y=0.6,z=0.8}, + inventory_image = "rangedweapons_magazine_handgun.png", +}) +local rangedweapons_mag = { + physical = false, + timer = 0, + visual = "wielditem", + visual_size = {x=0.3, y=0.3}, + textures = {"rangedweapons:handgun_mag_black"}, + lastpos= {}, + collisionbox = {0, 0, 0, 0, 0, 0}, +} +rangedweapons_mag.on_step = function(self, dtime, pos) + self.timer = self.timer + dtime + local pos = self.object:get_pos() + local node = minetest.get_node(pos) + if self.lastpos.y ~= nil then + if minetest.registered_nodes[node.name] ~= nil then + if minetest.registered_nodes[node.name].walkable then + local vel = self.object:get_velocity() + local acc = self.object:get_acceleration() + self.object:set_velocity({x=0, y=0, z=0}) + self.object:set_acceleration({x=0, y=0, z=0}) + end end + end + if self.timer > 2.0 then + self.object:remove() + + end + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} +end + +minetest.register_entity("rangedweapons:mag", rangedweapons_mag) + +minetest.register_craftitem("rangedweapons:handgun_mag_white", { + wield_scale = {x=0.6,y=0.6,z=0.8}, + inventory_image = "rangedweapons_handgun_mag_white.png", +}) + +minetest.register_craftitem("rangedweapons:machinepistol_mag", { + wield_scale = {x=0.6,y=0.6,z=0.8}, + inventory_image = "rangedweapons_machinepistol_mag.png", +}) + +minetest.register_craftitem("rangedweapons:assaultrifle_mag", { + wield_scale = {x=0.6,y=0.6,z=0.8}, + inventory_image = "rangedweapons_assaultrifle_mag.png", +}) + +minetest.register_craftitem("rangedweapons:rifle_mag", { + wield_scale = {x=0.6,y=0.6,z=0.8}, + inventory_image = "rangedweapons_rifle_mag.png", +}) + +minetest.register_craftitem("rangedweapons:9mm", { + stack_max= 500, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff","9x19mm Parabellum\n")..core.colorize("#FFFFFF", "Bullet damage: 1 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.25 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 1% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 25 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 1 \n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_9mm.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=1,knockback=1}, + ammo_critEffc = 0.25, + ammo_crit = 1, + ammo_velocity = 25, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + } +}) +minetest.register_craftitem("rangedweapons:45acp", { + stack_max= 450, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff",".45ACP catridge\n")..core.colorize("#FFFFFF", "Bullet damage: 2 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.50 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 2% \n") +..core.colorize("#FFFFFF", "Bullet velocity: 20 \n") +..core.colorize("#FFFFFF", "Bullet knockback: 2 \n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_45acp.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=2,knockback=1}, + ammo_critEffc = 0.50, + ammo_crit = 1, + ammo_velocity = 20, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + }, +}) +minetest.register_craftitem("rangedweapons:10mm", { + stack_max= 400, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff","10mm Auto\n")..core.colorize("#FFFFFF", "Bullet damage: 2 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency:0.30 \n") ..core.colorize("#FFFFFF", "Bullet velocity: 25 \n") +..core.colorize("#FFFFFF", "Bullet knockback: 1 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 1% \n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_10mm.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=2,knockback=1}, + ammo_critEffc = 0.3, + ammo_crit = 1, + ammo_velocity = 25, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shell_whitedrop", + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + } +}) + + +minetest.register_craftitem("rangedweapons:357", { + stack_max= 150, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff",".357 magnum round\n")..core.colorize("#FFFFFF", "Bullet damage: 4 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.6 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 3% \n") ..core.colorize("#FFFFFF", "Bullet knockback: 5 \n") ..core.colorize("#FFFFFF", "Bullet enemy Penetration: 5%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 45 \n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_357.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=4,knockback=5}, + ammo_critEffc = 0.6, + ammo_crit = 3, + ammo_velocity = 45, + ammo_glass_breaking = 1, + ammo_mob_penetration = 5, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + } +}) + +minetest.register_craftitem("rangedweapons:50ae", { + stack_max= 100, + wield_scale = {x=0.6,y=0.6,z=1.5}, + description = "" ..core.colorize("#35cdff",".50AE catridge\n")..core.colorize("#FFFFFF", "Bullet damage: 8 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.9 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 6% \n") ..core.colorize("#FFFFFF", "Bullet knockback: 10 \n") ..core.colorize("#FFFFFF", "Bullet enemy Penetration: 15%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 55 \n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_50ae.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=8,knockback=10}, + ammo_critEffc = 0.9, + ammo_crit = 6, + ammo_velocity = 55, + ammo_glass_breaking = 1, + ammo_mob_penetration = 15, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + } +}) + +minetest.register_craftitem("rangedweapons:44", { + stack_max= 150, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff",".44 magnum round\n")..core.colorize("#FFFFFF", "Bullet damage: 4 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.7 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 4% \n") ..core.colorize("#FFFFFF", "Bullet knockback: 6 \n") ..core.colorize("#FFFFFF", "Bullet enemy Penetration: 6%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 50 \n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_44.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=4,knockback=6}, + ammo_critEffc = 0.7, + ammo_crit = 4, + ammo_velocity = 50, + ammo_glass_breaking = 1, + ammo_mob_penetration = 6, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + } +}) +minetest.register_craftitem("rangedweapons:762mm", { + stack_max= 250, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff","7.62mm round\n")..core.colorize("#FFFFFF", "Bullet damage: 4 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.5 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 2% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 40 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 4 \n") ..core.colorize("#FFFFFF", "Bullet enemy Penetration: 5%\n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_762mm.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=4,knockback=4}, + ammo_critEffc = 0.5, + ammo_crit = 2, + ammo_velocity = 40, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_mob_penetration = 5, + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + }, +}) +minetest.register_craftitem("rangedweapons:556mm", { + stack_max= 300, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff","5.56mm round\n")..core.colorize("#FFFFFF", "Bullet damage: 3 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.4 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 2% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 35 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 3 \n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_556mm.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=3,knockback=3}, + ammo_critEffc = 0.4, + ammo_crit = 2, + ammo_velocity = 35, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_projectile_size = 0.0025, + has_sparks = 1, + ignites_explosives = 1, + }, +}) +minetest.register_craftitem("rangedweapons:shell", { + stack_max= 50, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff","12 Gauge shell\n")..core.colorize("#FFFFFF", "Bullet damage: 2 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.15 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 1% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 20 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 4 \n") ..core.colorize("#FFFFFF", "Bullet gravity: 5 \n") ..core.colorize("#FFFFFF", "Bullet projectile multiplier: 1.5x\n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_shell.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=2,knockback=4}, + ammo_projectile_multiplier = 1.5, + ammo_critEffc = 0.15, + ammo_crit = 1, + ammo_velocity = 20, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "sprite", + ammo_texture = "rangedweapons_buckball.png", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shell_shotgundrop", + ammo_gravity = 5, + ammo_projectile_size = 0.00175, + ammo_projectile_glow = 0, + has_sparks = 1, + ignites_explosives = 1, + }, +}) +minetest.register_craftitem("rangedweapons:308winchester", { + stack_max= 75, + wield_scale = {x=0.4,y=0.4,z=1.2}, + description = "" ..core.colorize("#35cdff",".308 winchester round\n")..core.colorize("#FFFFFF", "Bullet damage: 8 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.75 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 4% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 60 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 10 \n") ..core.colorize("#FFFFFF", "Damage gain over 1 sec of flight time: 40 \n") ..core.colorize("#FFFFFF", "Bullet enemy Penetration: 20%\n") ..core.colorize("#FFFFFF", "Bullet node Penetration: 10%\n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_308winchester.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=8,knockback=10}, + ammo_critEffc = 0.75, + ammo_crit = 2, + ammo_velocity = 60, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_mob_penetration = 20, + ammo_node_penetration = 10, + ammo_projectile_size = 0.0025, + ammo_dps = 40, + has_sparks = 1, + ignites_explosives = 1, + }, +}) + +minetest.register_craftitem("rangedweapons:408cheytac", { + stack_max= 40, + wield_scale = {x=0.65,y=0.65,z=1.5}, + description = "" ..core.colorize("#35cdff",".408 chey tac\n")..core.colorize("#FFFFFF", "Bullet damage: 10 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 0.8 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 5% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 70 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 15 \n") ..core.colorize("#FFFFFF", "Damage gain over 1 sec of flight time: 80 \n") ..core.colorize("#FFFFFF", "Bullet enemy Penetration: 45%\n") ..core.colorize("#FFFFFF", "Bullet node Penetration: 20%\n") ..core.colorize("#FFFFFF", "Ammunition for some guns"), + inventory_image = "rangedweapons_408cheytac.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=10,knockback=15}, + ammo_critEffc = 0.8, + ammo_crit = 5, + ammo_velocity = 70, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "wielditem", + ammo_texture = "rangedweapons:shot_bullet_visual", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shelldrop", + ammo_mob_penetration = 45, + ammo_node_penetration = 20, + ammo_projectile_size = 0.0025, + ammo_dps = 80, + has_sparks = 1, + ignites_explosives = 1, + }, +}) + +minetest.register_craftitem("rangedweapons:40mm", { + stack_max= 25, + wield_scale = {x=0.8,y=0.8,z=2.4}, + description = "" ..core.colorize("#35cdff",".40mm grenade\n")..core.colorize("#FFFFFF", "Bullet damage: 10 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 1.0 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 1% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 15 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 10 \n") ..core.colorize("#FFFFFF", "Bullet gravity: 5 \n") ..core.colorize("#FFFFFF", "explodes on impact with a radius of 2\n") ..core.colorize("#FFFFFF", "Ammunition for grenade launchers"), + inventory_image = "rangedweapons_40mm.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=10,knockback=15}, + ammo_critEffc = 1.0, + ammo_crit = 1, + ammo_velocity = 15, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "sprite", + ammo_texture = "rangedweapons_rocket_fly.png", + shell_entity = "rangedweapons:empty_shell", + shell_visual = "wielditem", + shell_texture = "rangedweapons:shell_grenadedrop", + ammo_projectile_size = 0.15, + has_sparks = 1, + ammo_gravity = 5, + ignites_explosives = 1, + +OnCollision = function(player,bullet,target) + tnt.boom(bullet.object:get_pos(), {radius = 2}) +end, +ammo_particles = { + velocity = {x=1,y=1,z=1}, + acceleration = {x=1,y=1,z=1}, + collisiondetection = true, + lifetime = 1, + texture = "tnt_smoke.png", + minsize = 50, + maxsize = 75, + pos_randomness = 50, + glow = 20, + gravity = 10, + amount = {1,1} +}, +}, +}) + +minetest.register_craftitem("rangedweapons:rocket", { + stack_max= 15, + wield_scale = {x=1.2,y=1.2,z=2.4}, + description = "" ..core.colorize("#35cdff","rocket\n")..core.colorize("#FFFFFF", "Bullet damage: 15 \n") ..core.colorize("#FFFFFF", "Bullet crit efficiency: 1.0 \n") ..core.colorize("#FFFFFF", "Bullet crit chance: 1% \n") ..core.colorize("#FFFFFF", "Bullet velocity: 20 \n") ..core.colorize("#FFFFFF", "Bullet knockback: 20 \n") ..core.colorize("#FFFFFF", "Bullet gravity: 5 \n") ..core.colorize("#FFFFFF", "explodes on impact with a radius of 3\n") ..core.colorize("#FFFFFF", "Ammunition for rocket launchers"), + inventory_image = "rangedweapons_rocket.png", + RW_ammo_capabilities = { + ammo_damage = {fleshy=15,knockback=20}, + ammo_critEffc = 1.0, + ammo_crit = 1, + ammo_velocity = 20, + ammo_glass_breaking = 1, + ammo_entity = "rangedweapons:shot_bullet", + ammo_visual = "sprite", + ammo_texture = "rangedweapons_rocket_fly.png", + ammo_projectile_size = 0.15, + has_sparks = 1, + ignites_explosives = 1, + +OnCollision = function(player,bullet,target) + tnt.boom(bullet.object:get_pos() , {radius = 3}) +end, +ammo_particles = { + velocity = {x=1,y=1,z=1}, + acceleration = {x=1,y=1,z=1}, + collisiondetection = true, + lifetime = 1, + texture = "tnt_smoke.png", + minsize = 50, + maxsize = 75, + pos_randomness = 50, + glow = 20, + gravity = 10, + amount = {1,1} +}, +}, +}) diff --git a/mods/rangedweapons/awp.lua b/mods/rangedweapons/awp.lua new file mode 100644 index 0000000..7e8d2fe --- /dev/null +++ b/mods/rangedweapons/awp.lua @@ -0,0 +1,102 @@ + + +minetest.register_tool("rangedweapons:awp_uld", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.1}, + range = 0, + description = "" ..core.colorize("#35cdff","A.W.P. \n") ..core.colorize("#FFFFFF", "Ranged damage:18 + 35/sec of bullet lifetime\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 15\n") ..core.colorize("#FFFFFF", "Critical chance: 30%\n") ..core.colorize("#FFFFFF", "Critical efficiency: x3\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm round/308.Winchester rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 1.0\n") ..core.colorize("#FFFFFF", "Reload time: 2.0\n") ..core.colorize("#FFFFFF", "Zoom: 12x\n") ..core.colorize("#be0d00", "Right-click to eject empty bullet shell\n") ..core.colorize("#FFFFFF", "Clip size: 10/10\n") ..core.colorize("#FFFFFF", "Enemy penetration:30%\n") ..core.colorize("#FFFFFF", "Block penetration:10%\n") ..core.colorize("#FFFFFF", "Gun type: Rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 75"), + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_awp.png", + weapon_zoom = 7.5, + on_use = function(user) + minetest.sound_play("rangedweapons_empty", {user}) + end, +on_secondary_use = function(itemstack, user, pointed_thing) +eject_shell(itemstack,user,"rangedweapons:awp_rld",1.0,"rangedweapons_rifle_reload_a","rangedweapons:empty_shell") +return itemstack +end, +}) + + +minetest.register_tool("rangedweapons:awp_r", { + rw_next_reload = "rangedweapons:awp_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_awp_noclip.png", +}) +minetest.register_tool("rangedweapons:awp_rr", { + rw_next_reload = "rangedweapons:awp_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_awp.png", +}) +minetest.register_tool("rangedweapons:awp_rrr", { + rw_next_reload = "rangedweapons:awp", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_awp_rld.png", +}) + + +minetest.register_tool("rangedweapons:awp_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + loaded_gun = "rangedweapons:awp", + loaded_sound = "rangedweapons_rifle_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_awp_rld.png", +}) + + +minetest.register_tool("rangedweapons:awp", { + description = "" ..core.colorize("#35cdff","A.W.P. \n") ..core.colorize("#FFFFFF", "Ranged damage:18 + 35/sec of bullet lifetime\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 15\n") ..core.colorize("#FFFFFF", "Critical chance: 30%\n") ..core.colorize("#FFFFFF", "Critical efficiency: x3\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm round/308.Winchester rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 1.0\n") ..core.colorize("#FFFFFF", "Reload time: 2.0\n") ..core.colorize("#FFFFFF", "Zoom: 12x\n") ..core.colorize("#27a600", "The gun is loaded!\n") ..core.colorize("#FFFFFF", "Clip size: 10/10\n") ..core.colorize("#FFFFFF", "Enemy penetration:30%\n") ..core.colorize("#FFFFFF", "Block penetration:10%\n") ..core.colorize("#FFFFFF", "Gun type: Rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 75"), + range = 0, + weapon_zoom = 7.5, + wield_scale = {x=1.9,y=1.9,z=1.1}, + inventory_image = "rangedweapons_awp.png", +RW_gun_capabilities = { + gun_damage = {fleshy=18,knockback=15}, + gun_crit = 30, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:762mm",10},{"rangedweapons:308winchester",10}}, + gun_skill = {"rifle_skill",20}, + gun_magazine = "rangedweapons:rifle_mag", + gun_icon = "rangedweapons_awp_icon.png", + gun_unloaded = "rangedweapons:awp_r", + gun_cooling = "rangedweapons:awp_uld", + gun_velocity = 75, + gun_accuracy = 100, + gun_cooldown = 1.0, + gun_reload = 2.0/4, + gun_projectiles = 1, + has_shell = 0, + gun_durability = 700, + gun_smokeSize = 8, + gun_dps = 35, + gun_mob_penetration = 30, + gun_node_penetration = 10, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_rifle_b", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, + +}) + diff --git a/mods/rangedweapons/benelli.lua b/mods/rangedweapons/benelli.lua new file mode 100644 index 0000000..9dd9d8d --- /dev/null +++ b/mods/rangedweapons/benelli.lua @@ -0,0 +1,63 @@ +minetest.register_tool("rangedweapons:benelli_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + loaded_gun = "rangedweapons:benelli", + loaded_sound = "rangedweapons_shotgun_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_benelli_rld.png", +}) + +minetest.register_tool("rangedweapons:benelli", { + description = "" ..core.colorize("#35cdff","benelli m3\n") ..core.colorize("#FFFFFF", "Ranged damage: 2\n") ..core.colorize("#FFFFFF", "projectiles: 5\n") ..core.colorize("#FFFFFF", "Gun gravity: 4\n") ..core.colorize("#FFFFFF", "Accuracy: 48%\n")..core.colorize("#FFFFFF", "knockback: 6\n") ..core.colorize("#FFFFFF", "Critical chance: 6%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shells\n") ..core.colorize("#FFFFFF", "Pump delay: 0.6\n")..core.colorize("#FFFFFF", "Clip size: 7\n") ..core.colorize("#27a600", "Gun is ready to fire!\n") ..core.colorize("#fff21c", "Right-click to load in a bullet!\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 26"), + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + inventory_image = "rangedweapons_benelli.png", +RW_gun_capabilities = { + gun_damage = {fleshy=2,knockback=6}, + gun_crit = 6, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:shell",7}}, + gun_skill = {"shotgun_skill",20}, + gun_icon = "rangedweapons_benelli_icon.png", + gun_unloaded = "rangedweapons:benelli_rld", + gun_cooling = "rangedweapons:benelli_uld", + gun_velocity = 25, + gun_accuracy = 48, + gun_cooldown = 0.6, + gun_gravity = 4, + gun_reload = 0.25, + gun_projectiles = 5, + has_shell = 0, + gun_durability = 325, + gun_smokeSize = 14, + gun_door_breaking = 1, + gun_sound = "rangedweapons_shotgun_shot", + gun_unload_sound = "rangedweapons_shell_insert", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_single_load_gun(itemstack, user, "") +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + +minetest.register_tool("rangedweapons:benelli_uld", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.1}, + range = 0, + description = "" ..core.colorize("#35cdff","benelli m3\n") ..core.colorize("#FFFFFF", "Ranged damage: 2\n") ..core.colorize("#FFFFFF", "projectiles: 5\n") ..core.colorize("#FFFFFF", "Gun gravity: 4\n") ..core.colorize("#FFFFFF", "Accuracy: 48%\n")..core.colorize("#FFFFFF", "knockback: 6\n") ..core.colorize("#FFFFFF", "Critical chance: 6%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shells\n") ..core.colorize("#FFFFFF", "Pump delay: 0.6\n")..core.colorize("#FFFFFF", "Clip size: 7\n") ..core.colorize("#be0d00", "Right-click, to eject the empty shell!\n") ..core.colorize("#fff21c", "Right-click to load in a bullet!\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + inventory_image = "rangedweapons_benelli.png", + groups = {not_in_creative_inventory = 1}, + on_use = function(user) + minetest.sound_play("rangedweapons_empty", {user}) + end, +on_secondary_use = function(itemstack, user, pointed_thing) +eject_shell(itemstack,user,"rangedweapons:benelli_rld",0.6,"rangedweapons_shotgun_reload_a","rangedweapons:empty_shell") +return itemstack +end, +}) diff --git a/mods/rangedweapons/beretta.lua b/mods/rangedweapons/beretta.lua new file mode 100644 index 0000000..e52f659 --- /dev/null +++ b/mods/rangedweapons/beretta.lua @@ -0,0 +1,58 @@ + + +minetest.register_tool("rangedweapons:beretta_rld", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "", + range = 0, + loaded_gun = "rangedweapons:beretta", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_beretta_rld.png", +}) +minetest.register_tool("rangedweapons:beretta_r", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "", + rw_next_reload = "rangedweapons:beretta", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_beretta_rld.png", +}) + +minetest.register_tool("rangedweapons:beretta", { + description = "" ..core.colorize("#35cdff","Beretta M9\n") ..core.colorize("#FFFFFF", "Gun damage: 4\n")..core.colorize("#FFFFFF", "Accuracy: 94%\n") ..core.colorize("#FFFFFF", "gun knockback: 4\n") ..core.colorize("#FFFFFF", "Gun crit chance: 13%\n")..core.colorize("#FFFFFF", "Critical efficiency: 2.1x\n") ..core.colorize("#FFFFFF", "Reload delay: 0.5\n")..core.colorize("#FFFFFF", "Clip size: 15\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm Parabellum\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.4\n") ..core.colorize("#FFFFFF", "Gun type: Handgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + wield_scale = {x=1.1,y=1.1,z=1.05}, + range = 0, + inventory_image = "rangedweapons_beretta.png", +RW_gun_capabilities = { + gun_damage = {fleshy=4,knockback=4}, + gun_crit = 15, + gun_critEffc = 2.1, + suitable_ammo = {{"rangedweapons:9mm",15}}, + gun_skill = {"handgun_skill",43}, + gun_magazine = "rangedweapons:handgun_mag_black", + gun_icon = "rangedweapons_beretta_icon.png", + gun_unloaded = "rangedweapons:beretta_r", + gun_cooling = "rangedweapons:beretta_rld", + gun_velocity = 25, + gun_accuracy = 94, + gun_cooldown = 0.4, + gun_reload = 0.5, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 1150, + gun_smokeSize = 5, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_beretta", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + diff --git a/mods/rangedweapons/bullet_knockback.lua b/mods/rangedweapons/bullet_knockback.lua new file mode 100644 index 0000000..11be72a --- /dev/null +++ b/mods/rangedweapons/bullet_knockback.lua @@ -0,0 +1,15 @@ +function projectile_kb(victim,projectile,kbamount) + +if victim:get_pos() and projectile:get_pos() then +rw_proj_kb_pos_x = victim:get_pos().x - projectile:get_pos().x +rw_proj_kb_pos_y = victim:get_pos().y - projectile:get_pos().y +rw_proj_kb_pos_z = victim:get_pos().z - projectile:get_pos().z +else +rw_proj_kb_pos_x = 1 +rw_proj_kb_pos_y = 1 +rw_proj_kb_pos_z = 1 +end + +victim:add_player_velocity({x=kbamount*(rw_proj_kb_pos_x*2),y= kbamount*(math.abs(rw_proj_kb_pos_y)/2), z=kbamount*(rw_proj_kb_pos_z*2)}) + +end \ No newline at end of file diff --git a/mods/rangedweapons/cooldown_stuff.lua b/mods/rangedweapons/cooldown_stuff.lua new file mode 100644 index 0000000..678430e --- /dev/null +++ b/mods/rangedweapons/cooldown_stuff.lua @@ -0,0 +1,102 @@ +minetest.register_globalstep(function(dtime, player) + for _, player in pairs(minetest.get_connected_players()) do + + + + + + local w_item = player:get_wielded_item() + + +local controls = player:get_player_control() +if w_item:get_definition().weapon_zoom ~= nil then + + if controls.zoom then +player:hud_change(scope_hud, "text", "rangedweapons_scopehud.png") + else +player:hud_change(scope_hud, "text", "rangedweapons_empty_icon.png") + end + +local wpn_zoom = w_item:get_definition().weapon_zoom + if player:get_properties().zoom_fov ~= wpn_zoom then + player:set_properties({zoom_fov = wpn_zoom}) + + end + +end + +if w_item:get_definition().weapon_zoom == nil then +player:hud_change(scope_hud, "text", "rangedweapons_empty_icon.png") + if player:get_inventory():contains_item( + "main", "binoculars:binoculars") then + new_zoom_fov = 10 + if player:get_properties().zoom_fov ~= new_zoom_fov then + player:set_properties({zoom_fov = new_zoom_fov}) + end + else + new_zoom_fov = 0 + if player:get_properties().zoom_fov ~= new_zoom_fov then + player:set_properties({zoom_fov = new_zoom_fov}) + end + end +end + + +local u_meta = player:get_meta() +local cool_down = u_meta:get_float("rw_cooldown") or 0 + + +if u_meta:get_float("rw_cooldown") > 0 then +u_meta:set_float("rw_cooldown", cool_down - dtime) +end + +local itemstack = player:get_wielded_item() + +if controls.LMB then +if player:get_wielded_item():get_definition().RW_gun_capabilities then +if +player:get_wielded_item():get_definition().RW_gun_capabilities.automatic_gun and player:get_wielded_item():get_definition().RW_gun_capabilities.automatic_gun > 0 then + +rangedweapons_shoot_gun(itemstack, player) +player:set_wielded_item(itemstack) +end end + +if player:get_wielded_item():get_definition().RW_powergun_capabilities then +if player:get_wielded_item():get_definition().RW_powergun_capabilities.automatic_gun and player:get_wielded_item():get_definition().RW_powergun_capabilities.automatic_gun > 0 then + +rangedweapons_shoot_powergun(itemstack, player) +player:set_wielded_item(itemstack) +end end + + end + + + +--minetest.chat_send_all(u_meta:get_float("rw_cooldown")) + +if u_meta:get_float("rw_cooldown") <= 0 then +if player:get_wielded_item():get_definition().loaded_gun ~= nil then + local itemstack = player:get_wielded_item() + +if player:get_wielded_item():get_definition().loaded_sound ~= nil then +minetest.sound_play(itemstack:get_definition().loaded_sound, {player}) +end + itemstack:set_name(player:get_wielded_item():get_definition().loaded_gun) + player:set_wielded_item(itemstack) +end + +if player:get_wielded_item():get_definition().rw_next_reload ~= nil then + local itemstack = player:get_wielded_item() + if itemstack:get_definition().load_sound ~= nil then +minetest.sound_play(itemstack:get_definition().load_sound, {player}) + end + gunMeta = itemstack:get_meta() + u_meta:set_float("rw_cooldown",gunMeta:get_float("RW_reload_delay")) + itemstack:set_name(player:get_wielded_item():get_definition().rw_next_reload) + player:set_wielded_item(itemstack) +end +end + +end end) + + diff --git a/mods/rangedweapons/deagle.lua b/mods/rangedweapons/deagle.lua new file mode 100644 index 0000000..d45ab80 --- /dev/null +++ b/mods/rangedweapons/deagle.lua @@ -0,0 +1,121 @@ + + + +minetest.register_tool("rangedweapons:deagle_rld", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.5}, + description = "", + range = 0, + loaded_gun = "rangedweapons:deagle", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_deagle_rld.png", +}) +minetest.register_tool("rangedweapons:deagle_r", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.5}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:deagle", + load_sound = "rangedweapons_handgun_mag_in", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_deagle_rld.png", +}) + +minetest.register_tool("rangedweapons:deagle", { + description = "" ..core.colorize("#35cdff","Desert Eagle\n")..core.colorize("#FFFFFF", "Ranged damage: 11\n") ..core.colorize("#FFFFFF", "Accuracy: 85%\n") ..core.colorize("#FFFFFF", "knockback: 6\n") ..core.colorize("#FFFFFF", "Critical chance: 20%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 3x\n")..core.colorize("#FFFFFF", "Reload delay: 0.6\n")..core.colorize("#FFFFFF", "Clip size: 9/8/7\n") ..core.colorize("#FFFFFF", "Ammunition: .357 Magnum rounds/.44 magnum rounds/.50AE catridges\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.7\n") ..core.colorize("#FFFFFF", "Gun type: Magnum\n") ..core.colorize("#FFFFFF", "Block penetration: 5%\n") +..core.colorize("#FFFFFF", "penetration: 15%\n")..core.colorize("#FFFFFF", "Bullet velocity: 50"), + wield_scale = {x=1.25,y=1.25,z=1.5}, + range = 0, + inventory_image = "rangedweapons_deagle.png", +RW_gun_capabilities = { + gun_damage = {fleshy=11,knockback=6}, + gun_crit = 20, + gun_critEffc = 2.2, + suitable_ammo = {{"rangedweapons:357",9},{"rangedweapons:44",8},{"rangedweapons:50ae",7}}, + gun_skill = {"revolver_skill",40}, + gun_magazine = "rangedweapons:handgun_mag_white", + gun_icon = "rangedweapons_deagle_icon.png", + gun_unloaded = "rangedweapons:deagle_r", + gun_cooling = "rangedweapons:deagle_rld", + gun_velocity = 50, + gun_accuracy = 85, + gun_cooldown = 0.7, + gun_reload = 0.6/1, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 900, + gun_smokeSize = 7, + gun_mob_penetration = 15, + gun_node_penetration = 5, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_deagle", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + +minetest.register_tool("rangedweapons:golden_deagle_rld", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.5}, + description = "", + range = 0, + loaded_gun = "rangedweapons:golden_deagle", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_golden_deagle_rld.png", +}) +minetest.register_tool("rangedweapons:golden_deagle_r", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.5}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:golden_deagle", + load_sound = "rangedweapons_handgun_mag_in", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_golden_deagle_rld.png", +}) + +minetest.register_tool("rangedweapons:golden_deagle", { + description = "" ..core.colorize("#35cdff","Golden Desert Eagle\n")..core.colorize("#FFFFFF", "Ranged damage: 14\n") ..core.colorize("#FFFFFF", "Accuracy: 90%\n") ..core.colorize("#FFFFFF", "knockback: 6\n") ..core.colorize("#FFFFFF", "Critical chance: 23%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 3x\n")..core.colorize("#FFFFFF", "Reload delay: 0.6\n")..core.colorize("#FFFFFF", "Clip size: 9/8/7\n") ..core.colorize("#FFFFFF", "Ammunition: .357 Magnum rounds/.44 magnum rounds/.50AE catridges\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.75\n") ..core.colorize("#FFFFFF", "Gun type: Magnum\n") ..core.colorize("#FFFFFF", "Block penetration: 5%\n") +..core.colorize("#FFFFFF", "penetration: 15%\n")..core.colorize("#FFFFFF", "Bullet velocity: 50"), + wield_scale = {x=1.25,y=1.25,z=1.5}, + range = 0, + inventory_image = "rangedweapons_golden_deagle.png", +RW_gun_capabilities = { + gun_damage = {fleshy=14,knockback=6}, + gun_crit = 23, + gun_critEffc = 2.2, + suitable_ammo = {{"rangedweapons:357",9},{"rangedweapons:44",8},{"rangedweapons:50ae",7}}, + gun_skill = {"revolver_skill",38}, + gun_magazine = "rangedweapons:handgun_mag_white", + gun_icon = "rangedweapons_golden_deagle_icon.png", + gun_unloaded = "rangedweapons:golden_deagle_r", + gun_cooling = "rangedweapons:golden_deagle_rld", + gun_velocity = 50, + gun_accuracy = 90, + gun_cooldown = 0.75, + gun_reload = 0.6/1, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 1000, + gun_smokeSize = 7, + gun_mob_penetration = 15, + gun_node_penetration = 5, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_deagle", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + diff --git a/mods/rangedweapons/depends.txt b/mods/rangedweapons/depends.txt new file mode 100644 index 0000000..b28b04f --- /dev/null +++ b/mods/rangedweapons/depends.txt @@ -0,0 +1,3 @@ + + + diff --git a/mods/rangedweapons/explosives.lua b/mods/rangedweapons/explosives.lua new file mode 100644 index 0000000..ff8426b --- /dev/null +++ b/mods/rangedweapons/explosives.lua @@ -0,0 +1,203 @@ +--[[local he_boom = { + name = "rangedweapons:he_explosion", + --description = "DuN mInD mEh...", + radius = 2, + tiles = { + side = "rangedweapons_invisible.png", + top = "rangedweapons_invisible.png", + bottom = "rangedweapons_invisible.png", + burning = "rangedweapons_invisible.png" + }, +} +tnt.register_tnt(he_boom) + +local rocket_boom = { + name = "rangedweapons:rocket_explosion", + --description = "DuN mInD mEh...", + radius = 3, + tiles = { + side = "rangedweapons_invisible.png", + top = "rangedweapons_invisible.png", + bottom = "rangedweapons_invisible.png", + burning = "rangedweapons_invisible.png" + }, +} +tnt.register_tnt(rocket_boom) +]] +local rangedweapons_rocket = { + physical = false, + timer = 0, + visual = "sprite", + visual_size = {x=0.0, y=0.0}, + textures = {"rangedweapons_invisible.png"}, + lastpos= {}, + collisionbox = {0, 0, 0, 0, 0, 0}, +} +rangedweapons_rocket.on_step = function(self, dtime, pos) + self.timer = self.timer + dtime + local tiem = 0.002 + local pos = self.object:getpos() + local node = minetest.get_node(pos) + if self.timer >= 0.002 then + minetest.add_particle({ + pos = pos, + velocity = 0, + acceleration = {x=0, y=0, z=0}, + expirationtime = 0.04, + size = 7, + collisiondetection = false, + vertical = false, + texture = "rangedweapons_rocket_fly.png", + glow = 15, + }) + minetest.add_particle({ + pos = pos, + velocity = 0, + acceleration = {x=0, y=6, z=0}, + expirationtime = 0.4, + size = 4, + collisiondetection = false, + vertical = false, + texture = "tnt_smoke.png", + glow = 5, + }) + tiem = tiem + 0.002 + end + if self.timer >= 0.375 then + local objs = minetest.get_objects_inside_radius({x = pos.x, y = pos.y, z = pos.z}, 1.5) + for k, obj in pairs(objs) do + if obj:get_luaentity() ~= nil then + if obj:get_luaentity().name ~= "rangedweapons:rocket" and obj:get_luaentity().name ~= "__builtin:item" then + --tnt.boom(pos, rocket_boom) + self.object:remove() + end + end + end +end + if self.lastpos.x ~= nil then + if minetest.registered_nodes[node.name].walkable then + --tnt.boom(pos, rocket_boom) + self.object:remove() + end + if self.timer >= 7.5 then + --tnt.boom(pos, rocket_boom) + self.object:remove() + end + end + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} +end + +minetest.register_entity("rangedweapons:rocket", rangedweapons_rocket) + + +local rangedweapons_he_grenade = { + physical = false, + timer = 0, + visual = "sprite", + visual_size = {x=0.0, y=0.0}, + textures = {"rangedweapons_invisible.png"}, + lastpos= {}, + collisionbox = {0, 0, 0, 0, 0, 0}, +} +rangedweapons_he_grenade.on_step = function(self, dtime, pos) + self.timer = self.timer + dtime + local tiem = 0.002 + local pos = self.object:getpos() + local node = minetest.get_node(pos) + if self.timer >= 0.002 then + minetest.add_particle({ + pos = pos, + velocity = 0, + acceleration = {x=0, y=0, z=0}, + expirationtime = 0.04, + size = 7, + collisiondetection = false, + vertical = false, + texture = "rangedweapons_rocket_fly.png", + glow = 15, + }) + minetest.add_particle({ + pos = pos, + velocity = 0, + acceleration = {x=0, y=16, z=0}, + expirationtime = 0.4, + size = 4, + collisiondetection = false, + vertical = false, + texture = "tnt_smoke.png", + glow = 5, + }) + tiem = tiem + 0.002 + end + if self.timer >= 0.4 then + local objs = minetest.get_objects_inside_radius({x = pos.x, y = pos.y, z = pos.z}, 1.5) + for k, obj in pairs(objs) do + if obj:get_luaentity() ~= nil then + if obj:get_luaentity().name ~= "rangedweapons:he_grenade" and obj:get_luaentity().name ~= "__builtin:item" then + --tnt.boom(pos, rocket_boom) + self.object:remove() + end + end + end +end + if self.lastpos.x ~= nil then + if minetest.registered_nodes[node.name].walkable then + --tnt.boom(pos, he_boom) + self.object:remove() + end + if self.timer >= 7.5 then + --tnt.boom(pos, he_boom) + self.object:remove() + end + end + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} +end + +minetest.register_entity("rangedweapons:he_grenade", rangedweapons_he_grenade) + + +local barrel_boom = { + name = "rangedweapons:explosion", + --description = "DuN mInD mEh...", + radius = 3, + tiles = { + side = "rangedweapons_invisible.png", + top = "rangedweapons_invisible.png", + bottom = "rangedweapons_invisible.png", + burning = "rangedweapons_invisible.png" + }, +} +--tnt.register_tnt(barrel_boom) + +minetest.register_node("rangedweapons:barrel", { + description = "" ..core.colorize("#35cdff","Explosive barrel\n")..core.colorize("#FFFFFF", "It will explode if shot by gun"), + tiles = { + "rangedweapons_barrel_top.png", + "rangedweapons_barrel_top.png", + "rangedweapons_barrel_side.png", + "rangedweapons_barrel_side.png", + "rangedweapons_barrel_side.png", + "rangedweapons_barrel_side.png" + }, + drawtype = "nodebox", + paramtype = "light", + groups = {choppy = 3, oddly_breakable_by_hand = 3}, + on_blast = function(pos) + --tnt.boom(pos, {radius = 3}) + end, + + node_box = { + type = "fixed", + fixed = { + {-0.1875, -0.5, -0.5, 0.1875, 0.5, 0.5}, -- NodeBox1 + {-0.5, -0.5, -0.1875, 0.5, 0.5, 0.1875}, -- NodeBox2 + {-0.4375, -0.5, -0.3125, 0.4375, 0.5, 0.3125}, -- NodeBox3 + {-0.3125, -0.5, -0.4375, 0.3125, 0.5, 0.4375}, -- NodeBox4 + {-0.375, -0.5, -0.375, 0.375, 0.5, 0.375}, -- NodeBox5 + } + } +}) + + + + diff --git a/mods/rangedweapons/forcegun.lua b/mods/rangedweapons/forcegun.lua new file mode 100644 index 0000000..b57186e --- /dev/null +++ b/mods/rangedweapons/forcegun.lua @@ -0,0 +1,148 @@ +minetest.register_tool("rangedweapons:forcegun", { + description = "" ..core.colorize("#35cdff","Force gun\n") ..core.colorize("#FFFFFF", "Completelly harmless... by itself...\n")..core.colorize("#FFFFFF", "It's projectile will push either the entity it hits directly, or everyone near the node it collides with far away.\n") ..core.colorize("#FFFFFF", "Perfect for rocket-jumping or YEETing enemies away.\n")..core.colorize("#FFFFFF", "Power usage: 40\n")..core.colorize("#FFFFFF", "Gun type:Power Special-gun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 60"), + range = 0, + wield_scale = {x=2.0,y=2.0,z=1.75}, + inventory_image = "rangedweapons_forcegun.png", + on_use = function(itemstack, user, pointed_thing) + + local pos = user:get_pos() + local dir = user:get_look_dir() + local yaw = user:get_look_yaw() + local inv = user:get_inventory() +if inv:contains_item("main", "rangedweapons:power_particle 40") then + if pos and dir then + inv:remove_item("main", "rangedweapons:power_particle 25") + pos.y = pos.y + 1.5 + local obj = minetest.add_entity(pos, "rangedweapons:forceblast") + if obj then + minetest.sound_play("rangedweapons_rocket", {object=obj}) + obj:set_velocity({x=dir.x * 60, y=dir.y * 60, z=dir.z * 60}) + + obj:setyaw(yaw + math.pi) + proj_dir = dir + local ent = obj:get_luaentity() + if ent then + ent.player = ent.player or user + end + end + end + end + end, +}) + +local rangedweapons_forceblast = { + timer = 0, +initial_properties = { + physical = true, + hp_max = 420, + glow = 30, + visual = "sprite", + visual_size = {x=0.4, y=0.4,}, + textures = {"rangedweapons_force_bullet.png"}, + lastpos = {}, + collide_with_objects = false, + collisionbox = {-0.25, -0.25, -0.25, 0.25, 0.25, 0.25}, +}, + +} +rangedweapons_forceblast.on_step = function(self, dtime, moveresult) + self.timer = self.timer + dtime + local pos = self.object:get_pos() + proj_dir = proj_dir or ({x=0,y=0,z=0}) + + +if self.timer > 10 then +self.object:remove() +end + +if self.timer > 0.05 then +self.object:set_properties({collide_with_objects = true}) +end + +if moveresult.collides == true then +if moveresult.collisions[1] ~= nil then + +if moveresult.collisions[1].type == "object" then +if moveresult.collisions[1].object:is_player() then + +moveresult.collisions[1].object:add_player_velocity({x=proj_dir.x * 20, y=5+ (proj_dir.y * 20), z=proj_dir.z * 20}) + else +moveresult.collisions[1].object:add_velocity({x=proj_dir.x * 20, y=5+ (proj_dir.y * 20), z=proj_dir.z * 20}) + +end + minetest.add_particle({ + pos = ({x = pos.x, y = pos.y, z = pos.z}), + velocity ={x=0,y=0,z=0}, + acceleration ={x=0,y=0,z=0}, + expirationtime = 0.20, + size = 16, + collisiondetection = true, + collision_removal = false, + vertical = false, + texture = "rangedweapons_force_blast.png", + glow = 20, + animation = {type="vertical_frames", aspect_w=64, aspect_h=64, length = 0.20,}, + }) + self.object:remove() +end + +if moveresult.collisions[1].type == "node" then + +local objs = minetest.get_objects_inside_radius({x = pos.x, y = pos.y, z = pos.z}, 7) + for k, obj in pairs(objs) do + +if obj:get_pos() then +posd_x = pos.x - obj:get_pos().x +posd_y = pos.y - obj:get_pos().y +posd_z = pos.z - obj:get_pos().z +else +posd_x = 1 +posd_y = 1 +posd_z = 1 +end + + +if posd_y < 0 and posd_y > -1 then posd_y = -1 end +if posd_y > 0 and posd_y < 1 then posd_y = 1 end + +if posd_y > 0 then posd_y=posd_y*3 end + +posd_y = (posd_y + 0.5) * (((math.abs(posd_x)+0.5)+(math.abs(posd_z)+0.5))/2) + +if posd_y > -1.0 and posd_y < 0 then posd_y = -1.0 end + + if obj:get_luaentity() ~= nil then + if obj:get_luaentity().name ~= "rangedweapons:forceblast" then + obj:add_velocity({x=10*(-posd_x), y=30*(-1/posd_y), z=10*(-posd_z)}) + self.object:remove() +end + else + obj:add_player_velocity({x=30*((-posd_x)/(1+math.abs(posd_x))), y=25*(-1/posd_y), z=30*((-posd_z)/(1+math.abs(posd_z)))}) + self.object:remove() + +end +end + + minetest.add_particle({ + pos = ({x = pos.x, y = pos.y, z = pos.z}), + velocity ={x=0,y=0,z=0}, + acceleration ={x=0,y=0,z=0}, + expirationtime = 0.20, + size = 128, + collisiondetection = true, + collision_removal = false, + vertical = false, + texture = "rangedweapons_force_blast.png", + glow = 20, + animation = {type="vertical_frames", aspect_w=64, aspect_h=64, length = 0.20,}, + }) + self.object:remove() + end + + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} +end +end +end + + +minetest.register_entity("rangedweapons:forceblast", rangedweapons_forceblast) diff --git a/mods/rangedweapons/g36.lua b/mods/rangedweapons/g36.lua new file mode 100644 index 0000000..aa90e52 --- /dev/null +++ b/mods/rangedweapons/g36.lua @@ -0,0 +1,74 @@ + + +minetest.register_tool("rangedweapons:g36_r", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:g36_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_g36_rld.png", +}) + +minetest.register_tool("rangedweapons:g36_rr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:g36_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_g36.png", +}) + +minetest.register_tool("rangedweapons:g36_rrr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:g36", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_g36.png", +}) + + + minetest.register_tool("rangedweapons:g36", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "" ..core.colorize("#35cdff","g36\n") ..core.colorize("#FFFFFF", "Gun damage: 7\n") ..core.colorize("#FFFFFF", "accuracy: 80%\n") ..core.colorize("#FFFFFF", "Gun knockback: 5\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 12%\n")..core.colorize("#FFFFFF", "Critical efficiency: 2.9x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.2\n") ..core.colorize("#FFFFFF", "Clip size: 30\n") ..core.colorize("#FFFFFF", "Ammunition: 5.56mm rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.08(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: assault rifle\n") ..core.colorize("#FFFFFF", "Block penetration: 6%\n") +..core.colorize("#FFFFFF", "Enemy penetration: 17%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 40"), + range = 0, + inventory_image = "rangedweapons_g36.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=7,knockback=5}, + gun_crit = 12, + gun_critEffc = 2.9, + suitable_ammo = {{"rangedweapons:556mm",30}}, + gun_skill = {"arifle_skill",55}, + gun_magazine = "rangedweapons:assaultrifle_mag", + gun_icon = "rangedweapons_g36_icon.png", + gun_unloaded = "rangedweapons:g36_r", + gun_velocity = 40, + gun_accuracy = 80, + gun_cooldown = 0.08, + gun_reload = 1.2/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1500, + gun_smokeSize = 5, + gun_mob_penetration = 17, + gun_node_penetration = 6, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_smg", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + + inventory_image = "rangedweapons_g36.png", +}) \ No newline at end of file diff --git a/mods/rangedweapons/generator.lua b/mods/rangedweapons/generator.lua new file mode 100644 index 0000000..3f6d288 --- /dev/null +++ b/mods/rangedweapons/generator.lua @@ -0,0 +1,39 @@ + + +minetest.register_node("rangedweapons:generator", { + description = "" ..core.colorize("#35cdff","Power particle generator\n")..core.colorize("#FFFFFF", "generates 1 power particle every 3 seconds (can hold up to 200). Punch to harvest them"), + tiles = { + "rangedweapons_generator_top.png", + "rangedweapons_generator_bottom.png", + "rangedweapons_generator_side.png", + "rangedweapons_generator_side.png", + "rangedweapons_generator_side.png", + "rangedweapons_generator_side.png" + }, + paramtype = "light", + light_source = 9, + groups = {cracky = 3, oddly_breakable_by_hand = 3}, + on_timer = function(pos, elapsed) + minetest.get_node_timer(pos):start(3) + local nodemeta = minetest.get_meta(pos) +if nodemeta:get_int("power_generated") < 200 then + nodemeta:set_int("power_generated",nodemeta:get_int("power_generated")+1) + nodemeta:set_string("infotext", "currently generated power:"..nodemeta:get_int("power_generated")) +end + end, + on_punch = function(pos, node, puncher) +local nodemeta = minetest.get_meta(pos) +local inv = puncher:get_inventory() +inv:add_item("main", "rangedweapons:power_particle "..nodemeta:get_int("power_generated")) +nodemeta:set_int("power_generated",0) +nodemeta:set_string("infotext", "currently generated power:"..nodemeta:get_int("power_generated")) + end, + on_construct = function(pos) + minetest.get_node_timer(pos):start(3) + end, + sounds = default.node_sound_wood_defaults(), +}) + + + + diff --git a/mods/rangedweapons/glass_breaking.lua b/mods/rangedweapons/glass_breaking.lua new file mode 100644 index 0000000..a31eb8c --- /dev/null +++ b/mods/rangedweapons/glass_breaking.lua @@ -0,0 +1,31 @@ +minetest.register_craftitem("rangedweapons:glass_shards", { + description = "" ..core.colorize("#35cdff","Glass shards\n")..core.colorize("#FFFFFF", "3 of those, can be crafted into a file of glass fragments"), + inventory_image = "rangedweapons_glass_shards.png", +}) +minetest.register_craft({ + output = "vessels:glass_fragments", + recipe = { + {"rangedweapons:glass_shards", "rangedweapons:glass_shards", "rangedweapons:glass_shards"}, + } +}) + +minetest.register_node("rangedweapons:broken_glass", { + description = "Broken glass", + drawtype = "glasslike", + tiles = { + "rangedweapons_broken_glass.png" + }, + paramtype = "light", + walkable = false, + is_ground_content = false, + liquidtype = "source", + liquid_alternative_flowing = "rangedweapons:broken_glass", + liquid_alternative_source = "rangedweapons:broken_glass", + liquid_viscosity = 7, + alpha = 160, + liquid_range= 0, + liquid_renewable = false, + damage_per_second = 2, + groups = {oddly_breakable_by_hand = 3}, +}) + diff --git a/mods/rangedweapons/glock17.lua b/mods/rangedweapons/glock17.lua new file mode 100644 index 0000000..a99b715 --- /dev/null +++ b/mods/rangedweapons/glock17.lua @@ -0,0 +1,84 @@ + + +minetest.register_tool("rangedweapons:glock17_rld", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "", + loaded_gun = "rangedweapons:glock17", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_glock17_rld.png", +}) + + +minetest.register_tool("rangedweapons:glock17_r", { + stack_max= 1, + wield_scale = {x=1.2,y=1.2,z=1.2}, + description = "", + rw_next_reload = "rangedweapons:glock17_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_glock17.png", +}) + +minetest.register_tool("rangedweapons:glock17_rr", { + stack_max= 1, + wield_scale = {x=1.2,y=1.2,z=1.2}, + description = "", + rw_next_reload = "rangedweapons:glock17_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_glock17.png", +}) + +minetest.register_tool("rangedweapons:glock17_rrr", { + stack_max= 1, + wield_scale = {x=1.2,y=1.2,z=1.2}, + description = "", + rw_next_reload = "rangedweapons:glock17", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_glock17_rld.png", +}) + + + + +minetest.register_tool("rangedweapons:glock17", { + description = "" ..core.colorize("#35cdff","Glock 17\n") ..core.colorize("#FFFFFF", "Gun damage: 5\n") ..core.colorize("#FFFFFF", "Accuracy: 96%\n") ..core.colorize("#FFFFFF", "Gun knockback: 4\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 15%\n") ..core.colorize("#FFFFFF", "Gun Critical efficiency: 2.2x\n") ..core.colorize("#FFFFFF", "Reload delay: 0.9\n")..core.colorize("#FFFFFF", "Clip size: 17/17/17\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm Parabellum/10mm Auto/.45acp\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.35\n") ..core.colorize("#FFFFFF", "Gun type: Handgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 30"), + wield_scale = {x=1.2,y=1.2,z=1.2}, + range = 0, + inventory_image = "rangedweapons_glock17.png", +RW_gun_capabilities = { + gun_damage = {fleshy=5,knockback=4}, + gun_crit = 15, + gun_critEffc = 2.2, + suitable_ammo = {{"rangedweapons:9mm",17},{"rangedweapons:10mm",17},{"rangedweapons:45acp",17}}, + gun_skill = {"handgun_skill",45}, + gun_magazine = "rangedweapons:handgun_mag_black", + gun_icon = "rangedweapons_glock17_icon.png", + gun_unloaded = "rangedweapons:glock17_r", + gun_cooling = "rangedweapons:glock17_rld", + gun_velocity = 30, + gun_accuracy = 96, + gun_cooldown = 0.35, + gun_reload = 0.9/4, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 1400, + gun_smokeSize = 5, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_glock", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) diff --git a/mods/rangedweapons/hand_grenade.lua b/mods/rangedweapons/hand_grenade.lua new file mode 100644 index 0000000..e0ac479 --- /dev/null +++ b/mods/rangedweapons/hand_grenade.lua @@ -0,0 +1,149 @@ + + +minetest.register_craftitem("rangedweapons:pin", { + wield_scale = {x=2.5,y=2.5,z=1.0}, + inventory_image = "rangedweapons_pin.png", +}) +local rangedweapons_grenade_pin = { + physical = false, + timer = 0, + visual = "wielditem", + visual_size = {x=0.15, y=0.15}, + textures = {"rangedweapons:pin"}, + lastpos= {}, + collisionbox = {0, 0, 0, 0, 0, 0}, +} +rangedweapons_grenade_pin.on_step = function(self, dtime, pos) + self.timer = self.timer + dtime + local pos = self.object:get_pos() + local node = minetest.get_node(pos) + if self.lastpos.x ~= nil then + if minetest.registered_nodes[node.name].walkable then + self.object:remove() + minetest.sound_play("rangedweapons_bulletdrop", {pos = self.lastpos, gain = 0.8}) + end + end + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} +end + + + +minetest.register_entity("rangedweapons:grenade_pin", rangedweapons_grenade_pin) + +local grenade_boom = { + name = "rangedweapons:grenade_explosion", + --description = "DuN mInD mEh...", + radius = 3, + tiles = { + side = "rangedweapons_invisible.png", + top = "rangedweapons_invisible.png", + bottom = "rangedweapons_invisible.png", + burning = "rangedweapons_invisible.png" + }, +} + local gtimer = 0 +minetest.register_craftitem("rangedweapons:hand_grenade", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "" ..core.colorize("#35cdff","Hand grenade\n") ..core.colorize("#FFFFFF", "Explosion radius: 3\n")..core.colorize("#FFFFFF", "Throw force: 12\n") ..core.colorize("#FFFFFF", "Grenade gravitational pull: 6\n") ..core.colorize("#ffc000", "Right-click to unpin, Left click to throw after unpinning\n") ..core.colorize("#ffc000", "Thrown or not, it will explode after 3 secons from unpinning, be careful!"), + range = 0, + inventory_image = "rangedweapons_hand_grenade.png", + on_secondary_use = function(itemstack, user, pointed_thing) +if minetest.find_node_near(user:get_pos(), 10,"rangedweapons:antigun_block") +then + minetest.chat_send_player(user:get_player_name(), "" ..core.colorize("#ff0000","Grenades are prohibited in this area!")) + return itemstack + end + + gtimer = 0 + minetest.sound_play("rangedweapons_reload_a", {user}) + itemstack = "rangedweapons:hand_grenade_nopin" +local pos = user:get_pos() +pos.y = pos.y + 1.5 +local pinEnt = minetest.add_entity(pos, "rangedweapons:grenade_pin") +if pinEnt then +local dir = user:get_look_dir() +local yaw = user:get_look_yaw() +local svertical = user:get_look_vertical() +pinEnt:setvelocity({x=dir.x * -10, y=dir.y * -10, z=dir.z * -10}) +pinEnt:setacceleration({x=dir.x * -5, y= -10, z=dir.z * -5}) +pinEnt:set_rotation({x=0,y=yaw + math.pi,z=-svertical}) +end + return itemstack end, +}) + + +minetest.register_craftitem("rangedweapons:hand_grenade_nopin", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "***HURRY UP AND THROW IT!!!***", + range = 0, + inventory_image = "rangedweapons_hand_grenade_nopin.png", + groups = {not_in_creative_inventory = 1}, + + on_use = function(itemstack, user, pointed_thing) + local pos = user:get_pos() + local dir = user:get_look_dir() + local yaw = user:get_look_yaw() + if pos and dir and yaw then + pos.y = pos.y + 1.6 + local obj = minetest.add_entity(pos, "rangedweapons:grenade") + if obj then + obj:set_velocity({x=dir.x * 12, y=dir.y * 12, z=dir.z * 12}) + obj:set_acceleration({x=0, y=-6, z=0}) + obj:set_yaw(yaw + math.pi) + btimer = gtimer + local ent = obj:get_luaentity() + if ent then + ent.player = ent.player or user + itemstack = "" + end + end + end + return itemstack + end, +}) + +tnt.register_tnt(grenade_boom) + + +minetest.register_globalstep(function(dtime, player, pos) + gtimer = gtimer + dtime; + if gtimer >= 3.0 then + for _, player in pairs(minetest.get_connected_players()) do + local pos = player:get_pos() + if player:get_wielded_item():get_name() == "rangedweapons:hand_grenade_nopin" then + player:set_wielded_item("") + gtimer = 0 + tnt.boom(pos, grenade_boom) + end end end end) + +local rangedweapons_grenade = { + physical = true, + btimer = 0, + timer = 0, + hp_max = 420, + visual = "sprite", + visual_size = {x=0.5, y=0.5}, + textures = {"rangedweapons_hand_grenade_nopin.png"}, + lastpos= {}, + collisionbox = {-0.1, -0.1, -0.1, 0.1, 0.1, 0.1}, +} +rangedweapons_grenade.on_step = function(self, dtime, pos) + local pos = self.object:get_pos() + local node = minetest.get_node(pos) + local btimer = btimer or 0 + self.timer = self.timer + dtime + if self.timer > (3.0 - btimer) then + tnt.boom(pos, grenade_boom) + self.object:remove() + end + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} + +end + + + +minetest.register_entity("rangedweapons:grenade", rangedweapons_grenade) + + diff --git a/mods/rangedweapons/init.lua b/mods/rangedweapons/init.lua new file mode 100644 index 0000000..eef613e --- /dev/null +++ b/mods/rangedweapons/init.lua @@ -0,0 +1,975 @@ + + +local modpath = minetest.get_modpath(minetest.get_current_modname()) + +if minetest.global_exists("armor") and armor.attributes then + table.insert(armor.attributes, "bullet_res") +end +if minetest.global_exists("armor") and armor.attributes then + table.insert(armor.attributes, "ammo_save") +end +if minetest.global_exists("armor") and armor.attributes then + table.insert(armor.attributes, "ranged_dmg") +end + +minetest.register_node("rangedweapons:antigun_block", { + description = "" ..core.colorize("#35cdff","Anti-gun block\n")..core.colorize("#FFFFFF", "Prevents people from using guns, in 10 node radius to each side from this block"), + tiles = {"rangedweapons_antigun_block.png"}, + groups = {choppy = 3, oddly_breakable_by_hand = 3}, + +}) +---- +---- gun_funcs +---- + +make_sparks = function(pos) +minetest.sound_play("rengedweapons_ricochet", {pos, gain = 0.75}) + for i=1,9 do + minetest.add_particle({ + pos = pos, + velocity = {x=math.random(-6.0,6.0), y=math.random(-10.0,15.0), z=math.random(-6.0,6.0)}, + acceleration = {x=math.random(-9.0,9.0), y=math.random(-15.0,-3.0), z=math.random(-9.0,9.0)}, + expirationtime = 1.0, + size = math.random(1,2), + collisiondetection = true, + vertical = false, + texture = "rangedweapons_spark.png", + glow = 25, + }) +end +end + + +rangedweapons_gain_skill = function(player,skill,chance) + +if math.random(1, chance) == 1 then + local p_meta = player:get_meta() +local skill_num = p_meta:get_int(skill) +if skill_num < rweapons_max_gun_efficiency then +p_meta:set_int(skill, skill_num + 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#25c200","You've improved your skill with this type of gun!")) +end +end + +end + + +rangedweapons_reload_gun = function(itemstack, player) + +GunCaps = itemstack:get_definition().RW_gun_capabilities + +if GunCaps ~= nil then +gun_unload_sound = GunCaps.gun_unload_sound or "" +end + +minetest.sound_play(gun_unload_sound, {player}) + + +local gun_reload = 0.25 + +if GunCaps ~= nil then +gun_reload = GunCaps.gun_reload or 0.25 +end + +local playerMeta = player:get_meta() +local gunMeta = itemstack:get_meta() + +gunMeta:set_float("RW_reload_delay",gun_reload) + +playerMeta:set_float("rw_cooldown",gun_reload) + +local player_has_ammo = 0 +local clipSize = 0 +local reload_ammo = "" + +if GunCaps.suitable_ammo ~= nil then +local inv = player:get_inventory() +for i = 1,inv:get_size("main") do + +for _, ammo in pairs(GunCaps.suitable_ammo) do +if inv:get_stack("main",i):get_name() == ammo[1] then +reload_ammo = inv:get_stack("main",i) +clipSize = ammo[2] + +player_has_ammo = 1 +break +end end + +if player_has_ammo == 1 then +break +end + +end end + +if player_has_ammo == 1 then +local gun_icon = "rangedweapons_emergency_gun_icon.png" + +if GunCaps.gun_icon ~= nil then +gun_icon = GunCaps.gun_icon +end + +local ammo_icon = "rangedweapons_emergency_ammo_icon.png" + +if reload_ammo:get_definition().inventory_image ~= nil then +ammo_icon = reload_ammo:get_definition().inventory_image +end + + player:hud_change(gunimg, "text", gun_icon) + player:hud_change(ammoimg, "text", ammo_icon) + +local gunMeta = itemstack:get_meta() +local ammoCount = gunMeta:get_int("RW_bullets") +local ammoName = gunMeta:get_string("RW_ammo_name") +local inv = player:get_inventory() + +inv:add_item("main",ammoName.." "..ammoCount) + + +if inv:contains_item("main",reload_ammo:get_name().." "..clipSize) then +inv:remove_item("main",reload_ammo:get_name().." "..clipSize) +gunMeta:set_int("RW_bullets",clipSize) +else +gunMeta:set_int("RW_bullets",reload_ammo:get_count()) +inv:remove_item("main",reload_ammo:get_name().." "..reload_ammo:get_count()) +end + +gunMeta:set_string("RW_ammo_name",reload_ammo:get_name()) + +player:hud_change(gunammo, "text", gunMeta:get_int("RW_bullets")) + +if GunCaps.gun_magazine ~= nil then + local pos = player:get_pos() + local dir = player:get_look_dir() + local yaw = player:get_look_yaw() + if pos and dir and yaw then + pos.y = pos.y + 1.4 +local obj = minetest.add_entity(pos,"rangedweapons:mag") + if obj then +obj:set_properties({textures = {GunCaps.gun_magazine}}) + obj:set_velocity({x=dir.x*2, y=dir.y*2, z=dir.z*2}) + obj:set_acceleration({x=0, y=-5, z=0}) + obj:set_rotation({x=0,y=yaw+math.pi,z=0}) +end end end + +if GunCaps.gun_unloaded ~= nil then +itemstack:set_name(GunCaps.gun_unloaded) +end + + +end +end + + + +rangedweapons_single_load_gun = function(itemstack, player) + +GunCaps = itemstack:get_definition().RW_gun_capabilities + +if GunCaps ~= nil then +gun_unload_sound = GunCaps.gun_unload_sound or "" +end + +minetest.sound_play(gun_unload_sound, {player}) + +local gun_reload = 0.25 + +if GunCaps ~= nil then +gun_reload = GunCaps.gun_reload or 0.25 +end + +local playerMeta = player:get_meta() +local gunMeta = itemstack:get_meta() + +gunMeta:set_float("RW_reload_delay",gun_reload) + +playerMeta:set_float("rw_cooldown",gun_reload) + +local player_has_ammo = 0 +local clipSize = 0 +local reload_ammo = "" + +if GunCaps.suitable_ammo ~= nil then +local inv = player:get_inventory() +for i = 1,inv:get_size("main") do + +for _, ammo in pairs(GunCaps.suitable_ammo) do +if inv:get_stack("main",i):get_name() == ammo[1] then +reload_ammo = inv:get_stack("main",i) +clipSize = ammo[2] + +player_has_ammo = 1 +break +end end + +if player_has_ammo == 1 then +break +end + +end end + +if player_has_ammo == 1 then +local gun_icon = "rangedweapons_emergency_gun_icon.png" + +if GunCaps.gun_icon ~= nil then +gun_icon = GunCaps.gun_icon +end + +local ammo_icon = "rangedweapons_emergency_ammo_icon.png" + +if reload_ammo:get_definition().inventory_image ~= nil then +ammo_icon = reload_ammo:get_definition().inventory_image +end + + player:hud_change(gunimg, "text", gun_icon) + player:hud_change(ammoimg, "text", ammo_icon) + +local gunMeta = itemstack:get_meta() +local ammoCount = gunMeta:get_int("RW_bullets") +local ammoName = gunMeta:get_string("RW_ammo_name") +local inv = player:get_inventory() + +if ammoName ~= reload_ammo:get_name() then +inv:add_item("main",ammoName.." "..ammoCount) +gunMeta:set_int("RW_bullets",0) +end + +if inv:contains_item("main",reload_ammo:get_name()) and +gunMeta:get_int("RW_bullets") < clipSize then +inv:remove_item("main",reload_ammo:get_name()) +gunMeta:set_int("RW_bullets",gunMeta:get_int("RW_bullets")+1) +end + +gunMeta:set_string("RW_ammo_name",reload_ammo:get_name()) + +player:hud_change(gunammo, "text", gunMeta:get_int("RW_bullets")) + +if GunCaps.gun_unloaded ~= nil then +itemstack:set_name(GunCaps.gun_unloaded) +end + +end +end + +rangedweapons_yeet = function(itemstack, player) + +if minetest.find_node_near(player:getpos(), 10,"rangedweapons:antigun_block") +then + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","throwable weapons are prohibited in this area!")) +else + +ThrowCaps = itemstack:get_definition().RW_throw_capabilities +playerMeta = player:get_meta() + +if ThrowCaps ~= nil then +throw_cooldown = ThrowCaps.throw_cooldown or 0 +end + +if playerMeta:get_float("rw_cooldown") <= 0 then + +playerMeta:set_float("rw_cooldown", throw_cooldown) + +local throw_damage = {fleshy=1} +local throw_sound = "rangedweapons_throw" +local throw_velocity = 20 +local throw_accuracy = 100 +local throw_cooling = 0 +local throw_crit = 0 +local throw_critEffc = 1 +local throw_mobPen = 0 +local throw_nodePen = 0 +local throw_dps = 0 +local throw_gravity = 0 +local throw_door_breaking = 0 +local throw_skill = "" +local throw_skillChance = 0 +local throw_smokeSize = 0 +local throw_ent = "rangedweapons:shot_bullet" +local throw_visual = "wielditem" +local throw_texture = "rangedweapons:shot_bullet_visual" +local throw_glass_breaking = 0 +local throw_particles = {} +local throw_sparks = 0 +local throw_bomb_ignite = 0 +local throw_size = 0 +local throw_glow = 0 + +if ThrowCaps ~= nil then +throw_damage = ThrowCaps.throw_damage or {fleshy=1} +throw_sound = ThrowCaps.throw_sound or "rangedweapons_glock" +throw_velocity = ThrowCaps.throw_velocity or 20 +throw_accuracy = ThrowCaps.throw_accuracy or 100 +throw_cooling = ThrowCaps.throw_cooling or itemstack:get_name() +throw_crit = ThrowCaps.throw_crit or 0 +throw_critEffc = ThrowCaps.throw_critEffc or 1 +throw_projectiles = ThrowCaps.throw_projectiles or 1 +throw_mobPen = ThrowCaps.throw_mob_penetration or 0 +throw_nodePen = ThrowCaps.throw_node_penetration or 0 +throw_dps = ThrowCaps.throw_dps or 0 +throw_gravity = ThrowCaps.throw_gravity or 0 +throw_door_breaking = ThrowCaps.throw_door_breaking or 0 +throw_ent = ThrowCaps.throw_entity or "rangedweapons:shot_bullet" +throw_visual = ThrowCaps.throw_visual or "wielditem" +throw_texture = ThrowCaps.throw_texture or "rangedweapons:shot_bullet_visual" +throw_glass_breaking = ThrowCaps.throw_glass_breaking or 0 +throw_particles = ThrowCaps.throw_particles or nil +throw_sparks = ThrowCaps.throw_sparks or 0 +throw_bomb_ignite = ThrowCaps.ignites_explosives or 0 +throw_size = ThrowCaps.throw_projectile_size or 0 +throw_glow = ThrowCaps.throw_projectile_glow or 0 +OnCollision = ThrowCaps.OnCollision or function()end + +if ThrowCaps.throw_skill ~= nil then +throw_skill = ThrowCaps.throw_skill[1] or "" +throw_skillChance = ThrowCaps.throw_skill[2] or 0 +else +throw_skill = "" +throw_skillChance = 0 +end +end + +if throw_skillChance > 0 and throw_skill ~= "" then +rangedweapons_gain_skill(player,throw_skill,throw_skillChance) +end + +if throw_skill ~= "" then +skill_value = playerMeta:get_int(throw_skill)/100 +else +skill_value = 1 +end + +rangedweapons_launch_projectile(player,throw_projectiles,throw_damage,throw_ent,throw_visual,throw_texture,throw_sound,throw_velocity,throw_accuracy,skill_value,OnCollision,throw_crit,throw_critEffc,throw_mobPen,throw_nodePen,0,"","","",throw_dps,throw_gravity,throw_door_breaking,throw_glass_breaking,throw_particles,throw_sparks,throw_bomb_ignite,throw_size,0,itemstack:get_wear(),throw_glow) + +itemstack:take_item() + +end +end + +end + + +rangedweapons_shoot_gun = function(itemstack, player) + +if minetest.find_node_near(player:getpos(), 10,"rangedweapons:antigun_block") +then +minetest.sound_play("rangedweapons_empty", {player}) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Guns are prohibited in this area!")) + +else + +local gun_cooldown = 0 +local GunCaps = itemstack:get_definition().RW_gun_capabilities +local gun_ammo_save = 0 + +if GunCaps ~= nil then +gun_cooldown = GunCaps.gun_cooldown or 0 +gun_ammo_save = GunCaps.ammo_saving or 0 +end + +local gunMeta = itemstack:get_meta() +local playerMeta = player:get_meta() + +if gunMeta:get_int("RW_bullets") > 0 and +playerMeta:get_float("rw_cooldown") <= 0 then + +playerMeta:set_float("rw_cooldown", gun_cooldown) + +if math.random(1,100) > gun_ammo_save then +gunMeta:set_int("RW_bullets",gunMeta:get_int("RW_bullets")-1) +end + +player:hud_change(gunammo, "text", gunMeta:get_int("RW_bullets")) + +local gun_icon = "rangedweapons_emergency_gun_icon.png" +if GunCaps.gun_icon ~= nil then +gun_icon = GunCaps.gun_icon +end + player:hud_change(gunimg, "text", gun_icon) + +local OnCollision = function() end + +local bulletStack = ItemStack({name = gunMeta:get_string("RW_ammo_name")}) +AmmoCaps = bulletStack:get_definition().RW_ammo_capabilities + +local gun_damage = {fleshy=1} +local gun_sound = "rangedweapons_glock" +local gun_velocity = 20 +local gun_accuracy = 100 +local gun_cooling = 0 +local gun_crit = 0 +local gun_critEffc = 1 +local gun_mobPen = 0 +local gun_nodePen = 0 +local gun_shell = 0 +local gun_durability = 0 +local gun_dps = 0 +local gun_gravity = 0 +local gun_door_breaking = 0 +local gun_skill = "" +local gun_skillChance = 0 +local gun_smokeSize = 0 + +local bullet_damage = {fleshy=0} +local bullet_velocity = 0 +local bullet_ent = "rangedweapons:shot_bullet" +local bullet_visual = "wielditem" +local bullet_texture = "rangedweapons:shot_bullet_visual" +local bullet_crit = 0 +local bullet_critEffc = 0 +local bullet_projMult = 1 +local bullet_mobPen = 0 +local bullet_nodePen = 0 +local bullet_shell_ent = "rangedweapons:empty_shell" +local bullet_shell_visual = "wielditem" +local bullet_shell_texture = "rangedweapons:shelldrop" +local bullet_dps = 0 +local bullet_gravity = 0 +local bullet_glass_breaking = 0 +local bullet_particles = {} +local bullet_sparks = 0 +local bullet_bomb_ignite = 0 +local bullet_size = 0 +local bullet_glow = 20 + + + +if GunCaps ~= nil then +gun_damage = GunCaps.gun_damage or {fleshy=1} +gun_sound = GunCaps.gun_sound or "rangedweapons_glock" +gun_velocity = GunCaps.gun_velocity or 20 +gun_accuracy = GunCaps.gun_accuracy or 100 +gun_cooling = GunCaps.gun_cooling or itemstack:get_name() +gun_crit = GunCaps.gun_crit or 0 +gun_critEffc = GunCaps.gun_critEffc or 1 +gun_projectiles = GunCaps.gun_projectiles or 1 +gun_mobPen = GunCaps.gun_mob_penetration or 0 +gun_nodePen = GunCaps.gun_node_penetration or 0 +gun_shell = GunCaps.has_shell or 0 +gun_durability = GunCaps.gun_durability or 0 +gun_dps = GunCaps.gun_dps or 0 +gun_ammo_save = GunCaps.ammo_saving or 0 +gun_gravity = GunCaps.gun_gravity or 0 +gun_door_breaking = GunCaps.gun_door_breaking or 0 +gun_smokeSize = GunCaps.gun_smokeSize or 0 + +if GunCaps.gun_skill ~= nil then +gun_skill = GunCaps.gun_skill[1] or "" +gun_skillChance = GunCaps.gun_skill[2] or 0 +else +gun_skill = "" +gun_skillChance = 0 +end + +end + +if gun_skillChance > 0 and gun_skill ~= "" then +rangedweapons_gain_skill(player,gun_skill,gun_skillChance) +end + +local ammo_icon = "rangedweapons_emergency_ammo_icon.png" +if bulletStack:get_definition().inventory_image ~= nil then +ammo_icon = bulletStack:get_definition().inventory_image +end +player:hud_change(ammoimg, "text", ammo_icon) + +if AmmoCaps ~= nil then + +OnCollision = AmmoCaps.OnCollision or function()end +bullet_damage = AmmoCaps.ammo_damage or {fleshy=1} +bullet_velocity = AmmoCaps.ammo_velocity or 0 +bullet_ent = AmmoCaps.ammo_entity or "rangedweapons:shot_bullet" +bullet_visual = AmmoCaps.ammo_visual or "wielditem" +bullet_texture = AmmoCaps.ammo_texture or "rangedweapons:shot_bullet_visual" +bullet_crit = AmmoCaps.ammo_crit or 0 +bullet_critEffc = AmmoCaps.ammo_critEffc or 0 +bullet_projMult = AmmoCaps.ammo_projectile_multiplier or 1 +bullet_mobPen = AmmoCaps.ammo_mob_penetration or 0 +bullet_nodePen = AmmoCaps.ammo_node_penetration or 0 +bullet_shell_ent = AmmoCaps.shell_entity or "rangedweapons:empty_shell" +bullet_shell_visual = AmmoCaps.shell_visual or "wielditem" +bullet_shell_texture = AmmoCaps.shell_texture or "rangedweapons:shelldrop" +bullet_dps = AmmoCaps.ammo_dps or 0 +bullet_gravity = AmmoCaps.ammo_gravity or 0 +bullet_glass_breaking = AmmoCaps.ammo_glass_breaking or 0 +bullet_particles = AmmoCaps.ammo_particles or nil +bullet_sparks = AmmoCaps.has_sparks or 0 +bullet_bomb_ignite = AmmoCaps.ignites_explosives or 0 +bullet_size = AmmoCaps.ammo_projectile_size or 0.0025 +bullet_glow = AmmoCaps.ammo_projectile_glow or 20 +end + + +local combined_crit = gun_crit + bullet_crit +local combined_critEffc = gun_critEffc + bullet_critEffc +local combined_velocity = gun_velocity + bullet_velocity +local combined_projNum = math.ceil(gun_projectiles * bullet_projMult) +local combined_mobPen = gun_mobPen + bullet_mobPen +local combined_nodePen = gun_nodePen + bullet_nodePen +local combined_dps = gun_dps + bullet_dps +local combined_dmg = {} +local combined_gravity = gun_gravity + bullet_gravity + +for _, gunDmg in pairs(gun_damage) do +if bullet_damage[_] ~= nil then +combined_dmg[_] = gun_damage[_] + bullet_damage[_] +else +combined_dmg[_] = gun_damage[_] +end +end +for _, bulletDmg in pairs(bullet_damage) do +if gun_damage[_] == nil then +combined_dmg[_] = bullet_damage[_] +end +end + +--minetest.chat_send_all(minetest.serialize(combined_dmg)) + +if gun_skill ~= "" then +skill_value = playerMeta:get_int(gun_skill)/100 +else +skill_value = 1 +end + +rangedweapons_launch_projectile(player,combined_projNum,combined_dmg,bullet_ent,bullet_visual,bullet_texture,gun_sound,combined_velocity,gun_accuracy,skill_value,OnCollision,combined_crit,combined_critEffc,combined_mobPen,combined_nodePen,gun_shell,bullet_shell_ent,bullet_shell_texture,bullet_shell_visual,combined_dps,combined_gravity,gun_door_breaking,bullet_glass_breaking,bullet_particles,bullet_sparks,bullet_bomb_ignite,bullet_size,gun_smokeSize,0,bullet_glow) + +if rweapons_gun_durability == "true" then +itemstack:add_wear(65535/gun_durability) +end +itemstack:set_name(gun_cooling) + +end +end end + + + + +rangedweapons_shoot_powergun = function(itemstack, player) + +if minetest.find_node_near(player:getpos(), 10,"rangedweapons:antigun_block") +then +minetest.sound_play("rangedweapons_empty", {player}) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Guns are prohibited in this area!")) +else +local power_cooldown = 0 + +PowerCaps = itemstack:get_definition().RW_powergun_capabilities + +if PowerCaps ~= nil then +power_cooldown = PowerCaps.power_cooldown or 0 +power_consumption = PowerCaps.power_consumption or 0 +end + +local inv = player:get_inventory() +local playerMeta = player:get_meta() + +if inv:contains_item("main", "rangedweapons:power_particle "..PowerCaps.power_consumption) and +playerMeta:get_float("rw_cooldown") <= 0 then +playerMeta:set_float("rw_cooldown", power_cooldown) + +local OnCollision = function() end + +local power_damage = {fleshy=1} +local power_sound = "rangedweapons_laser" +local power_velocity = 20 +local power_accuracy = 100 +local power_cooling = 0 +local power_crit = 0 +local power_critEffc = 1 +local power_mobPen = 0 +local power_nodePen = 0 +local power_durability = 0 +local power_dps = 0 +local power_gravity = 0 +local power_door_breaking = 0 +local power_skill = "" +local power_skillChance = 0 +local power_ent = "rangedweapons:shot_bullet" +local power_visual = "wielditem" +local power_texture = "rangedweapons:shot_bullet_visual" +local power_glass_breaking = 0 +local power_particles = {} +local power_sparks = 0 +local power_bomb_ignite = 0 +local power_size = 0 +local power_glow = 20 + +if PowerCaps ~= nil then +power_damage = PowerCaps.power_damage or {fleshy=1} +power_sound = PowerCaps.power_sound or "rangedweapons_glock" +power_velocity = PowerCaps.power_velocity or 20 +power_accuracy = PowerCaps.power_accuracy or 100 +power_cooling = PowerCaps.power_cooling or itemstack:get_name() +power_crit = PowerCaps.power_crit or 0 +power_critEffc = PowerCaps.power_critEffc or 1 +power_projectiles = PowerCaps.power_projectiles or 1 +power_mobPen = PowerCaps.power_mob_penetration or 0 +power_nodePen = PowerCaps.power_node_penetration or 0 +power_durability = PowerCaps.power_durability or 0 +power_dps = PowerCaps.power_dps or 0 +power_gravity = PowerCaps.power_gravity or 0 +power_door_breaking = PowerCaps.power_door_breaking or 0 +OnCollision = PowerCaps.OnCollision or function()end +power_ent = PowerCaps.power_entity or "rangedweapons:shot_bullet" +power_visual = PowerCaps.power_visual or "wielditem" +power_texture = PowerCaps.power_texture or "rangedweapons:shot_bullet_visual" +power_glass_breaking = PowerCaps.power_glass_breaking or 0 +power_particles = PowerCaps.power_particles or nil +power_sparks = PowerCaps.has_sparks or 0 +power_bomb_ignite = PowerCaps.ignites_explosives or 0 +power_size = PowerCaps.power_projectile_size or 0.0025 +power_glow = PowerCaps.power_projectile_glow or 20 + +if PowerCaps.power_skill ~= nil then +power_skill = PowerCaps.power_skill[1] or "" +power_skillChance = PowerCaps.power_skill[2] or 0 +else +power_skill = "" +power_skillChance = 0 +end + +end + +if power_skillChance > 0 and power_skill ~= "" then +rangedweapons_gain_skill(player,power_skill,power_skillChance) +end + +if power_skill ~= "" then +skill_value = playerMeta:get_int(power_skill)/100 +else +skill_value = 1 +end + +rangedweapons_launch_projectile(player,power_projectiles,power_damage,power_ent,power_visual,power_texture,power_sound,power_velocity,power_accuracy,skill_value,OnCollision,power_crit,power_critEffc,power_mobPen,power_nodePen,0,"","","",power_dps,power_gravity,power_door_breaking,power_glass_breaking,power_particles,power_sparks,power_bomb_ignite,power_size,0,0,power_glow) + +if rweapons_gun_durability == "true" then +itemstack:add_wear(65535/power_durability) +end +itemstack:set_name(power_cooling) + +inv:remove_item("main", "rangedweapons:power_particle "..PowerCaps.power_consumption) + +end +end end + +rangedweapons_launch_projectile = function(player,projNum,projDmg,projEnt,visualType,texture,shoot_sound,combined_velocity,accuracy,skill_value,ColResult,projCrit,projCritEffc,mobPen,nodePen,has_shell,shellEnt,shellTexture,shellVisual,dps,gravity,door_break,glass_break,bullet_particles,sparks,ignite,size,smokeSize,proj_wear,proj_glow) + +--minetest.chat_send_all(accuracy) + +---------------------------------- + local pos = player:get_pos() + local dir = player:get_look_dir() + local yaw = player:get_look_yaw() + local svertical = player:get_look_vertical() + + if pos and dir and yaw then + minetest.sound_play(shoot_sound, {player}) + pos.y = pos.y + 1.45 + + if has_shell > 0 then + local shl = minetest.add_entity(pos, shellEnt) +shl:setvelocity({x=dir.x * -10, y=dir.y * -10, z=dir.z * -10}) +shl:setacceleration({x=dir.x * -5, y= -10, z=dir.z * -5}) +shl:set_rotation({x=0,y=yaw + math.pi,z=-svertical}) +shl:set_properties({ +textures = {shellTexture}, +visual = shellVisual,}) + end +if smokeSize > 0 then + minetest.add_particle({ + pos = pos, + velocity = {x=(dir.x*3)+(math.random(-10,10)/10), y=(dir.y*3)+(math.random(-10,10)/10), z=(dir.z*3)+(math.random(-10,10)/10)} , + acceleration = {x=dir.x * -3, y=2, z=dir.z * -3}, + expirationtime = math.random(5,10)/10, + size = smokeSize, + collisiondetection = false, + vertical = false, + texture = "tnt_smoke.png", + glow = 5, + }) +end + + projectiles = projNum or 1 + for i=1,projectiles do + rndacc = (100 - accuracy) or 0 +local spawnpos_x = pos.x + (math.random(-rndacc,rndacc)/100) +local spawnpos_y = pos.y + (math.random(-rndacc,rndacc)/100) +local spawnpos_z = pos.z + (math.random(-rndacc,rndacc)/100) + + local obj = minetest.add_entity({x=spawnpos_x,y=spawnpos_y,z=spawnpos_z}, projEnt) + local ent = obj:get_luaentity() + +obj:set_properties( +{textures = {texture}, +visual = visualType, +collisionbox = {-size,-size,-size, size,size,size}, +glow = proj_glow,} +) + ent.owner = player:get_player_name() + if obj then + ent.damage = projDmg + ent.crit = projCrit + ent.critEffc = projCritEffc + ent.OnCollision = ColResult + ent.mobPen = mobPen + ent.nodePen = nodePen + ent.dps = dps + ent.door_break = door_break + ent.glass_break = glass_break + ent.skill_value = skill_value + ent.bullet_particles = bullet_particles + ent.sparks = sparks + ent.ignite = ignite + ent.size = size + ent.timer = 0 + (combined_velocity/2000) + ent.wear = proj_wear + obj:set_velocity({x=dir.x * combined_velocity, y=dir.y * combined_velocity, z=dir.z * combined_velocity}) + acc = ((( 100 - accuracy ) / 10) / skill_value ) or 0 + obj:set_acceleration({x=math.random(-acc,acc), y=math.random(-acc,acc)-gravity, z=math.random(-acc,acc)}) +obj:set_rotation({x=0,y=yaw + math.pi,z=-svertical}) + end end end + + +end + +eject_shell = function(itemstack,player,rld_item,rld_time,rldsound,shell) + itemstack:set_name(rld_item) + local meta = player:get_meta() + meta:set_float("rw_cooldown", rld_time) + +local gunMeta = itemstack:get_meta() + +local bulletStack = ItemStack({name = gunMeta:get_string("RW_ammo_name")}) + +minetest.sound_play(rldsound, {player}) + local pos = player:get_pos() + local dir = player:get_look_dir() + local yaw = player:get_look_yaw() + if pos and dir and yaw then + pos.y = pos.y + 1.6 + local obj = minetest.add_entity(pos, "rangedweapons:empty_shell") + +if AmmoCaps and bulletStack ~= "" then +AmmoCaps = bulletStack:get_definition().RW_ammo_capabilities + +local bullet_shell_visual = "wielditem" +local bullet_shell_texture = "rangedweapons:shelldrop" + +bullet_shell_visual = AmmoCaps.shell_visual or "wielditem" +bullet_shell_texture = AmmoCaps.shell_texture or "rangedweapons:shelldrop" + +obj:set_properties({textures = {bullet_shell_texture}}) +obj:set_properties({visual = bullet_shell_visual}) + +end + if obj then +obj:set_velocity({x=dir.x*-10, y=dir.y*-10, z=dir.z*-10}) +obj:set_acceleration({x=dir.x*-5, y=-10, z=dir.z*-5}) + obj:set_yaw(yaw + math.pi) + end end end +--------------------------------------------------- + + + +dofile(modpath.."/settings.lua") +dofile(modpath.."/cooldown_stuff.lua") +dofile(modpath.."/skills.lua") +dofile(modpath.."/misc.lua") +dofile(modpath.."/bullet_knockback.lua") +dofile(modpath.."/ammo.lua") + + +if rweapons_shurikens == "true" then + dofile(modpath.."/shurikens.lua") +end + +if rweapons_handguns == "true" then + dofile(modpath.."/makarov.lua") + dofile(modpath.."/luger.lua") + dofile(modpath.."/beretta.lua") + dofile(modpath.."/m1991.lua") + dofile(modpath.."/glock17.lua") + dofile(modpath.."/deagle.lua") +end + +if rweapons_forceguns == "true" then + dofile(modpath.."/forcegun.lua") +end + +if rweapons_javelins == "true" then + dofile(modpath.."/javelin.lua") +end + +if rweapons_machine_pistols == "true" then + dofile(modpath.."/tmp.lua") + dofile(modpath.."/tec9.lua") + dofile(modpath.."/uzi.lua") + dofile(modpath.."/kriss_sv.lua") +end +if rweapons_shotguns == "true" then + dofile(modpath.."/remington.lua") + dofile(modpath.."/spas12.lua") + dofile(modpath.."/benelli.lua") +end +--[[if rweapons_auto_shotguns == "true" then + dofile(modpath.."/jackhammer.lua") + dofile(modpath.."/aa12.lua") +end +if rweapons_smgs == "true" then + dofile(modpath.."/mp5.lua") + dofile(modpath.."/ump.lua") + dofile(modpath.."/mp40.lua") + dofile(modpath.."/thompson.lua") +end +if rweapons_rifles == "true" then + dofile(modpath.."/awp.lua") + dofile(modpath.."/svd.lua") + dofile(modpath.."/m200.lua") +end +if rweapons_heavy_machineguns == "true" then + dofile(modpath.."/m60.lua") + dofile(modpath.."/rpk.lua") + dofile(modpath.."/minigun.lua") +end +if rweapons_revolvers == "true" then + dofile(modpath.."/python.lua") + dofile(modpath.."/taurus.lua") +end +if rweapons_assault_rifles == "true" then + dofile(modpath.."/m16.lua") + dofile(modpath.."/g36.lua") + dofile(modpath.."/ak47.lua") + dofile(modpath.."/scar.lua") +end + +if rweapons_explosives == "true" then + dofile(modpath.."/explosives.lua") + dofile(modpath.."/m79.lua") + dofile(modpath.."/milkor.lua") + dofile(modpath.."/rpg.lua") + dofile(modpath.."/hand_grenade.lua") +end]] + + +if rweapons_glass_breaking == "true" then + dofile(modpath.."/glass_breaking.lua") +end +if not minetest.settings:get_bool("glass_breaking") then +minetest.register_abm({ + nodenames = {"rangedweapons:broken_glass"}, + interval = 1, + chance = 1, + action = function(pos, node) + if minetest.get_node(pos).name == "rangedweapons:broken_glass" then + node.name = "main:planks" + minetest.set_node(pos, node) + end + end +}) +end + +local rangedweapons_empty_shell = { + physical = false, + timer = 0, + visual = "wielditem", + visual_size = {x=0.3, y=0.3}, + textures = {"rangedweapons:shelldrop"}, + lastpos= {}, + collisionbox = {0, 0, 0, 0, 0, 0}, +} +rangedweapons_empty_shell.on_step = function(self, dtime, pos) + self.timer = self.timer + dtime + local pos = self.object:get_pos() + local node = minetest.get_node(pos) + if self.lastpos.y ~= nil then + if minetest.registered_nodes[node.name]~= nil then + if minetest.registered_nodes[node.name].walkable then + local vel = self.object:get_velocity() + local acc = self.object:get_acceleration() + self.object:set_velocity({x=vel.x*-0.3, y=vel.y*-0.75, z=vel.z*-0.3}) + minetest.sound_play("rangedweapons_shellhit", {pos = self.lastpos, gain = 0.8}) + self.object:set_acceleration({x=acc.x, y=acc.y, z=acc.z}) + end end + end + if self.timer > 1.69 then + minetest.sound_play("rangedweapons_bulletdrop", {pos = self.lastpos, gain = 0.8}) + self.object:remove() + + end + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} +end + +minetest.register_entity("rangedweapons:empty_shell", rangedweapons_empty_shell ) + + +minetest.register_abm({ + nodenames = {"doors:hidden"}, + interval = 1, + chance = 1, + action = function(pos, node) + pos.y = pos.y-1 + if minetest.get_node(pos).name == "air" then + pos.y = pos.y+1 + node.name = "air" + minetest.set_node(pos, node) + end + end +}) + +minetest.register_on_joinplayer(function(player) + gunammo = + player:hud_add({ + hud_elem_type = "text", + name = "gunammo", + text = "", + number = 0xFFFFFF, + scale = {x = 100, y = 20}, + position = {x = 0.7, y = 0.1}, + offset = {x = 30, y = 100}, + alignment = {x = 0, y = -1} + }) + gunimg = + player:hud_add({ + hud_elem_type = "image", + text = "rangedweapons_empty_icon.png", + scale = {x = 2, y = 2}, + position = {x = 0.7, y = 0.065}, + offset = {x = 30, y = 100}, + alignment = {x = 0, y = -1} + }) + ammoimg = + player:hud_add({ + hud_elem_type = "image", + text = "rangedweapons_empty_icon.png", + scale = {x = 1.5, y = 1.5}, + position = {x = 0.725, y = 0.1}, + offset = {x = 30, y = 100}, + alignment = {x = 0, y = -1} + }) + hit = + player:hud_add({ + hud_elem_type = "image", + text = "rangedweapons_empty_icon.png", + scale = {x = 2, y = 2}, + position = {x = 0.5, y = 0.5}, + offset = {x = 0, y = 0}, + alignment = {x = 0, y = 0} + }) +scope_hud = + player:hud_add({ + hud_elem_type = "image", + position = { x=0.5, y=0.5 }, + scale = { x=-100, y=-100 }, + text = "rangedweapons_empty_icon.png", + }) +end) + + local timer = 0 +minetest.register_globalstep(function(dtime, player) + timer = timer + dtime; + if timer >= 1.0 then + for _, player in pairs(minetest.get_connected_players()) do +player:hud_change(hit, "text", "rangedweapons_empty_icon.png") + timer = 0 + end + end + end) + diff --git a/mods/rangedweapons/jackhammer.lua b/mods/rangedweapons/jackhammer.lua new file mode 100644 index 0000000..c1b9d71 --- /dev/null +++ b/mods/rangedweapons/jackhammer.lua @@ -0,0 +1,69 @@ + + +minetest.register_tool("rangedweapons:jackhammer_r", { + stack_max= 1, + wield_scale = {x=2.6,y=2.6,z=1.8}, + description = "", + rw_next_reload = "rangedweapons:jackhammer_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_jackhammer_rld.png", +}) +minetest.register_tool("rangedweapons:jackhammer_rr", { + stack_max= 1, + wield_scale = {x=2.6,y=2.6,z=1.8}, + description = "", + rw_next_reload = "rangedweapons:jackhammer_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_jackhammer.png", +}) +minetest.register_tool("rangedweapons:jackhammer_rrr", { + stack_max= 1, + wield_scale = {x=2.6,y=2.6,z=1.8}, + description = "", + rw_next_reload = "rangedweapons:jackhammer", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_jackhammer.png", +}) +------------------------------------------- + + minetest.register_tool("rangedweapons:jackhammer", { + stack_max= 1, + wield_scale = {x=2.6,y=2.6,z=1.8}, + description = "" ..core.colorize("#35cdff","Jackhammer\n") ..core.colorize("#FFFFFF", "Ranged damage: 3\n") ..core.colorize("#FFFFFF", "projectiles: 8\n") ..core.colorize("#FFFFFF", "Gun gravity: 3\n") ..core.colorize("#FFFFFF", "accuracy: 35%\n") ..core.colorize("#FFFFFF", "knockback: 6\n") ..core.colorize("#FFFFFF", "Reload delay: 1.6\n") ..core.colorize("#FFFFFF", "Clip size: 10\n") ..core.colorize("#FFFFFF", "Critical chance: 7%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.2x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shell\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.25 (full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 30"), + range = 0, + inventory_image = "rangedweapons_jackhammer.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=3,knockback=6}, + gun_crit = 7, + gun_critEffc = 2.2, + suitable_ammo = {{"rangedweapons:shell",10}}, + gun_skill = {"shotgun_skill",35}, + gun_magazine = "rangedweapons:drum_mag", + gun_icon = "rangedweapons_jackhammer_icon.png", + gun_unloaded = "rangedweapons:jackhammer_r", + gun_velocity = 30, + gun_accuracy = 35, + gun_cooldown = 0.25, + gun_reload = 1.6/4, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 825, + gun_smokeSize = 9, + gun_door_breaking = 1, + gun_projectiles = 8, + gun_gravity = 3, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_shotgun_shot", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) diff --git a/mods/rangedweapons/javelin - Copy.lua b/mods/rangedweapons/javelin - Copy.lua new file mode 100644 index 0000000..e126211 --- /dev/null +++ b/mods/rangedweapons/javelin - Copy.lua @@ -0,0 +1,139 @@ + + + +minetest.register_craftitem("rangedweapons:thrown_javelin", { + wield_scale = {x=2.0,y=2.0,z=1.0}, + inventory_image = "rangedweapons_thrown_javelin.png", +}) + +minetest.register_craftitem("rangedweapons:javelin", { + description = "" ..core.colorize("#35cdff","Javelin\n") ..core.colorize("#FFFFFF", "Mele damage: 9\n") ..core.colorize("#FFFFFF", "Mele range: 5\n")..core.colorize("#FFFFFF", "Full punch interval: 1.25\n") ..core.colorize("#FFFFFF", "Ranged damage: 4-16\n") ..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "Mob knockback: 10\n") ..core.colorize("#FFFFFF", "Critical chance: 15%\n") ..core.colorize("#FFFFFF", "Critical damage: 25-45\n") ..core.colorize("#FFFFFF", "javelin survival rate: 95%\n")..core.colorize("#FFFFFF", "Projectile gravity: 4\n") ..core.colorize("#FFFFFF", "Projectile velocity: 20\n")..core.colorize("#ffc000", "Right-click to throw, Left-click to stab") , + wield_scale = {x=2.0,y=2.0,z=1.0}, + range = 5, + stack_max= 10, + inventory_image = "rangedweapons_javelin.png", + on_secondary_use = function(itemstack, user, pointed_thing) + if not minetest.setting_getbool("creative_mode") then itemstack:take_item() + end + if pointed_thing.type ~= "nothing" then + local pointed = minetest.get_pointed_thing_position(pointed_thing) + if vector.distance(user:getpos(), pointed) < 8 then + return itemstack + end + end + local pos = user:getpos() + local dir = user:get_look_dir() + local yaw = user:get_look_yaw() + if pos and dir then + pos.y = pos.y + 1.5 + local obj = minetest.add_entity(pos, "rangedweapons:javelin") + if obj then + minetest.sound_play("rangedweapons_throw", {object=obj}) + obj:setvelocity({x=dir.x * 20, y=dir.y * 20, z=dir.z * 20}) + obj:setacceleration({x=dir.x * -1, y=-4, z=dir.z * -1}) + obj:setyaw(yaw + math.pi) + local ent = obj:get_luaentity() + if ent then + ent.player = ent.player or user + end + end + end + return itemstack + end, + tool_capabilities = { + full_punch_interval = 1.25, + max_drop_level = 0, + groupcaps = { + stabby = {times={[1]=0.25, [2]=0.50, [3]=0.75}, uses=0, maxlevel=1}, + }, + damage_groups = {fleshy=9,knockback=10}, + } +}) + +local rangedweapons_javelin = { + physical = false, + timer = 0, + visual = "wielditem", + visual_size = {x=0.5, y=0.5,}, + textures = {"rangedweapons:thrown_javelin"}, + lastpos= {}, + collisionbox = {0, 0, 0, 0, 0, 0}, +} +rangedweapons_javelin.on_step = function(self, dtime) + self.timer = self.timer + dtime + local pos = self.object:getpos() + local node = minetest.get_node(pos) + + if self.timer > 0.15 then + local objs = minetest.get_objects_inside_radius({x = pos.x, y = pos.y, z = pos.z}, 1) + for k, obj in pairs(objs) do + if obj:get_luaentity() ~= nil then + if obj:get_luaentity().name ~= "rangedweapons:javelin" and obj:get_luaentity().name ~= "__builtin:item" then + if math.random(1, 100) <= 15 then + local damage = math.random(25,45) + obj:punch(self.object, 1.0, { + full_punch_interval = 1.0, + damage_groups= {fleshy = damage, knockback=20}, + }, nil) + minetest.sound_play("crit", {pos = self.lastpos, gain = 0.8}) + self.object:remove() + if not minetest.setting_getbool("creative_mode") and math.random(1, 100) <= 95 then + minetest.add_item(self.lastpos, "rangedweapons:javelin") + end + else + local damage = math.random(4,16) + obj:punch(self.object, 1.0, { + full_punch_interval = 1.0, + damage_groups= {fleshy = damage, knockback=10}, + }, nil) + minetest.sound_play("default_dig_cracky", {pos = self.lastpos, gain = 0.8}) + self.object:remove() + if not minetest.setting_getbool("creative_mode") and math.random(1, 100) <= 95 then + minetest.add_item(self.lastpos, "rangedweapons:javelin") + end + end + end + else + + if math.random(1, 100) <= 15 then + local damage = math.random(25,45) + obj:punch(self.object, 1.0, { + full_punch_interval = 1.0, + damage_groups= {fleshy = damage}, + }, nil) + minetest.sound_play("crit", {pos = self.lastpos, gain = 0.8}) + self.object:remove() + if not minetest.setting_getbool("creative_mode") and math.random(1, 100) <= 95 then + minetest.add_item(self.lastpos, "rangedweapons:javelin") + end + else + local damage = math.random(4,16) + obj:punch(self.object, 1.0, { + full_punch_interval = 1.0, + damage_groups= {fleshy = damage}, + }, nil) + minetest.sound_play("default_dig_cracky", {pos = self.lastpos, gain = 0.8}) + self.object:remove() + if not minetest.setting_getbool("creative_mode") and math.random(1, 100) <= 95 then + minetest.add_item(self.lastpos, "rangedweapons:javelin") + end + end + end +end +end + if self.lastpos.x ~= nil then + if minetest.registered_nodes[node.name].walkable then + if not minetest.setting_getbool("creative_mode") and math.random(1, 100) <= 95 then + minetest.add_item(self.lastpos, "rangedweapons:javelin") + end + minetest.sound_play("default_dig_cracky", {pos = self.lastpos, gain = 0.8}) + self.object:remove() + end + end + self.lastpos= {x = pos.x, y = pos.y, z = pos.z} +end + +minetest.register_entity("rangedweapons:javelin", rangedweapons_javelin) + + + diff --git a/mods/rangedweapons/javelin.lua b/mods/rangedweapons/javelin.lua new file mode 100644 index 0000000..0bd6972 --- /dev/null +++ b/mods/rangedweapons/javelin.lua @@ -0,0 +1,58 @@ + + + +minetest.register_craftitem("rangedweapons:thrown_javelin", { + wield_scale = {x=2.0,y=2.0,z=1.0}, + inventory_image = "rangedweapons_thrown_javelin.png", +}) + +minetest.register_tool("rangedweapons:javelin", { + description = "" ..core.colorize("#35cdff","Javelin\n") ..core.colorize("#FFFFFF", "Melee damage: 8\n") ..core.colorize("#FFFFFF", "Melee range: 4.5\n")..core.colorize("#FFFFFF", "Full punch interval: 1.25\n") ..core.colorize("#FFFFFF", "Ranged damage: 9\n") ..core.colorize("#FFFFFF", "Accuracy: 92%\n") ..core.colorize("#FFFFFF", "knockback: 10\n") ..core.colorize("#FFFFFF", "Critical chance: 11%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.5x\n") ..core.colorize("#FFFFFF", "Projectile gravity: 6\n") ..core.colorize("#FFFFFF", "Projectile velocity: 35\n") ..core.colorize("#FFFFFF", "Enemy penetration: 50%\n") ..core.colorize("#ffc000", "Right-click to throw, Left-click to stab\n")..core.colorize("#ffc000", "Throwing wears the javelin out 5x faster than stabbing.") , + wield_scale = {x=2.0,y=2.0,z=1.0}, + range = 4.5, + inventory_image = "rangedweapons_javelin.png", + tool_capabilities = { + full_punch_interval = 1.25, + max_drop_level = 0, + groupcaps = { + stabby = {times={[1]=0.25, [2]=0.50, [3]=0.75}, uses=66.6, maxlevel=2}, + }, + damage_groups = {fleshy=8,knockback=10}, + }, +RW_throw_capabilities = { + throw_damage = {fleshy=9,knockback=10}, + throw_crit = 11, + throw_critEffc = 2.5, + throw_skill = {"throw_skill",20}, + throw_velocity = 40, + throw_accuracy = 92, + throw_cooldown = 0.0, + throw_projectiles = 1, + throw_gravity = 6, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 50, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:thrown_javelin", + throw_projectile_size = 0.15, + throw_glass_breaking = 1, + has_sparks = 1, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +local throwDur = 40 +if bullet.wear+(65535/throwDur) < 65535 then +javStack = {name="rangedweapons:javelin",wear=(bullet.wear)+(65535/throwDur)} +minetest.add_item(bullet.object:get_pos(),javStack) end end, + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) + + + + diff --git a/mods/rangedweapons/kriss_sv.lua b/mods/rangedweapons/kriss_sv.lua new file mode 100644 index 0000000..0eed7ab --- /dev/null +++ b/mods/rangedweapons/kriss_sv.lua @@ -0,0 +1,68 @@ + +minetest.register_tool("rangedweapons:kriss_sv_r", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.15}, + description = "", + rw_next_reload = "rangedweapons:kriss_sv_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_kriss_sv_rld.png", +}) + +minetest.register_tool("rangedweapons:kriss_sv_rr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.15}, + description = "", + rw_next_reload = "rangedweapons:kriss_sv_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_kriss_sv.png", +}) + +minetest.register_tool("rangedweapons:kriss_sv_rrr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.15}, + description = "", + rw_next_reload = "rangedweapons:kriss_sv", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_kriss_sv.png", +}) + + + minetest.register_tool("rangedweapons:kriss_sv", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.15}, + description = "" ..core.colorize("#35cdff","Kriss Super V\n") ..core.colorize("#FFFFFF", "Gun damage: 1\n") ..core.colorize("#FFFFFF", "accuracy: 60%\n") ..core.colorize("#FFFFFF", "Gun knockback: 0\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 6%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 1.85x\n") ..core.colorize("#FFFFFF", "Reload delay: 0.9\n") ..core.colorize("#FFFFFF", "Clip size: 33/33/13\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum/10mm auto/.45 acp\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.05\n") ..core.colorize("#FFFFFF", "Gun type: machine pistol\n") ..core.colorize("#FFFFFF", "Bullet velocity: 20"), + range = 0, + inventory_image = "rangedweapons_kriss_sv.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=1,knockback=0}, + gun_crit = 6, + gun_critEffc = 1.95, + suitable_ammo = {{"rangedweapons:9mm",33},{"rangedweapons:10mm",33},{"rangedweapons:45acp",13}}, + gun_skill = {"mp_skill",90}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_kriss_sv_icon.png", + gun_unloaded = "rangedweapons:kriss_sv_r", + gun_velocity = 20, + gun_accuracy = 60, + gun_cooldown = 0.05, + gun_reload = 0.9/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1750, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_machine_pistol", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) diff --git a/mods/rangedweapons/laser_blaster.lua b/mods/rangedweapons/laser_blaster.lua new file mode 100644 index 0000000..df6a627 --- /dev/null +++ b/mods/rangedweapons/laser_blaster.lua @@ -0,0 +1,46 @@ +minetest.register_craftitem("rangedweapons:blue_ray_visual", { + wield_scale = {x=1.75,y=1.75,z=1.75}, + inventory_image = "rangedweapons_blue_ray.png", +}) + + minetest.register_tool("rangedweapons:laser_blaster", { + stack_max= 1, + wield_scale = {x=1.15,y=1.15,z=1.15}, + description = "" ..core.colorize("#35cdff","Laser blaster\n") ..core.colorize("#FFFFFF", "Ranged damage: 15\n") ..core.colorize("#FFFFFF", "accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 0\n") ..core.colorize("#FFFFFF", "Critical chance: 10%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Power usage: 10\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.3\n") ..core.colorize("#FFFFFF", "Enemy penetration: 50%\n") ..core.colorize("#FFFFFF", "Gun type: power pistol\n") ..core.colorize("#FFFFFF", "Bullet velocity: 65"), + range = 0, + inventory_image = "rangedweapons_laser_blaster.png", +RW_powergun_capabilities = { + power_damage = {fleshy=15,knockback=0}, + power_crit = 10, + power_critEffc = 2.0, + power_skill = {"",1}, + power_cooling = "rangedweapons:laser_blaster", + power_velocity = 65, + power_accuracy = 100, + power_cooldown = 0.3, + power_projectiles = 1, + power_durability = 5000, + power_sound = "rangedweapons_laser", + power_glass_breaking = 1, + power_door_breaking = 1, + power_dps = 0, + power_mob_penetration = 50, + power_node_penetration = 0, + power_dps = 0, + power_consumption = 10, + power_entity = "rangedweapons:shot_bullet", + power_visual = "wielditem", + power_texture = "rangedweapons:blue_ray_visual", + power_projectile_size = 0.1, + has_sparks = 0, + ignites_explosives = 1, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_powergun(itemstack, user) +return itemstack + end, + +}) + + + diff --git a/mods/rangedweapons/laser_rifle.lua b/mods/rangedweapons/laser_rifle.lua new file mode 100644 index 0000000..108f912 --- /dev/null +++ b/mods/rangedweapons/laser_rifle.lua @@ -0,0 +1,38 @@ +minetest.register_craftitem("rangedweapons:red_ray_visual", { + wield_scale = {x=1.5,y=1.5,z=2.0}, + inventory_image = "rangedweapons_red_ray.png", +}) + + minetest.register_tool("rangedweapons:laser_rifle", { + wield_scale = {x=1.9,y=1.9,z=2.5}, + description = "" ..core.colorize("#35cdff","Laser rifle\n") ..core.colorize("#FFFFFF", "Ranged damage: 12\n") ..core.colorize("#FFFFFF", "accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 0\n") ..core.colorize("#FFFFFF", "Critical chance: 9%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Power usage: 8\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.1 (full-auto)\n") ..core.colorize("#FFFFFF", "Enemy penetration: 40%\n") ..core.colorize("#FFFFFF", "Gun type: power assault rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 60"), + range = 0, +RW_powergun_capabilities = { + automatic_gun = 1, + power_damage = {fleshy=12,knockback=0}, + power_crit = 9, + power_critEffc = 2.0, + power_skill = {"",1}, + power_cooling = "rangedweapons:laser_rifle", + power_velocity = 60, + power_accuracy = 100, + power_cooldown = 0.1, + power_projectiles = 1, + power_durability = 12500, + power_sound = "rangedweapons_laser", + power_glass_breaking = 1, + power_door_breaking = 1, + power_dps = 0, + power_mob_penetration = 40, + power_node_penetration = 0, + power_dps = 0, + power_consumption = 8, + power_entity = "rangedweapons:shot_bullet", + power_visual = "wielditem", + power_texture = "rangedweapons:red_ray_visual", + power_projectile_size = 0.075, + has_sparks = 0, + ignites_explosives = 1, + }, + inventory_image = "rangedweapons_laser_rifle.png", +}) diff --git a/mods/rangedweapons/laser_shotgun.lua b/mods/rangedweapons/laser_shotgun.lua new file mode 100644 index 0000000..3d4ab5f --- /dev/null +++ b/mods/rangedweapons/laser_shotgun.lua @@ -0,0 +1,39 @@ + minetest.register_tool("rangedweapons:laser_shotgun", { + stack_max= 1, + wield_scale = {x=2.0,y=2.0,z=1.75}, + description = "" ..core.colorize("#35cdff","Laser shotgun\n") ..core.colorize("#FFFFFF", "Ranged damage: 10\n") ..core.colorize("#FFFFFF", "accuracy: 40%\n") ..core.colorize("#FFFFFF", "projectiles: 6\n") ..core.colorize("#FFFFFF", "knockback: 0\n") ..core.colorize("#FFFFFF", "Critical chance: 8%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.2x\n") ..core.colorize("#FFFFFF", "Power usage: 30\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.5\n") ..core.colorize("#FFFFFF", "Enemy penetration: 40%\n") ..core.colorize("#FFFFFF", "Gun type: power pistol\n") ..core.colorize("#FFFFFF", "Bullet velocity: 55"), + range = 0, + inventory_image = "rangedweapons_laser_shotgun.png", +RW_powergun_capabilities = { + power_damage = {fleshy=10,knockback=0}, + power_crit = 8, + power_critEffc = 2.2, + power_skill = {"",1}, + power_cooling = "rangedweapons:laser_shotgun", + power_velocity = 55, + power_accuracy = 40, + power_cooldown = 0.5, + power_projectiles = 1, + power_durability = 2000, + power_sound = "rangedweapons_laser", + power_glass_breaking = 1, + power_door_breaking = 1, + power_dps = 0, + power_mob_penetration = 40, + power_node_penetration = 0, + power_dps = 0, + power_consumption = 30, + power_entity = "rangedweapons:shot_bullet", + power_visual = "sprite", + power_texture = "rangedweapons_green_ray.png", + power_projectile_size = 0.005, + power_projectiles = 6, + has_sparks = 0, + ignites_explosives = 1, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_powergun(itemstack, user) +return itemstack + end, + +}) \ No newline at end of file diff --git a/mods/rangedweapons/license.txt b/mods/rangedweapons/license.txt new file mode 100644 index 0000000..1113ff7 --- /dev/null +++ b/mods/rangedweapons/license.txt @@ -0,0 +1 @@ +cc-by-sa 4.0 \ No newline at end of file diff --git a/mods/rangedweapons/luger.lua b/mods/rangedweapons/luger.lua new file mode 100644 index 0000000..ab42244 --- /dev/null +++ b/mods/rangedweapons/luger.lua @@ -0,0 +1,78 @@ +------------reload-------------------- +minetest.register_tool("rangedweapons:luger_r", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + groups = {not_in_creative_inventory = 1}, + rw_next_reload = "rangedweapons:luger_rr", + load_sound = "rangedweapons_handgun_mag_in", + inventory_image = "rangedweapons_luger.png", +}) +minetest.register_tool("rangedweapons:luger_rr", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + groups = {not_in_creative_inventory = 1}, + rw_next_reload = "rangedweapons:luger_rrr", + load_sound = "rangedweapons_reload_a", + inventory_image = "rangedweapons_luger.png", +}) +minetest.register_tool("rangedweapons:luger_rrr", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + groups = {not_in_creative_inventory = 1}, + rw_next_reload = "rangedweapons:luger", + load_sound = "rangedweapons_reload_b", + inventory_image = "rangedweapons_luger_rld.png", +}) +minetest.register_tool("rangedweapons:luger_rld", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + loaded_gun = "rangedweapons:luger", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_luger_rld.png", +}) +-----------------gun-------------- + +minetest.register_tool("rangedweapons:luger", { + description = "" ..core.colorize("#35cdff","Luger P08\n") ..core.colorize("#FFFFFF", "Ranged damage: 4\n")..core.colorize("#FFFFFF", "Accuracy: 92%\n") ..core.colorize("#FFFFFF", "Gun knockback: 3\n") ..core.colorize("#FFFFFF", "Critical chance: 10%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2x\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum\n")..core.colorize("#FFFFFF", "Reload delay: 1.0\n")..core.colorize("#FFFFFF", "Clip size: 8\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.625\n") ..core.colorize("#FFFFFF", "Gun type: Handgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 20"), + range = 0, + wield_scale = {x=0.9,y=0.9,z=1.0}, + inventory_image = "rangedweapons_luger.png", + RW_gun_capabilities = { + gun_damage = {fleshy=4,knockback=3}, + gun_crit = 10, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:9mm",8}}, + gun_skill = {"handgun_skill",40}, + gun_magazine = "rangedweapons:handgun_mag_black", + gun_icon = "rangedweapons_luger_icon.png", + gun_unloaded = "rangedweapons:luger_r", + gun_cooling = "rangedweapons:luger_rld", + gun_velocity = 20, + gun_accuracy = 92, + gun_cooldown = 0.625, + gun_reload = 1.0/4, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 600, + gun_smokeSize = 5, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_glock", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + diff --git a/mods/rangedweapons/m16.lua b/mods/rangedweapons/m16.lua new file mode 100644 index 0000000..06dc147 --- /dev/null +++ b/mods/rangedweapons/m16.lua @@ -0,0 +1,73 @@ + + +minetest.register_tool("rangedweapons:m16_r", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:m16_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m16_rld.png", +}) + +minetest.register_tool("rangedweapons:m16_rr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:m16_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m16.png", +}) + +minetest.register_tool("rangedweapons:m16_rrr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:m16", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m16.png", +}) + + + minetest.register_tool("rangedweapons:m16", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "" ..core.colorize("#35cdff","m16\n") ..core.colorize("#FFFFFF", "Gun damage: 6\n") ..core.colorize("#FFFFFF", "accuracy: 75%\n") ..core.colorize("#FFFFFF", "Gun knockback: 4\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 11%\n")..core.colorize("#FFFFFF", "Critical efficiency: 2.75x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n") ..core.colorize("#FFFFFF", "Clip size: 20\n") ..core.colorize("#FFFFFF", "Ammunition: 5.56mm rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.067(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: assault rifle\n") +..core.colorize("#FFFFFF", "Enemy penetration: 10%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 35"), + range = 0, + inventory_image = "rangedweapons_m16.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=6,knockback=4}, + gun_crit = 11, + gun_critEffc = 2.75, + suitable_ammo = {{"rangedweapons:556mm",20}}, + gun_skill = {"arifle_skill",55}, + gun_magazine = "rangedweapons:assaultrifle_mag", + gun_icon = "rangedweapons_m16_icon.png", + gun_unloaded = "rangedweapons:m16_r", + gun_velocity = 35, + gun_accuracy = 75, + gun_cooldown = 0.067, + gun_reload = 1.0/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1350, + gun_smokeSize = 5, + gun_mob_penetration = 10, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_smg", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + + inventory_image = "rangedweapons_m16.png", +}) \ No newline at end of file diff --git a/mods/rangedweapons/m1991.lua b/mods/rangedweapons/m1991.lua new file mode 100644 index 0000000..696459a --- /dev/null +++ b/mods/rangedweapons/m1991.lua @@ -0,0 +1,78 @@ + + +minetest.register_tool("rangedweapons:m1991_rld", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "", + range = 0, + loaded_gun = "rangedweapons:m1991", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m1991_rld.png", +}) +minetest.register_tool("rangedweapons:m1991_r", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "", + rw_next_reload = "rangedweapons:m1991_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m1991.png", +}) +minetest.register_tool("rangedweapons:m1991_rr", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "", + rw_next_reload = "rangedweapons:m1991_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m1991.png", +}) +minetest.register_tool("rangedweapons:m1991_rrr", { + stack_max= 1, + wield_scale = {x=1.1,y=1.1,z=1.05}, + description = "", + rw_next_reload = "rangedweapons:m1991", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m1991_rld.png", +}) + +minetest.register_tool("rangedweapons:m1991", { + description = "" ..core.colorize("#35cdff","m1991\n") ..core.colorize("#FFFFFF", "Gun damage: 4\n")..core.colorize("#FFFFFF", "Accuracy: 92%\n") ..core.colorize("#FFFFFF", "gun knockback: 4\n") ..core.colorize("#FFFFFF", "Gun crit chance: 13%\n")..core.colorize("#FFFFFF", "Critical efficiency: 2.1x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n")..core.colorize("#FFFFFF", "Clip size: 8\n") ..core.colorize("#FFFFFF", "Ammunition: .45acp\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.4\n") ..core.colorize("#FFFFFF", "Gun type: Handgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + wield_scale = {x=1.1,y=1.1,z=1.05}, + range = 0, + inventory_image = "rangedweapons_m1991.png", +RW_gun_capabilities = { + gun_damage = {fleshy=4,knockback=4}, + gun_crit = 15, + gun_critEffc = 2.1, + suitable_ammo = {{"rangedweapons:45acp",8}}, + gun_skill = {"handgun_skill",40}, + gun_magazine = "rangedweapons:handgun_mag_black", + gun_icon = "rangedweapons_m1991_icon.png", + gun_unloaded = "rangedweapons:m1991_r", + gun_cooling = "rangedweapons:m1991_rld", + gun_velocity = 25, + gun_accuracy = 92, + gun_cooldown = 0.4, + gun_reload = 1.0/4, + gun_projectiles = 1, + has_shell = 1, + gun_durability = 1000, + gun_smokeSize = 5, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_beretta", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + diff --git a/mods/rangedweapons/m200.lua b/mods/rangedweapons/m200.lua new file mode 100644 index 0000000..231bc33 --- /dev/null +++ b/mods/rangedweapons/m200.lua @@ -0,0 +1,103 @@ + + +minetest.register_tool("rangedweapons:m200_uld", { + stack_max= 1, + wield_scale = {x=2.1,y=2.1,z=1.2}, + range = 0, + description = "" ..core.colorize("#35cdff","m200 intervention \n") ..core.colorize("#FFFFFF", "Ranged damage:22 + 75/sec of bullet lifetime\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 20\n") ..core.colorize("#FFFFFF", "Critical chance: 33%\n") ..core.colorize("#FFFFFF", "Critical efficiency: x3.25\n") ..core.colorize("#FFFFFF", "Ammunition: .408 chey tac\n") ..core.colorize("#FFFFFF", "Rate of fire: 1.5\n") ..core.colorize("#FFFFFF", "Reload time: 2.5\n") ..core.colorize("#FFFFFF", "Zoom: 15x\n") ..core.colorize("#be0d00", "Right-click to eject empty bullet shell\n") ..core.colorize("#FFFFFF", "Clip size: 7\n") ..core.colorize("#FFFFFF", "Enemy penetration:45%\n") ..core.colorize("#FFFFFF", "Block penetration:15%\n") ..core.colorize("#FFFFFF", "Gun type: Rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 80"), + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m200.png", + weapon_zoom = 7.5, + on_use = function(user) + minetest.sound_play("rangedweapons_empty", {user}) + end, +on_secondary_use = function(itemstack, user, pointed_thing) +eject_shell(itemstack,user,"rangedweapons:m200_rld",1.0,"rangedweapons_rifle_reload_a","rangedweapons:empty_shell") +return itemstack +end, +}) + + +minetest.register_tool("rangedweapons:m200_r", { + rw_next_reload = "rangedweapons:m200_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + wield_scale = {x=2.1,y=2.1,z=1.2}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m200_noclip.png", +}) +minetest.register_tool("rangedweapons:m200_rr", { + rw_next_reload = "rangedweapons:m200_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + wield_scale = {x=2.1,y=2.1,z=1.2}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m200.png", +}) +minetest.register_tool("rangedweapons:m200_rrr", { + rw_next_reload = "rangedweapons:m200", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + wield_scale = {x=2.1,y=2.1,z=1.2}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m200_rld.png", +}) + + +minetest.register_tool("rangedweapons:m200_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=2.1,y=2.1,z=1.2}, + description = "", + loaded_gun = "rangedweapons:m200", + loaded_sound = "rangedweapons_rifle_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m200_rld.png", +}) + + +minetest.register_tool("rangedweapons:m200", { + description = "" ..core.colorize("#35cdff","m200 intervention \n") ..core.colorize("#FFFFFF", "Ranged damage:22 + 75/sec of bullet lifetime\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 20\n") ..core.colorize("#FFFFFF", "Critical chance: 33%\n") ..core.colorize("#FFFFFF", "Critical efficiency: x3.25\n") ..core.colorize("#FFFFFF", "Ammunition: .408 chey tac\n") ..core.colorize("#FFFFFF", "Rate of fire: 1.5\n") ..core.colorize("#FFFFFF", "Reload time: 2.5\n") ..core.colorize("#FFFFFF", "Zoom: 15x\n") ..core.colorize("#27a600", "The gun is loaded!\n") ..core.colorize("#FFFFFF", "Clip size: 7\n") ..core.colorize("#FFFFFF", "Enemy penetration:45%\n") ..core.colorize("#FFFFFF", "Block penetration:15%\n") ..core.colorize("#FFFFFF", "Gun type: Rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 80"), + range = 0, + weapon_zoom = 6, + wield_scale = {x=2.1,y=2.1,z=1.2}, + inventory_image = "rangedweapons_m200.png", +RW_gun_capabilities = { + gun_damage = {fleshy=22,knockback=20}, + gun_crit = 33, + gun_critEffc = 3.25, + suitable_ammo = {{"rangedweapons:408cheytac",7}}, + gun_skill = {"rifle_skill",12}, + gun_magazine = "rangedweapons:rifle_mag", + gun_icon = "rangedweapons_m200_icon.png", + gun_unloaded = "rangedweapons:m200_r", + gun_cooling = "rangedweapons:m200_uld", + gun_velocity = 80, + gun_accuracy = 100, + gun_cooldown = 1.5, + gun_reload = 2.5/4, + gun_projectiles = 1, + has_shell = 0, + gun_durability = 900, + gun_smokeSize = 8, + gun_dps = 75, + gun_mob_penetration = 45, + gun_node_penetration = 15, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_rifle_b", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, + +}) + + diff --git a/mods/rangedweapons/m60.lua b/mods/rangedweapons/m60.lua new file mode 100644 index 0000000..0e322d4 --- /dev/null +++ b/mods/rangedweapons/m60.lua @@ -0,0 +1,53 @@ + +minetest.register_tool("rangedweapons:m60_r", { + stack_max= 1, + wield_scale = {x=2.0,y=2.0,z=1.4}, + description = "", + rw_next_reload = "rangedweapons:m60", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_m60_rld.png", +}) + + minetest.register_tool("rangedweapons:m60", { + stack_max= 1, + wield_scale = {x=2.0,y=2.0,z=1.4}, + description = "" ..core.colorize("#35cdff","m60\n") ..core.colorize("#FFFFFF", "Gun damage: 9\n") ..core.colorize("#FFFFFF", "accuracy: 65%\n") ..core.colorize("#FFFFFF", "Gun knockback: 7\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 13%\n")..core.colorize("#FFFFFF", "Critical efficiency: 3.0x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n") ..core.colorize("#FFFFFF", "Clip size: 100\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.09(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: heavy machinegun\n") ..core.colorize("#FFFFFF", "Block penetration: 12%\n") +..core.colorize("#FFFFFF", "Enemy penetration: 27%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 64"), + range = 0, + inventory_image = "rangedweapons_m60.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=9,knockback=7}, + gun_crit = 13, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:762mm",100}}, + gun_skill = {"heavy_skill",60}, + gun_icon = "rangedweapons_m60_icon.png", + gun_unloaded = "rangedweapons:m60_r", + gun_velocity = 64, + gun_accuracy = 65, + gun_cooldown = 0.09, + gun_reload = 1.0, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 2750, + gun_smokeSize = 5, + gun_mob_penetration = 27, + gun_node_penetration = 12, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_machinegun", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + + inventory_image = "rangedweapons_m60.png", +}) + + + + diff --git a/mods/rangedweapons/m79.lua b/mods/rangedweapons/m79.lua new file mode 100644 index 0000000..2bf48de --- /dev/null +++ b/mods/rangedweapons/m79.lua @@ -0,0 +1,51 @@ + +minetest.register_tool("rangedweapons:m79_r", { + stack_max= 1, + wield_scale = {x=2.0,y=2.0,z=2.5}, + range = 0, + description = "", + groups = {not_in_creative_inventory = 1}, + rw_next_reload = "rangedweapons:m79", + load_sound = "rangedweapons_reload_a", + inventory_image = "rangedweapons_m79_rld.png", +}) + +minetest.register_tool("rangedweapons:m79", { + description = "" ..core.colorize("#35cdff","m79\n") ..core.colorize("#FFFFFF", "Direct contact damage: 10\n")..core.colorize("#FFFFFF", "Accuracy: 92%\n") ..core.colorize("#FFFFFF", "direct contact knockback: 25\n") ..core.colorize("#FFFFFF", "Gun crit chance: 8%\n")..core.colorize("#FFFFFF", "Critical efficiency: 3x\n") ..core.colorize("#FFFFFF", "Reload delay: 0.9\n")..core.colorize("#FFFFFF", "Clip size: 1\n") ..core.colorize("#FFFFFF", "Gun gravity: 5\n")..core.colorize("#FFFFFF", "Ammunition: 40mm grenades\n")..core.colorize("#FFFFFF", "Gun type: grenade launcher\n") ..core.colorize("#FFFFFF", "Bullet velocity: 20"), + range = 0, + wield_scale = {x=2.0,y=2.0,z=2.5}, + inventory_image = "rangedweapons_m79.png", + RW_gun_capabilities = { + gun_damage = {fleshy=10,knockback=25}, + gun_crit = 8, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:40mm",1}}, + gun_skill = {"",1}, + gun_magazine = "rangedweapons:shell_grenadedrop", + gun_icon = "rangedweapons_m79_icon.png", + gun_unloaded = "rangedweapons:m79_r", + gun_cooling = "rangedweapons:m79", + gun_velocity = 20, + gun_accuracy = 92, + gun_cooldown = 0.0, + gun_reload = 0.9, + gun_projectiles = 1, + gun_smokeSize = 15, + gun_durability = 100, + gun_gravity = 5, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_rocket", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + + + + diff --git a/mods/rangedweapons/makarov.lua b/mods/rangedweapons/makarov.lua new file mode 100644 index 0000000..962e5b7 --- /dev/null +++ b/mods/rangedweapons/makarov.lua @@ -0,0 +1,82 @@ + + +minetest.register_tool("rangedweapons:makarov_rld", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + loaded_gun = "rangedweapons:makarov", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_makarov_rld.png", +}) +minetest.register_tool("rangedweapons:makarov_r", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:makarov_rr", + load_sound = "rangedweapons_handgun_mag_in", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_makarov.png", +}) + +minetest.register_tool("rangedweapons:makarov_rr", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:makarov_rrr", + load_sound = "rangedweapons_reload_a", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_makarov.png", +}) + +minetest.register_tool("rangedweapons:makarov_rrr", { + stack_max= 1, + wield_scale = {x=0.9,y=0.9,z=1.0}, + description = "", + range = 0, + groups = {not_in_creative_inventory = 1}, + rw_next_reload = "rangedweapons:makarov", + load_sound = "rangedweapons_reload_b", + inventory_image = "rangedweapons_makarov_rld.png", +}) + + +minetest.register_tool("rangedweapons:makarov", { + description = "" ..core.colorize("#35cdff","Makarov pistol\n") ..core.colorize("#FFFFFF", "Gun damage: 3\n")..core.colorize("#FFFFFF", "Accuracy: 90%\n") ..core.colorize("#FFFFFF", "gun knockback: 3\n") ..core.colorize("#FFFFFF", "Gun crit chance: 10%\n")..core.colorize("#FFFFFF", "Critical efficiency: 2x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.1\n")..core.colorize("#FFFFFF", "Clip size: 8\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm Parabellum\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.5\n") ..core.colorize("#FFFFFF", "Gun type: Handgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 20"), + range = 0, + wield_scale = {x=0.9,y=0.9,z=1.0}, + inventory_image = "rangedweapons_makarov.png", + RW_gun_capabilities = { + gun_damage = {fleshy=3,knockback=3}, + gun_crit = 10, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:9mm",8}}, + gun_skill = {"handgun_skill",40}, + gun_magazine = "rangedweapons:handgun_mag_black", + gun_icon = "rangedweapons_makarov_icon.png", + gun_unloaded = "rangedweapons:makarov_r", + gun_cooling = "rangedweapons:makarov_rld", + gun_velocity = 20, + gun_accuracy = 90, + gun_cooldown = 0.5, + gun_reload = 1.1/4, + gun_projectiles = 1, + gun_smokeSize = 5, + has_shell = 1, + gun_durability = 450, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_glock", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + + diff --git a/mods/rangedweapons/milkor.lua b/mods/rangedweapons/milkor.lua new file mode 100644 index 0000000..3575fb0 --- /dev/null +++ b/mods/rangedweapons/milkor.lua @@ -0,0 +1,47 @@ + +minetest.register_tool("rangedweapons:milkor_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.75,y=1.75,z=2.0}, + description = "", + loaded_gun = "rangedweapons:milkor", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_milkor_rld.png", +}) + + +minetest.register_tool("rangedweapons:milkor", { + description = "" ..core.colorize("#35cdff","Milkor MGL\n") ..core.colorize("#FFFFFF", "Direct contact damage: 15\n")..core.colorize("#FFFFFF", "Accuracy: 96%\n") ..core.colorize("#FFFFFF", "Direct contact knockback: 25\n") ..core.colorize("#FFFFFF", "Critical chance: 9%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 3.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 40mm grenades\n") ..core.colorize("#FFFFFF", "Reload time: 0.75\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.35\n") ..core.colorize("#FFFFFF", "Gun gravity: 1\n") ..core.colorize("#FFFFFF", "Clip Size: 6\n")..core.colorize("#FFFFFF", "Gun type: grenade launcher\n") ..core.colorize("#FFFFFF", "Bullet velocity: 30"), + range = 0, + wield_scale = {x=1.75,y=1.75,z=2.0}, + inventory_image = "rangedweapons_milkor.png", +RW_gun_capabilities = { + gun_damage = {fleshy=15,knockback=25}, + gun_crit = 9, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:40mm",6}}, + gun_skill = {"",1}, + gun_magazine = "rangedweapons:shell_grenadedrop", + gun_icon = "rangedweapons_milkor_icon.png", + gun_unloaded = "rangedweapons:milkor_rld", + gun_cooling = "rangedweapons:milkor", + gun_velocity = 30, + gun_accuracy = 96, + gun_cooldown = 0.35, + gun_reload = 0.75, + gun_projectiles = 1, + gun_durability = 225, + gun_smokeSize = 15, + gun_gravity = 1, + gun_unload_sound = "rangedweapons_shell_insert", + gun_sound = "rangedweapons_rocket", + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_single_load_gun(itemstack, user) +return itemstack +end, +}) diff --git a/mods/rangedweapons/minigun.lua b/mods/rangedweapons/minigun.lua new file mode 100644 index 0000000..52b86c3 --- /dev/null +++ b/mods/rangedweapons/minigun.lua @@ -0,0 +1,52 @@ +if minetest.settings:get_bool("minigun_aswell") then + +minetest.register_tool("rangedweapons:minigun_r", { + stack_max= 1, + wield_scale = {x=3.0,y=3.0,z=3.0}, + description = "", + rw_next_reload = "rangedweapons:minigun", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_minigun_rld.png", +}) + + minetest.register_tool("rangedweapons:minigun", { + stack_max= 1, + wield_scale = {x=3.0,y=3.0,z=3.0}, + description = "" ..core.colorize("#35cdff","minigun\n") ..core.colorize("#FFFFFF", "Gun damage: 10\n") ..core.colorize("#FFFFFF", "accuracy: 50%\n") ..core.colorize("#FFFFFF", "Gun knockback: 8\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 14%\n")..core.colorize("#FFFFFF", "Critical efficiency: 3.0x\n") ..core.colorize("#FFFFFF", "Reload delay: 2.0\n") ..core.colorize("#FFFFFF", "Clip size: 100\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.04(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: heavy machinegun\n") ..core.colorize("#FFFFFF", "Block penetration: 15%\n") +..core.colorize("#FFFFFF", "Enemy penetration: 33%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 70"), + range = 0, + inventory_image = "rangedweapons_minigun.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=10,knockback=8}, + gun_crit = 14, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:762mm",200}}, + gun_skill = {"heavy_skill",100}, + gun_icon = "rangedweapons_minigun_icon.png", + gun_unloaded = "rangedweapons:minigun_r", + gun_velocity = 70, + gun_accuracy = 50, + gun_cooldown = 0.04, + gun_reload = 2.0, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 4000, + gun_smokeSize = 5, + gun_mob_penetration = 33, + gun_node_penetration = 15, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_machinegun", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + + inventory_image = "rangedweapons_minigun.png", +}) + +end \ No newline at end of file diff --git a/mods/rangedweapons/misc.lua b/mods/rangedweapons/misc.lua new file mode 100644 index 0000000..7156dda --- /dev/null +++ b/mods/rangedweapons/misc.lua @@ -0,0 +1,50 @@ + + +minetest.register_craftitem("rangedweapons:shell_shotgundrop", { + wield_scale = {x=2.5,y=1.5,z=1.0}, + inventory_image = "rangedweapons_shelldrop_shotgun.png", +}) + +minetest.register_craftitem("rangedweapons:shell_whitedrop", { + wield_scale = {x=2.5,y=1.5,z=1.0}, + inventory_image = "rangedweapons_shelldrop_white.png", +}) + +minetest.register_craftitem("rangedweapons:shell_grenadedrop", { + wield_scale = {x=2.5,y=1.5,z=3.0}, + inventory_image = "rangedweapons_shelldrop_grenade.png", +}) + +minetest.register_craftitem("rangedweapons:shelldrop", { + wield_scale = {x=2.5,y=1.5,z=1.0}, + inventory_image = "rangedweapons_shelldrop.png", +}) + +minetest.register_craftitem("rangedweapons:plastic_sheet", { + description = "" ..core.colorize("#35cdff","Black plastic sheet\n")..core.colorize("#FFFFFF", "Used in guncraft"), + inventory_image = "rangedweapons_plastic_sheet.png", +}) + +minetest.register_craftitem("rangedweapons:gunsteel_ingot", { + description = "" ..core.colorize("#35cdff","GunSteel ingot\n")..core.colorize("#FFFFFF", "A strong, but light alloy, used in guncraft"), + inventory_image = "rangedweapons_gunsteel_ingot.png", +}) + +minetest.register_craftitem("rangedweapons:ultra_gunsteel_ingot", { + description = "" ..core.colorize("#35cdff","Ultra-GunSteel ingot\n")..core.colorize("#FFFFFF", "A even stronger alloy, for even stronger guns."), + inventory_image = "rangedweapons_ultra_gunsteel_ingot.png", +}) + +minetest.register_craftitem("rangedweapons:gun_power_core", { + description = "" ..core.colorize("#35cdff","Gun Power Core\n")..core.colorize("#FFFFFF", "A powerful core, for making the most powerful weapons"), + inventory_image = "rangedweapons_gun_power_core.png", +}) + +minetest.register_craftitem("rangedweapons:power_particle", { + description = "" ..core.colorize("#35cdff","Power Particle\n")..core.colorize("#FFFFFF", "A power unit, that strangelly can be carryed arround with no vessel, used by power guns"), + stack_max = 10000, + inventory_image = "rangedweapons_power_particle.png", +}) + + + diff --git a/mods/rangedweapons/mod.conf b/mods/rangedweapons/mod.conf new file mode 100644 index 0000000..79426e0 --- /dev/null +++ b/mods/rangedweapons/mod.conf @@ -0,0 +1,3 @@ +name = rangedweapons +description = A mod that adds guns and throwable weapons +optional_depends = doors, xpanes, vessels, moreores, 3d_armor diff --git a/mods/rangedweapons/mp40.lua b/mods/rangedweapons/mp40.lua new file mode 100644 index 0000000..84764d6 --- /dev/null +++ b/mods/rangedweapons/mp40.lua @@ -0,0 +1,63 @@ + + minetest.register_tool("rangedweapons:mp40_r", { + wield_scale = {x=1.75,y=1.75,z=1.5}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:mp40_rr", + load_sound = "rangedweapons_handgun_mag_in", + inventory_image = "rangedweapons_mp40_rld.png", + groups = {not_in_creative_inventory = 1}, +}) + minetest.register_tool("rangedweapons:mp40_rr", { + wield_scale = {x=1.75,y=1.75,z=1.5}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:mp40_rrr", + load_sound = "rangedweapons_reload_a", + inventory_image = "rangedweapons_mp40.png", + groups = {not_in_creative_inventory = 1}, +}) + minetest.register_tool("rangedweapons:mp40_rrr", { + wield_scale = {x=1.75,y=1.75,z=1.5}, + description = "", + range = 0, + inventory_image = "rangedweapons_mp40.png", + rw_next_reload = "rangedweapons:mp40", + load_sound = "rangedweapons_reload_b", + groups = {not_in_creative_inventory = 1}, +}) + + minetest.register_tool("rangedweapons:mp40", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.5}, + description = "" ..core.colorize("#35cdff","MP-40\n") ..core.colorize("#FFFFFF", "Ranged damage: 2\n") ..core.colorize("#FFFFFF", "accuracy: 75%\n") ..core.colorize("#FFFFFF", "Gun knockback: 1\n") ..core.colorize("#FFFFFF", "Critical chance: 8%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2x\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum\n") ..core.colorize("#FFFFFF", "Clip size: 32\n") ..core.colorize("#FFFFFF", "Reload delay: 1.3\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.14\n") ..core.colorize("#FFFFFF", "Gun type: sub-machinegun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + range = 0, + inventory_image = "rangedweapons_mp40.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=2,knockback=1}, + gun_crit = 8, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:9mm",32}}, + gun_skill = {"smg_skill",75}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_mp40_icon.png", + gun_unloaded = "rangedweapons:mp40_r", + gun_velocity = 25, + gun_accuracy = 75, + gun_cooldown = 0.14, + gun_reload = 1.3/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1500, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_machine_pistol", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + +}) diff --git a/mods/rangedweapons/mp5.lua b/mods/rangedweapons/mp5.lua new file mode 100644 index 0000000..e6205b7 --- /dev/null +++ b/mods/rangedweapons/mp5.lua @@ -0,0 +1,68 @@ + +minetest.register_tool("rangedweapons:mp5_r", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.20}, + description = "", + rw_next_reload = "rangedweapons:mp5_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_mp5_rld.png", +}) + +minetest.register_tool("rangedweapons:mp5_rr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.20}, + description = "", + rw_next_reload = "rangedweapons:mp5_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_mp5.png", +}) + +minetest.register_tool("rangedweapons:mp5_rrr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.20}, + description = "", + rw_next_reload = "rangedweapons:mp5", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_mp5.png", +}) + + + minetest.register_tool("rangedweapons:mp5", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.20}, + description = "" ..core.colorize("#35cdff","MP5\n") ..core.colorize("#FFFFFF", "Gun damage: 3\n") ..core.colorize("#FFFFFF", "accuracy: 74%\n") ..core.colorize("#FFFFFF", "Gun knockback: 1\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 7%\n")..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n") ..core.colorize("#FFFFFF", "Clip size: 40/40\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum/10mm auto\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.075(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: sub-machinegun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + range = 0, + inventory_image = "rangedweapons_mp5.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=3,knockback=1}, + gun_crit = 7, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:9mm",40},{"rangedweapons:10mm",40}}, + gun_skill = {"smg_skill",75}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_mp5_icon.png", + gun_unloaded = "rangedweapons:mp5_r", + gun_velocity = 25, + gun_accuracy = 74, + gun_cooldown = 0.075, + gun_reload = 1.0/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1600, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_machine_pistol", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) diff --git a/mods/rangedweapons/python.lua b/mods/rangedweapons/python.lua new file mode 100644 index 0000000..6544bec --- /dev/null +++ b/mods/rangedweapons/python.lua @@ -0,0 +1,52 @@ + + + + +minetest.register_tool("rangedweapons:python_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.25,y=1.25,z=1.1}, + description = "", + loaded_gun = "rangedweapons:python", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_python_rld.png", +}) + + +minetest.register_tool("rangedweapons:python", { + description = "" ..core.colorize("#35cdff","Colt Python \n") ..core.colorize("#FFFFFF", "Ranged damage: 10\n")..core.colorize("#FFFFFF", "Accuracy: 95%\n") ..core.colorize("#FFFFFF", "Gun knockback: 6\n") ..core.colorize("#FFFFFF", "Critical chance: 19%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.5x\n") ..core.colorize("#FFFFFF", "Ammunition: .357 Magnum rounds\n") ..core.colorize("#FFFFFF", "Reload time: 0.25\n") ..core.colorize("#FFFFFF", "Clip Size: 6\n")..core.colorize("#FFFFFF", "Gun type: Revolver\n")..core.colorize("#FFFFFF", "Block penetration: 5%\n") +..core.colorize("#FFFFFF", "penetration: 15%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 55"), + range = 0, + wield_scale = {x=1.25,y=1.25,z=1.1}, + inventory_image = "rangedweapons_python.png", +RW_gun_capabilities = { + gun_damage = {fleshy=10,knockback=6}, + gun_crit = 19, + gun_critEffc = 2.2, + suitable_ammo = {{"rangedweapons:357",6}}, + gun_skill = {"revolver_skill",40}, + gun_icon = "rangedweapons_python_icon.png", + gun_unloaded = "rangedweapons:python_rld", + gun_cooling = "rangedweapons:python", + gun_velocity = 55, + gun_accuracy = 95, + gun_cooldown = 0.2, + gun_reload = 0.4, + gun_projectiles = 1, + gun_durability = 1000, + gun_smokeSize = 7, + gun_mob_penetration = 15, + gun_node_penetration = 5, + gun_unload_sound = "rangedweapons_shell_insert", + gun_sound = "rangedweapons_deagle", + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_single_load_gun(itemstack, user) +return itemstack +end, +}) + diff --git a/mods/rangedweapons/remington.lua b/mods/rangedweapons/remington.lua new file mode 100644 index 0000000..f9f8283 --- /dev/null +++ b/mods/rangedweapons/remington.lua @@ -0,0 +1,64 @@ +minetest.register_tool("rangedweapons:remington_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + loaded_gun = "rangedweapons:remington", + loaded_sound = "rangedweapons_shotgun_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_remington_rld.png", +}) + +minetest.register_tool("rangedweapons:remington", { + description = "" ..core.colorize("#35cdff","Remington 870\n") ..core.colorize("#FFFFFF", "Ranged damage: 1\n") ..core.colorize("#FFFFFF", "projectiles: 4\n") ..core.colorize("#FFFFFF", "Gun gravity: 5\n") ..core.colorize("#FFFFFF", "Accuracy: 40%\n")..core.colorize("#FFFFFF", "knockback: 5\n") ..core.colorize("#FFFFFF", "Critical chance: 4%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shells\n") ..core.colorize("#FFFFFF", "Pump delay: 0.8\n")..core.colorize("#FFFFFF", "Clip size: 4\n") ..core.colorize("#27a600", "Gun is ready to fire!\n") ..core.colorize("#fff21c", "Right-click to load in a bullet!\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 18"), + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + inventory_image = "rangedweapons_remington.png", +RW_gun_capabilities = { + gun_damage = {fleshy=1,knockback=5}, + gun_crit = 4, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:shell",4}}, + gun_skill = {"shotgun_skill",20}, + gun_icon = "rangedweapons_remington_icon.png", + gun_unloaded = "rangedweapons:remington_rld", + gun_cooling = "rangedweapons:remington_uld", + gun_velocity = 18, + gun_accuracy = 40, + gun_cooldown = 0.8, + gun_gravity = 5, + gun_reload = 0.25, + gun_projectiles = 4, + has_shell = 0, + gun_durability = 275, + gun_smokeSize = 14, + gun_door_breaking = 1, + gun_sound = "rangedweapons_shotgun_shot", + gun_unload_sound = "rangedweapons_shell_insert", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_single_load_gun(itemstack, user, "") +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + +minetest.register_tool("rangedweapons:remington_uld", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.1}, + range = 0, + description = "" ..core.colorize("#35cdff","Remington 870\n") ..core.colorize("#FFFFFF", "Ranged damage: 1\n") ..core.colorize("#FFFFFF", "projectiles: 4\n") ..core.colorize("#FFFFFF", "Gun gravity: 5\n") ..core.colorize("#FFFFFF", "Accuracy: 40%\n")..core.colorize("#FFFFFF", "knockback: 5\n") ..core.colorize("#FFFFFF", "Critical chance: 4%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shells\n") ..core.colorize("#FFFFFF", "Pump delay: 0.8\n")..core.colorize("#FFFFFF", "Clip size: 4\n") ..core.colorize("#be0d00", "Right-click, to eject the empty shell!\n") ..core.colorize("#fff21c", "Right-click to load in a bullet!\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 20"), + inventory_image = "rangedweapons_remington.png", + groups = {not_in_creative_inventory = 1}, + on_use = function(user) + minetest.sound_play("rangedweapons_empty", {user}) + end, +on_secondary_use = function(itemstack, user, pointed_thing) +eject_shell(itemstack,user,"rangedweapons:remington_rld",0.8,"rangedweapons_shotgun_reload_a","rangedweapons:empty_shell") +return itemstack +end, +}) + diff --git a/mods/rangedweapons/rpg.lua b/mods/rangedweapons/rpg.lua new file mode 100644 index 0000000..6ad5e03 --- /dev/null +++ b/mods/rangedweapons/rpg.lua @@ -0,0 +1,74 @@ +minetest.register_tool("rangedweapons:rpg_rld", { + description = "" ..core.colorize("#35cdff","rpg7\n") ..core.colorize("#FFFFFF", "Direct contact damage: 20\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "direct contact knockback: 35\n") ..core.colorize("#FFFFFF", "Gun crit chance: 10%\n")..core.colorize("#FFFFFF", "Critical efficiency: 3x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n")..core.colorize("#FFFFFF", "Clip size: 1\n") ..core.colorize("#FFFFFF", "Gun gravity: 5\n")..core.colorize("#FFFFFF", "Ammunition: rockets\n")..core.colorize("#FFFFFF", "Gun type: rocket launcher\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + range = 0, + wield_scale = {x=2.5,y=2.5,z=3.75}, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_rpg_rld.png", + RW_gun_capabilities = { + gun_damage = {fleshy=20,knockback=35}, + gun_crit = 10, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:rocket",1}}, + gun_skill = {"",1}, + gun_icon = "rangedweapons_rpg_icon.png", + gun_unloaded = "rangedweapons:rpg_rld", + gun_cooling = "rangedweapons:rpg", + gun_velocity = 25, + gun_accuracy = 100, + gun_cooldown = 1.0, + gun_reload = 1.0, + gun_projectiles = 1, + gun_smokeSize = 15, + gun_durability = 150, + gun_unload_sound = "", + gun_sound = "rangedweapons_rocket", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + +minetest.register_tool("rangedweapons:rpg", { + description = "" ..core.colorize("#35cdff","rpg7\n") ..core.colorize("#FFFFFF", "Direct contact damage: 20\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "direct contact knockback: 35\n") ..core.colorize("#FFFFFF", "Gun crit chance: 10%\n")..core.colorize("#FFFFFF", "Critical efficiency: 3x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n")..core.colorize("#FFFFFF", "Clip size: 1\n") ..core.colorize("#FFFFFF", "Gun gravity: 5\n")..core.colorize("#FFFFFF", "Ammunition: rockets\n")..core.colorize("#FFFFFF", "Gun type: rocket launcher\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + range = 0, + wield_scale = {x=2.5,y=2.5,z=3.75}, + inventory_image = "rangedweapons_rpg.png", + RW_gun_capabilities = { + gun_damage = {fleshy=20,knockback=35}, + gun_crit = 10, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:rocket",1}}, + gun_skill = {"",1}, + gun_icon = "rangedweapons_rpg_icon.png", + gun_unloaded = "rangedweapons:rpg_rld", + gun_cooling = "rangedweapons:rpg", + gun_velocity = 25, + gun_accuracy = 100, + gun_cooldown = 1.0, + gun_reload = 1.0, + gun_projectiles = 1, + gun_smokeSize = 15, + gun_durability = 150, + gun_unload_sound = "", + gun_sound = "rangedweapons_rocket", + gun_unload_sound = "rangedweapons_shell_insert", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + + + + + diff --git a/mods/rangedweapons/rpk.lua b/mods/rangedweapons/rpk.lua new file mode 100644 index 0000000..a365505 --- /dev/null +++ b/mods/rangedweapons/rpk.lua @@ -0,0 +1,76 @@ + +minetest.register_tool("rangedweapons:rpk_r", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:rpk_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_rpk_rld.png", +}) + +minetest.register_tool("rangedweapons:rpk_rr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:rpk_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_rpk.png", +}) + +minetest.register_tool("rangedweapons:rpk_rrr", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "", + rw_next_reload = "rangedweapons:rpk", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_rpk.png", +}) + + + minetest.register_tool("rangedweapons:rpk", { + stack_max= 1, + wield_scale = {x=1.75,y=1.75,z=1.3}, + description = "" ..core.colorize("#35cdff","rpk\n") ..core.colorize("#FFFFFF", "Gun damage: 7\n") ..core.colorize("#FFFFFF", "accuracy: 60%\n") ..core.colorize("#FFFFFF", "Gun knockback: 6\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 12%\n")..core.colorize("#FFFFFF", "Critical efficiency: 3.0x\n") ..core.colorize("#FFFFFF", "Reload delay: 2.0\n") ..core.colorize("#FFFFFF", "Clip size: 75\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm rounds\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.10(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: heavy machinegun\n") ..core.colorize("#FFFFFF", "Block penetration: 10%\n") +..core.colorize("#FFFFFF", "Enemy penetration: 25%\n") ..core.colorize("#FFFFFF", "Bullet velocity: 55"), + range = 0, + inventory_image = "rangedweapons_rpk.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=7,knockback=6}, + gun_crit = 12, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:762mm",75}}, + gun_skill = {"heavy_skill",55}, + gun_magazine = "rangedweapons:drum_mag", + gun_icon = "rangedweapons_rpk_icon.png", + gun_unloaded = "rangedweapons:rpk_r", + gun_velocity = 55, + gun_accuracy = 70, + gun_cooldown = 0.1, + gun_reload = 2.0/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 2250, + gun_smokeSize = 5, + gun_mob_penetration = 25, + gun_node_penetration = 10, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_ak", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + + inventory_image = "rangedweapons_rpk.png", +}) + + + diff --git a/mods/rangedweapons/scar.lua b/mods/rangedweapons/scar.lua new file mode 100644 index 0000000..5a3d6c5 --- /dev/null +++ b/mods/rangedweapons/scar.lua @@ -0,0 +1,75 @@ + +minetest.register_tool("rangedweapons:scar_r", { + stack_max= 1, + wield_scale = {x=1.7,y=1.7,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:scar_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_scar_rld.png", +}) + +minetest.register_tool("rangedweapons:scar_rr", { + stack_max= 1, + wield_scale = {x=1.7,y=1.7,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:scar_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_scar.png", +}) + +minetest.register_tool("rangedweapons:scar_rrr", { + stack_max= 1, + wield_scale = {x=1.7,y=1.7,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:scar", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_scar.png", +}) + + minetest.register_tool("rangedweapons:scar", { + stack_max= 1, + wield_scale = {x=1.7,y=1.7,z=1.25}, + description = "" ..core.colorize("#35cdff","FN SCAR 16\n") ..core.colorize("#FFFFFF", "Ranged damage: 9\n") ..core.colorize("#FFFFFF", "Accuracy: 85%\n") ..core.colorize("#FFFFFF", "Gun knockback: 6\n")..core.colorize("#FFFFFF", "Critical chance: 11%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.75x\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm rounds/5.56mm rounds\n") ..core.colorize("#FFFFFF", "Reload delay: 1.2\n") ..core.colorize("#FFFFFF", "Clip size: 20/30\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.15\n") ..core.colorize("#FFFFFF", "Block penetration: 7%\n") +..core.colorize("#FFFFFF", "penetration: 20%\n") ..core.colorize("#FFFFFF", "Gun type: Assault rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 45"), + range = 0, + inventory_image = "rangedweapons_scar.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=9,knockback=6}, + gun_crit = 11, + gun_critEffc = 2.75, + suitable_ammo = {{"rangedweapons:762mm",20},{"rangedweapons:556mm",30}}, + gun_skill = {"arifle_skill",50}, + gun_magazine = "rangedweapons:assaultrifle_mag", + gun_icon = "rangedweapons_scar_icon.png", + gun_unloaded = "rangedweapons:scar_r", + gun_velocity = 45, + gun_accuracy = 85, + gun_cooldown = 0.15, + gun_reload = 1.2/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1600, + gun_smokeSize = 5, + gun_mob_penetration = 20, + gun_node_penetration = 7, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_ak", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + inventory_image = "rangedweapons_scar.png", +}) + + + + diff --git a/mods/rangedweapons/settings.lua b/mods/rangedweapons/settings.lua new file mode 100644 index 0000000..c6afa1a --- /dev/null +++ b/mods/rangedweapons/settings.lua @@ -0,0 +1,29 @@ + +rweapons_player_dmg_multiplier = 1.0 +rweapons_mob_dmg_multiplier = 1.0 +rweapons_headshot_dmg_multiplier = 1.75 +rweapons_max_gun_efficiency = 300 +rweapons_min_gun_efficiency = 40 +rweapons_bloodyness = 10 + +rweapons_gun_crafting = "true" +rweapons_gun_durability = "true" +rweapons_shurikens = "true" +rweapons_handguns = "true" +rweapons_forceguns = "true" +rweapons_javelins = "true" +rweapons_power_weapons = "true" +rweapons_machine_pistols = "true" +rweapons_shotguns = "true" +rweapons_auto_shotguns = "true" +rweapons_smgs = "true" +rweapons_rifles = "true" +rweapons_assault_rifles = "true" +rweapons_heavy_machineguns = "true" +rweapons_revolvers = "true" +rweapons_explosives = "true" +rweapons_glass_breaking = "true" +rweapons_door_breaking = "true" +rweapons_other_weapon_crafting = "true" +rweapons_ammo_crafting = "true" +rweapons_item_crafting = "true" diff --git a/mods/rangedweapons/shurikens.lua b/mods/rangedweapons/shurikens.lua new file mode 100644 index 0000000..ef941a9 --- /dev/null +++ b/mods/rangedweapons/shurikens.lua @@ -0,0 +1,269 @@ + + +minetest.register_craftitem("rangedweapons:wooden_shuriken", { + description = "" ..core.colorize("#35cdff","Wooden shuriken\n") ..core.colorize("#FFFFFF", "Ranged damage: 2\n") ..core.colorize("#FFFFFF", "Accuracy: 80%\n") ..core.colorize("#FFFFFF", "knockback: 5\n") ..core.colorize("#FFFFFF", "Critical chance: 6%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2x\n") ..core.colorize("#FFFFFF", "Shuriken survival rate: 10%\n") ..core.colorize("#FFFFFF", "Projectile gravity: 10\n") ..core.colorize("#FFFFFF", "Throwing cooldown: 0.35\n") ..core.colorize("#FFFFFF", "Projectile velocity: 25"), + range = 0, + stack_max= 100, + wield_scale = {x=0.6,y=0.6,z=0.5}, + inventory_image = "rangedweapons_wooden_shuriken.png", + RW_throw_capabilities = { + throw_damage = {fleshy=2,knockback=5}, + throw_crit = 6, + throw_critEffc = 2.0, + throw_skill = {"throw_skill",35}, + throw_velocity = 25, + throw_accuracy = 80, + throw_cooldown = 0.35, + throw_projectiles = 1, + throw_gravity = 10, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 0, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:wooden_shuriken", + throw_projectile_size = 0.15, + throw_glass_breaking = 0, + has_sparks = 0, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +if math.random(1, 100) <= 10 then +minetest.add_item(bullet.object:get_pos(), "rangedweapons:wooden_shuriken") end end, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) + + +minetest.register_craftitem("rangedweapons:stone_shuriken", { + description = "" ..core.colorize("#35cdff","Stone shuriken\n") ..core.colorize("#FFFFFF", "Ranged damage: 4\n") ..core.colorize("#FFFFFF", "Accuracy: 75%\n") ..core.colorize("#FFFFFF", "knockback: 8\n") ..core.colorize("#FFFFFF", "Critical chance: 7%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.1x\n") ..core.colorize("#FFFFFF", "Shuriken survival rate: 15%\n") ..core.colorize("#FFFFFF", "Projectile gravity: 15\n") ..core.colorize("#FFFFFF", "Throwing cooldown: 0.35\n") ..core.colorize("#FFFFFF", "Projectile velocity: 20"), + range = 0, + stack_max= 125, + wield_scale = {x=0.6,y=0.6,z=0.5}, + inventory_image = "rangedweapons_stone_shuriken.png", + RW_throw_capabilities = { + throw_damage = {fleshy=4,knockback=8}, + throw_crit = 7, + throw_critEffc = 2.1, + throw_skill = {"throw_skill",30}, + throw_velocity = 20, + throw_accuracy = 75, + throw_cooldown = 0.5, + throw_projectiles = 1, + throw_gravity = 15, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 0, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:stone_shuriken", + throw_projectile_size = 0.15, + throw_glass_breaking = 1, + has_sparks = 0, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +if math.random(1, 100) <= 15 then +minetest.add_item(bullet.object:get_pos(), "rangedweapons:stone_shuriken") end end, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) + + +minetest.register_craftitem("rangedweapons:steel_shuriken", { + description = "" ..core.colorize("#35cdff","Steel shuriken\n") ..core.colorize("#FFFFFF", "Ranged damage: 6\n") ..core.colorize("#FFFFFF", "Accuracy: 85%\n") ..core.colorize("#FFFFFF", "knockback: 3\n") ..core.colorize("#FFFFFF", "Critical chance: 8%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.2x\n") ..core.colorize("#FFFFFF", "Shuriken survival rate: 35%\n") ..core.colorize("#FFFFFF", "Projectile gravity: 8\n") ..core.colorize("#FFFFFF", "Throwing cooldown: 0.25\n") ..core.colorize("#FFFFFF", "Projectile velocity: 30"), + range = 0, + stack_max= 150, + wield_scale = {x=0.6,y=0.6,z=0.5}, + inventory_image = "rangedweapons_steel_shuriken.png", + RW_throw_capabilities = { + throw_damage = {fleshy=6,knockback=3}, + throw_crit = 8, + throw_critEffc = 2.2, + throw_skill = {"throw_skill",40}, + throw_velocity = 30, + throw_accuracy = 85, + throw_cooldown = 0.25, + throw_projectiles = 1, + throw_gravity = 8, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 0, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:steel_shuriken", + throw_projectile_size = 0.15, + throw_glass_breaking = 0, + has_sparks = 1, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +if math.random(1, 100) <= 35 then +minetest.add_item(bullet.object:get_pos(), "rangedweapons:steel_shuriken") end end, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) + +minetest.register_craftitem("rangedweapons:bronze_shuriken", { + description = "" ..core.colorize("#35cdff","Bronze shuriken\n") ..core.colorize("#FFFFFF", "Ranged damage: 6\n") ..core.colorize("#FFFFFF", "Accuracy: 85%\n") ..core.colorize("#FFFFFF", "knockback: 3\n") ..core.colorize("#FFFFFF", "Critical chance: 8%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.2x\n") ..core.colorize("#FFFFFF", "Shuriken survival rate: 30%\n") ..core.colorize("#FFFFFF", "Projectile gravity: 8\n") ..core.colorize("#FFFFFF", "Throwing cooldown: 0.25\n") ..core.colorize("#FFFFFF", "Projectile velocity: 30"), + range = 0, + stack_max= 150, + wield_scale = {x=0.6,y=0.6,z=0.5}, + inventory_image = "rangedweapons_bronze_shuriken.png", + RW_throw_capabilities = { + throw_damage = {fleshy=6,knockback=3}, + throw_crit = 8, + throw_critEffc = 2.2, + throw_skill = {"throw_skill",40}, + throw_velocity = 30, + throw_accuracy = 85, + throw_cooldown = 0.25, + throw_projectiles = 1, + throw_gravity = 8, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 0, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:bronze_shuriken", + throw_projectile_size = 0.15, + throw_glass_breaking = 0, + has_sparks = 1, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +if math.random(1, 100) <= 30 then +minetest.add_item(bullet.object:get_pos(), "rangedweapons:bronze_shuriken") end end, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) + +minetest.register_craftitem("rangedweapons:golden_shuriken", { + description = "" ..core.colorize("#35cdff","Golden shuriken\n") ..core.colorize("#FFFFFF", "Ranged damage: 8\n") ..core.colorize("#FFFFFF", "Accuracy: 75%\n") ..core.colorize("#FFFFFF", "knockback: 10\n") ..core.colorize("#FFFFFF", "Critical chance: 12%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.5x\n") ..core.colorize("#FFFFFF", "Shuriken survival rate: 25%\n") ..core.colorize("#FFFFFF", "Projectile gravity: 15\n") ..core.colorize("#FFFFFF", "Throwing cooldown: 0.4\n") ..core.colorize("#FFFFFF", "Projectile velocity: 25"), + range = 0, + stack_max= 175, + wield_scale = {x=0.6,y=0.6,z=0.5}, + inventory_image = "rangedweapons_golden_shuriken.png", + RW_throw_capabilities = { + throw_damage = {fleshy=8,knockback=10}, + throw_crit = 12, + throw_critEffc = 2.5, + throw_skill = {"throw_skill",35}, + throw_velocity = 25, + throw_accuracy = 75, + throw_cooldown = 0.4, + throw_projectiles = 1, + throw_gravity = 15, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 0, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:golden_shuriken", + throw_projectile_size = 0.15, + throw_glass_breaking = 1, + has_sparks = 1, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +if math.random(1, 100) <= 25 then +minetest.add_item(bullet.object:get_pos(), "rangedweapons:golden_shuriken") end end, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) + +minetest.register_craftitem("rangedweapons:mese_shuriken", { + description = "" ..core.colorize("#35cdff","MESE shuriken\n") ..core.colorize("#FFFFFF", "Ranged damage: 7\n") ..core.colorize("#FFFFFF", "Accuracy: 90%\n") ..core.colorize("#FFFFFF", "knockback: 2\n") ..core.colorize("#FFFFFF", "Critical chance: 9%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.3x\n") ..core.colorize("#FFFFFF", "Shuriken survival rate: 50%\n") ..core.colorize("#FFFFFF", "Projectile gravity: 5\n") ..core.colorize("#FFFFFF", "Throwing cooldown: 0.2\n") ..core.colorize("#FFFFFF", "Enemy penetration: 25%\n") ..core.colorize("#FFFFFF", "Projectile velocity: 35"), + range = 0, + stack_max= 175, + wield_scale = {x=0.6,y=0.6,z=0.5}, + inventory_image = "rangedweapons_mese_shuriken.png", + RW_throw_capabilities = { + throw_damage = {fleshy=7,knockback=2}, + throw_crit = 9, + throw_critEffc = 2.3, + throw_skill = {"throw_skill",45}, + throw_velocity = 35, + throw_accuracy = 90, + throw_cooldown = 0.2, + throw_projectiles = 1, + throw_gravity = 5, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 25, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:mese_shuriken", + throw_projectile_size = 0.15, + throw_glass_breaking = 1, + has_sparks = 1, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +if math.random(1, 100) <= 50 then +minetest.add_item(bullet.object:get_pos(), "rangedweapons:mese_shuriken") end end, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) + +minetest.register_craftitem("rangedweapons:diamond_shuriken", { + description = "" ..core.colorize("#35cdff","Diamond shuriken\n") ..core.colorize("#FFFFFF", "Ranged damage: 8\n") ..core.colorize("#FFFFFF", "Accuracy: 95%\n") ..core.colorize("#FFFFFF", "knockback: 2\n") ..core.colorize("#FFFFFF", "Critical chance: 10%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.4x\n") ..core.colorize("#FFFFFF", "Shuriken survival rate: 60%\n") ..core.colorize("#FFFFFF", "Projectile gravity: 5\n") ..core.colorize("#FFFFFF", "Throwing cooldown: 0.15\n") ..core.colorize("#FFFFFF", "Enemy penetration: 33%\n") ..core.colorize("#FFFFFF", "Projectile velocity: 40"), + range = 0, + stack_max= 200, + wield_scale = {x=0.6,y=0.6,z=0.5}, + inventory_image = "rangedweapons_diamond_shuriken.png", + RW_throw_capabilities = { + throw_damage = {fleshy=8,knockback=2}, + throw_crit = 10, + throw_critEffc = 2.4, + throw_skill = {"throw_skill",50}, + throw_velocity = 40, + throw_accuracy = 95, + throw_cooldown = 0.15, + throw_projectiles = 1, + throw_gravity = 5, + throw_sound = "rangedweapons_throw", + throw_dps = 0, + throw_mob_penetration = 33, + throw_node_penetration = 0, + throw_entity = "rangedweapons:shot_bullet", + throw_visual = "wielditem", + throw_texture = "rangedweapons:diamond_shuriken", + throw_projectile_size = 0.15, + throw_glass_breaking = 1, + has_sparks = 1, + ignites_explosives = 0, + throw_door_breaking = 0, +OnCollision = function(player,bullet,target) +if math.random(1, 100) <= 60 then +minetest.add_item(bullet.object:get_pos(), "rangedweapons:diamond_shuriken") end end, + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_yeet(itemstack, user) +return itemstack + end, +}) \ No newline at end of file diff --git a/mods/rangedweapons/skills.lua b/mods/rangedweapons/skills.lua new file mode 100644 index 0000000..020f2ad --- /dev/null +++ b/mods/rangedweapons/skills.lua @@ -0,0 +1,154 @@ +minetest.register_on_joinplayer(function(player) +local meta = player:get_meta() +if meta:get_int("handgun_skill") == 0 +then + meta:set_int("handgun_skill",100) +end +if meta:get_int("mp_skill") == 0 +then + meta:set_int("mp_skill",100) +end +if meta:get_int("smg_skill") == 0 +then + meta:set_int("smg_skill",100) +end +if meta:get_int("shotgun_skill") == 0 +then + meta:set_int("shotgun_skill",100) +end +if meta:get_int("heavy_skill") == 0 +then + meta:set_int("heavy_skill",100) +end +if meta:get_int("arifle_skill") == 0 +then + meta:set_int("arifle_skill",100) +end +if meta:get_int("revolver_skill") == 0 +then + meta:set_int("revolver_skill",100) +end +if meta:get_int("rifle_skill") == 0 +then + meta:set_int("rifle_skill",100) +end +if meta:get_int("throw_skill") == 0 +then + meta:set_int("throw_skill",100) +end +end) + + +minetest.register_chatcommand("gunskills", { + func = function(name, param) + for _, player in pairs(minetest.get_connected_players()) do + local meta = player:get_meta() +local handguns = meta:get_int("handgun_skill") +local mps = meta:get_int("mp_skill") +local smgs = meta:get_int("smg_skill") +local shotguns = meta:get_int("shotgun_skill") +local heavy = meta:get_int("heavy_skill") +local arifle = meta:get_int("arifle_skill") +local revolver = meta:get_int("revolver_skill") +local rifle = meta:get_int("rifle_skill") +local throw = meta:get_int("throw_skill") + minetest.show_formspec(name, "rangedweapons:gunskills_form", +"size[11,7]".. +"label[0,0;Gun efficiency: increases damage, accuracy and crit chance.]".. +"image[0,1;1,1;rangedweapons_handgun_img.png]".. +"label[1,1.2;Handgun efficiency: " .. handguns .. "%]".. +"image[0,2;1,1;rangedweapons_machinepistol_img.png]".. +"label[1,2.2;M.Pistol efficiency: " .. mps .. "%]".. +"image[0,3;1,1;rangedweapons_smg_img.png]".. +"label[1,3.2;S.M.G efficiency: " .. smgs .. "%]".. +"image[0,4;1,1;rangedweapons_shotgun_img.png]".. +"label[1,4.2;Shotgun efficiency: " .. shotguns .. "%]".. +"image[0,5;1,1;rangedweapons_heavy_img.png]".. +"label[1,5.2;Heavy.MG efficiency: " .. heavy .. "%]".. +"image[0,6;1,1;rangedweapons_arifle_img.png]".. +"label[1,6.2;A.rifle efficiency: " .. arifle .. "%]".. +"image[5,1;1,1;rangedweapons_revolver_img.png]".. +"label[6,1.2;Revl./mgn. efficiency: " .. revolver .. "%]".. +"image[5,2;1,1;rangedweapons_rifle_img.png]".. +"label[6,2.2;Rifle efficiency: " .. rifle .. "%]".. +"image[5,3;1,1;rangedweapons_yeetable_img.png]".. +"label[6,3.2;Throwing efficiency: " .. throw .. "%]".. +"button_exit[9,0;2,1;exit;Done]") + +end + end +}) + + local timer = 0 +minetest.register_globalstep(function(dtime, player) + timer = timer + dtime; + if timer >= 60.0 then + for _, player in pairs(minetest.get_connected_players()) do + local meta = player:get_meta() +local handguns = meta:get_int("handgun_skill") +local mps = meta:get_int("mp_skill") +local smgs = meta:get_int("smg_skill") +local shotguns = meta:get_int("shotgun_skill") +local heavy = meta:get_int("heavy_skill") +local arifle = meta:get_int("arifle_skill") +local revolver = meta:get_int("revolver_skill") +local rifle = meta:get_int("rifle_skill") +local throw = meta:get_int("throw_skill") +if math.random(1, 40) == 1 then +if handguns > rweapons_min_gun_efficiency then + meta:set_int("handgun_skill", handguns - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Handgun skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if mps > rweapons_min_gun_efficiency then + meta:set_int("mp_skill", mps - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Machine Pistol skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if smgs > rweapons_min_gun_efficiency then + meta:set_int("smg_skill", smgs - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","S.M.G skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if shotguns > rweapons_min_gun_efficiency then + meta:set_int("shotgun_skill", shotguns - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Shotgun skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if heavy > rweapons_min_gun_efficiency then + meta:set_int("heavy_skill", heavy - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Heavy.MG skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if arifle > rweapons_min_gun_efficiency then + meta:set_int("arifle_skill", arifle - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","A.Rifle skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if revolver > rweapons_min_gun_efficiency then + meta:set_int("revolver_skill", revolver - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Revolver/magnum skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if rifle > rweapons_min_gun_efficiency then + meta:set_int("rifle_skill", rifle - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Rifle skill degraded! ")) + end + end +if math.random(1, 40) == 1 then +if throw > rweapons_min_gun_efficiency then + meta:set_int("throw_skill", throw - 1) + minetest.chat_send_player(player:get_player_name(), "" ..core.colorize("#ff0000","Throwing skill degraded! ")) + end + end + timer = 0 + end + end + end) diff --git a/mods/rangedweapons/sounds/glass_break.ogg b/mods/rangedweapons/sounds/glass_break.ogg new file mode 100644 index 0000000..b6cc9e8 Binary files /dev/null and b/mods/rangedweapons/sounds/glass_break.ogg differ diff --git a/mods/rangedweapons/sounds/hit.ogg b/mods/rangedweapons/sounds/hit.ogg new file mode 100644 index 0000000..1281384 Binary files /dev/null and b/mods/rangedweapons/sounds/hit.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_ak.ogg b/mods/rangedweapons/sounds/rangedweapons_ak.ogg new file mode 100644 index 0000000..0a3c4c2 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_ak.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_beretta.ogg b/mods/rangedweapons/sounds/rangedweapons_beretta.ogg new file mode 100644 index 0000000..3b82f9c Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_beretta.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_bulletdrop.ogg b/mods/rangedweapons/sounds/rangedweapons_bulletdrop.ogg new file mode 100644 index 0000000..6abe726 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_bulletdrop.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_deagle.ogg b/mods/rangedweapons/sounds/rangedweapons_deagle.ogg new file mode 100644 index 0000000..253289f Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_deagle.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_empty.ogg b/mods/rangedweapons/sounds/rangedweapons_empty.ogg new file mode 100644 index 0000000..8e60db8 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_empty.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_glock.ogg b/mods/rangedweapons/sounds/rangedweapons_glock.ogg new file mode 100644 index 0000000..43877bf Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_glock.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_handgun_mag_in.ogg b/mods/rangedweapons/sounds/rangedweapons_handgun_mag_in.ogg new file mode 100644 index 0000000..818c871 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_handgun_mag_in.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_handgun_mag_out.ogg b/mods/rangedweapons/sounds/rangedweapons_handgun_mag_out.ogg new file mode 100644 index 0000000..706b68e Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_handgun_mag_out.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_laser.ogg b/mods/rangedweapons/sounds/rangedweapons_laser.ogg new file mode 100644 index 0000000..6527660 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_laser.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_machine_pistol.ogg b/mods/rangedweapons/sounds/rangedweapons_machine_pistol.ogg new file mode 100644 index 0000000..d113b53 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_machine_pistol.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_machinegun.ogg b/mods/rangedweapons/sounds/rangedweapons_machinegun.ogg new file mode 100644 index 0000000..ff47c33 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_machinegun.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_makarov.ogg b/mods/rangedweapons/sounds/rangedweapons_makarov.ogg new file mode 100644 index 0000000..6083687 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_makarov.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_reload_a.ogg b/mods/rangedweapons/sounds/rangedweapons_reload_a.ogg new file mode 100644 index 0000000..939ad80 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_reload_a.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_reload_b.ogg b/mods/rangedweapons/sounds/rangedweapons_reload_b.ogg new file mode 100644 index 0000000..cc52cf0 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_reload_b.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_revolver.ogg b/mods/rangedweapons/sounds/rangedweapons_revolver.ogg new file mode 100644 index 0000000..722af13 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_revolver.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_rifle_a.ogg b/mods/rangedweapons/sounds/rangedweapons_rifle_a.ogg new file mode 100644 index 0000000..6e02c6d Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_rifle_a.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_rifle_b.ogg b/mods/rangedweapons/sounds/rangedweapons_rifle_b.ogg new file mode 100644 index 0000000..846486c Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_rifle_b.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_rifle_clip_in.ogg b/mods/rangedweapons/sounds/rangedweapons_rifle_clip_in.ogg new file mode 100644 index 0000000..caf60a9 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_rifle_clip_in.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_rifle_clip_out.ogg b/mods/rangedweapons/sounds/rangedweapons_rifle_clip_out.ogg new file mode 100644 index 0000000..5892b48 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_rifle_clip_out.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_rifle_reload_a.ogg b/mods/rangedweapons/sounds/rangedweapons_rifle_reload_a.ogg new file mode 100644 index 0000000..11b5e81 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_rifle_reload_a.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_rifle_reload_b.ogg b/mods/rangedweapons/sounds/rangedweapons_rifle_reload_b.ogg new file mode 100644 index 0000000..0c91a84 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_rifle_reload_b.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_rocket.ogg b/mods/rangedweapons/sounds/rangedweapons_rocket.ogg new file mode 100644 index 0000000..43bac1d Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_rocket.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_shell_insert.ogg b/mods/rangedweapons/sounds/rangedweapons_shell_insert.ogg new file mode 100644 index 0000000..e7a5b8b Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_shell_insert.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_shellhit.ogg b/mods/rangedweapons/sounds/rangedweapons_shellhit.ogg new file mode 100644 index 0000000..ef494dd Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_shellhit.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_shotgun_full.ogg b/mods/rangedweapons/sounds/rangedweapons_shotgun_full.ogg new file mode 100644 index 0000000..4e0cdf4 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_shotgun_full.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_a.ogg b/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_a.ogg new file mode 100644 index 0000000..aeeb450 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_a.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_b.ogg b/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_b.ogg new file mode 100644 index 0000000..8d18d5d Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_b.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_full.ogg b/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_full.ogg new file mode 100644 index 0000000..45c1468 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_shotgun_reload_full.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_shotgun_shot.ogg b/mods/rangedweapons/sounds/rangedweapons_shotgun_shot.ogg new file mode 100644 index 0000000..9a154e5 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_shotgun_shot.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_smg.ogg b/mods/rangedweapons/sounds/rangedweapons_smg.ogg new file mode 100644 index 0000000..ad7e09e Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_smg.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_throw.ogg b/mods/rangedweapons/sounds/rangedweapons_throw.ogg new file mode 100644 index 0000000..71ebb31 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_throw.ogg differ diff --git a/mods/rangedweapons/sounds/rangedweapons_woodbreak.ogg b/mods/rangedweapons/sounds/rangedweapons_woodbreak.ogg new file mode 100644 index 0000000..bd11566 Binary files /dev/null and b/mods/rangedweapons/sounds/rangedweapons_woodbreak.ogg differ diff --git a/mods/rangedweapons/sounds/rengedweapons_ricochet.ogg b/mods/rangedweapons/sounds/rengedweapons_ricochet.ogg new file mode 100644 index 0000000..715fac6 Binary files /dev/null and b/mods/rangedweapons/sounds/rengedweapons_ricochet.ogg differ diff --git a/mods/rangedweapons/spas12.lua b/mods/rangedweapons/spas12.lua new file mode 100644 index 0000000..2a0bad3 --- /dev/null +++ b/mods/rangedweapons/spas12.lua @@ -0,0 +1,63 @@ +minetest.register_tool("rangedweapons:spas12_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + loaded_gun = "rangedweapons:spas12", + loaded_sound = "rangedweapons_shotgun_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_spas12_rld.png", +}) + +minetest.register_tool("rangedweapons:spas12", { + description = "" ..core.colorize("#35cdff","spas-12\n") ..core.colorize("#FFFFFF", "Ranged damage: 3\n") ..core.colorize("#FFFFFF", "projectiles: 6\n") ..core.colorize("#FFFFFF", "Gun gravity: 3\n") ..core.colorize("#FFFFFF", "Accuracy: 52%\n")..core.colorize("#FFFFFF", "knockback: 7\n") ..core.colorize("#FFFFFF", "Critical chance: 7%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.1x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shells\n") ..core.colorize("#FFFFFF", "Pump delay: 0.45\n")..core.colorize("#FFFFFF", "Clip size: 8\n") ..core.colorize("#27a600", "Gun is ready to fire!\n") ..core.colorize("#fff21c", "Right-click to load in a bullet!\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 32"), + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + inventory_image = "rangedweapons_spas12.png", +RW_gun_capabilities = { + gun_damage = {fleshy=3,knockback=7}, + gun_crit = 7, + gun_critEffc = 2.1, + suitable_ammo = {{"rangedweapons:shell",8}}, + gun_skill = {"shotgun_skill",20}, + gun_icon = "rangedweapons_spas12_icon.png", + gun_unloaded = "rangedweapons:spas12_rld", + gun_cooling = "rangedweapons:spas12_uld", + gun_velocity = 32, + gun_accuracy = 52, + gun_cooldown = 0.45, + gun_gravity = 3, + gun_reload = 0.25, + gun_projectiles = 6, + has_shell = 0, + gun_durability = 550, + gun_smokeSize = 15, + gun_door_breaking = 1, + gun_sound = "rangedweapons_shotgun_shot", + gun_unload_sound = "rangedweapons_shell_insert", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_single_load_gun(itemstack, user, "") +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, +}) + +minetest.register_tool("rangedweapons:spas12_uld", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.1}, + range = 0, + description = "" ..core.colorize("#35cdff","spas-12\n") ..core.colorize("#FFFFFF", "Ranged damage: 2\n") ..core.colorize("#FFFFFF", "projectiles: 6\n") ..core.colorize("#FFFFFF", "Gun gravity: 3\n") ..core.colorize("#FFFFFF", "Accuracy: 52%\n")..core.colorize("#FFFFFF", "knockback: 7\n") ..core.colorize("#FFFFFF", "Critical chance: 7%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.1x\n") ..core.colorize("#FFFFFF", "Ammunition: 12 gauge shells\n") ..core.colorize("#FFFFFF", "Pump delay: 0.45\n")..core.colorize("#FFFFFF", "Clip size: 8\n") ..core.colorize("#be0d00", "Right-click, to eject the empty shell!\n") ..core.colorize("#fff21c", "Right-click to load in a bullet!\n") ..core.colorize("#FFFFFF", "Gun type: shotgun\n") ..core.colorize("#FFFFFF", "Bullet velocity: 28"), + inventory_image = "rangedweapons_spas12.png", + groups = {not_in_creative_inventory = 1}, + on_use = function(user) + minetest.sound_play("rangedweapons_empty", {user}) + end, +on_secondary_use = function(itemstack, user, pointed_thing) +eject_shell(itemstack,user,"rangedweapons:spas12_rld",0.6,"rangedweapons_shotgun_reload_a","rangedweapons:empty_shell") +return itemstack +end, +}) diff --git a/mods/rangedweapons/svd.lua b/mods/rangedweapons/svd.lua new file mode 100644 index 0000000..881c07c --- /dev/null +++ b/mods/rangedweapons/svd.lua @@ -0,0 +1,103 @@ + + +minetest.register_tool("rangedweapons:svd_uld", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.1}, + range = 0, + description = "" ..core.colorize("#35cdff","S.V.D. \n") ..core.colorize("#FFFFFF", "Ranged damage:17 + 30/sec of bullet lifetime\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 14\n") ..core.colorize("#FFFFFF", "Critical chance: 30%\n") ..core.colorize("#FFFFFF", "Critical efficiency: x3\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm round\n") ..core.colorize("#FFFFFF", "Rate of fire: 1.0\n") ..core.colorize("#FFFFFF", "Reload time: 2.0\n") ..core.colorize("#FFFFFF", "Zoom: 10x\n") ..core.colorize("#be0d00", "Right-click to eject empty bullet shell\n") ..core.colorize("#FFFFFF", "Clip size: 10\n") ..core.colorize("#FFFFFF", "Enemy penetration:30%\n") ..core.colorize("#FFFFFF", "Block penetration:10%\n") ..core.colorize("#FFFFFF", "Gun type: Rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 75"), + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_svd.png", + weapon_zoom = 9, + on_use = function(user) + minetest.sound_play("rangedweapons_empty", {user}) + end, +on_secondary_use = function(itemstack, user, pointed_thing) +eject_shell(itemstack,user,"rangedweapons:svd_rld",1.0,"rangedweapons_rifle_reload_a","rangedweapons:empty_shell") +return itemstack +end, +}) + + +minetest.register_tool("rangedweapons:svd_r", { + rw_next_reload = "rangedweapons:svd_rr", + load_sound = "rangedweapons_rifle_clip_in", + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_svd_noclip.png", +}) +minetest.register_tool("rangedweapons:svd_rr", { + rw_next_reload = "rangedweapons:svd_rrr", + load_sound = "rangedweapons_rifle_reload_a", + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_svd.png", +}) +minetest.register_tool("rangedweapons:svd_rrr", { + rw_next_reload = "rangedweapons:svd", + load_sound = "rangedweapons_rifle_reload_b", + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_svd_rld.png", +}) + + +minetest.register_tool("rangedweapons:svd_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.9,y=1.9,z=1.1}, + description = "", + loaded_gun = "rangedweapons:svd", + loaded_sound = "rangedweapons_rifle_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_svd_rld.png", +}) + + +minetest.register_tool("rangedweapons:svd", { + description = "" ..core.colorize("#35cdff","S.V.D. \n") ..core.colorize("#FFFFFF", "Ranged damage:17 + 30/sec of bullet lifetime\n")..core.colorize("#FFFFFF", "Accuracy: 100%\n") ..core.colorize("#FFFFFF", "knockback: 14\n") ..core.colorize("#FFFFFF", "Critical chance: 30%\n") ..core.colorize("#FFFFFF", "Critical efficiency: x3\n") ..core.colorize("#FFFFFF", "Ammunition: 7.62mm round\n") ..core.colorize("#FFFFFF", "Rate of fire: 1.0\n") ..core.colorize("#FFFFFF", "Reload time: 2.0\n") ..core.colorize("#FFFFFF", "Zoom: 10x\n") ..core.colorize("#27a600", "The gun is loaded!\n") ..core.colorize("#FFFFFF", "Clip size: 10\n") ..core.colorize("#FFFFFF", "Enemy penetration:30%\n") ..core.colorize("#FFFFFF", "Block penetration:10%\n") ..core.colorize("#FFFFFF", "Gun type: Rifle\n") ..core.colorize("#FFFFFF", "Bullet velocity: 75"), + range = 0, + weapon_zoom = 9, + wield_scale = {x=1.9,y=1.9,z=1.1}, + inventory_image = "rangedweapons_svd.png", +RW_gun_capabilities = { + gun_damage = {fleshy=17,knockback=14}, + gun_crit = 30, + gun_critEffc = 3.0, + suitable_ammo = {{"rangedweapons:762mm",10}}, + gun_skill = {"rifle_skill",20}, + gun_magazine = "rangedweapons:rifle_mag", + gun_icon = "rangedweapons_svd_icon.png", + gun_unloaded = "rangedweapons:svd_r", + gun_cooling = "rangedweapons:svd_uld", + gun_velocity = 75, + gun_accuracy = 100, + gun_cooldown = 1.0, + gun_reload = 2.0/4, + gun_projectiles = 1, + has_shell = 0, + gun_durability = 700, + gun_smokeSize = 8, + gun_dps = 30, + gun_mob_penetration = 30, + gun_node_penetration = 10, + gun_unload_sound = "rangedweapons_rifle_clip_out", + gun_sound = "rangedweapons_rifle_b", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, + +}) + + diff --git a/mods/rangedweapons/taurus.lua b/mods/rangedweapons/taurus.lua new file mode 100644 index 0000000..a164ae9 --- /dev/null +++ b/mods/rangedweapons/taurus.lua @@ -0,0 +1,50 @@ + +minetest.register_tool("rangedweapons:taurus_rld", { + stack_max= 1, + range = 0, + wield_scale = {x=1.25,y=1.25,z=1.1}, + description = "", + loaded_gun = "rangedweapons:taurus", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_taurus_rld.png", +}) + + +minetest.register_tool("rangedweapons:taurus", { + description = "" ..core.colorize("#35cdff","Taurus raging bull \n") ..core.colorize("#FFFFFF", "Ranged damage: 14\n")..core.colorize("#FFFFFF", "Accuracy: 97%\n") ..core.colorize("#FFFFFF", "Gun knockback: 8\n") ..core.colorize("#FFFFFF", "Critical chance: 22%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 3.1x\n") ..core.colorize("#FFFFFF", "Ammunition: .44 Magnum rounds\n") ..core.colorize("#FFFFFF", "Reload time: 0.25\n") ..core.colorize("#FFFFFF", "Clip Size: 6\n") ..core.colorize("#FFFFFF", "Block penetration: 8%\n") +..core.colorize("#FFFFFF", "penetration: 24%\n") ..core.colorize("#FFFFFF", "Gun type: Revolver\n") ..core.colorize("#FFFFFF", "Bullet velocity: 64"), + range = 0, + wield_scale = {x=1.25,y=1.25,z=1.1}, + inventory_image = "rangedweapons_taurus.png", +RW_gun_capabilities = { + gun_damage = {fleshy=14,knockback=8}, + gun_crit = 22, + gun_critEffc = 3.1, + suitable_ammo = {{"rangedweapons:44",6}}, + gun_skill = {"revolver_skill",40}, + gun_icon = "rangedweapons_taurus_icon.png", + gun_unloaded = "rangedweapons:taurus_rld", + gun_cooling = "rangedweapons:taurus", + gun_velocity = 55, + gun_accuracy = 97, + gun_cooldown = 0.2, + gun_reload = 0.4, + gun_projectiles = 1, + gun_durability = 1750, + gun_smokeSize = 7, + gun_mob_penetration = 24, + gun_node_penetration = 8, + gun_unload_sound = "rangedweapons_shell_insert", + gun_sound = "rangedweapons_deagle", + }, + on_use = function(itemstack, user, pointed_thing) +rangedweapons_shoot_gun(itemstack, user) +return itemstack + end, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_single_load_gun(itemstack, user) +return itemstack +end, +}) + + diff --git a/mods/rangedweapons/tec9.lua b/mods/rangedweapons/tec9.lua new file mode 100644 index 0000000..af84fc4 --- /dev/null +++ b/mods/rangedweapons/tec9.lua @@ -0,0 +1,72 @@ + + + +minetest.register_craftitem("rangedweapons:tec9_r", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.50}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:tec9_rr", + load_sound = "rangedweapons_handgun_mag_in", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_tec9_rld.png", +}) + +minetest.register_craftitem("rangedweapons:tec9_rr", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.50}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:tec9_rrr", + load_sound = "rangedweapons_reload_a", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_tec9.png", +}) + +minetest.register_craftitem("rangedweapons:tec9_rrr", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.50}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:tec9", + load_sound = "rangedweapons_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_tec9.png", +}) + + + + minetest.register_craftitem("rangedweapons:tec9", { + stack_max= 1, + wield_scale = {x=1.25,y=1.25,z=1.50}, + description = "" ..core.colorize("#35cdff","TEC-9\n") ..core.colorize("#FFFFFF", "Gun damage: 1\n") ..core.colorize("#FFFFFF", "accuracy: 75%\n") ..core.colorize("#FFFFFF", "Gun knockback: 0\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 9%\n") ..core.colorize("#FFFFFF", "Gun Critical efficiency: 1.9x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n") ..core.colorize("#FFFFFF", "Clip size: 50\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.2\n") ..core.colorize("#FFFFFF", "Gun type: machine pistol\n") ..core.colorize("#FFFFFF", "Bullet velocity: 20"), + range = 0, + inventory_image = "rangedweapons_tec9.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=1,knockback=0}, + gun_crit = 9, + gun_critEffc = 1.9, + suitable_ammo = {{"rangedweapons:9mm",50}}, + gun_skill = {"mp_skill",80}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_tec9_icon.png", + gun_unloaded = "rangedweapons:tec9_r", + gun_velocity = 20, + gun_accuracy = 75, + gun_cooldown = 0.2, + gun_reload = 1.0/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1100, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_machine_pistol", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) + diff --git a/mods/rangedweapons/textures/rangedweapons_10mm.png b/mods/rangedweapons/textures/rangedweapons_10mm.png new file mode 100644 index 0000000..327827f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_10mm.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_308winchester.png b/mods/rangedweapons/textures/rangedweapons_308winchester.png new file mode 100644 index 0000000..6b3f0d0 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_308winchester.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_357.png b/mods/rangedweapons/textures/rangedweapons_357.png new file mode 100644 index 0000000..3994395 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_357.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_408cheytac.png b/mods/rangedweapons/textures/rangedweapons_408cheytac.png new file mode 100644 index 0000000..c331948 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_408cheytac.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_40mm.png b/mods/rangedweapons/textures/rangedweapons_40mm.png new file mode 100644 index 0000000..3be4ff0 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_40mm.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_44.png b/mods/rangedweapons/textures/rangedweapons_44.png new file mode 100644 index 0000000..c9acbc3 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_44.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_45acp.png b/mods/rangedweapons/textures/rangedweapons_45acp.png new file mode 100644 index 0000000..d377215 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_45acp.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_50ae.png b/mods/rangedweapons/textures/rangedweapons_50ae.png new file mode 100644 index 0000000..b586818 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_50ae.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_556mm.png b/mods/rangedweapons/textures/rangedweapons_556mm.png new file mode 100644 index 0000000..c7c0773 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_556mm.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_762mm.png b/mods/rangedweapons/textures/rangedweapons_762mm.png new file mode 100644 index 0000000..1e60138 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_762mm.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_9mm.png b/mods/rangedweapons/textures/rangedweapons_9mm.png new file mode 100644 index 0000000..11204f4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_9mm.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_aa12.png b/mods/rangedweapons/textures/rangedweapons_aa12.png new file mode 100644 index 0000000..b2d8c2f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_aa12.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_aa12_icon.png b/mods/rangedweapons/textures/rangedweapons_aa12_icon.png new file mode 100644 index 0000000..ba0c48e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_aa12_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_aa12_rld.png b/mods/rangedweapons/textures/rangedweapons_aa12_rld.png new file mode 100644 index 0000000..e3d1ea7 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_aa12_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ak47.png b/mods/rangedweapons/textures/rangedweapons_ak47.png new file mode 100644 index 0000000..51da45e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ak47.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ak47_icon.png b/mods/rangedweapons/textures/rangedweapons_ak47_icon.png new file mode 100644 index 0000000..7f0b70c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ak47_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ak47_rld.png b/mods/rangedweapons/textures/rangedweapons_ak47_rld.png new file mode 100644 index 0000000..fc54533 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ak47_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_antigun_block.png b/mods/rangedweapons/textures/rangedweapons_antigun_block.png new file mode 100644 index 0000000..9e87ea0 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_antigun_block.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_arifle_img.png b/mods/rangedweapons/textures/rangedweapons_arifle_img.png new file mode 100644 index 0000000..bba65ba Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_arifle_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_assaultrifle_mag.png b/mods/rangedweapons/textures/rangedweapons_assaultrifle_mag.png new file mode 100644 index 0000000..58236ae Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_assaultrifle_mag.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_awp.png b/mods/rangedweapons/textures/rangedweapons_awp.png new file mode 100644 index 0000000..e439b92 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_awp.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_awp_icon.png b/mods/rangedweapons/textures/rangedweapons_awp_icon.png new file mode 100644 index 0000000..80c3272 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_awp_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_awp_noclip.png b/mods/rangedweapons/textures/rangedweapons_awp_noclip.png new file mode 100644 index 0000000..5825b87 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_awp_noclip.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_awp_rld.png b/mods/rangedweapons/textures/rangedweapons_awp_rld.png new file mode 100644 index 0000000..7529171 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_awp_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_barrel_side.png b/mods/rangedweapons/textures/rangedweapons_barrel_side.png new file mode 100644 index 0000000..205abd9 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_barrel_side.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_barrel_top.png b/mods/rangedweapons/textures/rangedweapons_barrel_top.png new file mode 100644 index 0000000..3367945 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_barrel_top.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_benelli.png b/mods/rangedweapons/textures/rangedweapons_benelli.png new file mode 100644 index 0000000..0200ef5 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_benelli.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_benelli_icon.png b/mods/rangedweapons/textures/rangedweapons_benelli_icon.png new file mode 100644 index 0000000..eb575cd Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_benelli_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_benelli_rld.png b/mods/rangedweapons/textures/rangedweapons_benelli_rld.png new file mode 100644 index 0000000..19db4df Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_benelli_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_beretta.png b/mods/rangedweapons/textures/rangedweapons_beretta.png new file mode 100644 index 0000000..5c74455 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_beretta.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_beretta_icon.png b/mods/rangedweapons/textures/rangedweapons_beretta_icon.png new file mode 100644 index 0000000..b1309f4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_beretta_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_beretta_rld.png b/mods/rangedweapons/textures/rangedweapons_beretta_rld.png new file mode 100644 index 0000000..a10d2f4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_beretta_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_blood.png b/mods/rangedweapons/textures/rangedweapons_blood.png new file mode 100644 index 0000000..af6acec Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_blood.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_blood_alt.png b/mods/rangedweapons/textures/rangedweapons_blood_alt.png new file mode 100644 index 0000000..89c84b2 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_blood_alt.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_blue_ray.png b/mods/rangedweapons/textures/rangedweapons_blue_ray.png new file mode 100644 index 0000000..96e1eb5 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_blue_ray.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_boltaction_img.png b/mods/rangedweapons/textures/rangedweapons_boltaction_img.png new file mode 100644 index 0000000..ee655bb Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_boltaction_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_broken_glass.png b/mods/rangedweapons/textures/rangedweapons_broken_glass.png new file mode 100644 index 0000000..2cc40f0 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_broken_glass.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_bronze_shuriken.png b/mods/rangedweapons/textures/rangedweapons_bronze_shuriken.png new file mode 100644 index 0000000..7e46465 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_bronze_shuriken.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_buckball.png b/mods/rangedweapons/textures/rangedweapons_buckball.png new file mode 100644 index 0000000..342f442 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_buckball.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_bullet_fly.png b/mods/rangedweapons/textures/rangedweapons_bullet_fly.png new file mode 100644 index 0000000..3e31b6b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_bullet_fly.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_bullethole.png b/mods/rangedweapons/textures/rangedweapons_bullethole.png new file mode 100644 index 0000000..ea8ba84 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_bullethole.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_bulletshot.png b/mods/rangedweapons/textures/rangedweapons_bulletshot.png new file mode 100644 index 0000000..dddfa81 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_bulletshot.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_crit.png b/mods/rangedweapons/textures/rangedweapons_crit.png new file mode 100644 index 0000000..c2ee63f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_crit.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_crithit.png b/mods/rangedweapons/textures/rangedweapons_crithit.png new file mode 100644 index 0000000..6524d99 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_crithit.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_deagle.png b/mods/rangedweapons/textures/rangedweapons_deagle.png new file mode 100644 index 0000000..50f1d6c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_deagle.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_deagle_icon.png b/mods/rangedweapons/textures/rangedweapons_deagle_icon.png new file mode 100644 index 0000000..8a07591 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_deagle_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_deagle_rld.png b/mods/rangedweapons/textures/rangedweapons_deagle_rld.png new file mode 100644 index 0000000..df7931d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_deagle_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_diamond_shuriken.png b/mods/rangedweapons/textures/rangedweapons_diamond_shuriken.png new file mode 100644 index 0000000..f00bd6d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_diamond_shuriken.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_drum_mag.png b/mods/rangedweapons/textures/rangedweapons_drum_mag.png new file mode 100644 index 0000000..0aa64db Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_drum_mag.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_electroball.png b/mods/rangedweapons/textures/rangedweapons_electroball.png new file mode 100644 index 0000000..02e1240 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_electroball.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_emergency_ammo_icon.png b/mods/rangedweapons/textures/rangedweapons_emergency_ammo_icon.png new file mode 100644 index 0000000..cb6c690 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_emergency_ammo_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_emergency_gun_icon.png b/mods/rangedweapons/textures/rangedweapons_emergency_gun_icon.png new file mode 100644 index 0000000..11d4760 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_emergency_gun_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_empty_icon.png b/mods/rangedweapons/textures/rangedweapons_empty_icon.png new file mode 100644 index 0000000..ae7ff3f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_empty_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_empty_shell.png b/mods/rangedweapons/textures/rangedweapons_empty_shell.png new file mode 100644 index 0000000..5751af1 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_empty_shell.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_energycharge.png b/mods/rangedweapons/textures/rangedweapons_energycharge.png new file mode 100644 index 0000000..22ac37b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_energycharge.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_fire_particle.png b/mods/rangedweapons/textures/rangedweapons_fire_particle.png new file mode 100644 index 0000000..2a0ddd3 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_fire_particle.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_force_blast.png b/mods/rangedweapons/textures/rangedweapons_force_blast.png new file mode 100644 index 0000000..4a48712 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_force_blast.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_force_bullet.png b/mods/rangedweapons/textures/rangedweapons_force_bullet.png new file mode 100644 index 0000000..57f23f9 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_force_bullet.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_forcegun.png b/mods/rangedweapons/textures/rangedweapons_forcegun.png new file mode 100644 index 0000000..93e827f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_forcegun.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_g36.png b/mods/rangedweapons/textures/rangedweapons_g36.png new file mode 100644 index 0000000..d7473c1 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_g36.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_g36_icon.png b/mods/rangedweapons/textures/rangedweapons_g36_icon.png new file mode 100644 index 0000000..46ea728 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_g36_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_g36_rld.png b/mods/rangedweapons/textures/rangedweapons_g36_rld.png new file mode 100644 index 0000000..c7af1f5 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_g36_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_generator_bottom.png b/mods/rangedweapons/textures/rangedweapons_generator_bottom.png new file mode 100644 index 0000000..f85dbe8 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_generator_bottom.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_generator_side.png b/mods/rangedweapons/textures/rangedweapons_generator_side.png new file mode 100644 index 0000000..97ab78b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_generator_side.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_generator_top.png b/mods/rangedweapons/textures/rangedweapons_generator_top.png new file mode 100644 index 0000000..61e53a1 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_generator_top.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_glass_shards.png b/mods/rangedweapons/textures/rangedweapons_glass_shards.png new file mode 100644 index 0000000..8699426 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_glass_shards.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_glock17.png b/mods/rangedweapons/textures/rangedweapons_glock17.png new file mode 100644 index 0000000..7f8d3a7 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_glock17.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_glock17_icon.png b/mods/rangedweapons/textures/rangedweapons_glock17_icon.png new file mode 100644 index 0000000..1e29029 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_glock17_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_glock17_rld.png b/mods/rangedweapons/textures/rangedweapons_glock17_rld.png new file mode 100644 index 0000000..84f386f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_glock17_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_golden_deagle.png b/mods/rangedweapons/textures/rangedweapons_golden_deagle.png new file mode 100644 index 0000000..bf517d6 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_golden_deagle.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_golden_deagle_icon.png b/mods/rangedweapons/textures/rangedweapons_golden_deagle_icon.png new file mode 100644 index 0000000..03a109e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_golden_deagle_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_golden_deagle_rld.png b/mods/rangedweapons/textures/rangedweapons_golden_deagle_rld.png new file mode 100644 index 0000000..b68ca20 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_golden_deagle_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_golden_shuriken.png b/mods/rangedweapons/textures/rangedweapons_golden_shuriken.png new file mode 100644 index 0000000..3e52e0a Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_golden_shuriken.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_green_ray.png b/mods/rangedweapons/textures/rangedweapons_green_ray.png new file mode 100644 index 0000000..1093b76 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_green_ray.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_gun_power_core.png b/mods/rangedweapons/textures/rangedweapons_gun_power_core.png new file mode 100644 index 0000000..67f3012 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_gun_power_core.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_gunsteel_ingot.png b/mods/rangedweapons/textures/rangedweapons_gunsteel_ingot.png new file mode 100644 index 0000000..565df6f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_gunsteel_ingot.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_hand_grenade.png b/mods/rangedweapons/textures/rangedweapons_hand_grenade.png new file mode 100644 index 0000000..334d3c7 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_hand_grenade.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_hand_grenade_nopin.png b/mods/rangedweapons/textures/rangedweapons_hand_grenade_nopin.png new file mode 100644 index 0000000..2c76632 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_hand_grenade_nopin.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_handgun_img.png b/mods/rangedweapons/textures/rangedweapons_handgun_img.png new file mode 100644 index 0000000..24dcea1 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_handgun_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_handgun_mag_black.png b/mods/rangedweapons/textures/rangedweapons_handgun_mag_black.png new file mode 100644 index 0000000..236cdee Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_handgun_mag_black.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_handgun_mag_white.png b/mods/rangedweapons/textures/rangedweapons_handgun_mag_white.png new file mode 100644 index 0000000..7bd3425 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_handgun_mag_white.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_headhit.png b/mods/rangedweapons/textures/rangedweapons_headhit.png new file mode 100644 index 0000000..705a9aa Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_headhit.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_headshot.png b/mods/rangedweapons/textures/rangedweapons_headshot.png new file mode 100644 index 0000000..03384df Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_headshot.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_heavy_img.png b/mods/rangedweapons/textures/rangedweapons_heavy_img.png new file mode 100644 index 0000000..610f22c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_heavy_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_hit.png b/mods/rangedweapons/textures/rangedweapons_hit.png new file mode 100644 index 0000000..97db97b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_hit.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_invisible.png b/mods/rangedweapons/textures/rangedweapons_invisible.png new file mode 100644 index 0000000..91aa779 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_invisible.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_jackhammer.png b/mods/rangedweapons/textures/rangedweapons_jackhammer.png new file mode 100644 index 0000000..99a41e4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_jackhammer.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_jackhammer_icon.png b/mods/rangedweapons/textures/rangedweapons_jackhammer_icon.png new file mode 100644 index 0000000..f5cb670 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_jackhammer_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_jackhammer_rld.png b/mods/rangedweapons/textures/rangedweapons_jackhammer_rld.png new file mode 100644 index 0000000..4712020 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_jackhammer_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_javelin.png b/mods/rangedweapons/textures/rangedweapons_javelin.png new file mode 100644 index 0000000..5e8cd6d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_javelin.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_kriss_sv.png b/mods/rangedweapons/textures/rangedweapons_kriss_sv.png new file mode 100644 index 0000000..150cc9c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_kriss_sv.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_kriss_sv_icon.png b/mods/rangedweapons/textures/rangedweapons_kriss_sv_icon.png new file mode 100644 index 0000000..5ee40c0 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_kriss_sv_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_kriss_sv_rld.png b/mods/rangedweapons/textures/rangedweapons_kriss_sv_rld.png new file mode 100644 index 0000000..62e6879 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_kriss_sv_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_laser_blaster.png b/mods/rangedweapons/textures/rangedweapons_laser_blaster.png new file mode 100644 index 0000000..4efc420 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_laser_blaster.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_laser_rifle.png b/mods/rangedweapons/textures/rangedweapons_laser_rifle.png new file mode 100644 index 0000000..237121a Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_laser_rifle.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_laser_shotgun.png b/mods/rangedweapons/textures/rangedweapons_laser_shotgun.png new file mode 100644 index 0000000..0abdce5 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_laser_shotgun.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_leaf.png b/mods/rangedweapons/textures/rangedweapons_leaf.png new file mode 100644 index 0000000..ac228fd Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_leaf.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_luger.png b/mods/rangedweapons/textures/rangedweapons_luger.png new file mode 100644 index 0000000..bf53dcc Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_luger.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_luger_icon.png b/mods/rangedweapons/textures/rangedweapons_luger_icon.png new file mode 100644 index 0000000..2b4dccc Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_luger_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_luger_rld.png b/mods/rangedweapons/textures/rangedweapons_luger_rld.png new file mode 100644 index 0000000..ed932d1 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_luger_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m16.png b/mods/rangedweapons/textures/rangedweapons_m16.png new file mode 100644 index 0000000..07e8301 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m16.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m16_icon.png b/mods/rangedweapons/textures/rangedweapons_m16_icon.png new file mode 100644 index 0000000..6fa3218 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m16_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m16_rld.png b/mods/rangedweapons/textures/rangedweapons_m16_rld.png new file mode 100644 index 0000000..c8f70ea Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m16_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m1991.png b/mods/rangedweapons/textures/rangedweapons_m1991.png new file mode 100644 index 0000000..0644871 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m1991.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m1991_icon.png b/mods/rangedweapons/textures/rangedweapons_m1991_icon.png new file mode 100644 index 0000000..382d943 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m1991_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m1991_rld.png b/mods/rangedweapons/textures/rangedweapons_m1991_rld.png new file mode 100644 index 0000000..1ca14f7 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m1991_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m200.png b/mods/rangedweapons/textures/rangedweapons_m200.png new file mode 100644 index 0000000..f68fbbe Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m200.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m200_icon.png b/mods/rangedweapons/textures/rangedweapons_m200_icon.png new file mode 100644 index 0000000..b122838 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m200_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m200_noclip.png b/mods/rangedweapons/textures/rangedweapons_m200_noclip.png new file mode 100644 index 0000000..eec6971 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m200_noclip.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m200_rld.png b/mods/rangedweapons/textures/rangedweapons_m200_rld.png new file mode 100644 index 0000000..583f258 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m200_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m60.png b/mods/rangedweapons/textures/rangedweapons_m60.png new file mode 100644 index 0000000..d2a4c77 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m60.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m60_icon.png b/mods/rangedweapons/textures/rangedweapons_m60_icon.png new file mode 100644 index 0000000..8acc084 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m60_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m60_rld.png b/mods/rangedweapons/textures/rangedweapons_m60_rld.png new file mode 100644 index 0000000..b0aff91 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m60_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m79.png b/mods/rangedweapons/textures/rangedweapons_m79.png new file mode 100644 index 0000000..d7e5b4e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m79.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m79_icon.png b/mods/rangedweapons/textures/rangedweapons_m79_icon.png new file mode 100644 index 0000000..988c3f2 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m79_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_m79_rld.png b/mods/rangedweapons/textures/rangedweapons_m79_rld.png new file mode 100644 index 0000000..56ebae4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_m79_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_machinepistol_img.png b/mods/rangedweapons/textures/rangedweapons_machinepistol_img.png new file mode 100644 index 0000000..353df2d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_machinepistol_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_machinepistol_mag.png b/mods/rangedweapons/textures/rangedweapons_machinepistol_mag.png new file mode 100644 index 0000000..f473cda Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_machinepistol_mag.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_magazine_handgun.png b/mods/rangedweapons/textures/rangedweapons_magazine_handgun.png new file mode 100644 index 0000000..a27f5ca Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_magazine_handgun.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_magazine_mp5.png b/mods/rangedweapons/textures/rangedweapons_magazine_mp5.png new file mode 100644 index 0000000..e440b3e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_magazine_mp5.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_magazine_smg.png b/mods/rangedweapons/textures/rangedweapons_magazine_smg.png new file mode 100644 index 0000000..478baab Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_magazine_smg.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_makarov.png b/mods/rangedweapons/textures/rangedweapons_makarov.png new file mode 100644 index 0000000..b085b4f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_makarov.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_makarov_icon.png b/mods/rangedweapons/textures/rangedweapons_makarov_icon.png new file mode 100644 index 0000000..a9e5668 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_makarov_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_makarov_rld.png b/mods/rangedweapons/textures/rangedweapons_makarov_rld.png new file mode 100644 index 0000000..ada698c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_makarov_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_mese_shuriken.png b/mods/rangedweapons/textures/rangedweapons_mese_shuriken.png new file mode 100644 index 0000000..8126952 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_mese_shuriken.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_milkor.png b/mods/rangedweapons/textures/rangedweapons_milkor.png new file mode 100644 index 0000000..16d70b9 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_milkor.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_milkor_icon.png b/mods/rangedweapons/textures/rangedweapons_milkor_icon.png new file mode 100644 index 0000000..99677f4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_milkor_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_milkor_rld.png b/mods/rangedweapons/textures/rangedweapons_milkor_rld.png new file mode 100644 index 0000000..7a5292d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_milkor_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_minigun.png b/mods/rangedweapons/textures/rangedweapons_minigun.png new file mode 100644 index 0000000..fa2847b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_minigun.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_minigun_icon.png b/mods/rangedweapons/textures/rangedweapons_minigun_icon.png new file mode 100644 index 0000000..3935f72 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_minigun_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_minigun_rld.png b/mods/rangedweapons/textures/rangedweapons_minigun_rld.png new file mode 100644 index 0000000..3881e9a Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_minigun_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_mp40.png b/mods/rangedweapons/textures/rangedweapons_mp40.png new file mode 100644 index 0000000..7126e61 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_mp40.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_mp40_icon.png b/mods/rangedweapons/textures/rangedweapons_mp40_icon.png new file mode 100644 index 0000000..c7171c6 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_mp40_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_mp40_rld.png b/mods/rangedweapons/textures/rangedweapons_mp40_rld.png new file mode 100644 index 0000000..4e01ec0 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_mp40_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_mp5.png b/mods/rangedweapons/textures/rangedweapons_mp5.png new file mode 100644 index 0000000..ca22dd1 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_mp5.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_mp5_icon.png b/mods/rangedweapons/textures/rangedweapons_mp5_icon.png new file mode 100644 index 0000000..247f868 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_mp5_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_mp5_rld.png b/mods/rangedweapons/textures/rangedweapons_mp5_rld.png new file mode 100644 index 0000000..e4c519e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_mp5_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_pin.png b/mods/rangedweapons/textures/rangedweapons_pin.png new file mode 100644 index 0000000..50cb95b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_pin.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_plastic_sheet.png b/mods/rangedweapons/textures/rangedweapons_plastic_sheet.png new file mode 100644 index 0000000..f25c8ef Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_plastic_sheet.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_power_particle.png b/mods/rangedweapons/textures/rangedweapons_power_particle.png new file mode 100644 index 0000000..8309290 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_power_particle.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_python.png b/mods/rangedweapons/textures/rangedweapons_python.png new file mode 100644 index 0000000..f58f0e9 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_python.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_python_icon.png b/mods/rangedweapons/textures/rangedweapons_python_icon.png new file mode 100644 index 0000000..e23c7d5 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_python_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_python_rld.png b/mods/rangedweapons/textures/rangedweapons_python_rld.png new file mode 100644 index 0000000..5305456 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_python_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ray_blue.png b/mods/rangedweapons/textures/rangedweapons_ray_blue.png new file mode 100644 index 0000000..f9771b4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ray_blue.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ray_green.png b/mods/rangedweapons/textures/rangedweapons_ray_green.png new file mode 100644 index 0000000..91bf907 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ray_green.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ray_red.png b/mods/rangedweapons/textures/rangedweapons_ray_red.png new file mode 100644 index 0000000..89b41d6 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ray_red.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_red_ray.png b/mods/rangedweapons/textures/rangedweapons_red_ray.png new file mode 100644 index 0000000..4deb76b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_red_ray.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_remington.png b/mods/rangedweapons/textures/rangedweapons_remington.png new file mode 100644 index 0000000..5c0a23f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_remington.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_remington_icon.png b/mods/rangedweapons/textures/rangedweapons_remington_icon.png new file mode 100644 index 0000000..587576f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_remington_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_remington_rld.png b/mods/rangedweapons/textures/rangedweapons_remington_rld.png new file mode 100644 index 0000000..d32e9f2 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_remington_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_revolver_img.png b/mods/rangedweapons/textures/rangedweapons_revolver_img.png new file mode 100644 index 0000000..96ea77d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_revolver_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rifle_img.png b/mods/rangedweapons/textures/rangedweapons_rifle_img.png new file mode 100644 index 0000000..ee655bb Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rifle_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rifle_mag.png b/mods/rangedweapons/textures/rangedweapons_rifle_mag.png new file mode 100644 index 0000000..60fc871 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rifle_mag.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rifleshot.png b/mods/rangedweapons/textures/rangedweapons_rifleshot.png new file mode 100644 index 0000000..e0033e4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rifleshot.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rocket.png b/mods/rangedweapons/textures/rangedweapons_rocket.png new file mode 100644 index 0000000..5e7d01a Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rocket.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rocket_fly.png b/mods/rangedweapons/textures/rangedweapons_rocket_fly.png new file mode 100644 index 0000000..00e80db Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rocket_fly.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rocket_fly_alternate.png b/mods/rangedweapons/textures/rangedweapons_rocket_fly_alternate.png new file mode 100644 index 0000000..a267f7f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rocket_fly_alternate.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rpg.png b/mods/rangedweapons/textures/rangedweapons_rpg.png new file mode 100644 index 0000000..bdec5a7 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rpg.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rpg_icon.png b/mods/rangedweapons/textures/rangedweapons_rpg_icon.png new file mode 100644 index 0000000..f1df51c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rpg_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rpg_rld.png b/mods/rangedweapons/textures/rangedweapons_rpg_rld.png new file mode 100644 index 0000000..9d209d0 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rpg_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rpk.png b/mods/rangedweapons/textures/rangedweapons_rpk.png new file mode 100644 index 0000000..7f2c0c4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rpk.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rpk_icon.png b/mods/rangedweapons/textures/rangedweapons_rpk_icon.png new file mode 100644 index 0000000..9495ba2 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rpk_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_rpk_rld.png b/mods/rangedweapons/textures/rangedweapons_rpk_rld.png new file mode 100644 index 0000000..b9a80fd Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_rpk_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_scar.png b/mods/rangedweapons/textures/rangedweapons_scar.png new file mode 100644 index 0000000..8e5c987 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_scar.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_scar_icon.png b/mods/rangedweapons/textures/rangedweapons_scar_icon.png new file mode 100644 index 0000000..47d40c4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_scar_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_scar_rld.png b/mods/rangedweapons/textures/rangedweapons_scar_rld.png new file mode 100644 index 0000000..097b01c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_scar_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_scopehud.png b/mods/rangedweapons/textures/rangedweapons_scopehud.png new file mode 100644 index 0000000..aa523df Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_scopehud.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_shell.png b/mods/rangedweapons/textures/rangedweapons_shell.png new file mode 100644 index 0000000..b6a6874 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_shell.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_shelldrop.png b/mods/rangedweapons/textures/rangedweapons_shelldrop.png new file mode 100644 index 0000000..cd86136 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_shelldrop.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_shelldrop_grenade.png b/mods/rangedweapons/textures/rangedweapons_shelldrop_grenade.png new file mode 100644 index 0000000..7892447 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_shelldrop_grenade.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_shelldrop_shotgun.png b/mods/rangedweapons/textures/rangedweapons_shelldrop_shotgun.png new file mode 100644 index 0000000..cf829fd Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_shelldrop_shotgun.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_shelldrop_white.png b/mods/rangedweapons/textures/rangedweapons_shelldrop_white.png new file mode 100644 index 0000000..57de44c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_shelldrop_white.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_shotgun_img.png b/mods/rangedweapons/textures/rangedweapons_shotgun_img.png new file mode 100644 index 0000000..bb2754c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_shotgun_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_smg_img.png b/mods/rangedweapons/textures/rangedweapons_smg_img.png new file mode 100644 index 0000000..edba557 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_smg_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_spark.png b/mods/rangedweapons/textures/rangedweapons_spark.png new file mode 100644 index 0000000..f372cdc Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_spark.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_spas12.png b/mods/rangedweapons/textures/rangedweapons_spas12.png new file mode 100644 index 0000000..9fdcfba Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_spas12.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_spas12_icon.png b/mods/rangedweapons/textures/rangedweapons_spas12_icon.png new file mode 100644 index 0000000..9543646 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_spas12_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_spas12_rld.png b/mods/rangedweapons/textures/rangedweapons_spas12_rld.png new file mode 100644 index 0000000..778b61f Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_spas12_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_squirtgun.png b/mods/rangedweapons/textures/rangedweapons_squirtgun.png new file mode 100644 index 0000000..e00514c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_squirtgun.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_squirtgun_rld.png b/mods/rangedweapons/textures/rangedweapons_squirtgun_rld.png new file mode 100644 index 0000000..1886440 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_squirtgun_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_sriffle_img.png b/mods/rangedweapons/textures/rangedweapons_sriffle_img.png new file mode 100644 index 0000000..54fd2c6 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_sriffle_img.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_steel_shuriken.png b/mods/rangedweapons/textures/rangedweapons_steel_shuriken.png new file mode 100644 index 0000000..abdda91 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_steel_shuriken.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_stone_shuriken.png b/mods/rangedweapons/textures/rangedweapons_stone_shuriken.png new file mode 100644 index 0000000..6ddb3fa Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_stone_shuriken.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_svd.png b/mods/rangedweapons/textures/rangedweapons_svd.png new file mode 100644 index 0000000..d21efb9 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_svd.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_svd_icon.png b/mods/rangedweapons/textures/rangedweapons_svd_icon.png new file mode 100644 index 0000000..2785999 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_svd_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_svd_noclip.png b/mods/rangedweapons/textures/rangedweapons_svd_noclip.png new file mode 100644 index 0000000..a541e97 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_svd_noclip.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_svd_rld.png b/mods/rangedweapons/textures/rangedweapons_svd_rld.png new file mode 100644 index 0000000..28722bb Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_svd_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_taurus.png b/mods/rangedweapons/textures/rangedweapons_taurus.png new file mode 100644 index 0000000..1f09a73 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_taurus.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_taurus_icon.png b/mods/rangedweapons/textures/rangedweapons_taurus_icon.png new file mode 100644 index 0000000..686dbc4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_taurus_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_taurus_rld.png b/mods/rangedweapons/textures/rangedweapons_taurus_rld.png new file mode 100644 index 0000000..a53d8b5 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_taurus_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_tec9.png b/mods/rangedweapons/textures/rangedweapons_tec9.png new file mode 100644 index 0000000..692f409 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_tec9.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_tec9_icon.png b/mods/rangedweapons/textures/rangedweapons_tec9_icon.png new file mode 100644 index 0000000..012d112 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_tec9_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_tec9_rld.png b/mods/rangedweapons/textures/rangedweapons_tec9_rld.png new file mode 100644 index 0000000..6cae31d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_tec9_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_thompson.png b/mods/rangedweapons/textures/rangedweapons_thompson.png new file mode 100644 index 0000000..afec2d4 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_thompson.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_thompson_icon.png b/mods/rangedweapons/textures/rangedweapons_thompson_icon.png new file mode 100644 index 0000000..61e942e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_thompson_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_thompson_rld.png b/mods/rangedweapons/textures/rangedweapons_thompson_rld.png new file mode 100644 index 0000000..d0dff23 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_thompson_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_thrown_javelin.png b/mods/rangedweapons/textures/rangedweapons_thrown_javelin.png new file mode 100644 index 0000000..08f397c Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_thrown_javelin.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_tmp.png b/mods/rangedweapons/textures/rangedweapons_tmp.png new file mode 100644 index 0000000..e3b537e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_tmp.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_tmp_icon.png b/mods/rangedweapons/textures/rangedweapons_tmp_icon.png new file mode 100644 index 0000000..72ecc72 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_tmp_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_tmp_rld.png b/mods/rangedweapons/textures/rangedweapons_tmp_rld.png new file mode 100644 index 0000000..ce36a46 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_tmp_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ultra_gunsteel_ingot.png b/mods/rangedweapons/textures/rangedweapons_ultra_gunsteel_ingot.png new file mode 100644 index 0000000..e0e4eab Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ultra_gunsteel_ingot.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ump.png b/mods/rangedweapons/textures/rangedweapons_ump.png new file mode 100644 index 0000000..b41ad00 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ump.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ump_icon.png b/mods/rangedweapons/textures/rangedweapons_ump_icon.png new file mode 100644 index 0000000..abc89e2 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ump_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_ump_rld.png b/mods/rangedweapons/textures/rangedweapons_ump_rld.png new file mode 100644 index 0000000..ab5b73e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_ump_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_uzi.png b/mods/rangedweapons/textures/rangedweapons_uzi.png new file mode 100644 index 0000000..8a5ea5b Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_uzi.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_uzi_icon.png b/mods/rangedweapons/textures/rangedweapons_uzi_icon.png new file mode 100644 index 0000000..1f76cb2 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_uzi_icon.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_uzi_rld.png b/mods/rangedweapons/textures/rangedweapons_uzi_rld.png new file mode 100644 index 0000000..e7c1a6d Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_uzi_rld.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_wooden_shuriken.png b/mods/rangedweapons/textures/rangedweapons_wooden_shuriken.png new file mode 100644 index 0000000..6577ba9 Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_wooden_shuriken.png differ diff --git a/mods/rangedweapons/textures/rangedweapons_yeetable_img.png b/mods/rangedweapons/textures/rangedweapons_yeetable_img.png new file mode 100644 index 0000000..7239a3e Binary files /dev/null and b/mods/rangedweapons/textures/rangedweapons_yeetable_img.png differ diff --git a/mods/rangedweapons/thompson.lua b/mods/rangedweapons/thompson.lua new file mode 100644 index 0000000..c76abd2 --- /dev/null +++ b/mods/rangedweapons/thompson.lua @@ -0,0 +1,72 @@ + + +minetest.register_tool("rangedweapons:thompson_r", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:thompson_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_thompson_rld.png", +}) +minetest.register_tool("rangedweapons:thompson_rr", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:thompson_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_thompson.png", +}) +minetest.register_tool("rangedweapons:thompson_rrr", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:thompson", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_thompson.png", +}) +------------------------------------------- + + minetest.register_tool("rangedweapons:thompson", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "" ..core.colorize("#35cdff","Thompson SMG\n") ..core.colorize("#FFFFFF", "Ranged damage: 4\n") ..core.colorize("#FFFFFF", "accuracy: 75%\n") ..core.colorize("#FFFFFF", "knockback: 1\n") ..core.colorize("#FFFFFF", "Reload delay: 1.4\n") ..core.colorize("#FFFFFF", "Clip size: 30/30\n") ..core.colorize("#FFFFFF", "Critical chance: 8%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 10mm auto/.45acp\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.1 (full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: smg\n") ..core.colorize("#FFFFFF", "Bullet velocity: 30"), + range = 0, + inventory_image = "rangedweapons_thompson.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=4,knockback=1}, + gun_crit = 8, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:10mm",30},{"rangedweapons:45acp",30}}, + gun_skill = {"smg_skill",65}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_thompson_icon.png", + gun_unloaded = "rangedweapons:thompson_r", + gun_velocity = 30, + gun_accuracy = 75, + gun_cooldown = 0.1, + gun_reload = 1.4/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1250, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_smg", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) + + + + + diff --git a/mods/rangedweapons/tmp.lua b/mods/rangedweapons/tmp.lua new file mode 100644 index 0000000..dd5fc08 --- /dev/null +++ b/mods/rangedweapons/tmp.lua @@ -0,0 +1,68 @@ + +minetest.register_tool("rangedweapons:tmp_r", { + stack_max= 1, + wield_scale = {x=1.15,y=1.15,z=1.15}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:tmp_rr", + load_sound = "rangedweapons_handgun_mag_in", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_tmp_rld.png", +}) + +minetest.register_tool("rangedweapons:tmp_rr", { + stack_max= 1, + wield_scale = {x=1.15,y=1.15,z=1.15}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:tmp_rrr", + load_sound = "rangedweapons_reload_a", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_tmp.png", +}) + +minetest.register_tool("rangedweapons:tmp_rrr", { + stack_max= 1, + wield_scale = {x=1.15,y=1.15,z=1.15}, + description = "", + range = 0, + rw_next_reload = "rangedweapons:tmp", + load_sound = "rangedweapons_reload_b", + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_tmp.png", +}) + + minetest.register_tool("rangedweapons:tmp", { + stack_max= 1, + wield_scale = {x=1.15,y=1.15,z=1.15}, + description = "" ..core.colorize("#35cdff","Steyr T.M.P.\n") ..core.colorize("#FFFFFF", "Gun damage: 1\n") ..core.colorize("#FFFFFF", "accuracy: 64%\n") ..core.colorize("#FFFFFF", "Gun knockback: 0\n") ..core.colorize("#FFFFFF", "Gun Critical chance: 4%\n")..core.colorize("#FFFFFF", "Critical efficiency: 1.85x\n") ..core.colorize("#FFFFFF", "Reload delay: 1.0\n") ..core.colorize("#FFFFFF", "Clip size: 30\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.066(full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: machine pistol\n") ..core.colorize("#FFFFFF", "Bullet velocity: 20"), + range = 0, + inventory_image = "rangedweapons_tmp.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=1,knockback=0}, + gun_crit = 4, + gun_critEffc = 1.85, + suitable_ammo = {{"rangedweapons:9mm",30}}, + gun_skill = {"mp_skill",85}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_tmp_icon.png", + gun_unloaded = "rangedweapons:tmp_r", + gun_velocity = 20, + gun_accuracy = 64, + gun_cooldown = 0.066, + gun_reload = 1.0/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1200, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_machine_pistol", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) + diff --git a/mods/rangedweapons/ump.lua b/mods/rangedweapons/ump.lua new file mode 100644 index 0000000..cf099d4 --- /dev/null +++ b/mods/rangedweapons/ump.lua @@ -0,0 +1,70 @@ + + + +minetest.register_tool("rangedweapons:ump_r", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:ump_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_ump_rld.png", +}) +minetest.register_tool("rangedweapons:ump_rr", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:ump_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_ump.png", +}) +minetest.register_tool("rangedweapons:ump_rrr", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "", + rw_next_reload = "rangedweapons:ump", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_ump.png", +}) +------------------------------------------- + + minetest.register_tool("rangedweapons:ump", { + stack_max= 1, + wield_scale = {x=1.9,y=1.9,z=1.25}, + description = "" ..core.colorize("#35cdff","UMP-9\n") ..core.colorize("#FFFFFF", "Ranged damage: 5\n") ..core.colorize("#FFFFFF", "accuracy: 79%\n") ..core.colorize("#FFFFFF", "knockback: 1\n") ..core.colorize("#FFFFFF", "Reload delay: 1.25\n") ..core.colorize("#FFFFFF", "Clip size: 25/25\n") ..core.colorize("#FFFFFF", "Critical chance: 9%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 2.0x\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum/.45acp\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.115 (full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: smg\n") ..core.colorize("#FFFFFF", "Bullet velocity: 32"), + range = 0, + inventory_image = "rangedweapons_ump.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=5,knockback=1}, + gun_crit = 9, + gun_critEffc = 2.0, + suitable_ammo = {{"rangedweapons:9mm",25},{"rangedweapons:45acp",25}}, + gun_skill = {"smg_skill",60}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_ump_icon.png", + gun_unloaded = "rangedweapons:ump_r", + gun_velocity = 32, + gun_accuracy = 79, + gun_cooldown = 0.115, + gun_reload = 1.25/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1500, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_smg", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) + + diff --git a/mods/rangedweapons/uzi.lua b/mods/rangedweapons/uzi.lua new file mode 100644 index 0000000..d959eac --- /dev/null +++ b/mods/rangedweapons/uzi.lua @@ -0,0 +1,72 @@ + + +minetest.register_tool("rangedweapons:uzi_r", { + stack_max= 1, + wield_scale = {x=1.6,y=1.6,z=1.10}, + description = "", + rw_next_reload = "rangedweapons:uzi_rr", + load_sound = "rangedweapons_handgun_mag_in", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_uzi_rld.png", +}) +minetest.register_tool("rangedweapons:uzi_rr", { + stack_max= 1, + wield_scale = {x=1.6,y=1.6,z=1.10}, + description = "", + rw_next_reload = "rangedweapons:uzi_rrr", + load_sound = "rangedweapons_reload_a", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_uzi.png", +}) +minetest.register_tool("rangedweapons:uzi_rrr", { + stack_max= 1, + wield_scale = {x=1.6,y=1.6,z=1.10}, + description = "", + rw_next_reload = "rangedweapons:uzi", + load_sound = "rangedweapons_reload_b", + range = 0, + groups = {not_in_creative_inventory = 1}, + inventory_image = "rangedweapons_uzi.png", +}) +------------------------------------------- + + minetest.register_tool("rangedweapons:uzi", { + stack_max= 1, + wield_scale = {x=1.6,y=1.6,z=1.10}, + description = "" ..core.colorize("#35cdff","UZI\n") ..core.colorize("#FFFFFF", "Ranged damage: 2\n") ..core.colorize("#FFFFFF", "accuracy: 72%\n") ..core.colorize("#FFFFFF", "knockback: 0\n") ..core.colorize("#FFFFFF", "Reload delay: 1.2\n") ..core.colorize("#FFFFFF", "Clip size: 40/22\n") ..core.colorize("#FFFFFF", "Critical chance: 5%\n") ..core.colorize("#FFFFFF", "Critical efficiency: 1.9x\n") ..core.colorize("#FFFFFF", "Ammunition: 9x19mm parabellum/.45acp\n") ..core.colorize("#FFFFFF", "Rate of fire: 0.08 (full-auto)\n") ..core.colorize("#FFFFFF", "Gun type: machine pistol\n") ..core.colorize("#FFFFFF", "Bullet velocity: 25"), + range = 0, + inventory_image = "rangedweapons_uzi.png", + RW_gun_capabilities = { + automatic_gun = 1, + gun_damage = {fleshy=2,knockback=0}, + gun_crit = 5, + gun_critEffc = 1.9, + suitable_ammo = {{"rangedweapons:9mm",40},{"rangedweapons:45acp",22}}, + gun_skill = {"mp_skill",80}, + gun_magazine = "rangedweapons:machinepistol_mag", + gun_icon = "rangedweapons_uzi_icon.png", + gun_unloaded = "rangedweapons:uzi_r", + gun_velocity = 25, + gun_accuracy = 72, + gun_cooldown = 0.08, + gun_reload = 1.2/4, + gun_projectiles = 1, + has_shell = 1, + gun_gravity = 0, + gun_durability = 1500, + gun_smokeSize = 4, + gun_unload_sound = "rangedweapons_handgun_mag_out", + gun_sound = "rangedweapons_machine_pistol", + }, + on_secondary_use = function(itemstack, user, pointed_thing) +rangedweapons_reload_gun(itemstack, user) +return itemstack +end, +}) + + + + + diff --git a/mods/skybox/description.txt b/mods/skybox/description.txt new file mode 100644 index 0000000..3b4bc85 --- /dev/null +++ b/mods/skybox/description.txt @@ -0,0 +1 @@ +Allows changing your sky to unimaginably epic scenes. diff --git a/mods/skybox/init.lua b/mods/skybox/init.lua new file mode 100644 index 0000000..e406095 --- /dev/null +++ b/mods/skybox/init.lua @@ -0,0 +1,153 @@ + +--[[ + +Copyright (C) 2017 - Auke Kok + +"skybox" is free software; you can redistribute it and/or modify +it under the terms of the GNU Lesser General Public License as +published by the Free Software Foundation; either version 2.1 +of the license, or (at your option) any later version. + +]]-- + +-- +-- Builtin sky box textures and color/shadings, clouds +-- + +local skies = { + {"DarkStormy", "#1f2226", 0.5, { density = 0.5, color = "#aaaaaae0", ambient = "#000000", + height = 64, thickness = 32, speed = {x = 6, y = -6},}}, + {"CloudyLightRays", "#5f5f5e", 0.9, { density = 0.4, color = "#efe3d5d0", ambient = "#000000", + height = 96, thickness = 24, speed = {x = 4, y = 0},}}, + {"FullMoon", "#24292c", 0.2, { density = 0.25, color = "#ffffff80", ambient = "#404040", + height = 140, thickness = 8, speed = {x = -2, y = 2},}}, + {"SunSet", "#72624d", 0.4, { density = 0.2, color = "#f8d8e8e0", ambient = "#000000", + height = 120, thickness = 16, speed = {x = 0, y = -2},}}, + {"ThickCloudsWater", "#a57850", 0.8, { density = 0.35, color = "#ebe4ddfb", ambient = "#000000", + height = 80, thickness = 32, speed = {x = 4, y = 3},}}, + {"TropicalSunnyDay", "#f1f4ee", 1.0, { density = 0.25, color = "#fffffffb", ambient = "#000000", + height = 120, thickness = 8, speed = {x = -2, y = 0},}}, +} + +-- +-- API +-- + +skybox = {} + +skybox.set = function(player, number) + if number == 0 then + skybox.clear(player) + else + local sky = skies[number] + player:override_day_night_ratio(sky[3]) + local textures = { + sky[1] .. "Up.jpg", + sky[1] .. "Down.jpg", + sky[1] .. "Front.jpg", + sky[1] .. "Back.jpg", + sky[1] .. "Left.jpg", + sky[1] .. "Right.jpg", + } + if player.get_sky_color ~= nil then + player:set_sky({ + base_color = sky[2], + type = "skybox", + textures = textures, + clouds = true + }) + player:set_sun({visible = false, sunrise_visible = false}) + player:set_moon({visible = false}) + player:set_stars({visible = false}) + else + player:set_sky(sky[2], "skybox", textures, true) + end + player:set_clouds(sky[4]) + player:set_attribute("skybox:skybox", sky[1]) + end +end + +skybox.clear = function(player) + player:override_day_night_ratio(nil) + if player.get_sky_color ~= nil then + player:set_sky({base_color = "white", type = "regular"}) + else + player:set_sky("white", "regular") + end + player:set_clouds({ + density = 0.4, + color = "#fff0f0e5", + ambient = "#000000", + height = 120, + thickness = 16, + speed = {x = 0, y = -2}, + }) + player:set_sun({visible = true, sunrise_visible = true}) + player:set_moon({visible = true}) + player:set_stars({visible = true}) + + player:set_attribute("skybox:skybox", "off") +end + +skybox.add = function(def) + table.add(skies, def) +end + +skybox.get_skies = function() + return table.copy(skies) +end + +-- +-- registrations and load/save code +-- + +minetest.register_on_joinplayer(function(player) + local sky = player:get_attribute("skybox:skybox") + if not sky or sky == "" then + skybox.clear(player) + else + for k, v in ipairs(skies) do + if sky == v[1] then + skybox.set(player, k) + return + end + end + skybox.clear(player) + end +end) + +minetest.register_privilege("skybox", { + description = "Change sky box for yourself", +}) + +minetest.register_chatcommand("skybox", { + params = " or or \"off\" or empty to list skyboxes", + description = "Change your sky box set", + privs = "skybox", + func = function(name, param) + local player = minetest.get_player_by_name(name) + if not player then + return + end + if param == nil or param == "" then + minetest.chat_send_player(name, "Available sky boxes:") + for _, v in ipairs(skies) do + minetest.chat_send_player(name, v[1]) + end + return + elseif tonumber(param) ~= nil and tonumber(param) >= 1 and tonumber(param) <= table.getn(skies) then + skybox.set(player, tonumber(param)) + return + elseif param == "off" or param == "0" then + skybox.clear(player) + return + end + for k, v in ipairs(skies) do + if v[1] == param then + skybox.set(player, k) + return + end + end + minetest.chat_send_player(name, "Could not find that sky box.") + end +}) diff --git a/mods/skybox/mod.conf b/mods/skybox/mod.conf new file mode 100644 index 0000000..ce31e2d --- /dev/null +++ b/mods/skybox/mod.conf @@ -0,0 +1,5 @@ +name = skybox +description = Allows changing your sky to unimaginably epic scenes. +release = 8628 +author = sofar +title = Skybox diff --git a/mods/skybox/readme.md b/mods/skybox/readme.md new file mode 100644 index 0000000..8b87001 --- /dev/null +++ b/mods/skybox/readme.md @@ -0,0 +1,57 @@ + +## skybox - a player skybox mod (and API!) + +### License of code and artwork + +* Code: + +Copyright (C) 2017 - Auke Kok + +Provides a basic API for modifying a player sky box in a coherent +fashion. + +* Artwork (textures): + +SkyboxSet by Heiko Irrgang ( http://gamvas.com ) is licensed under +the Creative Commons Attribution-ShareAlike 3.0 Unported License. +Based on a work at http://93i.de. + + +### Usage + +The `skybox` privilege allows players to change their own sky boxes. +The command allows listing, and changing skyboxes, or turning skybox +settings `off`. + +### API + +The `skybox` handle can be used to perform various actions: + +`skybox.clear(player)` + -- Reverts the player skybox setting to the default. + +`skybox.set(player, number)` + -- Sets the skybox to the `number` in the list of current skyboxes. + +`skybox.add(skyboxdef)` + -- Add a new skybox with skyboxdef to the list of available skyboxes. + +`skybox.get_skies()` + -- Get a list of availiable skyboxes + -- Example value of `skybox.get_skies()[1]`: + --[[ + ```lua + {"DarkStormy", "#1f2226", 0.5, { density = 0.5, color = "#aaaaaae0", ambient = "#000000", + height = 64, thickness = 32, speed = {x = 6, y = -6},}}, + ``` + ]] + + +``` +skyboxdef = { + [1] -- Base name of texture. The 6 textures you need to + -- provide need to start with this value, and then + -- have "Up", "Down", "Front", "Back", "Left" and + -- "Right", Followed by ".jpg" as the file name. + [2] -- Sky color (colorstring) + [3] -- Day/Night ratio value (float - [0.0, 1.0]) diff --git a/mods/skybox/screenshot.png b/mods/skybox/screenshot.png new file mode 100644 index 0000000..bbb25d2 Binary files /dev/null and b/mods/skybox/screenshot.png differ diff --git a/mods/skybox/textures/CloudyLightRaysBack.jpg b/mods/skybox/textures/CloudyLightRaysBack.jpg new file mode 100644 index 0000000..9cd6fc2 Binary files /dev/null and b/mods/skybox/textures/CloudyLightRaysBack.jpg differ diff --git a/mods/skybox/textures/CloudyLightRaysDown.jpg b/mods/skybox/textures/CloudyLightRaysDown.jpg new file mode 100644 index 0000000..1b4783c Binary files /dev/null and b/mods/skybox/textures/CloudyLightRaysDown.jpg differ diff --git a/mods/skybox/textures/CloudyLightRaysFront.jpg b/mods/skybox/textures/CloudyLightRaysFront.jpg new file mode 100644 index 0000000..aee4703 Binary files /dev/null and b/mods/skybox/textures/CloudyLightRaysFront.jpg differ diff --git a/mods/skybox/textures/CloudyLightRaysLeft.jpg b/mods/skybox/textures/CloudyLightRaysLeft.jpg new file mode 100644 index 0000000..c8221f1 Binary files /dev/null and b/mods/skybox/textures/CloudyLightRaysLeft.jpg differ diff --git a/mods/skybox/textures/CloudyLightRaysRight.jpg b/mods/skybox/textures/CloudyLightRaysRight.jpg new file mode 100644 index 0000000..bed91bc Binary files /dev/null and b/mods/skybox/textures/CloudyLightRaysRight.jpg differ diff --git a/mods/skybox/textures/CloudyLightRaysUp.jpg b/mods/skybox/textures/CloudyLightRaysUp.jpg new file mode 100644 index 0000000..e5b0c56 Binary files /dev/null and b/mods/skybox/textures/CloudyLightRaysUp.jpg differ diff --git a/mods/skybox/textures/DarkStormyBack.jpg b/mods/skybox/textures/DarkStormyBack.jpg new file mode 100644 index 0000000..b6c5eee Binary files /dev/null and b/mods/skybox/textures/DarkStormyBack.jpg differ diff --git a/mods/skybox/textures/DarkStormyDown.jpg b/mods/skybox/textures/DarkStormyDown.jpg new file mode 100644 index 0000000..d6f3ed9 Binary files /dev/null and b/mods/skybox/textures/DarkStormyDown.jpg differ diff --git a/mods/skybox/textures/DarkStormyFront.jpg b/mods/skybox/textures/DarkStormyFront.jpg new file mode 100644 index 0000000..6dde1b8 Binary files /dev/null and b/mods/skybox/textures/DarkStormyFront.jpg differ diff --git a/mods/skybox/textures/DarkStormyLeft.jpg b/mods/skybox/textures/DarkStormyLeft.jpg new file mode 100644 index 0000000..7329077 Binary files /dev/null and b/mods/skybox/textures/DarkStormyLeft.jpg differ diff --git a/mods/skybox/textures/DarkStormyRight.jpg b/mods/skybox/textures/DarkStormyRight.jpg new file mode 100644 index 0000000..053e9bc Binary files /dev/null and b/mods/skybox/textures/DarkStormyRight.jpg differ diff --git a/mods/skybox/textures/DarkStormyUp.jpg b/mods/skybox/textures/DarkStormyUp.jpg new file mode 100644 index 0000000..07bdcec Binary files /dev/null and b/mods/skybox/textures/DarkStormyUp.jpg differ diff --git a/mods/skybox/textures/FullMoonBack.jpg b/mods/skybox/textures/FullMoonBack.jpg new file mode 100644 index 0000000..66775da Binary files /dev/null and b/mods/skybox/textures/FullMoonBack.jpg differ diff --git a/mods/skybox/textures/FullMoonDown.jpg b/mods/skybox/textures/FullMoonDown.jpg new file mode 100644 index 0000000..9f066e9 Binary files /dev/null and b/mods/skybox/textures/FullMoonDown.jpg differ diff --git a/mods/skybox/textures/FullMoonFront.jpg b/mods/skybox/textures/FullMoonFront.jpg new file mode 100644 index 0000000..1593909 Binary files /dev/null and b/mods/skybox/textures/FullMoonFront.jpg differ diff --git a/mods/skybox/textures/FullMoonLeft.jpg b/mods/skybox/textures/FullMoonLeft.jpg new file mode 100644 index 0000000..da68f62 Binary files /dev/null and b/mods/skybox/textures/FullMoonLeft.jpg differ diff --git a/mods/skybox/textures/FullMoonRight.jpg b/mods/skybox/textures/FullMoonRight.jpg new file mode 100644 index 0000000..a3e44f2 Binary files /dev/null and b/mods/skybox/textures/FullMoonRight.jpg differ diff --git a/mods/skybox/textures/FullMoonUp.jpg b/mods/skybox/textures/FullMoonUp.jpg new file mode 100644 index 0000000..bc023be Binary files /dev/null and b/mods/skybox/textures/FullMoonUp.jpg differ diff --git a/mods/skybox/textures/LICENSE.txt b/mods/skybox/textures/LICENSE.txt new file mode 100644 index 0000000..f06aa06 --- /dev/null +++ b/mods/skybox/textures/LICENSE.txt @@ -0,0 +1,8 @@ +SkyboxSet by Heiko Irrgang ( http://gamvas.com ) is licensed under +the Creative Commons Attribution-ShareAlike 3.0 Unported License. +Based on a work at http://93i.de. + +To view a copy of this license, visit +http://creativecommons.org/licenses/by-sa/3.0/ or send a letter to +Creative Commons, 444 Castro Street, Suite 900, Mountain View, +California, 94041, USA. diff --git a/mods/skybox/textures/README.txt b/mods/skybox/textures/README.txt new file mode 100644 index 0000000..3f19342 --- /dev/null +++ b/mods/skybox/textures/README.txt @@ -0,0 +1,16 @@ +You may use this textures for free in games, even commercial. + +See LICENSE.txt for details. + +Please also have a look on my other projects: + +Gamvas - a HTML5 game engine for the canvas element + +http://gamvas.com + +Brukkon - a puzzle game using the skybox textures + +http://93i.de/cms/products/games/brukkon + +Kind Regards, +Heiko Irrgang diff --git a/mods/skybox/textures/SunSetBack.jpg b/mods/skybox/textures/SunSetBack.jpg new file mode 100644 index 0000000..1e25dcb Binary files /dev/null and b/mods/skybox/textures/SunSetBack.jpg differ diff --git a/mods/skybox/textures/SunSetDown.jpg b/mods/skybox/textures/SunSetDown.jpg new file mode 100644 index 0000000..b0f16ad Binary files /dev/null and b/mods/skybox/textures/SunSetDown.jpg differ diff --git a/mods/skybox/textures/SunSetFront.jpg b/mods/skybox/textures/SunSetFront.jpg new file mode 100644 index 0000000..675d039 Binary files /dev/null and b/mods/skybox/textures/SunSetFront.jpg differ diff --git a/mods/skybox/textures/SunSetLeft.jpg b/mods/skybox/textures/SunSetLeft.jpg new file mode 100644 index 0000000..0dbe759 Binary files /dev/null and b/mods/skybox/textures/SunSetLeft.jpg differ diff --git a/mods/skybox/textures/SunSetRight.jpg b/mods/skybox/textures/SunSetRight.jpg new file mode 100644 index 0000000..5cd5a58 Binary files /dev/null and b/mods/skybox/textures/SunSetRight.jpg differ diff --git a/mods/skybox/textures/SunSetUp.jpg b/mods/skybox/textures/SunSetUp.jpg new file mode 100644 index 0000000..ac32168 Binary files /dev/null and b/mods/skybox/textures/SunSetUp.jpg differ diff --git a/mods/skybox/textures/ThickCloudsWaterBack.jpg b/mods/skybox/textures/ThickCloudsWaterBack.jpg new file mode 100644 index 0000000..eaf31c0 Binary files /dev/null and b/mods/skybox/textures/ThickCloudsWaterBack.jpg differ diff --git a/mods/skybox/textures/ThickCloudsWaterDown.jpg b/mods/skybox/textures/ThickCloudsWaterDown.jpg new file mode 100644 index 0000000..593b879 Binary files /dev/null and b/mods/skybox/textures/ThickCloudsWaterDown.jpg differ diff --git a/mods/skybox/textures/ThickCloudsWaterFront.jpg b/mods/skybox/textures/ThickCloudsWaterFront.jpg new file mode 100644 index 0000000..2ade37f Binary files /dev/null and b/mods/skybox/textures/ThickCloudsWaterFront.jpg differ diff --git a/mods/skybox/textures/ThickCloudsWaterLeft.jpg b/mods/skybox/textures/ThickCloudsWaterLeft.jpg new file mode 100644 index 0000000..9b96687 Binary files /dev/null and b/mods/skybox/textures/ThickCloudsWaterLeft.jpg differ diff --git a/mods/skybox/textures/ThickCloudsWaterRight.jpg b/mods/skybox/textures/ThickCloudsWaterRight.jpg new file mode 100644 index 0000000..71900ad Binary files /dev/null and b/mods/skybox/textures/ThickCloudsWaterRight.jpg differ diff --git a/mods/skybox/textures/ThickCloudsWaterUp.jpg b/mods/skybox/textures/ThickCloudsWaterUp.jpg new file mode 100644 index 0000000..e17635c Binary files /dev/null and b/mods/skybox/textures/ThickCloudsWaterUp.jpg differ diff --git a/mods/skybox/textures/TropicalSunnyDayBack.jpg b/mods/skybox/textures/TropicalSunnyDayBack.jpg new file mode 100644 index 0000000..e883eb9 Binary files /dev/null and b/mods/skybox/textures/TropicalSunnyDayBack.jpg differ diff --git a/mods/skybox/textures/TropicalSunnyDayDown.jpg b/mods/skybox/textures/TropicalSunnyDayDown.jpg new file mode 100644 index 0000000..95bb109 Binary files /dev/null and b/mods/skybox/textures/TropicalSunnyDayDown.jpg differ diff --git a/mods/skybox/textures/TropicalSunnyDayFront.jpg b/mods/skybox/textures/TropicalSunnyDayFront.jpg new file mode 100644 index 0000000..db75471 Binary files /dev/null and b/mods/skybox/textures/TropicalSunnyDayFront.jpg differ diff --git a/mods/skybox/textures/TropicalSunnyDayLeft.jpg b/mods/skybox/textures/TropicalSunnyDayLeft.jpg new file mode 100644 index 0000000..30a8b4d Binary files /dev/null and b/mods/skybox/textures/TropicalSunnyDayLeft.jpg differ diff --git a/mods/skybox/textures/TropicalSunnyDayRight.jpg b/mods/skybox/textures/TropicalSunnyDayRight.jpg new file mode 100644 index 0000000..57d191a Binary files /dev/null and b/mods/skybox/textures/TropicalSunnyDayRight.jpg differ diff --git a/mods/skybox/textures/TropicalSunnyDayUp.jpg b/mods/skybox/textures/TropicalSunnyDayUp.jpg new file mode 100644 index 0000000..a3b4eff Binary files /dev/null and b/mods/skybox/textures/TropicalSunnyDayUp.jpg differ diff --git a/mods/telephone/README.md b/mods/telephone/README.md new file mode 100644 index 0000000..c1d8a57 --- /dev/null +++ b/mods/telephone/README.md @@ -0,0 +1 @@ +This is a mod that adds numerous telecommunications devices, including, but not limited to, computer networks, telephone systems, and more. \ No newline at end of file diff --git a/mods/telephone/api.lua b/mods/telephone/api.lua new file mode 100644 index 0000000..e69de29 diff --git a/mods/telephone/init.lua b/mods/telephone/init.lua new file mode 100644 index 0000000..6ce0819 --- /dev/null +++ b/mods/telephone/init.lua @@ -0,0 +1,167 @@ +dofile(minetest.get_modpath('telephone')..'/api.lua') + +minetest.register_chatcommand("call", { + description = "Displays the calling formspec", + + func = function(name, param) + minetest.show_formspec(name, "telephone:call", + "size[10,10]" .. + "real_coordinates[true]" .. + "field[0.3,1;5,0.8;caller;Caller #;]" .. + "field[0.3,2;5,0.8;target;Target #;]" .. + "button[0.3,5;5,1;call;Call]") + end, +}) + +minetest.register_on_player_receive_fields(function(player, formname, fields) + if formname ~= "telephone:call" then + + return false + end + + + minetest.chat_send_player(player:get_player_name(), minetest.get_node(fields.target)) + --if minetest.get_node(fields.target).name == "telephone:neusonic_kxt2378mxwd" then + --minetest.chat_send_player(player:get_player_name(), "Calling the number " .. fields.target .. ". Your number is " .. fields.caller .. ".") + --end + return true +end) + +minetest.register_node("telephone:neusonic_kxt2378", { + description = "Neusonic KX-T2378", + tiles = { + "telephone_neusonic_kxt2378.png", + "telephone_neusonic_kxt2378_bottom.png", + "telephone_neusonic_kxt2378_side.png", + "telephone_neusonic_kxt2378_side.png", + "telephone_neusonic_kxt2378_front.png", + "telephone_neusonic_kxt2378_front.png" + }, + drawtype = "nodebox", + paramtype = "light", + paramtype2 = "facedir", + groups = {cracky = 2}, + on_punch = function(pos, node, puncher, pointed_thing) + node.name = "telephone:neusonic_kxt2378_offhook" + minetest.set_node(pos, node) + end, + + node_box = { + type = "fixed", + fixed = { + {-0.3125, -0.5, -0.4375, 0.3125, -0.25, 0.4375}, + } + } +}) + +minetest.register_node("telephone:neusonic_kxt2378_offhook", { + description = "Neusonic KX-T2378 (Off Hook)", + tiles = { + "telephone_neusonic_kxt2378_offhook.png", + "telephone_neusonic_kxt2378_bottom.png", + "telephone_neusonic_kxt2378_side.png", + "telephone_neusonic_kxt2378_side.png", + "telephone_neusonic_kxt2378_front.png", + "telephone_neusonic_kxt2378_front.png" + }, + drawtype = "nodebox", + paramtype = "light", + paramtype2 = "facedir", + groups = {cracky = 2}, + on_punch = function(pos, node, puncher, pointed_thing) + node.name = "telephone:neusonic_kxt2378" + minetest.set_node(pos, node) + end, + + node_box = { + type = "fixed", + fixed = { + {-0.3125, -0.5, -0.4375, 0.3125, -0.25, 0.4375}, + } + } +}) + +--minetest.register_node("telephone:neusonic_kxt2378mxwd_ringing", { +-- description = "Neusonic KXT-2378MXWD (Ringing)", + --tiles = {"telephone_neusonic_kxt2378mxwd_ringing.png"}, + --groups = {cracky = 2}, + --on_punch = function(pos, node, puncher, pointed_thing) + -- minetest.set_node({x = pos.x, y = pos.y, z = pos.z}, {name = "telephone:neusonic_kxt2378mxwd_conversation"}) + + + --end, +--}) + +--Saxom exKanto +minetest.register_node("telephone:saxom_exkanto", { + description = "Saxom eXkanto", + groups = {cracky = 2}, + + on_punch = function(pos, node, puncher, pointed_thing) + node.name = "telephone:saxom_exkanto_offhook" + minetest.set_node(pos, node) + end, + + tiles = { + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_bottom.png", + "telephone_saxom_exkanto.png" + }, + drawtype = "nodebox", + paramtype = "light", + paramtype2 = "facedir", + node_box = { + type = "fixed", + fixed = { + {-0.375, -0.4375, 0.0625, 0.375, 0.4375, 0.5}, + } + } +}) + +minetest.register_node("telephone:saxom_exkanto_offhook", { + description = "Saxom eXkanto (Off Hook)", + groups = {cracky = 2}, + + on_punch = function(pos, node, puncher, pointed_thing) + node.name = "telephone:saxom_exkanto" + minetest.set_node(pos, node) + end, + + tiles = { + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_side.png", + "telephone_saxom_exkanto_bottom.png", + "telephone_saxom_exkanto_offhook.png" + }, + drawtype = "nodebox", + paramtype = "light", + paramtype2 = "facedir", + node_box = { + type = "fixed", + fixed = { + {-0.375, -0.4375, 0.0625, 0.375, 0.4375, 0.5}, + } + } +}) + + +minetest.register_craftitem("telephone:coin_2", { + description = "2-Golden Coin", + inventory_image = "telephone_coin_2.png", +}) + +minetest.register_craftitem("telephone:card_magnetic", { + description = "Magnetic Payphone Card", + inventory_image = "telephone_card_magnetic.png", +}) + +minetest.register_craftitem("telephone:card_electronic", { + description = "Electronic Payphone Card", + inventory_image = "telephone_card_electronic.png", +}) + diff --git a/mods/telephone/textures/telephone_card_electronic.png b/mods/telephone/textures/telephone_card_electronic.png new file mode 100644 index 0000000..1673fb6 Binary files /dev/null and b/mods/telephone/textures/telephone_card_electronic.png differ diff --git a/mods/telephone/textures/telephone_card_magnetic.png b/mods/telephone/textures/telephone_card_magnetic.png new file mode 100644 index 0000000..636e22a Binary files /dev/null and b/mods/telephone/textures/telephone_card_magnetic.png differ diff --git a/mods/telephone/textures/telephone_coin_2.png b/mods/telephone/textures/telephone_coin_2.png new file mode 100644 index 0000000..c23c9e9 Binary files /dev/null and b/mods/telephone/textures/telephone_coin_2.png differ diff --git a/mods/telephone/textures/telephone_neusonic_kxt2378.png b/mods/telephone/textures/telephone_neusonic_kxt2378.png new file mode 100644 index 0000000..fef4849 Binary files /dev/null and b/mods/telephone/textures/telephone_neusonic_kxt2378.png differ diff --git a/mods/telephone/textures/telephone_neusonic_kxt2378_bottom.png b/mods/telephone/textures/telephone_neusonic_kxt2378_bottom.png new file mode 100644 index 0000000..0d3103d Binary files /dev/null and b/mods/telephone/textures/telephone_neusonic_kxt2378_bottom.png differ diff --git a/mods/telephone/textures/telephone_neusonic_kxt2378_front.png b/mods/telephone/textures/telephone_neusonic_kxt2378_front.png new file mode 100644 index 0000000..6270e00 Binary files /dev/null and b/mods/telephone/textures/telephone_neusonic_kxt2378_front.png differ diff --git a/mods/telephone/textures/telephone_neusonic_kxt2378_offhook.png b/mods/telephone/textures/telephone_neusonic_kxt2378_offhook.png new file mode 100644 index 0000000..324fb29 Binary files /dev/null and b/mods/telephone/textures/telephone_neusonic_kxt2378_offhook.png differ diff --git a/mods/telephone/textures/telephone_neusonic_kxt2378_side.png b/mods/telephone/textures/telephone_neusonic_kxt2378_side.png new file mode 100644 index 0000000..286ecd0 Binary files /dev/null and b/mods/telephone/textures/telephone_neusonic_kxt2378_side.png differ diff --git a/mods/telephone/textures/telephone_patriot.png b/mods/telephone/textures/telephone_patriot.png new file mode 100644 index 0000000..4ce3baf Binary files /dev/null and b/mods/telephone/textures/telephone_patriot.png differ diff --git a/mods/telephone/textures/telephone_patriot_offhook.png b/mods/telephone/textures/telephone_patriot_offhook.png new file mode 100644 index 0000000..89aacd0 Binary files /dev/null and b/mods/telephone/textures/telephone_patriot_offhook.png differ diff --git a/mods/telephone/textures/telephone_saxom_exkanto.png b/mods/telephone/textures/telephone_saxom_exkanto.png new file mode 100644 index 0000000..0dabada Binary files /dev/null and b/mods/telephone/textures/telephone_saxom_exkanto.png differ diff --git a/mods/telephone/textures/telephone_saxom_exkanto_bottom.png b/mods/telephone/textures/telephone_saxom_exkanto_bottom.png new file mode 100644 index 0000000..8a7ab5d Binary files /dev/null and b/mods/telephone/textures/telephone_saxom_exkanto_bottom.png differ diff --git a/mods/telephone/textures/telephone_saxom_exkanto_offhook.png b/mods/telephone/textures/telephone_saxom_exkanto_offhook.png new file mode 100644 index 0000000..104d7e2 Binary files /dev/null and b/mods/telephone/textures/telephone_saxom_exkanto_offhook.png differ diff --git a/mods/telephone/textures/telephone_saxom_exkanto_side.png b/mods/telephone/textures/telephone_saxom_exkanto_side.png new file mode 100644 index 0000000..6ae01fd Binary files /dev/null and b/mods/telephone/textures/telephone_saxom_exkanto_side.png differ diff --git a/mods/telephone/textures/telephone_unitel.png b/mods/telephone/textures/telephone_unitel.png new file mode 100644 index 0000000..f9d9e52 Binary files /dev/null and b/mods/telephone/textures/telephone_unitel.png differ