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

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

?? vehicle_chopper.cpp

?? hl2 source code. Do not use it illegal.
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
{
	SetMoveType( MOVETYPE_FLYGRAVITY );
	m_flGravity = 0.3;

	UTIL_SetSize( this, Vector( -32, -32, -64), Vector( 32, 32, 0) );
	SetThink( DyingThink );
	SetTouch( CrashTouch );

	SetNextThink( gpGlobals->curtime + 0.1f );
	m_iHealth = 0;
	m_takedamage = DAMAGE_NO;

	if (m_spawnflags & SF_NOWRECKAGE)
	{
		m_flNextRocket = gpGlobals->curtime + 4.0;
	}
	else
	{
		m_flNextRocket = gpGlobals->curtime + 15.0;
	}

	CreateRagGib( "models/combine_soldier.mdl", GetAbsOrigin(), GetAbsAngles(), m_vecVelocity * 50 );
	
	m_OnDeath.FireOutput( pAttacker, this );
}


void CNPC_Helicopter::GibMonster( void )
{
}


//------------------------------------------------------------------------------
// Purpose :
// Input   :
// Output  :
//------------------------------------------------------------------------------
#define CHOPPER_MISSILE_HOMING_STRENGTH		0.3
#define CHOPPER_MISSILE_HOMING_DELAY		0.5
#define CHOPPER_MISSILE_HOMING_RAMP_UP		0.5
#define CHOPPER_MISSILE_HOMING_DURATION		1.0
#define CHOPPER_MISSILE_HOMING_RAMP_DOWN	0.5
void CNPC_Helicopter::FireRocket( Vector vLaunchPos, Vector vLaunchDir )
{
	CGrenadeHomer *pGrenade = CGrenadeHomer::CreateGrenadeHomer( MAKE_STRING("models/weapons/w_missile.mdl"), MAKE_STRING("weapons/stinger_fire1.wav"), vLaunchPos, vLaunchDir, edict() );
	pGrenade->Spawn( );
	pGrenade->SetHoming(CHOPPER_MISSILE_HOMING_STRENGTH,
						CHOPPER_MISSILE_HOMING_DELAY,
						CHOPPER_MISSILE_HOMING_RAMP_UP,
						CHOPPER_MISSILE_HOMING_DURATION,
						CHOPPER_MISSILE_HOMING_RAMP_DOWN);
	pGrenade->Launch(this,m_hEnemy,m_vecVelocity+vLaunchDir*500,500,0.5,true);
	UTIL_EmitSoundDyn(pev, CHAN_WEAPON, "weapons/stinger_fire1.wav", 1.0, 0.5, 1,100);

	m_flNextRocket = gpGlobals->curtime + 4.0;

	g_pEffects->Smoke(vLaunchPos,random->RandomInt(10, 15), 10);
}

//------------------------------------------------------------------------------
// Purpose :
// Input   :
// Output  :
//------------------------------------------------------------------------------
void CNPC_Helicopter::AimRocketGun( )
{
	Vector forward, right, up;
	AngleVectors( GetAngles(), &forward, &right, &up );
		
	Vector vBasePos, vBaseAng;
	Vector vTipPos, vTipAng;
	GetAttachment( CHOPPER_AP_LR_POD_BASE, vBasePos, vBaseAng );
	GetAttachment( CHOPPER_AP_LR_POD_TIP, vTipPos, vTipAng );
	
	// ----------------------------
	//  Aim Left
	// ----------------------------
	Vector vTargetDir;
	if (m_hEnemy != NULL)
	{
		vTargetDir = m_posTarget - vTipPos;
	}
	else
	{
		vTargetDir = forward;
	}
	VectorNormalize( vTargetDir );

	Vector vecOut;
	vecOut.x = DotProduct( forward, vTargetDir );
	vecOut.y = -DotProduct( right, vTargetDir );
	vecOut.z = DotProduct( up, vTargetDir );

	Vector angles;
	VectorAngles(vecOut, angles);

	if (angles.y > 180)
		angles.y = angles.y - 360;
	if (angles.y < -180)
		angles.y = angles.y + 360;
	if (angles.x > 180)
		angles.x = angles.x - 360;
	if (angles.x < -180)
		angles.x = angles.x + 360;

	if (angles.x > m_angPod.x)
		m_angPod.x = min( angles.x, m_angPod.x + 12 );
	if (angles.x < m_angPod.x)
		m_angPod.x = max( angles.x, m_angPod.x - 12 );
	if (angles.y > m_angPod.y)
		m_angPod.y = min( angles.y, m_angPod.y + 12 );
	if (angles.y < m_angPod.y)
		m_angPod.y = max( angles.y, m_angPod.y - 12 );

	m_angPod.x = SetBoneController( CHOPPER_BC_POD_PITCH,	m_angPod.x );

	// ------------------------
	// If no enemy we're done
	// ------------------------
	if (m_hEnemy == NULL)
	{
		return;
	}

	// --------------------------------
	//  Can I attack yet?
	// --------------------------------
	if (gpGlobals->curtime < m_flNextRocket)
	{
		return;
	}

	// -------------------------------
	// Don't fire when close to enemy
	// -------------------------------
	float flDist = (GetAbsOrigin() - m_hEnemy->GetAbsOrigin()).Length();
	if (flDist < CHOPPER_MIN_ROCKET_DIST)
	{
		return;
	}

	// -------------------------------
	//  Pick a pod to fire from
	//  Is left or right side closer?
	// -------------------------------
	Vector vMyFacing;
	BodyDirection2D(&vMyFacing);
	vMyFacing.z = 0;

	Vector	vEnemyDir   = m_hEnemy->EyePosition() - GetAbsOrigin();
	vEnemyDir.z = 0;

	Vector crossProduct;
	CrossProduct(vMyFacing, vEnemyDir, crossProduct);
	if (crossProduct.z < 0)
	{
		if (random->RandomInt(0,1)==0)
		{
			GetAttachment( CHOPPER_AP_RR_POD_BASE, vBasePos, vBaseAng );
			GetAttachment( CHOPPER_AP_RR_POD_TIP, vTipPos, vTipAng );
		}
		else
		{
			GetAttachment( CHOPPER_AP_RL_POD_BASE, vBasePos, vBaseAng );
			GetAttachment( CHOPPER_AP_RL_POD_TIP, vTipPos, vTipAng );
		}
	}
	else
	{
		if (random->RandomInt(0,1)==0)
		{
			GetAttachment( CHOPPER_AP_LR_POD_BASE, vBasePos, vBaseAng );
			GetAttachment( CHOPPER_AP_LR_POD_TIP, vTipPos, vTipAng );
		}
		else
		{
			GetAttachment( CHOPPER_AP_LL_POD_BASE, vBasePos, vBaseAng );
			GetAttachment( CHOPPER_AP_LL_POD_TIP, vTipPos, vTipAng );
		}
	}

	Vector vGunDir = vTipPos - vBasePos;
	VectorNormalize( vGunDir );
	
	float fDotPr = DotProduct( vGunDir, vTargetDir );

	if (fDotPr > 0.5)
	{
		FireRocket(vBasePos,vGunDir);
	}
}

//------------------------------------------------------------------------------
// Purpose :
// Input   :
// Output  :
//------------------------------------------------------------------------------
bool CNPC_Helicopter::FireGun( )
{
	Vector forward, right, up;
	AngleVectors( GetAngles(), &forward, &right, &up );
		
	// Get gun attachment points
	Vector vBasePos, vBaseAng;
	GetAttachment( CHOPPER_AP_GUN_BASE, vBasePos, vBaseAng );
	Vector vTipPos, vTipAng;
	GetAttachment( CHOPPER_AP_GUN_TIP, vTipPos, vTipAng );

	Vector vTargetDir = m_posTarget - vBasePos;
	VectorNormalize( vTargetDir );

	Vector vecOut;
	vecOut.x = DotProduct( forward, vTargetDir );
	vecOut.y = -DotProduct( right, vTargetDir );
	vecOut.z = DotProduct( up, vTargetDir );

	Vector angles;
	VectorAngles(vecOut, angles);

	if (angles.y > 180)
		angles.y = angles.y - 360;
	if (angles.y < -180)
		angles.y = angles.y + 360;
	if (angles.x > 180)
		angles.x = angles.x - 360;
	if (angles.x < -180)
		angles.x = angles.x + 360;

	if (angles.x > m_angGun.x)
		m_angGun.x = min( angles.x, m_angGun.x + 12 );
	if (angles.x < m_angGun.x)
		m_angGun.x = max( angles.x, m_angGun.x - 12 );
	if (angles.y > m_angGun.y)
		m_angGun.y = min( angles.y, m_angGun.y + 12 );
	if (angles.y < m_angGun.y)
		m_angGun.y = max( angles.y, m_angGun.y - 12 );

	m_angGun.y = SetBoneController( CHOPPER_BC_GUN_YAW,		m_angGun.y );
	m_angGun.x = SetBoneController( CHOPPER_BC_GUN_PITCH,	m_angGun.x );


	// -----------------------------------------
	//  Don't fire if far away, rockets do that
	// -----------------------------------------
	if (m_hEnemy)
	{
		float flDist = (GetAbsOrigin() - m_hEnemy->GetAbsOrigin()).Length();
		if (flDist > CHOPPER_MAX_GUN_DIST)
		{
			return false;
		}
	}
	Vector vGunDir = vBasePos - vTipPos;
	VectorNormalize( vGunDir );
	
	float fDotPr = DotProduct( vGunDir, vTargetDir );
	if (fDotPr > 0.95)
	{
		UTIL_EmitSound(pev, CHAN_WEAPON, "weapons/ar2/ar2_fire2.wav", 1.0, 0.2);//<<TEMP>>temp sound
		FireBullets( 1, vBasePos, vGunDir, VECTOR_CONE_1DEGREES, 8192, m_iAmmoType, 1 );
		return true;
	}
	return false;
}



void CNPC_Helicopter::ShowDamage( void )
{
	if (m_iDoSmokePuff > 0 || random->RandomInt(0,99) > m_iHealth)
	{
		Vector vSmoke = GetAbsOrigin();
		vSmoke.z -= 32;
		UTIL_Smoke(vSmoke,random->RandomInt(10, 15), 10);
	}
	if (m_iDoSmokePuff > 0)
	{
		m_iDoSmokePuff--;
	}
}


int CNPC_Helicopter::OnTakeDamage_Alive( const CTakeDamageInfo &info )
{
#if 0
	// This code didn't port easily. WTF does it do? (sjb)
	if (pevInflictor->m_owner == pev)
		return 0;
#endif

	if (bitsDamageType & DMG_BLAST)
	{
		flDamage *= 2;
	}

	/*
	if ( (bitsDamageType & DMG_BULLET) && flDamage > 50)
	{
		// clip bullet damage at 50
		flDamage = 50;
	}
	*/

	return BaseClass::OnTakeDamage_Alive( info );
}



void CNPC_Helicopter::TraceAttack( edict_t *pevAttacker, float flDamage, const Vector &vecDir, trace_t *ptr, int bitsDamageType)
{
	// ALERT( at_console, "%d %.0f\n", ptr->iHitgroup, flDamage );

#if 0 
	// HITGROUPS don't work currently.
	// ignore blades
	if (ptr->iHitgroup == 6 && (bitsDamageType & (DMG_ENERGYBEAM|DMG_BULLET|DMG_CLUB)))
		return;

	// hit hard, hits cockpit, hits engines
	if (flDamage > 50 || ptr->iHitgroup == 1 || ptr->iHitgroup == 2)
	{
		// ALERT( at_console, "%map .0f\n", flDamage );
		AddMultiDamage( pevAttacker, this, flDamage, bitsDamageType );
		m_iDoSmokePuff = 3 + (flDamage / 5.0);
	}
	else
	{
		// do half damage in the body
		// AddMultiDamage( pevAttacker, this, flDamage / 2.0, bitsDamageType );
		UTIL_Ricochet( ptr->vecEndPos );
	}
#endif
}

//------------------------------------------------------------------------------
// Purpose :
// Input   :
// Output  :
//------------------------------------------------------------------------------
CNPC_Helicopter::~CNPC_Helicopter(void)
{
}


#endif // 0

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲人成电影网站色mp4| 国产欧美一区二区三区在线老狼| 成人av电影在线网| 国产精品一区二区三区四区| 韩国欧美一区二区| 国产精品中文字幕一区二区三区| 国产精品中文字幕欧美| 国产精品亚洲一区二区三区在线| 国内精品视频666| 国产传媒日韩欧美成人| 成人免费视频国产在线观看| 成人精品国产一区二区4080| 91免费视频大全| 欧美在线播放高清精品| 欧美日韩免费在线视频| 日韩一区二区三区精品视频| www国产亚洲精品久久麻豆| 国产欧美日韩亚州综合| 亚洲日本在线看| 午夜成人在线视频| 国模一区二区三区白浆| 成+人+亚洲+综合天堂| 欧美中文字幕一区二区三区| 91麻豆精品国产91久久久久久| 欧美电视剧免费观看| 中文字幕精品一区二区精品绿巨人 | 色婷婷亚洲综合| 欧美日韩国产小视频| 欧美精品一区二区在线观看| 国产精品女上位| 日韩黄色一级片| 成人va在线观看| 欧美日本韩国一区二区三区视频| 久久综合九色综合97婷婷| 亚洲欧美偷拍另类a∨色屁股| 午夜欧美大尺度福利影院在线看| 国产麻豆视频一区| 欧美在线短视频| 中文字幕高清不卡| 日本欧美韩国一区三区| 99久久精品国产精品久久| 日韩一区二区免费电影| 日韩码欧中文字| 九一九一国产精品| 在线观看三级视频欧美| 久久精品视频一区二区三区| 亚洲成在线观看| 成人黄色大片在线观看| 日韩美女天天操| 性欧美大战久久久久久久久| av影院午夜一区| 久久一二三国产| 爽爽淫人综合网网站| 一本色道久久综合亚洲aⅴ蜜桃 | 2023国产精品| 日日夜夜精品视频免费| 色香色香欲天天天影视综合网| 久久亚洲综合av| 老司机精品视频一区二区三区| 欧美午夜一区二区三区免费大片| 国产精品国产三级国产aⅴ无密码| 久久99精品一区二区三区| 欧美午夜片在线看| 亚洲欧美激情小说另类| av电影在线观看完整版一区二区| 2021中文字幕一区亚洲| 久久91精品国产91久久小草 | 久久精品噜噜噜成人av农村| 欧美高清dvd| 日韩激情一区二区| 欧美精品电影在线播放| 午夜精品影院在线观看| 欧美色精品在线视频| 亚洲一区电影777| 欧美人伦禁忌dvd放荡欲情| 一区二区三区在线视频观看58| 97久久精品人人做人人爽 | 日韩高清欧美激情| 欧美视频中文一区二区三区在线观看| 自拍偷拍国产亚洲| 色视频成人在线观看免| 一区二区三区在线免费播放| 成人蜜臀av电影| 亚洲桃色在线一区| 日本韩国精品一区二区在线观看| 亚洲女与黑人做爰| 欧美日韩一区二区三区四区五区| 亚洲一区二区精品视频| 717成人午夜免费福利电影| 日本不卡一区二区| 亚洲精品在线电影| 成人自拍视频在线| 亚洲同性gay激情无套| 欧美三级视频在线播放| 蜜桃久久久久久久| 久久九九影视网| 色综合色综合色综合| 亚洲第一成人在线| 久久综合色综合88| 99精品1区2区| 日本中文在线一区| 国产午夜精品一区二区三区视频| 91尤物视频在线观看| 午夜视频在线观看一区二区三区| 欧美成人官网二区| 99视频在线精品| 免费视频一区二区| 中文字幕在线免费不卡| 欧美精品v日韩精品v韩国精品v| 老色鬼精品视频在线观看播放| 国产精品天天看| 欧美日韩一卡二卡| 成人少妇影院yyyy| 美脚の诱脚舐め脚责91| 国产精品高清亚洲| 中文字幕乱码日本亚洲一区二区| 在线精品视频免费观看| 精品一区二区免费视频| 一区二区三区四区在线播放| 精品福利在线导航| 精品视频一区二区三区免费| 国产成人亚洲综合a∨婷婷| 亚洲国产aⅴ天堂久久| 国产精品日产欧美久久久久| 欧美疯狂性受xxxxx喷水图片| www.欧美.com| 国产呦萝稀缺另类资源| 亚洲h在线观看| 日韩毛片精品高清免费| 26uuu久久综合| 欧美一级一级性生活免费录像| 91免费国产在线| 不卡电影一区二区三区| 狠狠色丁香久久婷婷综| 免费黄网站欧美| 亚洲成a人片在线不卡一二三区| 亚洲色图一区二区三区| 国产欧美一区二区在线观看| 久久综合九色欧美综合狠狠 | 国内成人免费视频| 日韩精品亚洲一区二区三区免费| 亚洲另类春色校园小说| 国产精品美日韩| 国产日韩影视精品| 国产日韩欧美制服另类| 久久在线免费观看| 26uuu亚洲婷婷狠狠天堂| 精品国产乱码久久久久久夜甘婷婷| 欧美日韩国产高清一区二区 | 欧美成人aa大片| 欧美一区在线视频| 欧美精品日韩一区| 欧美高清视频www夜色资源网| 欧美日韩精品综合在线| 欧美视频你懂的| 欧美日韩免费不卡视频一区二区三区| 欧洲国内综合视频| 欧美午夜精品久久久久久超碰| 欧美日韩在线播放三区四区| 欧美日韩高清不卡| 91精品国产入口在线| 欧美变态tickle挠乳网站| 日韩欧美不卡一区| 国产欧美综合在线观看第十页| 国产欧美日韩精品a在线观看| 中文字幕日韩精品一区| 亚洲美女一区二区三区| 午夜影院在线观看欧美| 轻轻草成人在线| 国产电影精品久久禁18| av亚洲精华国产精华| 欧美手机在线视频| 日韩精品中午字幕| 国产午夜精品久久久久久免费视| 国产精品美女久久久久久久久| 樱花草国产18久久久久| 日本最新不卡在线| 懂色av一区二区三区免费看| 91麻豆成人久久精品二区三区| 欧美二区三区的天堂| 26uuu亚洲综合色欧美| 亚洲免费大片在线观看| 日本va欧美va精品发布| 大胆亚洲人体视频| 欧美体内she精视频| 久久只精品国产| 一区二区在线观看视频在线观看| 蜜臂av日日欢夜夜爽一区| 国产成人h网站| 欧美日韩一级黄| 日本一区二区三区免费乱视频| 一区二区成人在线视频| 国内不卡的二区三区中文字幕 | 欧美一区二区观看视频| 久久精品视频免费| 五月天国产精品| 成人aaaa免费全部观看| 日韩欧美电影在线| 一区二区三区在线观看动漫 | 亚洲嫩草精品久久|