diff options
author | enneract <trem.redman@gmail.com> | 2014-12-14 14:56:38 +0100 |
---|---|---|
committer | enneract <trem.redman@gmail.com> | 2014-12-14 14:56:38 +0100 |
commit | 7c02e34b08a4e44a7f7935bf6b1bee45c3a8df6c (patch) | |
tree | e3ff69394522a6cc7dd11edf27cd69df6c0a5819 | |
parent | bd6fc418d171378de5de2b7450e22f70b4899b5c (diff) | |
parent | 5130cdd357c5b3b442d39ee05052739419456e77 (diff) |
Merge branch 'newguns'
Conflicts:
src/cgame/cg_local.h
src/cgame/cg_main.c
72 files changed, 988 insertions, 160 deletions
diff --git a/assets/gfx/rocketx/0002.jpg b/assets/gfx/rocketx/0002.jpg Binary files differnew file mode 100644 index 0000000..776768b --- /dev/null +++ b/assets/gfx/rocketx/0002.jpg diff --git a/assets/gfx/rocketx/0003.jpg b/assets/gfx/rocketx/0003.jpg Binary files differnew file mode 100644 index 0000000..91313e7 --- /dev/null +++ b/assets/gfx/rocketx/0003.jpg diff --git a/assets/gfx/rocketx/0004.jpg b/assets/gfx/rocketx/0004.jpg Binary files differnew file mode 100644 index 0000000..a1848ed --- /dev/null +++ b/assets/gfx/rocketx/0004.jpg diff --git a/assets/gfx/rocketx/0005.jpg b/assets/gfx/rocketx/0005.jpg Binary files differnew file mode 100644 index 0000000..da5e255 --- /dev/null +++ b/assets/gfx/rocketx/0005.jpg diff --git a/assets/gfx/rocketx/0006.jpg b/assets/gfx/rocketx/0006.jpg Binary files differnew file mode 100644 index 0000000..6d026ba --- /dev/null +++ b/assets/gfx/rocketx/0006.jpg diff --git a/assets/gfx/rocketx/0007.jpg b/assets/gfx/rocketx/0007.jpg Binary files differnew file mode 100644 index 0000000..c18ce0d --- /dev/null +++ b/assets/gfx/rocketx/0007.jpg diff --git a/assets/gfx/rocketx/0008.jpg b/assets/gfx/rocketx/0008.jpg Binary files differnew file mode 100644 index 0000000..06a2d74 --- /dev/null +++ b/assets/gfx/rocketx/0008.jpg diff --git a/assets/gfx/rocketx/0009.jpg b/assets/gfx/rocketx/0009.jpg Binary files differnew file mode 100644 index 0000000..6e7bc69 --- /dev/null +++ b/assets/gfx/rocketx/0009.jpg diff --git a/assets/gfx/rocketx/0010.jpg b/assets/gfx/rocketx/0010.jpg Binary files differnew file mode 100644 index 0000000..400d603 --- /dev/null +++ b/assets/gfx/rocketx/0010.jpg diff --git a/assets/gfx/rocketx/0011.jpg b/assets/gfx/rocketx/0011.jpg Binary files differnew file mode 100644 index 0000000..17e0220 --- /dev/null +++ b/assets/gfx/rocketx/0011.jpg diff --git a/assets/gfx/rocketx/0012.jpg b/assets/gfx/rocketx/0012.jpg Binary files differnew file mode 100644 index 0000000..6765bf9 --- /dev/null +++ b/assets/gfx/rocketx/0012.jpg diff --git a/assets/gfx/rocketx/0013.jpg b/assets/gfx/rocketx/0013.jpg Binary files differnew file mode 100644 index 0000000..a543aba --- /dev/null +++ b/assets/gfx/rocketx/0013.jpg diff --git a/assets/gfx/rocketx/0014.jpg b/assets/gfx/rocketx/0014.jpg Binary files differnew file mode 100644 index 0000000..5ed10d8 --- /dev/null +++ b/assets/gfx/rocketx/0014.jpg diff --git a/assets/gfx/rocketx/0015.jpg b/assets/gfx/rocketx/0015.jpg Binary files differnew file mode 100644 index 0000000..5fe6015 --- /dev/null +++ b/assets/gfx/rocketx/0015.jpg diff --git a/assets/gfx/rocketx/0016.jpg b/assets/gfx/rocketx/0016.jpg Binary files differnew file mode 100644 index 0000000..24f0d16 --- /dev/null +++ b/assets/gfx/rocketx/0016.jpg diff --git a/assets/gfx/rocketx/0017.jpg b/assets/gfx/rocketx/0017.jpg Binary files differnew file mode 100644 index 0000000..3b037f5 --- /dev/null +++ b/assets/gfx/rocketx/0017.jpg diff --git a/assets/gfx/rocketx/0018.jpg b/assets/gfx/rocketx/0018.jpg Binary files differnew file mode 100644 index 0000000..b479532 --- /dev/null +++ b/assets/gfx/rocketx/0018.jpg diff --git a/assets/gfx/rocketx/0019.jpg b/assets/gfx/rocketx/0019.jpg Binary files differnew file mode 100644 index 0000000..288bd52 --- /dev/null +++ b/assets/gfx/rocketx/0019.jpg diff --git a/assets/gfx/rocketx/0020.jpg b/assets/gfx/rocketx/0020.jpg Binary files differnew file mode 100644 index 0000000..97f2d10 --- /dev/null +++ b/assets/gfx/rocketx/0020.jpg diff --git a/assets/gfx/rocketx/0021.jpg b/assets/gfx/rocketx/0021.jpg Binary files differnew file mode 100644 index 0000000..3443b96 --- /dev/null +++ b/assets/gfx/rocketx/0021.jpg diff --git a/assets/gfx/rocketx/0022.jpg b/assets/gfx/rocketx/0022.jpg Binary files differnew file mode 100644 index 0000000..b14747d --- /dev/null +++ b/assets/gfx/rocketx/0022.jpg diff --git a/assets/gfx/rocketx/0023.jpg b/assets/gfx/rocketx/0023.jpg Binary files differnew file mode 100644 index 0000000..da23eb0 --- /dev/null +++ b/assets/gfx/rocketx/0023.jpg diff --git a/assets/gfx/rocketx/0024.jpg b/assets/gfx/rocketx/0024.jpg Binary files differnew file mode 100644 index 0000000..bfe4476 --- /dev/null +++ b/assets/gfx/rocketx/0024.jpg diff --git a/assets/gfx/rocketx/0025.jpg b/assets/gfx/rocketx/0025.jpg Binary files differnew file mode 100644 index 0000000..e6a7923 --- /dev/null +++ b/assets/gfx/rocketx/0025.jpg diff --git a/assets/gfx/rocketx/0026.jpg b/assets/gfx/rocketx/0026.jpg Binary files differnew file mode 100644 index 0000000..99ef757 --- /dev/null +++ b/assets/gfx/rocketx/0026.jpg diff --git a/assets/gfx/rocketx/0027.jpg b/assets/gfx/rocketx/0027.jpg Binary files differnew file mode 100644 index 0000000..220234b --- /dev/null +++ b/assets/gfx/rocketx/0027.jpg diff --git a/assets/gfx/rocketx/0028.jpg b/assets/gfx/rocketx/0028.jpg Binary files differnew file mode 100644 index 0000000..5b2b4e6 --- /dev/null +++ b/assets/gfx/rocketx/0028.jpg diff --git a/assets/gfx/rocketx/0029.jpg b/assets/gfx/rocketx/0029.jpg Binary files differnew file mode 100644 index 0000000..585257e --- /dev/null +++ b/assets/gfx/rocketx/0029.jpg diff --git a/assets/gfx/rocketx/0030.jpg b/assets/gfx/rocketx/0030.jpg Binary files differnew file mode 100644 index 0000000..09721ca --- /dev/null +++ b/assets/gfx/rocketx/0030.jpg diff --git a/assets/icons/iconw_lightning.tga b/assets/icons/iconw_lightning.tga Binary files differnew file mode 100644 index 0000000..280e83d --- /dev/null +++ b/assets/icons/iconw_lightning.tga diff --git a/assets/icons/iconw_smoke.tga b/assets/icons/iconw_smoke.tga Binary files differdeleted file mode 100644 index 0dd72b1..0000000 --- a/assets/icons/iconw_smoke.tga +++ /dev/null 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 Binary files differnew file mode 100644 index 0000000..07d7ef1 --- /dev/null +++ b/assets/models/weapons/lightning/bolt.jpg diff --git a/assets/models/weapons/lightning/firing.wav b/assets/models/weapons/lightning/firing.wav Binary files differnew file mode 100644 index 0000000..3ba7722 --- /dev/null +++ b/assets/models/weapons/lightning/firing.wav diff --git a/assets/models/weapons/lightning/flash.jpg b/assets/models/weapons/lightning/flash.jpg Binary files differnew file mode 100644 index 0000000..070d8fa --- /dev/null +++ b/assets/models/weapons/lightning/flash.jpg diff --git a/assets/models/weapons/lightning/flash0.wav b/assets/models/weapons/lightning/flash0.wav Binary files differnew file mode 100644 index 0000000..5895c02 --- /dev/null +++ b/assets/models/weapons/lightning/flash0.wav diff --git a/assets/models/weapons/lightning/impact0.wav b/assets/models/weapons/lightning/impact0.wav Binary files differnew file mode 100644 index 0000000..8f70050 --- /dev/null +++ b/assets/models/weapons/lightning/impact0.wav diff --git a/assets/models/weapons/lightning/impact1.wav b/assets/models/weapons/lightning/impact1.wav Binary files differnew file mode 100644 index 0000000..530d28b --- /dev/null +++ b/assets/models/weapons/lightning/impact1.wav diff --git a/assets/models/weapons/lightning/impact2.wav b/assets/models/weapons/lightning/impact2.wav Binary files differnew file mode 100644 index 0000000..ffff0d2 --- /dev/null +++ b/assets/models/weapons/lightning/impact2.wav diff --git a/assets/models/weapons/lightning/lightning.jpg b/assets/models/weapons/lightning/lightning.jpg Binary files differnew file mode 100644 index 0000000..f7955d6 --- /dev/null +++ b/assets/models/weapons/lightning/lightning.jpg diff --git a/assets/models/weapons/lightning/lightning.md3 b/assets/models/weapons/lightning/lightning.md3 Binary files differnew file mode 100644 index 0000000..c96197b --- /dev/null +++ b/assets/models/weapons/lightning/lightning.md3 diff --git a/assets/models/weapons/lightning/lightning_flash.md3 b/assets/models/weapons/lightning/lightning_flash.md3 Binary files differnew file mode 100644 index 0000000..2f6ceb0 --- /dev/null +++ b/assets/models/weapons/lightning/lightning_flash.md3 diff --git a/assets/models/weapons/lightning/lightning_hand.md3 b/assets/models/weapons/lightning/lightning_hand.md3 Binary files differnew file mode 100644 index 0000000..edda546 --- /dev/null +++ b/assets/models/weapons/lightning/lightning_hand.md3 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 Binary files differindex 009febe..89e78b7 100644 --- a/assets/models/weapons/rocketl/flash0.wav +++ b/assets/models/weapons/rocketl/flash0.wav diff --git a/assets/models/weapons/rocketl/rocketl.md3 b/assets/models/weapons/rocketl/rocketl.md3 Binary files differindex 4119209..d515cf4 100644 --- a/assets/models/weapons/rocketl/rocketl.md3 +++ b/assets/models/weapons/rocketl/rocketl.md3 diff --git a/assets/models/weapons/rocketl/rocketl_flash.md3 b/assets/models/weapons/rocketl/rocketl_flash.md3 Binary files differnew file mode 100644 index 0000000..c1acf35 --- /dev/null +++ b/assets/models/weapons/rocketl/rocketl_flash.md3 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 Binary files differdeleted file mode 100644 index a001de3..0000000 --- a/assets/models/weapons/smoke/smoke.jpg +++ /dev/null diff --git a/assets/models/weapons/smoke/smoke.md3 b/assets/models/weapons/smoke/smoke.md3 Binary files differdeleted file mode 100644 index 53fed50..0000000 --- a/assets/models/weapons/smoke/smoke.md3 +++ /dev/null diff --git a/assets/models/weapons/smoke/smoke.wav b/assets/models/weapons/smoke/smoke.wav Binary files differdeleted file mode 100644 index 6c2d7ea..0000000 --- a/assets/models/weapons/smoke/smoke.wav +++ /dev/null diff --git a/assets/models/weapons/smoke/smokegfx.tga b/assets/models/weapons/smoke/smokegfx.tga Binary files differdeleted file mode 100644 index f028d75..0000000 --- a/assets/models/weapons/smoke/smokegfx.tga +++ /dev/null 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 = ¢->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 |