summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorenneract <trem.redman@gmail.com>2014-12-14 14:56:38 +0100
committerenneract <trem.redman@gmail.com>2014-12-14 14:56:38 +0100
commit7c02e34b08a4e44a7f7935bf6b1bee45c3a8df6c (patch)
treee3ff69394522a6cc7dd11edf27cd69df6c0a5819
parentbd6fc418d171378de5de2b7450e22f70b4899b5c (diff)
parent5130cdd357c5b3b442d39ee05052739419456e77 (diff)
Merge branch 'newguns'
Conflicts: src/cgame/cg_local.h src/cgame/cg_main.c
-rw-r--r--assets/gfx/rocketx/0002.jpgbin0 -> 4605 bytes
-rw-r--r--assets/gfx/rocketx/0003.jpgbin0 -> 6454 bytes
-rw-r--r--assets/gfx/rocketx/0004.jpgbin0 -> 7373 bytes
-rw-r--r--assets/gfx/rocketx/0005.jpgbin0 -> 7978 bytes
-rw-r--r--assets/gfx/rocketx/0006.jpgbin0 -> 8260 bytes
-rw-r--r--assets/gfx/rocketx/0007.jpgbin0 -> 8351 bytes
-rw-r--r--assets/gfx/rocketx/0008.jpgbin0 -> 8448 bytes
-rw-r--r--assets/gfx/rocketx/0009.jpgbin0 -> 8560 bytes
-rw-r--r--assets/gfx/rocketx/0010.jpgbin0 -> 8660 bytes
-rw-r--r--assets/gfx/rocketx/0011.jpgbin0 -> 8827 bytes
-rw-r--r--assets/gfx/rocketx/0012.jpgbin0 -> 8947 bytes
-rw-r--r--assets/gfx/rocketx/0013.jpgbin0 -> 9079 bytes
-rw-r--r--assets/gfx/rocketx/0014.jpgbin0 -> 9090 bytes
-rw-r--r--assets/gfx/rocketx/0015.jpgbin0 -> 9029 bytes
-rw-r--r--assets/gfx/rocketx/0016.jpgbin0 -> 9019 bytes
-rw-r--r--assets/gfx/rocketx/0017.jpgbin0 -> 8935 bytes
-rw-r--r--assets/gfx/rocketx/0018.jpgbin0 -> 8850 bytes
-rw-r--r--assets/gfx/rocketx/0019.jpgbin0 -> 8662 bytes
-rw-r--r--assets/gfx/rocketx/0020.jpgbin0 -> 8450 bytes
-rw-r--r--assets/gfx/rocketx/0021.jpgbin0 -> 8249 bytes
-rw-r--r--assets/gfx/rocketx/0022.jpgbin0 -> 8022 bytes
-rw-r--r--assets/gfx/rocketx/0023.jpgbin0 -> 7930 bytes
-rw-r--r--assets/gfx/rocketx/0024.jpgbin0 -> 7733 bytes
-rw-r--r--assets/gfx/rocketx/0025.jpgbin0 -> 6127 bytes
-rw-r--r--assets/gfx/rocketx/0026.jpgbin0 -> 5150 bytes
-rw-r--r--assets/gfx/rocketx/0027.jpgbin0 -> 3942 bytes
-rw-r--r--assets/gfx/rocketx/0028.jpgbin0 -> 2777 bytes
-rw-r--r--assets/gfx/rocketx/0029.jpgbin0 -> 1718 bytes
-rw-r--r--assets/gfx/rocketx/0030.jpgbin0 -> 1193 bytes
-rw-r--r--assets/icons/iconw_lightning.tgabin0 -> 6814 bytes
-rw-r--r--assets/icons/iconw_smoke.tgabin40044 -> 0 bytes
-rw-r--r--assets/models/weapons/grenade/weapon.cfg1
-rw-r--r--assets/models/weapons/lcannon/weapon.cfg2
-rw-r--r--assets/models/weapons/lightning/CREDITS15
-rw-r--r--assets/models/weapons/lightning/bolt.jpgbin0 -> 4775 bytes
-rw-r--r--assets/models/weapons/lightning/firing.wavbin0 -> 653456 bytes
-rw-r--r--assets/models/weapons/lightning/flash.jpgbin0 -> 7842 bytes
-rw-r--r--assets/models/weapons/lightning/flash0.wavbin0 -> 138302 bytes
-rw-r--r--assets/models/weapons/lightning/impact0.wavbin0 -> 23760 bytes
-rw-r--r--assets/models/weapons/lightning/impact1.wavbin0 -> 29234 bytes
-rw-r--r--assets/models/weapons/lightning/impact2.wavbin0 -> 23370 bytes
-rw-r--r--assets/models/weapons/lightning/lightning.jpgbin0 -> 51257 bytes
-rw-r--r--assets/models/weapons/lightning/lightning.md3bin0 -> 20692 bytes
-rw-r--r--assets/models/weapons/lightning/lightning_flash.md3bin0 -> 868 bytes
-rw-r--r--assets/models/weapons/lightning/lightning_hand.md3bin0 -> 2628 bytes
-rw-r--r--assets/models/weapons/lightning/sidrial license.txt245
-rw-r--r--assets/models/weapons/lightning/weapon.cfg20
-rw-r--r--assets/models/weapons/rocketl/flash0.wavbin99924 -> 99924 bytes
-rw-r--r--assets/models/weapons/rocketl/rocketl.md3bin5796 -> 6004 bytes
-rw-r--r--assets/models/weapons/rocketl/rocketl_flash.md3bin0 -> 868 bytes
-rw-r--r--assets/models/weapons/rocketl/weapon.cfg2
-rw-r--r--assets/models/weapons/smoke/smoke.jpgbin99790 -> 0 bytes
-rw-r--r--assets/models/weapons/smoke/smoke.md3bin2652 -> 0 bytes
-rw-r--r--assets/models/weapons/smoke/smoke.wavbin52974 -> 0 bytes
-rw-r--r--assets/models/weapons/smoke/smokegfx.tgabin262188 -> 0 bytes
-rw-r--r--assets/models/weapons/smoke/weapon.cfg11
-rw-r--r--assets/scripts/hw_lightning.particle35
-rw-r--r--assets/scripts/hw_lightning.shader36
-rw-r--r--assets/scripts/hw_rocketl.particle41
-rw-r--r--assets/scripts/hw_rocketl.shader302
-rw-r--r--src/cgame/cg_event.c18
-rw-r--r--src/cgame/cg_local.h12
-rw-r--r--src/cgame/cg_main.c16
-rw-r--r--src/cgame/cg_view.c37
-rw-r--r--src/cgame/cg_weapons.c176
-rw-r--r--src/game/bg_misc.c50
-rw-r--r--src/game/bg_mod.h2
-rw-r--r--src/game/bg_public.h2
-rw-r--r--src/game/g_active.c15
-rw-r--r--src/game/g_missile.c38
-rw-r--r--src/game/g_weapon.c64
-rw-r--r--src/game/tremulous.h8
72 files changed, 988 insertions, 160 deletions
diff --git a/assets/gfx/rocketx/0002.jpg b/assets/gfx/rocketx/0002.jpg
new file mode 100644
index 0000000..776768b
--- /dev/null
+++ b/assets/gfx/rocketx/0002.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0003.jpg b/assets/gfx/rocketx/0003.jpg
new file mode 100644
index 0000000..91313e7
--- /dev/null
+++ b/assets/gfx/rocketx/0003.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0004.jpg b/assets/gfx/rocketx/0004.jpg
new file mode 100644
index 0000000..a1848ed
--- /dev/null
+++ b/assets/gfx/rocketx/0004.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0005.jpg b/assets/gfx/rocketx/0005.jpg
new file mode 100644
index 0000000..da5e255
--- /dev/null
+++ b/assets/gfx/rocketx/0005.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0006.jpg b/assets/gfx/rocketx/0006.jpg
new file mode 100644
index 0000000..6d026ba
--- /dev/null
+++ b/assets/gfx/rocketx/0006.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0007.jpg b/assets/gfx/rocketx/0007.jpg
new file mode 100644
index 0000000..c18ce0d
--- /dev/null
+++ b/assets/gfx/rocketx/0007.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0008.jpg b/assets/gfx/rocketx/0008.jpg
new file mode 100644
index 0000000..06a2d74
--- /dev/null
+++ b/assets/gfx/rocketx/0008.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0009.jpg b/assets/gfx/rocketx/0009.jpg
new file mode 100644
index 0000000..6e7bc69
--- /dev/null
+++ b/assets/gfx/rocketx/0009.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0010.jpg b/assets/gfx/rocketx/0010.jpg
new file mode 100644
index 0000000..400d603
--- /dev/null
+++ b/assets/gfx/rocketx/0010.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0011.jpg b/assets/gfx/rocketx/0011.jpg
new file mode 100644
index 0000000..17e0220
--- /dev/null
+++ b/assets/gfx/rocketx/0011.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0012.jpg b/assets/gfx/rocketx/0012.jpg
new file mode 100644
index 0000000..6765bf9
--- /dev/null
+++ b/assets/gfx/rocketx/0012.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0013.jpg b/assets/gfx/rocketx/0013.jpg
new file mode 100644
index 0000000..a543aba
--- /dev/null
+++ b/assets/gfx/rocketx/0013.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0014.jpg b/assets/gfx/rocketx/0014.jpg
new file mode 100644
index 0000000..5ed10d8
--- /dev/null
+++ b/assets/gfx/rocketx/0014.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0015.jpg b/assets/gfx/rocketx/0015.jpg
new file mode 100644
index 0000000..5fe6015
--- /dev/null
+++ b/assets/gfx/rocketx/0015.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0016.jpg b/assets/gfx/rocketx/0016.jpg
new file mode 100644
index 0000000..24f0d16
--- /dev/null
+++ b/assets/gfx/rocketx/0016.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0017.jpg b/assets/gfx/rocketx/0017.jpg
new file mode 100644
index 0000000..3b037f5
--- /dev/null
+++ b/assets/gfx/rocketx/0017.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0018.jpg b/assets/gfx/rocketx/0018.jpg
new file mode 100644
index 0000000..b479532
--- /dev/null
+++ b/assets/gfx/rocketx/0018.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0019.jpg b/assets/gfx/rocketx/0019.jpg
new file mode 100644
index 0000000..288bd52
--- /dev/null
+++ b/assets/gfx/rocketx/0019.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0020.jpg b/assets/gfx/rocketx/0020.jpg
new file mode 100644
index 0000000..97f2d10
--- /dev/null
+++ b/assets/gfx/rocketx/0020.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0021.jpg b/assets/gfx/rocketx/0021.jpg
new file mode 100644
index 0000000..3443b96
--- /dev/null
+++ b/assets/gfx/rocketx/0021.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0022.jpg b/assets/gfx/rocketx/0022.jpg
new file mode 100644
index 0000000..b14747d
--- /dev/null
+++ b/assets/gfx/rocketx/0022.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0023.jpg b/assets/gfx/rocketx/0023.jpg
new file mode 100644
index 0000000..da23eb0
--- /dev/null
+++ b/assets/gfx/rocketx/0023.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0024.jpg b/assets/gfx/rocketx/0024.jpg
new file mode 100644
index 0000000..bfe4476
--- /dev/null
+++ b/assets/gfx/rocketx/0024.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0025.jpg b/assets/gfx/rocketx/0025.jpg
new file mode 100644
index 0000000..e6a7923
--- /dev/null
+++ b/assets/gfx/rocketx/0025.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0026.jpg b/assets/gfx/rocketx/0026.jpg
new file mode 100644
index 0000000..99ef757
--- /dev/null
+++ b/assets/gfx/rocketx/0026.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0027.jpg b/assets/gfx/rocketx/0027.jpg
new file mode 100644
index 0000000..220234b
--- /dev/null
+++ b/assets/gfx/rocketx/0027.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0028.jpg b/assets/gfx/rocketx/0028.jpg
new file mode 100644
index 0000000..5b2b4e6
--- /dev/null
+++ b/assets/gfx/rocketx/0028.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0029.jpg b/assets/gfx/rocketx/0029.jpg
new file mode 100644
index 0000000..585257e
--- /dev/null
+++ b/assets/gfx/rocketx/0029.jpg
Binary files differ
diff --git a/assets/gfx/rocketx/0030.jpg b/assets/gfx/rocketx/0030.jpg
new file mode 100644
index 0000000..09721ca
--- /dev/null
+++ b/assets/gfx/rocketx/0030.jpg
Binary files differ
diff --git a/assets/icons/iconw_lightning.tga b/assets/icons/iconw_lightning.tga
new file mode 100644
index 0000000..280e83d
--- /dev/null
+++ b/assets/icons/iconw_lightning.tga
Binary files differ
diff --git a/assets/icons/iconw_smoke.tga b/assets/icons/iconw_smoke.tga
deleted file mode 100644
index 0dd72b1..0000000
--- a/assets/icons/iconw_smoke.tga
+++ /dev/null
Binary files differ
diff --git a/assets/models/weapons/grenade/weapon.cfg b/assets/models/weapons/grenade/weapon.cfg
index a0d2f1b..9d0811c 100644
--- a/assets/models/weapons/grenade/weapon.cfg
+++ b/assets/models/weapons/grenade/weapon.cfg
@@ -9,4 +9,5 @@ primary
impactParticleSystem models/weapons/grenade/impactPS2
impactSound 0 models/weapons/grenade/impact0.wav
+ impactQuake 120
}
diff --git a/assets/models/weapons/lcannon/weapon.cfg b/assets/models/weapons/lcannon/weapon.cfg
index e6f1ab4..5719fdc 100644
--- a/assets/models/weapons/lcannon/weapon.cfg
+++ b/assets/models/weapons/lcannon/weapon.cfg
@@ -16,6 +16,7 @@ primary
impactMark 32 gfx/marks/bullet_mrk
impactSound 0 models/weapons/lcannon/impact0.wav
impactParticleSystem models/weapons/lcannon/impactPS2
+ impactQuake 1
}
secondary
@@ -30,4 +31,5 @@ secondary
impactMark 8 gfx/marks/bullet_mrk
impactSound 0 models/weapons/lcannon/impact0.wav
impactParticleSystem models/weapons/lcannon/secondaryImpactPS2
+ impactQuake 5
}
diff --git a/assets/models/weapons/lightning/CREDITS b/assets/models/weapons/lightning/CREDITS
new file mode 100644
index 0000000..9ce05bb
--- /dev/null
+++ b/assets/models/weapons/lightning/CREDITS
@@ -0,0 +1,15 @@
+firing.wav:
+ http://freesound.org/people/HerbertBoland/sounds/114595/
+
+flash0.wav:
+ http://freesound.org/people/roper1911/sounds/152322/
+
+impact0.wav:
+impact1.wav:
+impact2.wav:
+ http://freesound.org/people/FreqMan/sounds/24726/
+
+lightning.md3:
+lightning.jpg:
+ see "sidrial license.txt"
+
diff --git a/assets/models/weapons/lightning/bolt.jpg b/assets/models/weapons/lightning/bolt.jpg
new file mode 100644
index 0000000..07d7ef1
--- /dev/null
+++ b/assets/models/weapons/lightning/bolt.jpg
Binary files differ
diff --git a/assets/models/weapons/lightning/firing.wav b/assets/models/weapons/lightning/firing.wav
new file mode 100644
index 0000000..3ba7722
--- /dev/null
+++ b/assets/models/weapons/lightning/firing.wav
Binary files differ
diff --git a/assets/models/weapons/lightning/flash.jpg b/assets/models/weapons/lightning/flash.jpg
new file mode 100644
index 0000000..070d8fa
--- /dev/null
+++ b/assets/models/weapons/lightning/flash.jpg
Binary files differ
diff --git a/assets/models/weapons/lightning/flash0.wav b/assets/models/weapons/lightning/flash0.wav
new file mode 100644
index 0000000..5895c02
--- /dev/null
+++ b/assets/models/weapons/lightning/flash0.wav
Binary files differ
diff --git a/assets/models/weapons/lightning/impact0.wav b/assets/models/weapons/lightning/impact0.wav
new file mode 100644
index 0000000..8f70050
--- /dev/null
+++ b/assets/models/weapons/lightning/impact0.wav
Binary files differ
diff --git a/assets/models/weapons/lightning/impact1.wav b/assets/models/weapons/lightning/impact1.wav
new file mode 100644
index 0000000..530d28b
--- /dev/null
+++ b/assets/models/weapons/lightning/impact1.wav
Binary files differ
diff --git a/assets/models/weapons/lightning/impact2.wav b/assets/models/weapons/lightning/impact2.wav
new file mode 100644
index 0000000..ffff0d2
--- /dev/null
+++ b/assets/models/weapons/lightning/impact2.wav
Binary files differ
diff --git a/assets/models/weapons/lightning/lightning.jpg b/assets/models/weapons/lightning/lightning.jpg
new file mode 100644
index 0000000..f7955d6
--- /dev/null
+++ b/assets/models/weapons/lightning/lightning.jpg
Binary files differ
diff --git a/assets/models/weapons/lightning/lightning.md3 b/assets/models/weapons/lightning/lightning.md3
new file mode 100644
index 0000000..c96197b
--- /dev/null
+++ b/assets/models/weapons/lightning/lightning.md3
Binary files differ
diff --git a/assets/models/weapons/lightning/lightning_flash.md3 b/assets/models/weapons/lightning/lightning_flash.md3
new file mode 100644
index 0000000..2f6ceb0
--- /dev/null
+++ b/assets/models/weapons/lightning/lightning_flash.md3
Binary files differ
diff --git a/assets/models/weapons/lightning/lightning_hand.md3 b/assets/models/weapons/lightning/lightning_hand.md3
new file mode 100644
index 0000000..edda546
--- /dev/null
+++ b/assets/models/weapons/lightning/lightning_hand.md3
Binary files differ
diff --git a/assets/models/weapons/lightning/sidrial license.txt b/assets/models/weapons/lightning/sidrial license.txt
new file mode 100644
index 0000000..14ac66d
--- /dev/null
+++ b/assets/models/weapons/lightning/sidrial license.txt
@@ -0,0 +1,245 @@
+The weapons (blaster, gat, grenner) their effects and
+icons as well as the powerup-models are taken from
+Sidrial Quake3-MOD by Fountainhead Entertainment
+----------------------------------------------------------
+
+
+LIMITED USE SOFTWARE LICENSE AGREEMENT
+
+This Limited Use Software License Agreement (this
+"Agreement") is a legal agreement between you, the
+end-user, and Fountainhead Entertainment, Inc.
+("Fountainhead"). BY CONTINUING THE INSTALLATION
+OF THE TOTAL CONVERSION TITLED SIDRIAL (THE
+"SOFTWARE"), BY LOADING OR RUNNING THE SOFTWARE,
+OR BY PLACING OR COPYING THE SOFTWARE ONTO YOUR
+COMPUTER HARD DRIVE, COMPUTER RAM OR OTHER
+STORAGE, YOU ARE AGREEING TO BE BOUND BY THE TERMS
+OF THIS AGREEMENT.
+
+1. Grant of License. Subject to the terms
+and provisions of this Agreement and so long as
+you fully comply at all times with this Agreement,
+Fountainhead grants to you the non-exclusive and
+limited right to use the Software only in
+executable or object code form. The term
+"Software" includes all elements of the Software,
+including, without limitation, data files and
+screen displays. You are not receiving any
+ownership or proprietary right, title or interest
+in or to the Software or the copyrights,
+trademarks, or other rights related thereto. For
+purposes of the first sentence of this section,
+"use" means loading the Software into RAM and/or
+onto computer hard drive, as well as installation
+of the Software on a hard disk or other storage
+device, and means the uses permitted in sections
+2. and 4. herein below. You agree that the
+Software will not be downloaded, shipped,
+transferred, exported or re-exported into any
+country in violation of the U.S. Export
+Administration Act (or any other law governing
+such matters) by you or anyone at your direction
+and that you will not utilize and will not
+authorize anyone to utilize, in any other manner,
+the Software in violation of any applicable law.
+The Software shall not be downloaded or otherwise
+exported or re-exported into (or to a national or
+resident of) any country to which the U.S. has
+embargoed goods or to anyone or into any country
+who/which are prohibited, by applicable law, from
+receiving such property. In exercising your
+limited rights hereunder, you shall comply, at all
+times, with all applicable laws, regulations,
+ordinances and statutes. Fountainhead reserves
+all rights not granted in this Agreement,
+including, without limitation, all rights to
+Fountainhead's trademarks. All other trademarks
+and trade names are properties of their respective
+owners.
+
+2. Permitted New Creations. Subject to the
+terms and provisions of this Agreement and so long
+as you fully comply at all times with this
+Agreement, Fountainhead grants to you the
+non-exclusive and limited right to create for the
+Software (except any Software code) your own
+modifications (the "New Creations") which shall
+operate only with the Software (but not any demo,
+test or other version of the Software). You may
+include within the New Creations certain textures
+and other images (the "Software Images") from the
+Software. You shall not create any New Creations
+which infringe against any third party right or
+which are libelous, defamatory, obscene, false,
+misleading, or otherwise illegal or unlawful. You
+agree that the New Creations will not be
+downloaded, shipped, transferred, exported or
+re-exported into any country in violation of the
+U.S. Export Administration Act (or any other law
+governing such matters) by you or anyone at your
+direction and that you will not utilize and will
+not authorize anyone to utilize, in any other
+manner, the New Creations in violation of any
+applicable law. The New Creations shall not be
+downloaded or otherwise exported or re-exported
+into (or to a national or resident of) any country
+to which the U.S. has embargoed goods or to anyone
+or into any country who/which are prohibited, by
+applicable law, from receiving such property. You
+shall not rent, sell, lease, lend, offer on a
+pay-per-play basis or otherwise commercially
+exploit or commercially distribute the New
+Creations. You are only permitted to distribute,
+without any cost or charge, the New Creations to
+other end-users so long as such distribution is
+not infringing against any third party right and
+is not otherwise illegal or unlawful. As noted
+below, in the event you commit any breach of this
+Agreement, your license and this Agreement shall
+automatically terminate, without notice.
+
+3. Intellectual Property Rights. Certain
+
+printed materials (the "Printed Materials") may
+accompany the Software. The Software, the Printed
+Materials and all copyrights, trademarks and all
+other conceivable intellectual property rights
+related to the Software and the Printed Materials
+are owned by Fountainhead and are protected by
+United States copyright laws, international treaty
+provisions and all applicable law, such as the
+Lanham Act. You must treat the Software and the
+Printed Materials like any other copyrighted
+material, as required by 17 U.S.C., §101 et seq.
+and other applicable law. You agree to use your
+best efforts to see that any user of the Software
+licensed hereunder, the Printed Materials or the
+New Creations complies with this Agreement. You
+agree that you are receiving a copy of the
+Software and the Printed Materials by limited
+license only and not by sale and that the "first
+sale" doctrine of 17 U.S.C. §109 does not apply to
+your receipt or use of the Software or the Printed
+Materials. This section shall survive the
+cancellation or termination of this Agreement.
+
+4. NO FOUNTAINHEAD WARRANTIES. FOUNTAINHEAD
+DISCLAIMS ALL WARRANTIES, WHETHER EXPRESS OR
+IMPLIED, INCLUDING, BUT NOT LIMITED TO, IMPLIED
+WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
+PARTICULAR PURPOSE AND ANY WARRANTY OF
+NON-INFRINGEMENT, WITH RESPECT TO THE SOFTWARE,
+THE PRINTED MATERIALS, THE SOFTWARE IMAGES AND
+OTHERWISE. THE SOFTWARE IS PROVIDED "AS IS" AND
+WITHOUT WARRANTY. FOUNTAINHEAD DOES NOT WARRANT
+THAT THE SOFTWARE OR THE OPERATION OF THE SOFTWARE
+WILL BE UNINTERRUPTED OR ERROR FREE OR THAT THE
+SOFTWARE WILL MEET YOUR SPECIFIC OR SPECIAL
+REQUIREMENTS. ADDITIONAL STATEMENTS, WHETHER ORAL
+OR WRITTEN, DO NOT CONSTITUTE WARRANTIES BY
+FOUNTAINHEAD AND SHOULD NOT BE RELIED UPON. This
+section shall survive the cancellation or
+termination of this Agreement.
+
+5. Governing Law, Venue, Indemnity and
+Liability Limitation. This Agreement shall be
+construed in accordance with and governed by the
+applicable laws of the State of Texas and
+applicable United States federal law. Except as
+set forth below, exclusive venue for all
+litigation regarding this Agreement shall be in
+Dallas County, Texas and you agree to submit to
+the jurisdiction of the federal and state courts
+in Dallas County, Texas for any such litigation.
+You hereby agree to indemnify, defend and hold
+harmless Fountainhead and Fountainhead's
+respective officers, employees, directors, agents,
+licensees (excluding you), sub-licensees
+(excluding you), successors and assigns from and
+against all losses, lawsuits, damages, causes of
+action and claims relating to and/or arising from
+the New Creations or the distribution or other use
+of the New Creations or relating to and/or arising
+from your breach of this Agreement. You agree
+that your unauthorized use of the Software Images,
+the Printed Materials, or the Software, or any
+part thereof, may immediately and irreparably
+damage Fountainhead such that Fountainhead could
+not be adequately compensated solely by a monetary
+award, and in such event, Fountainhead's option,
+that Fountainhead shall be entitled to an
+injunctive order, in addition to all other
+available remedies including a monetary award, to
+prohibit such unauthorized use without the
+necessity of Fountainhead posting bond or other
+security. IN ANY CASE, FOUNTAINHEAD AND
+FOUNTAINHEAD'S RESPECTIVE OFFICERS, EMPLOYEES,
+DIRECTORS, SHAREHOLDERS, REPRESENTATIVES, AGENTS,
+LICENSEES (EXCLUDING YOU), SUBLICENSEES (EXCLUSING
+YOU), SUCCESSORS AND ASSIGNS SHALL NOT BE LIABLE
+FOR LOSS OF DATA, LOSS OF PROFITS, LOST SAVINGS,
+SPECIAL, INCIDENTAL, CONSEQUENTIAL, INDIRECT OR
+PUNITIVE DAMAGES OR ANY OTHER DAMAGES ARISING FROM
+ANY ALLEGED CLAIM FOR BREACH OF WARRANTY, BREACH
+OF CONTRACT, NEGLIGENCE, STRICT PRODUCT LIABILITY,
+OR OTHER LEGAL THEORY EVEN IF FOUNTAINHEAD OR
+THEIR RESPECTIVE AGENT(S) HAVE BEEN ADVISED OF THE
+POSSIBILITY OF ANY SUCH DAMAGES, OR EVEN IF SUCH
+DAMAGES ARE FORESEEABLE, OR LIABLE FOR ANY CLAIM
+BY ANY OTHER PARTY. This section shall survive
+the cancellation or termination of this Agreement.
+
+6. General Provisions. Neither this
+Agreement nor any part or portion hereof shall be
+assigned or sublicensed by you. Fountainhead may
+assign its respective rights under this Agreement
+in the assigning party's sole discretion. Should
+any provision of this Agreement be held to be
+void, invalid, unenforceable or illegal by a court
+of competent jurisdiction, the validity and
+enforceability of the other provisions shall not
+be affected thereby. If any provision is
+determined to be unenforceable by a court of
+competent jurisdiction, you agree to a
+modification of such provision to provide for
+enforcement of the provision's intent, to the
+extent permitted by applicable law. Failure of
+Fountainhead to enforce any provision of this
+Agreement shall not constitute or be construed as
+a waiver of such provision or of the right to
+enforce such provision. IMMEDIATELY UPON YOUR
+FAILURE TO COMPLY WITH OR BREACH OF ANY TERM OR
+PROVISION OF THIS AGREEMENT, YOUR LICENSE GRANTED
+HEREIN AND THIS AGREEMENT SHALL AUTOMATICALLY
+TERMINATE, WITHOUT NOTICE, AND FOUNTAINHEAD MAY
+PURSUE ALL RELIEF AND REMEDIES AGAINST YOU, WHICH
+ARE AVAILABLE UNDER APPLICABLE LAW AND/OR THIS
+AGREEMENT. Immediately upon termination of this
+Agreement, any and all rights you are granted
+hereunder shall terminate, you shall have no right
+to use the Software, the Printed Materials or the
+New Creations, in any manner, and you shall
+immediately destroy all copies of the Software,
+the Printed Materials and the New Creations in
+your possession, custody or control, and all
+rights granted hereunder shall revert, without
+notice, to and be vested in Fountainhead.
+
+YOU ACKNOWLEDGE THAT YOU HAVE READ THIS AGREEMENT,
+YOU UNDERSTAND THIS AGREEMENT, AND UNDERSTAND THAT
+BY CONTINUING THE INSTALLATION OF THE SOFTWARE, BY
+LOADING OR RUNNING THE SOFTWARE, OR BY PLACING OR
+COPYING THE SOFTWARE ONTO YOUR COMPUTER HARD DRIVE
+OR RAM, YOU AGREE TO BE BOUND BY THE TERMS AND
+CONDITIONS OF THIS AGREEMENT. YOU FURTHER AGREE
+THAT, EXCEPT FOR WRITTEN SEPARATE AGREEMENTS, IF
+ANY, BETWEEN FOUNTAINHEAD AND YOU, THIS AGREEMENT
+IS A COMPLETE AND EXCLUSIVE STATEMENT OF THE
+RIGHTS AND LIABILITIES OF THE PARTIES HERETO,
+RELATING TO THE SUBJECT MATTER HEREOF. THIS
+AGREEMENT SUPERSEDES ALL PRIOR ORAL AGREEMENTS,
+PROPOSALS OR UNDERSTANDINGS, AND ANY OTHER
+COMMUNICATIONS, IF ANY, BETWEEN FOUNTAINHEAD AND
+YOU RELATING TO THE SUBJECT MATTER OF THIS
+AGREEMENT.
diff --git a/assets/models/weapons/lightning/weapon.cfg b/assets/models/weapons/lightning/weapon.cfg
new file mode 100644
index 0000000..9b33568
--- /dev/null
+++ b/assets/models/weapons/lightning/weapon.cfg
@@ -0,0 +1,20 @@
+weaponModel models/weapons/lightning/lightning.md3
+icon icons/iconw_lightning
+crosshair 24 gfx/2d/crosshair-lgun_s
+
+primary
+{
+ continuousFlash
+
+ flashDlightColor 0.8 0.9 1.0
+
+ flashSound 0 models/weapons/lightning/flash0.wav
+ firingSound models/weapons/lightning/firing.wav
+ flashQuake 0.6
+
+ impactMark 6 gfx/marks/bullet_mrk
+ impactSound 0 models/weapons/lightning/impact0.wav
+ impactSound 1 models/weapons/lightning/impact1.wav
+ impactSound 2 models/weapons/lightning/impact2.wav
+}
+
diff --git a/assets/models/weapons/rocketl/flash0.wav b/assets/models/weapons/rocketl/flash0.wav
index 009febe..89e78b7 100644
--- a/assets/models/weapons/rocketl/flash0.wav
+++ b/assets/models/weapons/rocketl/flash0.wav
Binary files differ
diff --git a/assets/models/weapons/rocketl/rocketl.md3 b/assets/models/weapons/rocketl/rocketl.md3
index 4119209..d515cf4 100644
--- a/assets/models/weapons/rocketl/rocketl.md3
+++ b/assets/models/weapons/rocketl/rocketl.md3
Binary files differ
diff --git a/assets/models/weapons/rocketl/rocketl_flash.md3 b/assets/models/weapons/rocketl/rocketl_flash.md3
new file mode 100644
index 0000000..c1acf35
--- /dev/null
+++ b/assets/models/weapons/rocketl/rocketl_flash.md3
Binary files differ
diff --git a/assets/models/weapons/rocketl/weapon.cfg b/assets/models/weapons/rocketl/weapon.cfg
index e5dafc6..5c6b70b 100644
--- a/assets/models/weapons/rocketl/weapon.cfg
+++ b/assets/models/weapons/rocketl/weapon.cfg
@@ -11,9 +11,11 @@ primary
flashDlightColor 1.0 0.7 0.0
flashSound 0 models/weapons/rocketl/flash0.wav
+ flashQuake 1
impactMark 32 gfx/marks/bullet_mrk
impactSound 0 models/weapons/rocketl/impact0.wav
impactParticleSystem models/weapons/rocketl/impactPS
+ impactQuake 50
}
diff --git a/assets/models/weapons/smoke/smoke.jpg b/assets/models/weapons/smoke/smoke.jpg
deleted file mode 100644
index a001de3..0000000
--- a/assets/models/weapons/smoke/smoke.jpg
+++ /dev/null
Binary files differ
diff --git a/assets/models/weapons/smoke/smoke.md3 b/assets/models/weapons/smoke/smoke.md3
deleted file mode 100644
index 53fed50..0000000
--- a/assets/models/weapons/smoke/smoke.md3
+++ /dev/null
Binary files differ
diff --git a/assets/models/weapons/smoke/smoke.wav b/assets/models/weapons/smoke/smoke.wav
deleted file mode 100644
index 6c2d7ea..0000000
--- a/assets/models/weapons/smoke/smoke.wav
+++ /dev/null
Binary files differ
diff --git a/assets/models/weapons/smoke/smokegfx.tga b/assets/models/weapons/smoke/smokegfx.tga
deleted file mode 100644
index f028d75..0000000
--- a/assets/models/weapons/smoke/smokegfx.tga
+++ /dev/null
Binary files differ
diff --git a/assets/models/weapons/smoke/weapon.cfg b/assets/models/weapons/smoke/weapon.cfg
deleted file mode 100644
index 93fd03a..0000000
--- a/assets/models/weapons/smoke/weapon.cfg
+++ /dev/null
@@ -1,11 +0,0 @@
-icon icons/iconw_smoke
-idleSound models/weapons/smoke/smoke.wav
-primary
-{
-
- missileParticleSystem models/weapons/smoke/impactPS
-
- missileModel models/weapons/smoke/smoke.md3
- missileAnimates 0 20 20 0
-
-}
diff --git a/assets/scripts/hw_lightning.particle b/assets/scripts/hw_lightning.particle
new file mode 100644
index 0000000..f9370d5
--- /dev/null
+++ b/assets/scripts/hw_lightning.particle
@@ -0,0 +1,35 @@
+
+models/weapons/lightning/impactPS
+{
+ ejector
+ {
+ particle
+ {
+ shader sync gfx/lightning/particle
+
+ displacement 0 0 0 ~2.0
+
+ velocityType normal
+ velocityDir linear
+ velocityMagnitude 100
+ velocity 0 0 -1 ~10
+
+ accelerationType static
+ accelerationDir linear
+ accelerationMagnitude 800
+ acceleration 0 0 -1 ~10
+
+ radius 0 9 0
+ alpha 0 1.0 1.0
+ rotation 0 ~360 -
+ bounce 0.5
+
+ lifeTime 100
+ }
+
+ count 1
+ delay 0
+ period 0 - ~0%
+ }
+}
+
diff --git a/assets/scripts/hw_lightning.shader b/assets/scripts/hw_lightning.shader
new file mode 100644
index 0000000..c42612b
--- /dev/null
+++ b/assets/scripts/hw_lightning.shader
@@ -0,0 +1,36 @@
+gfx/lightning/particle
+{
+ {
+ map models/weapons/lightning/flash.jpg
+ blendFunc add
+ }
+}
+
+gfx/lightning/beam
+{
+ nomipmaps
+ {
+ map models/weapons/lightning/bolt.jpg
+ blendFunc add
+ tcMod scroll -5 0
+ tcMod scale 5 1
+ }
+}
+
+models/weapons/lightning/flash
+{
+ cull none
+ {
+ map models/weapons/lightning/flash.jpg
+ blendFunc add
+ }
+}
+
+models/weapons/lightning/bolt
+{
+ cull none
+ {
+ map models/weapons/lightning/bolt.jpg
+ blendFunc add
+ }
+}
diff --git a/assets/scripts/hw_rocketl.particle b/assets/scripts/hw_rocketl.particle
index 891ac18..5fbf798 100644
--- a/assets/scripts/hw_rocketl.particle
+++ b/assets/scripts/hw_rocketl.particle
@@ -38,40 +38,7 @@ models/weapons/rocketl/impactPS
{
particle
{
- shader sync rocketFlareParticle
- displacement 0 0 0 0
-
- velocityType normal
-
- velocityDir linear
-
- velocityMagnitude 0
- velocity 0 0 0 ~0
-
- accelerationType static
- accelerationDir linear
- acceleration 0 0 0 ~0
- accelerationMagnitude 0
-
- radius 0 50 100
- alpha 250 1 0
- rotation 0 ~-15 ~15
- bounce 0.0
-
- lifeTime 40
- }
-
- count 1
- delay 0
- period 0 - 0
- }
-
- ejector
- {
- particle
- {
shader sync gfx/sprites/smoke
- //shader sync flame3 flame4 flame5 flame6 flame7 flame8 flame9 flame10 flame11 flame12 flame13 flame14 flame15 flame16 flame17 flame18 flame19 flame20 flame21 flame22 flame23 flame24 flame25
displacement 0 0 0 0
velocityType normal
@@ -103,7 +70,7 @@ models/weapons/rocketl/impactPS
{
particle
{
- shader sync flame3 flame4 flame5 flame6 flame7 flame8 flame9 flame10 flame11 flame12 flame13 flame14 flame15 flame16 flame17 flame18 flame19 flame20 flame21 flame22 flame23 flame24 flame25
+ shader sync rocketx1 rocketx2 rocketx3 rocketx4 rocketx5 rocketx6 rocketx7 rocketx8 rocketx9 rocketx10 rocketx11 rocketx12 rocketx13 rocketx14 rocketx15 rocketx16 rocketx17 rocketx18 rocketx19 rocketx20 rocketx21 rocketx22 rocketx23 rocketx24 rocketx25 rocketx26 rocketx27 rocketx28 rocketx29
displacement 0 0 0 0
velocityType normal
@@ -118,9 +85,9 @@ models/weapons/rocketl/impactPS
acceleration 0 0 -1 ~5
accelerationMagnitude 25
- radius 0 0 100
- alpha 250 .75 0
- rotation 0 ~-15 ~15
+ radius 0 30 70
+ alpha 250 1 1
+ rotation ~360 0 0
bounce 0.0
color 0 { 0.8 0.2 0.2 } -
diff --git a/assets/scripts/hw_rocketl.shader b/assets/scripts/hw_rocketl.shader
index 28c56cb..45abbb8 100644
--- a/assets/scripts/hw_rocketl.shader
+++ b/assets/scripts/hw_rocketl.shader
@@ -56,3 +56,305 @@ rocketThrust
}
}
+models/weapons/rocketl/flash
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0006.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+// BEST ROCKET EPXLSION EVAR!
+rocketx1
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0002.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx2
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0003.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx3
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0004.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx4
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0005.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx5
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0006.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx6
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0007.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx7
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0008.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx8
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0009.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx9
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0010.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx10
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0011.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx11
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0012.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx12
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0013.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx13
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0014.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx14
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0015.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx15
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0016.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx16
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0017.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx17
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0018.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx18
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0019.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx19
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0020.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx20
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0021.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx21
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0022.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx22
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0023.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx23
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0024.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx24
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0025.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx25
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0026.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx26
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0027.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx27
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0028.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+
+rocketx28
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0029.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
+rocketx29
+{
+ nopicmip
+ cull disable
+ {
+ map gfx/rocketx/0030.jpg
+ blendFunc GL_ONE GL_ONE
+ }
+}
+
diff --git a/src/cgame/cg_event.c b/src/cgame/cg_event.c
index 794b8a4..e5002cd 100644
--- a/src/cgame/cg_event.c
+++ b/src/cgame/cg_event.c
@@ -244,10 +244,7 @@ static void CG_Obituary( entityState_t *ent )
else
message = "^5was terminated by own flames";
break;
-
- case MOD_SMOKE:
- message = "^5smoked himself up";
- break;
+
case MOD_ABOMB:
message = "^5bombed himself up";
break;
@@ -338,6 +335,9 @@ static void CG_Obituary( entityState_t *ent )
message = "^5almost dodged^7";
message2 = "^5's ^5rocket";
break;
+ case MOD_LIGHTNING:
+ message = "^5was electrocuted by^7";
+ break;
case MOD_GRENADE:
message = "^5couldn't escape^7";
message2 = "^5's ^5grenade";
@@ -357,11 +357,6 @@ static void CG_Obituary( entityState_t *ent )
message2 = "^5's ^5flames";
break;
- case MOD_SMOKE:
- message = "^5tasted^7";
- message2 = "^5's ^5smoke";
- break;
-
case MOD_ABUILDER_CLAW:
message = "^5should leave^7";
message2 = "^5's ^5buildings alone";
@@ -1014,9 +1009,12 @@ void CG_EntityEvent( centity_t *cent, vec3_t position )
CG_MissileHitWall( es->weapon, es->generic1, 0, position, dir, IMPACTSOUND_METAL, es->torsoAnim );
break;
+#define BUILDABLE_EXPLOSION_QUAKE 50
+
case EV_HUMAN_BUILDABLE_EXPLOSION:
ByteToDir( es->eventParm, dir );
CG_HumanBuildableExplosion( position, dir, es->modelindex );
+ CG_InduceViewQuake( position, BUILDABLE_EXPLOSION_QUAKE );
break;
case EV_ALIEN_BUILDABLE_EXPLOSION:
@@ -1025,6 +1023,8 @@ void CG_EntityEvent( centity_t *cent, vec3_t position )
if ( es->modelindex == BA_A_SPITEFUL_ABCESS )
CG_AlienSPITEFUL_ABCESSExplosion( position, dir );
+
+ CG_InduceViewQuake( position, BUILDABLE_EXPLOSION_QUAKE );
break;
//Scleim greifer schwanz f\FCr slime
diff --git a/src/cgame/cg_local.h b/src/cgame/cg_local.h
index 10e89fd..ab3e9e6 100644
--- a/src/cgame/cg_local.h
+++ b/src/cgame/cg_local.h
@@ -787,6 +787,7 @@ typedef struct weaponInfoMode_s
vec3_t flashDlightColor;
sfxHandle_t flashSound[ 4 ]; // fast firing weapons randomly choose
qboolean continuousFlash;
+ float flashQuake;
qhandle_t missileModel;
sfxHandle_t missileSound;
@@ -816,6 +817,7 @@ typedef struct weaponInfoMode_s
qhandle_t impactMarkSize;
sfxHandle_t impactSound[ 4 ]; //random impact sound
sfxHandle_t impactFleshSound[ 4 ]; //random impact sound
+ float impactQuake;
} weaponInfoMode_t;
// each WP_* weapon enum has an associated weaponInfo_t
@@ -1159,6 +1161,8 @@ typedef struct
int nearUsableBuildable;
int nextWeaponClickTime;
+
+ float viewQuake;
} cg_t;
@@ -1341,6 +1345,9 @@ typedef struct
qhandle_t humanBuildPoolBar;
qhandle_t alienNoBPFlash;
qhandle_t humanNoBPFlash;
+
+ qhandle_t lightningBeam;
+ qhandle_t lightningImpactPS;
} cgMedia_t;
typedef struct
@@ -1595,6 +1602,10 @@ extern vmCvar_t cg_chatTeamPrefix;
extern vmCvar_t cg_drawBubble;
extern vmCvar_t cg_BubbleZoom;
+extern vmCvar_t cg_viewQuake;
+extern vmCvar_t cg_viewQuakeLambda;
+extern vmCvar_t cg_viewQuakeLimit;
+
//
// cg_main.c
//
@@ -1636,6 +1647,7 @@ void CG_TestModelNextSkin_f( void );
void CG_TestModelPrevSkin_f( void );
void CG_AddBufferedSound( sfxHandle_t sfx );
void CG_DrawActiveFrame( int serverTime, stereoFrame_t stereoView, qboolean demoPlayback );
+void CG_InduceViewQuake( vec3_t src, float mag );
void CG_OffsetFirstPersonView( void );
void CG_OffsetThirdPersonView( void );
void CG_OffsetShoulderView( void );
diff --git a/src/cgame/cg_main.c b/src/cgame/cg_main.c
index 3985834..7ed3bfc 100644
--- a/src/cgame/cg_main.c
+++ b/src/cgame/cg_main.c
@@ -226,7 +226,11 @@ vmCvar_t cg_chatTeamPrefix;
vmCvar_t cg_drawBubble;
vmCvar_t cg_BubbleZoom;
-vmCvar_t cg_EDGEFPSFIX;
+vmCvar_t cg_EDGEFPSFIX;
+
+vmCvar_t cg_viewQuake;
+vmCvar_t cg_viewQuakeLambda;
+vmCvar_t cg_viewQuakeLimit;
typedef struct
{
@@ -371,7 +375,11 @@ static cvarTable_t cvarTable[ ] =
// { &cg_chatTeamPrefix, "cg_chatTeamPrefix", "1", CVAR_ARCHIVE}
{ &cg_chatTeamPrefix, "cg_chatTeamPrefix", "1", CVAR_ARCHIVE},
- { &cg_EDGEFPSFIX, "cg_EDGEFPSFIX", "0", CVAR_ARCHIVE|CVAR_USERINFO }
+ { &cg_EDGEFPSFIX, "cg_EDGEFPSFIX", "0", CVAR_ARCHIVE|CVAR_USERINFO },
+
+ { &cg_viewQuake, "cg_viewQuake", "1", CVAR_ARCHIVE },
+ { &cg_viewQuakeLambda, "cg_viewQuakeLambda", "-10", CVAR_ARCHIVE },
+ { &cg_viewQuakeLimit, "cg_viewQuakeLimit", "5", CVAR_ARCHIVE }
};
static int cvarTableSize = sizeof( cvarTable ) / sizeof( cvarTable[0] );
@@ -827,6 +835,8 @@ static void CG_RegisterGraphics( void )
cgs.media.alienNoBPFlash = trap_R_RegisterShader( "ui/assets/alien/nobp_flash.tga" );
cgs.media.humanNoBPFlash = trap_R_RegisterShader( "ui/assets/human/nobp_flash.tga" );
+ cgs.media.lightningBeam = trap_R_RegisterShader( "gfx/lightning/beam" );
+
cgs.media.disconnectPS = CG_RegisterParticleSystem( "disconnectPS" );
CG_UpdateMediaFraction( 0.7f );
@@ -870,6 +880,8 @@ static void CG_RegisterGraphics( void )
cgs.media.humanWoundsBleedPS = CG_RegisterParticleSystem( "humanWoundBleedPS" );
cgs.media.headShotPS = CG_RegisterParticleSystem( "headShotPS" );
+ cgs.media.lightningImpactPS = CG_RegisterParticleSystem( "models/weapons/lightning/impactPS" );
+
CG_BuildableStatusParse( "ui/assets/human/buildstat.cfg", &cgs.humanBuildStat );
CG_BuildableStatusParse( "ui/assets/alien/buildstat.cfg", &cgs.alienBuildStat );
diff --git a/src/cgame/cg_view.c b/src/cgame/cg_view.c
index a0142d0..eb6e88d 100644
--- a/src/cgame/cg_view.c
+++ b/src/cgame/cg_view.c
@@ -537,6 +537,29 @@ static void CG_StepOffset( void )
#define PCLOUD_ZOOM_FREQUENCY 0.625f // 2.5s / 4
#define PCLOUD_DISORIENT_DURATION 2500
+/*
+===============
+CG_InduceViewQuake
+===============
+*/
+
+void CG_InduceViewQuake( vec3_t src, float mag )
+{
+ if( !src )
+ {
+ cg.viewQuake += mag;
+ }
+ else
+ {
+ float dist;
+
+ dist = Distance( src, cg.refdef.vieworg );
+ cg.viewQuake += mag / dist / dist * 1000.0f;
+ }
+
+ if( cg.viewQuake > cg_viewQuakeLimit.value )
+ cg.viewQuake = cg_viewQuakeLimit.value;
+}
/*
===============
@@ -838,6 +861,20 @@ void CG_OffsetFirstPersonView( void )
// add step offset
CG_StepOffset( );
+
+
+ // view quake
+ if( cg.thisFrameTeleport )
+ {
+ cg.viewQuake = 0;
+ }
+ else
+ {
+ angles[ PITCH ] += crandom( ) * cg.viewQuake * cg_viewQuake.value;
+ angles[ YAW ] += crandom( ) * cg.viewQuake * cg_viewQuake.value;
+
+ cg.viewQuake *= pow( 2, (float)cg.frametime * 1.0e-3 * cg_viewQuakeLambda.value );
+ }
}
//======================================================================
diff --git a/src/cgame/cg_weapons.c b/src/cgame/cg_weapons.c
index 2b41d13..8e3b438 100644
--- a/src/cgame/cg_weapons.c
+++ b/src/cgame/cg_weapons.c
@@ -65,8 +65,6 @@ void CG_RegisterUpgrade( int upgradeNum )
upgradeInfo->upgradeIcon = cg_weapons[ WP_GRENADE ].weaponIcon;
else if( upgradeNum == UP_MINE )
upgradeInfo->upgradeIcon = cg_weapons[ WP_MINE ].weaponIcon;
- else if( upgradeNum == UP_SMOKE )
- upgradeInfo->upgradeIcon = cg_weapons[ WP_SMOKE ].weaponIcon;
else if( ( icon = BG_Upgrade( upgradeNum )->icon ) )
upgradeInfo->upgradeIcon = trap_R_RegisterShader( icon );
}
@@ -418,6 +416,26 @@ static qboolean CG_ParseWeaponModeSection( weaponInfoMode_t *wim, char **text_p
continue;
}
+ else if( !Q_stricmp( token, "impactQuake" ) )
+ {
+ token = COM_Parse( text_p );
+ if( !token )
+ break;
+
+ wim->impactQuake = atof( token );
+
+ continue;
+ }
+ else if( !Q_stricmp( token, "flashQuake" ) )
+ {
+ token = COM_Parse( text_p );
+ if( !token )
+ break;
+
+ wim->flashQuake = atof( token );
+
+ continue;
+ }
else if( !Q_stricmp( token, "}" ) )
return qtrue; //reached the end of this weapon section
else
@@ -868,6 +886,60 @@ static float CG_MachinegunSpinAngle( centity_t *cent, qboolean firing )
return angle;
}
+/*
+=============
+CG_RenderGenericBeam
+=============
+*/
+
+void CG_RenderGenericBeam( const vec3_t start, const vec3_t end, qhandle_t shader, float radius )
+{
+ vec3_t delta, viewdelta, side;
+ float length;
+ polyVert_t quad[ 4 ];
+
+ VectorSubtract( end, start, delta );
+ length = VectorLength( delta );
+ VectorSubtract( start, cg.refdef.vieworg, viewdelta );
+ CrossProduct( delta, viewdelta, side );
+ VectorNormalize( side );
+
+ VectorMA( start, radius, side, quad[ 3 ].xyz );
+ VectorMA( start, -radius, side, quad[ 2 ].xyz );
+ VectorMA( end, -radius, side, quad[ 1 ].xyz );
+ VectorMA( end, radius, side, quad[ 0 ].xyz );
+
+ quad[ 0 ].st[ 0 ] = length / radius * 0.1;
+ quad[ 0 ].st[ 1 ] = 0;
+ quad[ 0 ].modulate[ 0 ] = 255;
+ quad[ 0 ].modulate[ 1 ] = 255;
+ quad[ 0 ].modulate[ 2 ] = 255;
+ quad[ 0 ].modulate[ 3 ] = 255;
+
+ quad[ 1 ].st[ 0 ] = length / radius * 0.1;
+ quad[ 1 ].st[ 1 ] = 1;
+ quad[ 1 ].modulate[ 0 ] = 255;
+ quad[ 1 ].modulate[ 1 ] = 255;
+ quad[ 1 ].modulate[ 2 ] = 255;
+ quad[ 1 ].modulate[ 3 ] = 255;
+
+ quad[ 2 ].st[ 0 ] = 0;
+ quad[ 2 ].st[ 1 ] = 1;
+ quad[ 2 ].modulate[ 0 ] = 255;
+ quad[ 2 ].modulate[ 1 ] = 255;
+ quad[ 2 ].modulate[ 2 ] = 255;
+ quad[ 2 ].modulate[ 3 ] = 255;
+
+ quad[ 3 ].st[ 0 ] = 0;
+ quad[ 3 ].st[ 1 ] = 0;
+ quad[ 3 ].modulate[ 0 ] = 255;
+ quad[ 3 ].modulate[ 1 ] = 255;
+ quad[ 3 ].modulate[ 2 ] = 255;
+ quad[ 3 ].modulate[ 3 ] = 255;
+
+ trap_R_AddPolyToScene( shader, 4, quad );
+}
+
/*
=============
@@ -878,6 +950,7 @@ The main player will have this called for BOTH cases, so effects like light and
sound should only be done on the world model case.
=============
*/
+
void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent )
{
refEntity_t gun;
@@ -1116,6 +1189,66 @@ void CG_AddPlayerWeapon( refEntity_t *parent, playerState_t *ps, centity_t *cent
cent->muzzlePsTrigger = qfalse;
}
+ // Lightning Gun's beam
+ if( weaponNum == WP_LIGHTNING_GUN )
+ {
+ attachment_t attachment;
+ vec3_t muzzle, forward, end, beam_start;
+ trace_t tr;
+
+ if( ps )
+ {
+ BG_GetClientViewOrigin( ps, muzzle );
+ AngleVectors( ps->viewangles, forward, NULL, NULL );
+ }
+ else
+ {
+ // NOTE: this code assumes that the player's normal is (0,0,1)
+ // it will break when humans start walking on walls
+ class_t class = ( cent->currentState.misc >> 8 ) & 0xFF;
+
+ VectorCopy( cent->lerpOrigin, muzzle );
+
+ // the only way to tell if a human is crouching is to check its bbox
+ // which is transmitted in a weird, encoded form (hence the magic number)
+ if( class == PCL_HUMAN && cent->currentState.solid == 3151887 )
+ muzzle[ 2 ] += BG_ClassConfig( class )->crouchViewheight;
+ else
+ muzzle[ 2 ] += BG_ClassConfig( class )->viewheight;
+
+ AngleVectors( cent->lerpAngles, forward, NULL, NULL );
+ }
+
+ VectorMA( muzzle, LIGHTNING_RANGE, forward, end );
+
+ CG_Trace( &tr, muzzle, NULL, NULL, end, cg.predictedPlayerState.clientNum, MASK_SHOT );
+
+ memset( &attachment, 0, sizeof( attachment ) );
+
+ if( noGunModel )
+ CG_SetAttachmentTag( &attachment, *parent, parent->hModel, "tag_weapon" );
+ else
+ CG_SetAttachmentTag( &attachment, gun, gun.hModel, "tag_flash" );
+
+ CG_AttachToTag( &attachment );
+
+ if( CG_AttachmentPoint( &attachment, beam_start ) )
+ CG_RenderGenericBeam( beam_start, tr.endpos, cgs.media.lightningBeam, 3 );
+
+ if( tr.entityNum != ENTITYNUM_NONE &&
+ !( tr.surfaceFlags & SURF_NOIMPACT ) )
+ {
+ particleSystem_t *ps = CG_SpawnNewParticleSystem( cgs.media.lightningImpactPS );
+
+ if( CG_IsParticleSystemValid( &ps ) )
+ {
+ CG_SetAttachmentPoint( &ps->attachment, tr.endpos );
+ CG_SetParticleSystemNormal( ps, tr.plane.normal );
+ CG_AttachToPoint( &ps->attachment );
+ }
+ }
+ }
+
// make a dlight for the flash
if( weapon->wim[ weaponMode ].flashDlightColor[ 0 ] ||
weapon->wim[ weaponMode ].flashDlightColor[ 1 ] ||
@@ -1254,6 +1387,15 @@ void CG_AddViewWeapon( playerState_t *ps )
}
+ // Lightning Gun vibration effect
+ if( ( weapon == WP_LIGHTNING_GUN ) && ps->eFlags & EF_FIRING )
+ {
+ VectorMA( hand.origin, random( ) * 0.1, cg.refdef.viewaxis[ 0 ],
+ hand.origin );
+ VectorMA( hand.origin, random( ) * 0.1, cg.refdef.viewaxis[ 1 ],
+ hand.origin );
+ }
+
AnglesToAxis( angles, hand.axis );
// map torso animations to weapon animations
@@ -1654,6 +1796,7 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode )
int c;
weaponInfo_t *wi;
weapon_t weaponNum;
+ qboolean skipSound = qfalse;
es = &cent->currentState;
@@ -1673,6 +1816,10 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode )
wi = &cg_weapons[ weaponNum ];
+ if( wi->wim[ weaponMode ].continuousFlash &&
+ cent->muzzleFlashTime >= cg.time - 100 )
+ skipSound = qtrue;
+
// mark the entity as muzzle flashing, so when it is added it will
// append the flash to the weapon model
cent->muzzleFlashTime = cg.time;
@@ -1684,6 +1831,9 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode )
cent->muzzlePsTrigger = qtrue;
}
+ if( skipSound )
+ return;
+
// play a sound
for( c = 0; c < 4; c++ )
{
@@ -1697,6 +1847,14 @@ void CG_FireWeapon( centity_t *cent, weaponMode_t weaponMode )
if( wi->wim[ weaponMode ].flashSound[ c ] )
trap_S_StartSound( NULL, es->number, CHAN_WEAPON, wi->wim[ weaponMode ].flashSound[ c ] );
}
+
+ if( cent == &cg.predictedPlayerEntity )
+ {
+ float quake;
+
+ quake = wi->wim[ weaponMode ].flashQuake;
+ CG_InduceViewQuake( NULL, quake );
+ }
}
@@ -1713,7 +1871,7 @@ void CG_MissileHitWall( weapon_t weaponNum, weaponMode_t weaponMode, int clientN
qhandle_t mark = 0;
qhandle_t ps = 0;
int c;
- float radius = 1.0f;
+ float radius = 1.0f, quake;
weaponInfo_t *weapon = &cg_weapons[ weaponNum ];
if( weaponMode <= WPM_NONE || weaponMode >= WPM_NUM_WEAPONMODES )
@@ -1722,6 +1880,7 @@ void CG_MissileHitWall( weapon_t weaponNum, weaponMode_t weaponMode, int clientN
mark = weapon->wim[ weaponMode ].impactMark;
radius = weapon->wim[ weaponMode ].impactMarkSize;
ps = weapon->wim[ weaponMode ].impactParticleSystem;
+ quake = weapon->wim[ weaponMode ].impactQuake;
if( soundType == IMPACTSOUND_FLESH )
{
@@ -1775,6 +1934,11 @@ void CG_MissileHitWall( weapon_t weaponNum, weaponMode_t weaponMode, int clientN
//
if( radius > 0.0f )
CG_ImpactMark( mark, origin, dir, random( ) * 360, 1, 1, 1, 1, qfalse, radius, qfalse );
+
+ if( weaponNum == WP_LUCIFER_CANNON )
+ quake *= charge;
+
+ CG_InduceViewQuake( origin, quake );
}
@@ -1788,6 +1952,7 @@ void CG_MissileHitEntity( weapon_t weaponNum, weaponMode_t weaponMode,
{
vec3_t normal;
weaponInfo_t *weapon = &cg_weapons[ weaponNum ];
+ float quake = weapon->wim[ weaponMode ].impactQuake;
VectorCopy( dir, normal );
VectorInverse( normal );
@@ -1817,6 +1982,11 @@ void CG_MissileHitEntity( weapon_t weaponNum, weaponMode_t weaponMode,
CG_MissileHitWall( weaponNum, weaponMode, 0, origin, dir, sound, charge );
}
+
+ if( weaponNum == WP_LUCIFER_CANNON )
+ quake *= charge;
+
+ CG_InduceViewQuake( origin, quake );
}
diff --git a/src/game/bg_misc.c b/src/game/bg_misc.c
index 92f3826..efdc300 100644
--- a/src/game/bg_misc.c
+++ b/src/game/bg_misc.c
@@ -3575,6 +3575,31 @@ static const weaponAttributes_t bg_weapons[ ] =
TEAM_HUMANS //team_t team;
},
{
+ WP_LIGHTNING_GUN, //int weaponNum;
+ LIGHTNING_PRICE, //int price;
+ STAGE_GE_5, //int stages
+ SLOT_WEAPON, //int slots;
+ "lightning", //char *weaponName;
+ "[yefarms]Lightning Gun", //char *humanName;
+ "This is a lightning gun. It guns lightning.",
+ LIGHTNING_AMMO, //int maxAmmo;
+ 0, //int maxClips;
+ qfalse, //int infiniteAmmo;
+ qtrue, //int usesEnergy;
+ LIGHTNING_REPEAT, //int repeatRate1;
+ 0, //int repeatRate2;
+ 0, //int repeatRate3;
+ 0, //int reloadTime;
+ LIGHTNING_K_SCALE, //float knockbackScale;
+ qfalse, //qboolean hasAltMode;
+ qfalse, //qboolean hasThirdMode;
+ qfalse, //qboolean canZoom;
+ 90.0f, //float zoomFov;
+ qtrue, //qboolean purchasable;
+ qtrue, //qboolean longRanged;
+ TEAM_HUMANS //team_t team;
+ },
+ {
WP_LUCIFER_CANNON, //int weaponNum;
LCANNON_PRICE, //int price;
STAGE_GE_5, //int stages
@@ -3652,31 +3677,6 @@ static const weaponAttributes_t bg_weapons[ ] =
TEAM_HUMANS //team_t team;
},
{
- WP_SMOKE, //int weaponNum;
- SMOKE_PRICE, //int price;
- STAGE_GE_5, //int stages
- SLOT_NONE, //int slots;
- "smoke", //char *weaponName;
- "Smoke", //char *weaponHumanName;
- "",
- 1, //int maxAmmo;
- 0, //int maxClips;
- qfalse, //int infiniteAmmo;
- qfalse, //int usesEnergy;
- SMOKE_REPEAT, //int repeatRate1;
- 0, //int repeatRate2;
- 0, //int repeatRate3;
- 0, //int reloadTime;
- SMOKE_K_SCALE, //float knockbackScale;
- qfalse, //qboolean hasAltMode;
- qfalse, //qboolean hasThirdMode;
- qfalse, //qboolean canZoom;
- 90.0f, //float zoomFov;
- qfalse, //qboolean purchasable;
- qfalse, //qboolean longRanged;
- TEAM_HUMANS //WUTeam_t team;
- },
- {
WP_MINE, //int weaponNum;
MINE_PRICE, //int price;
STAGE_GE_5, //int stages
diff --git a/src/game/bg_mod.h b/src/game/bg_mod.h
index 5e4245b..6f09037 100644
--- a/src/game/bg_mod.h
+++ b/src/game/bg_mod.h
@@ -8,6 +8,7 @@ MOD( MOD_CHAINGUN ),
MOD( MOD_PRIFLE ),
MOD( MOD_MDRIVER ),
MOD( MOD_LASGUN ),
+MOD( MOD_LIGHTNING ),
MOD( MOD_LCANNON ),
MOD( MOD_LCANNON_SPLASH ),
MOD( MOD_FLAMER ),
@@ -18,7 +19,6 @@ MOD( MOD_GRENADE ),
MOD( MOD_PSAWBLADE ),
MOD( MOD_MINE ),
MOD( MOD_FLAMES ),
-MOD( MOD_SMOKE ),
MOD( MOD_SPITEFUL_ABCESS ),
MOD( MOD_WATER ),
MOD( MOD_SLIME ),
diff --git a/src/game/bg_public.h b/src/game/bg_public.h
index 9edd57b..bbf064e 100644
--- a/src/game/bg_public.h
+++ b/src/game/bg_public.h
@@ -357,10 +357,10 @@ typedef enum
WP_CHAINGUN,
WP_FLAMER,
WP_PULSE_RIFLE,
+ WP_LIGHTNING_GUN,
WP_LUCIFER_CANNON,
WP_ROCKET_LAUNCHER,
WP_GRENADE,
- WP_SMOKE,
WP_MINE,
WP_LOCKBLOB_LAUNCHER,
WP_HIVE,
diff --git a/src/game/g_active.c b/src/game/g_active.c
index c7a8977..951a3a9 100644
--- a/src/game/g_active.c
+++ b/src/game/g_active.c
@@ -1941,21 +1941,6 @@ void ClientThink_real( gentity_t *ent )
ent->s.weapon = lastWeapon;
}
- if( BG_InventoryContainsUpgrade( UP_SMOKE, client->ps.stats ) &&
- BG_UpgradeIsActive( UP_SMOKE, client->ps.stats ) )
- {
- int lastWeapon = ent->s.weapon;
-
- //remove SMOKE
- BG_DeactivateUpgrade( UP_SMOKE, client->ps.stats );
- BG_RemoveUpgradeFromInventory( UP_SMOKE, client->ps.stats );
-
- //M-M-M-M-MONSTER HACK
- ent->s.weapon = WP_SMOKE;
- FireWeapon( ent );
- ent->s.weapon = lastWeapon;
- }
-
// set speed
if( client->ps.pm_type == PM_NOCLIP )
client->ps.speed = client->pers.flySpeed;
diff --git a/src/game/g_missile.c b/src/game/g_missile.c
index fddfe3b..ab0156b 100644
--- a/src/game/g_missile.c
+++ b/src/game/g_missile.c
@@ -1242,44 +1242,6 @@ gentity_t *launch_saw( gentity_t *self, vec3_t start, vec3_t dir )
return bolt;
}
-
-gentity_t *launch_smoke( gentity_t *self, vec3_t start, vec3_t dir )
-{
- gentity_t *bolt;
-
- VectorNormalize( dir );
- bolt = G_Spawn( );
- bolt->classname = "smoke";
- bolt->nextthink = level.time + 200;
- bolt->think = G_ProcessSmoke;
- bolt->s.eType = ET_MISSILE;
- bolt->r.svFlags = SVF_USE_CURRENT_ORIGIN;
- bolt->s.weapon = WP_SMOKE;
- bolt->s.eFlags = EF_BOUNCE_HALF;
- bolt->s.generic1 = WPM_PRIMARY; //weaponMode
- bolt->r.ownerNum = self->s.number;
- bolt->parent = self;
- bolt->damage = SMOKE_DAMAGE;
- bolt->splashDamage = 0;
- bolt->splashRadius = 0;
- bolt->methodOfDeath = MOD_SMOKE;
- bolt->splashMethodOfDeath = MOD_SMOKE;
- bolt->clipmask = MASK_SHOT;
- bolt->target_ent = NULL;
- bolt->r.mins[ 0 ] = bolt->r.mins[ 1 ] = bolt->r.mins[ 2 ] = -3.0f;
- bolt->r.maxs[ 0 ] = bolt->r.maxs[ 1 ] = bolt->r.maxs[ 2 ] = 3.0f;
- bolt->s.time = level.time;
- bolt->s.pos.trType = TR_GRAVITY;
- bolt->s.pos.trTime = level.time - MISSILE_PRESTEP_TIME; // move a bit on the very first frame
- VectorCopy( start, bolt->s.pos.trBase );
- VectorScale( dir, SMOKE_SPEED, bolt->s.pos.trDelta );
- SnapVector( bolt->s.pos.trDelta ); // save net bandwidth
-
- VectorCopy( start, bolt->r.currentOrigin );
-
- return bolt;
-}
-
/*
================
AHive_SearchAndDestroy
diff --git a/src/game/g_weapon.c b/src/game/g_weapon.c
index 5453913..1c333ab 100644
--- a/src/game/g_weapon.c
+++ b/src/game/g_weapon.c
@@ -698,18 +698,6 @@ void acidBombFire2x( gentity_t *ent, int wp )
/*
======================================================================
-SMOKE
-======================================================================
-*/
-
-void throwSmoke( gentity_t *ent )
-{
- gentity_t *m;
- m = launch_smoke( ent, muzzle, forward );
-}
-
-/*
-======================================================================
LAS GUN
======================================================================
*/
@@ -831,9 +819,7 @@ void LCChargeFire( gentity_t *ent, qboolean secondary )
/*
======================================================================
-
-PULSE RIFLE
-
+ROCKET LAUNCHER
======================================================================
*/
@@ -842,6 +828,48 @@ void rocketLauncherFire( gentity_t *ent )
fire_rocket( ent, muzzle, forward );
}
+
+/*
+======================================================================
+LIGHTNING GUN
+======================================================================
+*/
+
+void lightningGunFire( gentity_t *ent )
+{
+ vec3_t start, end;
+ trace_t tr;
+ gentity_t *target;
+
+ VectorMA( muzzle, LIGHTNING_RANGE, forward, end );
+
+ G_UnlaggedOn( ent, muzzle, LIGHTNING_RANGE );
+ trap_Trace( &tr, muzzle, NULL, NULL, end, ent->s.number, MASK_SHOT );
+ G_UnlaggedOff( );
+
+ if( tr.fraction == 1.0f ||
+ tr.entityNum == ENTITYNUM_NONE ||
+ ( tr.surfaceFlags & SURF_NOIMPACT ) )
+ return;
+
+ target = g_entities + tr.entityNum;
+
+ if( target->s.eType == ET_PLAYER || target->s.eType == ET_BUILDABLE )
+ BloodSpurt( ent, target, &tr );
+ else
+ {
+ gentity_t *tent;
+
+ tent = G_TempEntity( tr.endpos, EV_MISSILE_MISS );
+ tent->s.eventParm = DirToByte( tr.plane.normal );
+ tent->s.weapon = ent->s.weapon;
+ tent->s.generic1 = ent->s.generic1;
+ }
+
+ G_Damage( target, ent, ent, forward, tr.endpos, LIGHTNING_DAMAGE, 0, MOD_LIGHTNING );
+}
+
+
/*
======================================================================
TESLA GENERATOR
@@ -1988,15 +2016,15 @@ void FireWeapon( gentity_t *ent )
case WP_ROCKET_LAUNCHER:
rocketLauncherFire( ent );
break;
+ case WP_LIGHTNING_GUN:
+ lightningGunFire( ent );
+ break;
case WP_GRENADE:
throwGrenade( ent );
break;
case WP_MINE:
throwMine( ent );
break;
- case WP_SMOKE:
- throwSmoke( ent );
- break;
case WP_LOCKBLOB_LAUNCHER:
lockBlobLauncherFire( ent );
break;
diff --git a/src/game/tremulous.h b/src/game/tremulous.h
index d05ebe4..3b9c8bc 100644
--- a/src/game/tremulous.h
+++ b/src/game/tremulous.h
@@ -514,6 +514,14 @@ TREMULOUS EDGE MOD SRC FILE
#define PRIFLE_SECONDARY_SPEED 900
#define PRIFLE_SECONDARY_REPEAT 400
+#define LIGHTNING_PRICE 500
+#define LIGHTNING_AMMO 300
+#define LIGHTNING_K_SCALE 1
+#define LIGHTNING_DPS 60 // damage per second
+#define LIGHTNING_REPEAT 50 // keep it as low as possible
+#define LIGHTNING_DAMAGE ( LIGHTNING_DPS * LIGHTNING_REPEAT / 1000 )
+#define LIGHTNING_RANGE 450
+
#define LCANNON_PRICE 600
#define LCANNON_AMMO 80
#define LCANNON_K_SCALE 1.0f