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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? p_plats.c

?? 游戲類程序源代碼---WinDoom 3D源程序.zip
?? C
字號:
// Emacs style mode select   -*- C++ -*- 
//-----------------------------------------------------------------------------
//
// $Id:$
//
// Copyright (C) 1993-1996 by id Software, Inc.
//
// This source is available for distribution and/or modification
// only under the terms of the DOOM Source Code License as
// published by id Software. All rights reserved.
//
// The source is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// FITNESS FOR A PARTICULAR PURPOSE. See the DOOM Source Code License
// for more details.
//
// $Log:$
//
// DESCRIPTION:
//	Plats (i.e. elevator platforms) code, raising/lowering.
//
//-----------------------------------------------------------------------------

static const char
rcsid[] = "$Id: p_plats.c,v 1.5 1997/02/03 22:45:12 b1 Exp $";


#include "i_system.h"
#include "z_zone.h"
#include "m_random.h"

#include "doomdef.h"
#include "p_local.h"

#include "s_sound.h"

// State.
#include "doomstat.h"
#include "r_state.h"

// Data.
#include "sounds.h"


plat_t*		activeplats[MAXPLATS];



//
// Move a plat up and down
//
void T_PlatRaise(plat_t* plat)
{
    result_e	res;
	
    switch(plat->status)
    {
      case up:
	res = T_MovePlane(plat->sector,
			  plat->speed,
			  plat->high,
			  plat->crush,0,1);
					
	if (plat->type == raiseAndChange
	    || plat->type == raiseToNearestAndChange)
	{
	    if (!(leveltime&7))
		S_StartSound((mobj_t *)&plat->sector->soundorg,
			     sfx_stnmov);
	}
	
				
	if (res == crushed && (!plat->crush))
	{
	    plat->count = plat->wait;
	    plat->status = down;
	    S_StartSound((mobj_t *)&plat->sector->soundorg,
			 sfx_pstart);
	}
	else
	{
	    if (res == pastdest)
	    {
		plat->count = plat->wait;
		plat->status = waiting;
		S_StartSound((mobj_t *)&plat->sector->soundorg,
			     sfx_pstop);

		switch(plat->type)
		{
		  case blazeDWUS:
		  case downWaitUpStay:
		    P_RemoveActivePlat(plat);
		    break;
		    
		  case raiseAndChange:
		  case raiseToNearestAndChange:
		    P_RemoveActivePlat(plat);
		    break;
		    
		  default:
		    break;
		}
	    }
	}
	break;
	
      case	down:
	res = T_MovePlane(plat->sector,plat->speed,plat->low,false,0,-1);

	if (res == pastdest)
	{
	    plat->count = plat->wait;
	    plat->status = waiting;
	    S_StartSound((mobj_t *)&plat->sector->soundorg,sfx_pstop);
	}
	break;
	
      case	waiting:
	if (!--plat->count)
	{
	    if (plat->sector->floorheight == plat->low)
		plat->status = up;
	    else
		plat->status = down;
	    S_StartSound((mobj_t *)&plat->sector->soundorg,sfx_pstart);
	}
      case	in_stasis:
	break;
    }
}


//
// Do Platforms
//  "amount" is only used for SOME platforms.
//
int
EV_DoPlat
( line_t*	line,
  plattype_e	type,
  int		amount )
{
    plat_t*	plat;
    int		secnum;
    int		rtn;
    sector_t*	sec;
	
    secnum = -1;
    rtn = 0;

    
    //	Activate all <type> plats that are in_stasis
    switch(type)
    {
      case perpetualRaise:
	P_ActivateInStasis(line->tag);
	break;
	
      default:
	break;
    }
	
    while ((secnum = P_FindSectorFromLineTag(line,secnum)) >= 0)
    {
	sec = &sectors[secnum];

	if (sec->specialdata)
	    continue;
	
	// Find lowest & highest floors around sector
	rtn = 1;
	plat = Z_Malloc( sizeof(*plat), PU_LEVSPEC, 0);
	P_AddThinker(&plat->thinker);
		
	plat->type = type;
	plat->sector = sec;
	plat->sector->specialdata = plat;
	plat->thinker.function.acp1 = (actionf_p1) T_PlatRaise;
	plat->crush = false;
	plat->tag = line->tag;
	
	switch(type)
	{
	  case raiseToNearestAndChange:
	    plat->speed = PLATSPEED/2;
	    sec->floorpic = sides[line->sidenum[0]].sector->floorpic;
	    plat->high = P_FindNextHighestFloor(sec,sec->floorheight);
	    plat->wait = 0;
	    plat->status = up;
	    // NO MORE DAMAGE, IF APPLICABLE
	    sec->special = 0;		

	    S_StartSound((mobj_t *)&sec->soundorg,sfx_stnmov);
	    break;
	    
	  case raiseAndChange:
	    plat->speed = PLATSPEED/2;
	    sec->floorpic = sides[line->sidenum[0]].sector->floorpic;
	    plat->high = sec->floorheight + amount*FRACUNIT;
	    plat->wait = 0;
	    plat->status = up;

	    S_StartSound((mobj_t *)&sec->soundorg,sfx_stnmov);
	    break;
	    
	  case downWaitUpStay:
	    plat->speed = PLATSPEED * 4;
	    plat->low = P_FindLowestFloorSurrounding(sec);

	    if (plat->low > sec->floorheight)
		plat->low = sec->floorheight;

	    plat->high = sec->floorheight;
	    plat->wait = 35*PLATWAIT;
	    plat->status = down;
	    S_StartSound((mobj_t *)&sec->soundorg,sfx_pstart);
	    break;
	    
	  case blazeDWUS:
	    plat->speed = PLATSPEED * 8;
	    plat->low = P_FindLowestFloorSurrounding(sec);

	    if (plat->low > sec->floorheight)
		plat->low = sec->floorheight;

	    plat->high = sec->floorheight;
	    plat->wait = 35*PLATWAIT;
	    plat->status = down;
	    S_StartSound((mobj_t *)&sec->soundorg,sfx_pstart);
	    break;
	    
	  case perpetualRaise:
	    plat->speed = PLATSPEED;
	    plat->low = P_FindLowestFloorSurrounding(sec);

	    if (plat->low > sec->floorheight)
		plat->low = sec->floorheight;

	    plat->high = P_FindHighestFloorSurrounding(sec);

	    if (plat->high < sec->floorheight)
		plat->high = sec->floorheight;

	    plat->wait = 35*PLATWAIT;
	    plat->status = P_Random()&1;

	    S_StartSound((mobj_t *)&sec->soundorg,sfx_pstart);
	    break;
	}
	P_AddActivePlat(plat);
    }
    return rtn;
}



void P_ActivateInStasis(int tag)
{
    int		i;
	
    for (i = 0;i < MAXPLATS;i++)
	if (activeplats[i]
	    && (activeplats[i])->tag == tag
	    && (activeplats[i])->status == in_stasis)
	{
	    (activeplats[i])->status = (activeplats[i])->oldstatus;
	    (activeplats[i])->thinker.function.acp1
	      = (actionf_p1) T_PlatRaise;
	}
}

void EV_StopPlat(line_t* line)
{
    int		j;
	
    for (j = 0;j < MAXPLATS;j++)
	if (activeplats[j]
	    && ((activeplats[j])->status != in_stasis)
	    && ((activeplats[j])->tag == line->tag))
	{
	    (activeplats[j])->oldstatus = (activeplats[j])->status;
	    (activeplats[j])->status = in_stasis;
	    (activeplats[j])->thinker.function.acv = (actionf_v)NULL;
	}
}

void P_AddActivePlat(plat_t* plat)
{
    int		i;
    
    for (i = 0;i < MAXPLATS;i++)
	if (activeplats[i] == NULL)
	{
	    activeplats[i] = plat;
	    return;
	}
    I_Error ("P_AddActivePlat: no more plats!");
}

void P_RemoveActivePlat(plat_t* plat)
{
    int		i;
    for (i = 0;i < MAXPLATS;i++)
	if (plat == activeplats[i])
	{
	    (activeplats[i])->sector->specialdata = NULL;
	    P_RemoveThinker(&(activeplats[i])->thinker);
	    activeplats[i] = NULL;
	    
	    return;
	}
    I_Error ("P_RemoveActivePlat: can't find plat!");
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区久久久| 久久久久久久久蜜桃| 一区二区三区成人| 欧美性受xxxx| 日本欧美大码aⅴ在线播放| 欧美日韩美少妇| 美女一区二区久久| 久久久www成人免费无遮挡大片| 国产精品一区二区无线| 久久精品一区二区三区不卡牛牛| 久久精品国产精品亚洲综合| 久久美女高清视频| 成人性生交大合| 尤物在线观看一区| 这里只有精品电影| 国产不卡视频在线观看| 国产精品亲子伦对白| 欧美亚洲图片小说| 国内偷窥港台综合视频在线播放| 国产精品午夜在线| 欧美色综合网站| 久久精工是国产品牌吗| 亚洲国产精品av| 欧美日韩一级片在线观看| 久久不见久久见免费视频7| 久久久精品日韩欧美| 色女孩综合影院| 精品一区二区三区在线观看国产| 国产精品婷婷午夜在线观看| 欧美精品视频www在线观看| 国精产品一区一区三区mba桃花| 国产精品久久久久影院亚瑟| 欧美区一区二区三区| 成人黄色一级视频| 日韩精品五月天| 亚洲欧洲日本在线| 欧美成人一区二区三区在线观看| 成人av网站在线| 老司机免费视频一区二区| 亚洲三级电影网站| 久久久一区二区三区| 欧美精品三级在线观看| av在线不卡电影| 久久精品99国产国产精| 亚洲国产日韩综合久久精品| 国产日韩一级二级三级| 91精品国产91久久综合桃花| 91网站黄www| 国产成人av电影免费在线观看| 午夜av一区二区三区| 国产精品成人免费在线| 亚洲精品一区二区三区在线观看| 欧美在线观看视频在线| 成人黄色在线视频| 狠狠狠色丁香婷婷综合激情 | k8久久久一区二区三区| 美腿丝袜亚洲色图| 天天综合网天天综合色| 亚洲另类在线一区| 日本一区二区成人在线| wwwwww.欧美系列| 91.com视频| 精品视频一区三区九区| 91麻豆高清视频| 99久久久精品| av不卡免费电影| 成人午夜视频免费看| 国产一区二区三区在线观看精品| 免费在线成人网| 日韩av一区二| 天堂va蜜桃一区二区三区 | 色8久久人人97超碰香蕉987| 成人免费视频视频| 风间由美一区二区三区在线观看| 精品一区二区三区视频在线观看| 午夜久久久久久久久| 亚洲国产婷婷综合在线精品| 亚洲国产一区二区三区青草影视| 亚洲午夜免费视频| 亚洲一区二区三区自拍| 亚洲午夜免费电影| 亚洲成人1区2区| 午夜精品久久久久久久| 五月婷婷综合在线| 蜜臀久久久99精品久久久久久| 日韩av不卡在线观看| 免费欧美日韩国产三级电影| 久久成人羞羞网站| 国产精品系列在线播放| 成人美女视频在线观看18| 不卡的电影网站| 色噜噜狠狠色综合中国| 欧美理论片在线| 日韩欧美一区二区三区在线| 精品美女一区二区| 国产精品美女久久久久久久久 | 91小视频在线| 欧美私模裸体表演在线观看| 欧美美女bb生活片| 欧美不卡一二三| 欧美激情一区二区三区全黄 | 久久精品亚洲一区二区三区浴池| 国产欧美一区视频| 亚洲男女毛片无遮挡| 视频在线在亚洲| 国产一区二区网址| av一区二区三区黑人| 色婷婷激情久久| 欧美一区二区在线观看| 久久久精品天堂| 亚洲综合男人的天堂| 日本aⅴ精品一区二区三区| 国产福利精品一区| 在线观看区一区二| 欧美大肚乱孕交hd孕妇| 欧美国产精品久久| 香蕉乱码成人久久天堂爱免费| 国内精品免费在线观看| 在线观看视频一区| 久久久亚洲国产美女国产盗摄| 亚洲日本韩国一区| 久草在线在线精品观看| www.99精品| 日韩美女一区二区三区| 一区二区中文字幕在线| 美女一区二区视频| 色吊一区二区三区| 久久久影院官网| 亚洲成人激情av| 白白色亚洲国产精品| 日韩免费视频一区| 一区二区三区成人在线视频| 国产精品自拍一区| 欧美另类videos死尸| 国产精品久久三区| 精品亚洲欧美一区| 欧美精三区欧美精三区| 亚洲品质自拍视频| 国产91精品久久久久久久网曝门| 69久久99精品久久久久婷婷| 亚洲免费伊人电影| 国产宾馆实践打屁股91| 日韩欧美国产麻豆| 夜夜嗨av一区二区三区中文字幕| 国产成人免费视频网站高清观看视频| 欧美日韩国产精品成人| 亚洲另类中文字| 99久久99久久久精品齐齐| 26uuu国产一区二区三区| 视频一区二区国产| 在线观看精品一区| 亚洲欧美视频在线观看| 懂色av中文字幕一区二区三区| 欧美大度的电影原声| 日韩中文字幕一区二区三区| 日本精品视频一区二区三区| 国产精品毛片大码女人| 国产寡妇亲子伦一区二区| 精品久久久久久久久久久久包黑料| 午夜欧美大尺度福利影院在线看| 色婷婷久久久综合中文字幕| 国产精品国产成人国产三级| 粉嫩高潮美女一区二区三区| 久久久99久久| 国产精品456| 国产欧美综合在线| 成人av网站免费| 国产精品久久免费看| 99久久精品情趣| 最新日韩av在线| 一本大道av一区二区在线播放 | 欧美电影免费观看高清完整版在线观看| 一区二区三区欧美激情| 欧美主播一区二区三区| 亚洲成人高清在线| 欧美一卡二卡三卡四卡| 青娱乐精品视频在线| 日韩欧美三级在线| 国产精品一二三| 国产精品久久久久久一区二区三区| 成人午夜视频在线| 亚洲日本青草视频在线怡红院| 日本电影欧美片| 亚洲福利电影网| 欧美一卡二卡在线| 国产精品一区二区久久精品爱涩 | 日韩美女视频一区二区| 色综合天天综合在线视频| 极品尤物av久久免费看| 欧美成人免费网站| 国产一区二区三区电影在线观看| 中文字幕高清不卡| 色综合色综合色综合| 亚洲高清三级视频| 精品日韩欧美在线| 丁香婷婷综合激情五月色| 亚洲乱码国产乱码精品精的特点| 欧美老女人在线| 国产成人精品一区二| 亚洲最大成人网4388xx|