mirror of
				https://github.com/ineedbots/iw4_bot_warfare.git
				synced 2025-10-24 23:15:53 +00:00 
			
		
		
		
	Improved smoke trace
This commit is contained in:
		| @@ -532,19 +532,51 @@ notifyAfterDelay(delay, not) | ||||
|  | ||||
| /* | ||||
| 	Pezbot's line sphere intersection. | ||||
| 	http://paulbourke.net/geometry/circlesphere/raysphere.c | ||||
| */ | ||||
| RaySphereIntersect(start, end, spherePos, radius) | ||||
| { | ||||
|    dp = end - start; | ||||
|    a = dp[0] * dp[0] + dp[1] * dp[1] + dp[2] * dp[2]; | ||||
|    b = 2 * (dp[0] * (start[0] - spherePos[0]) + dp[1] * (start[1] - spherePos[1]) + dp[2] * (start[2] - spherePos[2])); | ||||
|    c = spherePos[0] * spherePos[0] + spherePos[1] * spherePos[1] + spherePos[2] * spherePos[2]; | ||||
|    c += start[0] * start[0] + start[1] * start[1] + start[2] * start[2]; | ||||
|    c -= 2.0 * (spherePos[0] * start[0] + spherePos[1] * start[1] + spherePos[2] * start[2]); | ||||
|    c -= radius * radius; | ||||
|    bb4ac = b * b - 4.0 * a * c; | ||||
|     | ||||
|    return (bb4ac >= 0); | ||||
| 	// check if the start or end points are in the sphere | ||||
| 	r2 = radius * radius; | ||||
| 	if (DistanceSquared(start, spherePos) < r2) | ||||
| 		return true; | ||||
|  | ||||
| 	if (DistanceSquared(end, spherePos) < r2) | ||||
| 		return true; | ||||
|  | ||||
| 	// check if the line made by start and end intersect the sphere | ||||
| 	dp = end - start; | ||||
| 	a = dp[0] * dp[0] + dp[1] * dp[1] + dp[2] * dp[2]; | ||||
| 	b = 2 * (dp[0] * (start[0] - spherePos[0]) + dp[1] * (start[1] - spherePos[1]) + dp[2] * (start[2] - spherePos[2])); | ||||
| 	c = spherePos[0] * spherePos[0] + spherePos[1] * spherePos[1] + spherePos[2] * spherePos[2]; | ||||
| 	c += start[0] * start[0] + start[1] * start[1] + start[2] * start[2]; | ||||
| 	c -= 2.0 * (spherePos[0] * start[0] + spherePos[1] * start[1] + spherePos[2] * start[2]); | ||||
| 	c -= radius * radius; | ||||
| 	bb4ac = b * b - 4.0 * a * c; | ||||
|  | ||||
| 	if (abs(a) < 0.0001 || bb4ac < 0) | ||||
| 		return false; | ||||
|  | ||||
| 	mu1 = (0-b + sqrt(bb4ac)) / (2 * a); | ||||
| 	//mu2 = (0-b - sqrt(bb4ac)) / (2 * a); | ||||
|  | ||||
| 	// intersection points of the sphere | ||||
| 	ip1 = start + mu1 * dp; | ||||
| 	//ip2 = start + mu2 * dp; | ||||
|  | ||||
| 	myDist = DistanceSquared(start, end); | ||||
|  | ||||
| 	// check if both intersection points far | ||||
| 	if (DistanceSquared(start, ip1) > myDist/* && DistanceSquared(start, ip2) > myDist*/) | ||||
| 		return false; | ||||
|  | ||||
| 	dpAngles = VectorToAngles(dp); | ||||
|  | ||||
| 	// check if the point is behind us | ||||
| 	if (getConeDot(ip1, start, dpAngles) < 0/* || getConeDot(ip2, start, dpAngles) < 0*/) | ||||
| 		return false; | ||||
|  | ||||
| 	return true; | ||||
| } | ||||
|  | ||||
| /* | ||||
|   | ||||
		Reference in New Issue
	
	Block a user