亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? cl_newfx.java

?? JAKE2用JAVA寫的queck2的3D游戲開發(fā)引擎
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/* * CL_newfx.java * Copyright (C) 2004 *  * $Id: CL_newfx.java,v 1.7 2005/01/17 21:50:42 cawe Exp $ *//* Copyright (C) 1997-2001 Id Software, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.   See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. */// Created on 31.01.2004 by RST.package jake2.client;import jake2.Defines;import jake2.Globals;import jake2.util.Lib;import jake2.util.Math3D;/** * CL_newfx */public class CL_newfx {    static void Flashlight(int ent, float[] pos) {        CL_fx.cdlight_t dl;        dl = CL_fx.AllocDlight(ent);        Math3D.VectorCopy(pos, dl.origin);        dl.radius = 400;        dl.minlight = 250;        dl.die = Globals.cl.time + 100;        dl.color[0] = 1;        dl.color[1] = 1;        dl.color[2] = 1;    }    /*     * ====== CL_ColorFlash - flash of light ======     */    static void ColorFlash(float[] pos, int ent, int intensity, float r,            float g, float b) {        CL_fx.cdlight_t dl;        if ((Globals.vidref_val == Defines.VIDREF_SOFT)                && ((r < 0) || (g < 0) || (b < 0))) {            intensity = -intensity;            r = -r;            g = -g;            b = -b;        }        dl = CL_fx.AllocDlight(ent);        Math3D.VectorCopy(pos, dl.origin);        dl.radius = intensity;        dl.minlight = 250;        dl.die = Globals.cl.time + 100;        dl.color[0] = r;        dl.color[1] = g;        dl.color[2] = b;    }  	// stack variable  	private static final float[] move = {0, 0, 0};  	private static final float[] vec = {0, 0, 0};  	private static final float[] right = {0, 0, 0};  	private static final float[] up = {0, 0, 0};    /*     * ====== CL_DebugTrail ======     */    static void DebugTrail(float[] start, float[] end) {        float len;        //		int j;        cparticle_t p;        float dec;        //		int i;        //		float d, c, s;        //		float[] dir;        Math3D.VectorCopy(start, move);        Math3D.VectorSubtract(end, start, vec);        len = Math3D.VectorNormalize(vec);        Math3D.MakeNormalVectors(vec, right, up);        //		VectorScale(vec, RT2_SKIP, vec);        //		dec = 1.0;        //		dec = 0.75;        dec = 3;        Math3D.VectorScale(vec, dec, vec);        Math3D.VectorCopy(start, move);        while (len > 0) {            len -= dec;            if (CL_fx.free_particles == null)                return;            p = CL_fx.free_particles;            CL_fx.free_particles = p.next;            p.next = CL_fx.active_particles;            CL_fx.active_particles = p;            p.time = Globals.cl.time;            Math3D.VectorClear(p.accel);            Math3D.VectorClear(p.vel);            p.alpha = 1.0f;            p.alphavel = -0.1f;            //			p.alphavel = 0;            p.color = 0x74 + (Lib.rand() & 7);            Math3D.VectorCopy(move, p.org);            /*             * for (j=0 ; j <3 ; j++) { p.org[j] = move[j] + crand()*2; p.vel[j] =             * crand()*3; p.accel[j] = 0; }             */            Math3D.VectorAdd(move, vec, move);        }    }  	// stack variable    // move, vec    static void ForceWall(float[] start, float[] end, int color) {        float len;        int j;        cparticle_t p;        Math3D.VectorCopy(start, move);        Math3D.VectorSubtract(end, start, vec);        len = Math3D.VectorNormalize(vec);        Math3D.VectorScale(vec, 4, vec);        // FIXME: this is a really silly way to have a loop        while (len > 0) {            len -= 4;            if (CL_fx.free_particles == null)                return;            if (Globals.rnd.nextFloat() > 0.3) {                p = CL_fx.free_particles;                CL_fx.free_particles = p.next;                p.next = CL_fx.active_particles;                CL_fx.active_particles = p;                Math3D.VectorClear(p.accel);                p.time = Globals.cl.time;                p.alpha = 1.0f;                p.alphavel = -1.0f / (3.0f + Globals.rnd.nextFloat() * 0.5f);                p.color = color;                for (j = 0; j < 3; j++) {                    p.org[j] = move[j] + Lib.crand() * 3;                    p.accel[j] = 0;                }                p.vel[0] = 0;                p.vel[1] = 0;                p.vel[2] = -40 - (Lib.crand() * 10);            }            Math3D.VectorAdd(move, vec, move);        }    }  	// stack variable    // move, vec    /*     * =============== CL_BubbleTrail2 (lets you control the # of bubbles by     * setting the distance between the spawns)     *      * ===============     */    static void BubbleTrail2(float[] start, float[] end, int dist) {        float len;        int i, j;        cparticle_t p;        float dec;        Math3D.VectorCopy(start, move);        Math3D.VectorSubtract(end, start, vec);        len = Math3D.VectorNormalize(vec);        dec = dist;        Math3D.VectorScale(vec, dec, vec);        for (i = 0; i < len; i += dec) {            if (CL_fx.free_particles == null)                return;            p = CL_fx.free_particles;            CL_fx.free_particles = p.next;            p.next = CL_fx.active_particles;            CL_fx.active_particles = p;            Math3D.VectorClear(p.accel);            p.time = Globals.cl.time;            p.alpha = 1.0f;            p.alphavel = -1.0f / (1 + Globals.rnd.nextFloat() * 0.1f);            p.color = 4 + (Lib.rand() & 7);            for (j = 0; j < 3; j++) {                p.org[j] = move[j] + Lib.crand() * 2;                p.vel[j] = Lib.crand() * 10;            }            p.org[2] -= 4;            //			p.vel[2] += 6;            p.vel[2] += 20;            Math3D.VectorAdd(move, vec, move);        }    }  	// stack variable    // move, vec, right, up    private static final float[] dir = {0, 0, 0};    private static final float[] end = {0, 0, 0};        static void Heatbeam(float[] start, float[] forward) {        float len;        int j;        cparticle_t p;        int i;        float c, s;        float ltime;        float step = 32.0f, rstep;        float start_pt;        float rot;        float variance;        Math3D.VectorMA(start, 4096, forward, end);        Math3D.VectorCopy(start, move);        Math3D.VectorSubtract(end, start, vec);        len = Math3D.VectorNormalize(vec);        // FIXME - pmm - these might end up using old values?        //		MakeNormalVectors (vec, right, up);        Math3D.VectorCopy(Globals.cl.v_right, right);        Math3D.VectorCopy(Globals.cl.v_up, up);        if (Globals.vidref_val == Defines.VIDREF_GL) { // GL mode            Math3D.VectorMA(move, -0.5f, right, move);            Math3D.VectorMA(move, -0.5f, up, move);        }        // otherwise assume SOFT        ltime = (float) Globals.cl.time / 1000.0f;        start_pt = ltime * 96.0f % step;        Math3D.VectorMA(move, start_pt, vec, move);        Math3D.VectorScale(vec, step, vec);        //		Com_Printf ("%f\n", ltime);        rstep = (float) (Math.PI / 10.0);        float M_PI2 = (float) (Math.PI * 2.0);        for (i = (int) start_pt; i < len; i += step) {            if (i > step * 5) // don't bother after the 5th ring                break;            for (rot = 0; rot < M_PI2; rot += rstep) {                if (CL_fx.free_particles == null)                    return;                p = CL_fx.free_particles;                CL_fx.free_particles = p.next;                p.next = CL_fx.active_particles;                CL_fx.active_particles = p;                p.time = Globals.cl.time;                Math3D.VectorClear(p.accel);                //				rot+= fmod(ltime, 12.0)*M_PI;                //				c = cos(rot)/2.0;                //				s = sin(rot)/2.0;                //				variance = 0.4 + ((float)rand()/(float)RAND_MAX) *0.2;                variance = 0.5f;                c = (float) (Math.cos(rot) * variance);                s = (float) (Math.sin(rot) * variance);                // trim it so it looks like it's starting at the origin                if (i < 10) {                    Math3D.VectorScale(right, c * (i / 10.0f), dir);                    Math3D.VectorMA(dir, s * (i / 10.0f), up, dir);                } else {                    Math3D.VectorScale(right, c, dir);                    Math3D.VectorMA(dir, s, up, dir);                }                p.alpha = 0.5f;                //		p.alphavel = -1.0 / (1+frand()*0.2);                p.alphavel = -1000.0f;                //		p.color = 0x74 + (rand()&7);                p.color = 223 - (Lib.rand() & 7);                for (j = 0; j < 3; j++) {                    p.org[j] = move[j] + dir[j] * 3;                    //			p.vel[j] = dir[j]*6;                    p.vel[j] = 0;                }            }            Math3D.VectorAdd(move, vec, move);        }    }  	// stack variable    private static final float[] r = {0, 0, 0};    private static final float[] u = {0, 0, 0};    /*     * =============== CL_ParticleSteamEffect     *      * Puffs with velocity along direction, with some randomness thrown in     * ===============     */    static void ParticleSteamEffect(float[] org, float[] dir, int color,            int count, int magnitude) {        int i, j;        cparticle_t p;        float d;        //		vectoangles2 (dir, angle_dir);        //		AngleVectors (angle_dir, f, r, u);        Math3D.MakeNormalVectors(dir, r, u);        for (i = 0; i < count; i++) {            if (CL_fx.free_particles == null)                return;            p = CL_fx.free_particles;            CL_fx.free_particles = p.next;            p.next = CL_fx.active_particles;            CL_fx.active_particles = p;            p.time = Globals.cl.time;            p.color = color + (Lib.rand() & 7);            for (j = 0; j < 3; j++) {                p.org[j] = org[j] + magnitude * 0.1f * Lib.crand();                //				p.vel[j] = dir[j]*magnitude;            }            Math3D.VectorScale(dir, magnitude, p.vel);            d = Lib.crand() * magnitude / 3;            Math3D.VectorMA(p.vel, d, r, p.vel);            d = Lib.crand() * magnitude / 3;            Math3D.VectorMA(p.vel, d, u, p.vel);            p.accel[0] = p.accel[1] = 0;            p.accel[2] = -CL_fx.PARTICLE_GRAVITY / 2;            p.alpha = 1.0f;            p.alphavel = -1.0f / (0.5f + Globals.rnd.nextFloat() * 0.3f);        }    }  	// stack variable    // r, u, dir    static void ParticleSteamEffect2(cl_sustain_t self)    //	  float[] org, float[] dir, int color, int count, int magnitude)    {        int i, j;        cparticle_t p;        float d;        //		vectoangles2 (dir, angle_dir);        //		AngleVectors (angle_dir, f, r, u);        Math3D.VectorCopy(self.dir, dir);        Math3D.MakeNormalVectors(dir, r, u);        for (i = 0; i < self.count; i++) {            if (CL_fx.free_particles == null)                return;            p = CL_fx.free_particles;            CL_fx.free_particles = p.next;            p.next = CL_fx.active_particles;            CL_fx.active_particles = p;            p.time = Globals.cl.time;            p.color = self.color + (Lib.rand() & 7);            for (j = 0; j < 3; j++) {                p.org[j] = self.org[j] + self.magnitude * 0.1f * Lib.crand();                //				p.vel[j] = dir[j]*magnitude;            }            Math3D.VectorScale(dir, self.magnitude, p.vel);            d = Lib.crand() * self.magnitude / 3;            Math3D.VectorMA(p.vel, d, r, p.vel);            d = Lib.crand() * self.magnitude / 3;            Math3D.VectorMA(p.vel, d, u, p.vel);            p.accel[0] = p.accel[1] = 0;            p.accel[2] = -CL_fx.PARTICLE_GRAVITY / 2;            p.alpha = 1.0f;            p.alphavel = -1.0f / (0.5f + Globals.rnd.nextFloat() * 0.3f);        }        self.nextthink += self.thinkinterval;    }  	// stack variable    // move, vec, right, up     private static final float[] forward = {0, 0, 0};    private static final float[] angle_dir = {0, 0, 0};    /*     * =============== CL_TrackerTrail ===============     */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av午夜在线观看| 一区二区三区成人| 日本大香伊一区二区三区| 麻豆国产91在线播放| 中文字幕欧美区| 日韩一区二区免费电影| 色菇凉天天综合网| 成人激情动漫在线观看| 日韩av中文字幕一区二区 | 国产亚洲一区二区三区四区| 日本二三区不卡| 国产一区二三区| 视频一区在线视频| 亚洲欧洲精品一区二区三区不卡 | 一色桃子久久精品亚洲| 日韩免费一区二区| 欧美老女人第四色| 在线亚洲一区二区| 99国产欧美另类久久久精品| 国产乱人伦偷精品视频不卡| 久久精品国产**网站演员| 亚洲狠狠爱一区二区三区| 亚洲欧洲一区二区在线播放| 国产亚洲欧美激情| 精品久久久久香蕉网| 欧美一级午夜免费电影| 欧美日韩免费高清一区色橹橹 | 国产丝袜美腿一区二区三区| 欧美一区二区三区小说| 欧美日韩一级黄| 欧美日韩综合色| 欧美亚洲综合一区| 在线观看免费成人| 在线视频国内自拍亚洲视频| 欧美精品一级二级| 在线一区二区三区四区五区| 91麻豆免费视频| 一本久久综合亚洲鲁鲁五月天 | 波多野结衣欧美| 成人性视频网站| 成人国产在线观看| 91美女片黄在线观看91美女| 91捆绑美女网站| 在线视频你懂得一区二区三区| 色综合中文字幕国产 | 蜜桃视频在线观看一区| 美女精品一区二区| 国产一区视频导航| 成人性生交大片免费看在线播放| 岛国一区二区在线观看| 99久久777色| 欧美午夜寂寞影院| 欧美一级日韩免费不卡| 精品国产污网站| 欧美极品少妇xxxxⅹ高跟鞋| 亚洲视频你懂的| 亚洲国产精品人人做人人爽| 日韩avvvv在线播放| 久久av老司机精品网站导航| 激情久久五月天| 99热精品一区二区| 欧美中文字幕久久 | 亚洲精品乱码久久久久久| 亚洲乱码中文字幕综合| 午夜精品福利一区二区三区蜜桃| 美女脱光内衣内裤视频久久网站| 国产一区二区三区最好精华液| 国产精品白丝av| 色www精品视频在线观看| 欧美日韩激情一区二区三区| 精品美女在线观看| 欧美激情中文字幕一区二区| 亚洲成人在线免费| 国产成人精品影院| 亚洲欧洲制服丝袜| 国产欧美日韩精品一区| 亚洲欧美在线另类| 石原莉奈在线亚洲二区| 久久成人免费网站| 成人禁用看黄a在线| 欧美日韩视频一区二区| 欧美精品一区二区三区久久久| 国产精品久久久久影视| 视频一区二区三区入口| 国产999精品久久久久久| 欧美网站大全在线观看| 精品美女在线播放| 一区二区三区电影在线播| 久久99深爱久久99精品| 99re这里只有精品首页| 欧美一级二级三级蜜桃| 中文字幕综合网| 激情六月婷婷久久| 精品视频在线看| 国产精品天美传媒沈樵| 日韩高清不卡一区| 成年人国产精品| 欧美日韩国产综合视频在线观看 | 日韩欧美国产三级电影视频| 国产精品护士白丝一区av| 天天色综合成人网| 波多野结衣中文字幕一区二区三区 | 成人免费视频免费观看| 欧美老女人在线| 亚洲美女在线国产| 国产麻豆视频一区二区| 欧美日本在线观看| 亚洲欧洲一区二区三区| 国产一区二区电影| 91麻豆精品国产无毒不卡在线观看| 国产精品久久久99| 激情欧美一区二区三区在线观看| 欧美精品99久久久**| 亚洲欧美视频在线观看视频| 韩国女主播一区二区三区| 91精品麻豆日日躁夜夜躁| 亚洲欧洲中文日韩久久av乱码| 国产69精品久久99不卡| 日韩欧美aaaaaa| 日本不卡在线视频| 欧美日韩高清一区二区三区| 亚洲欧美一区二区久久| 99国产欧美久久久精品| 国产精品视频观看| 岛国精品一区二区| 久久综合色天天久久综合图片| 日韩av网站在线观看| 欧美精品少妇一区二区三区| 一区二区三区国产精品| 在线视频欧美区| 一区二区免费视频| 91黄色免费看| 一区二区三区四区激情| 色婷婷国产精品| 一区二区免费看| 欧美影片第一页| 香蕉影视欧美成人| 欧美精品欧美精品系列| 婷婷久久综合九色综合绿巨人| 欧美影院一区二区三区| 午夜私人影院久久久久| 欧美中文字幕一区| 性欧美疯狂xxxxbbbb| 91精品国产欧美日韩| 蜜桃久久av一区| 欧美大片在线观看一区二区| 毛片一区二区三区| 2020国产精品| 国产91精品欧美| 亚洲欧美一区二区三区国产精品| 欧美性xxxxx极品少妇| 亚洲成a人片在线不卡一二三区| 欧美日韩免费一区二区三区视频 | 亚洲一区二区免费视频| 欧美美女一区二区在线观看| 日韩国产欧美三级| 精品欧美乱码久久久久久1区2区| 狠狠色狠狠色综合| 日本一区二区在线不卡| 99久久免费精品高清特色大片| 亚洲免费高清视频在线| 91.麻豆视频| 国产一区二区日韩精品| 国产精品久久久久久久久免费丝袜 | 欧美日韩一级片在线观看| 男人的天堂久久精品| 国产无人区一区二区三区| 99精品久久99久久久久| 午夜精品一区二区三区免费视频| 精品少妇一区二区三区| 成人精品高清在线| 亚洲bt欧美bt精品777| 精品少妇一区二区三区在线播放 | 欧美精品精品一区| 精品无人码麻豆乱码1区2区| 欧美经典三级视频一区二区三区| 91久久一区二区| 精品一区二区三区在线观看 | 久久久久久久国产精品影院| av成人老司机| 日韩精品五月天| 中日韩免费视频中文字幕| 欧美三区在线视频| 国产精品77777| 亚洲福利一二三区| 久久影院午夜片一区| 日本大香伊一区二区三区| 精品一区二区三区在线视频| 亚洲综合久久久| 日本一区二区不卡视频| 欧美一级片在线观看| 99久免费精品视频在线观看| 日本不卡不码高清免费观看| 国产精品久久久久久户外露出| 欧美一级片免费看| 色婷婷av一区二区三区软件| 国产酒店精品激情| 日韩精品一二三| 亚洲精品高清在线观看| 久久久久久久久久久黄色|