|
Posted by metlslime on 2007/08/08 04:57:56 |
This is a counterpart to the "Mapping Help" thread. If you need help with QuakeC coding, or questions about how to do some engine modification, this is the place for you! We've got a few coders here on the forum and hopefully someone knows the answer. |
|
|
Necros Must Try Again! :)
#1979 posted by Skiffy on 2016/01/30 04:51:16
QMaster
#1980 posted by aDaya on 2016/01/31 21:38:39
I did what you said, and while the BFG orb doesn't crash, this is what happens:
*Picking up the BFG removes from the inventory all shotguns, puts in the nailgun, and all others inventory fuckery.
*The orb still fires at an arbitrary point in the map, probably a monster's waypoint beyond a wall.
*After firing, the upcoming weapon animation don't come up.
*When the orb collides with the world, only the particle explosion happen. No sound, no explosion sprite.
*When the orb collides with a monster, it changes direction.
*The proximity lightning which happens when the orb's active and an enemy is near it, it only happens when both the orb and the player are close to each other, and the lightning comes from the player.
*If the orb collides with an enemy and i'm too close to it, I die.
With all of this stuff happening, I'm just gonna post all of the qc files that mentions the BFG9500, since I just have absolutely no idea what's really going on, nor a single hint on how to fix it.
weapons.qc: http://pastebin.com/gW3P42yr
items.qc: http://pastebin.com/3u1ddwZM
defs.qc: http://pastebin.com/nV7xYWxH
player.qc: http://pastebin.com/DdyRggCm
Item Erasure
#1981 posted by Preach on 2016/01/31 22:56:53
As someone has already mentioned in the post above, your IT_BFG9500 value is too large, and that's what's removing the other items. Because you've got other weapons you're running out of space. One way out would be to use the slot from IT_SUPERHEALTH instead, it doesn't appear on the HUD when you set that, so you can safely remove it from the megahealth code.
You might also want to look at the mission pack 2 code, which uses an extra field called items2 to store more of the player inventory. There is extra support in the HUD for items2 if you use the mission pack command line switches as well.
Wrong Direction Of Attack
#1982 posted by Preach on 2016/01/31 23:14:21
The BFG shot goes in the wrong direction because of this line:
BFGShot(org, self.enemy.origin - self.origin);
It's important to know at this point which entity is self. It is the player. The problem is that the player does not have an enemy, because that's for the AI entities. So what's the default value if you don't have AI? The world!
This means that self.enemy.origin - self.origin is calculating the direction to the centre of the world. Instead you want to fire in the direction that the player is facing. When you do makevectors (self.v_angle); the direction the player faces is stored in a global called v_forward. So the fixes are:
1) Replace
makevectors (self.angles);
with
makevectors (self.v_angle);
2) Replace
BFGShot(org, self.enemy.origin - self.origin);
with
BFGShot(org, v_forward);
One Thought At A Time
#1983 posted by Preach on 2016/01/31 23:26:21
Now we come to
bfgsphere.nextthink = time + 0.1;
bfgsphere.think = bfgshot1;
self.nextthink = time + 0.1;
self.think = bfg_ball_think;
bfgsphere.nextthink = time + 5;
bfgsphere.think = SUB_Remove;
This segment of code is well intentioned but quite confused. The first thing to ask again is which entity is self? It is still the player! So the first step towards getting this working would be to change those from self to bfgsphere:
bfgsphere.nextthink = time + 0.1;
bfgsphere.think = bfgshot1;
bfgsphere.nextthink = time + 0.1;
bfgsphere.think = bfg_ball_think;
bfgsphere.nextthink = time + 5;
bfgsphere.think = SUB_Remove;
Now I ask what is stored in bfgsphere.think at the end of these 6 lines? It is SUB_Remove, because that last line overwrites the previous code which set it to bfg_ball_think, which itself overwrote bfgshot1.
I'm not going to post the solution yet, because this has tripped you up before Daya, and I wanna make sure the problem makes sense before we look at solving it. I fear in the past I've gone too fast over this issue which is why it's recurred...
The Thinks Must Be In Decreasing Order, Correct?
#1984 posted by aDaya on 2016/02/01 10:56:15
This is what I did (and the other stuff too) while changing bfg_ball_think's think back to 0.3.
After all that, the projectile almost works: the orb animates properly, it fires at the direction I want it to fire, it produces the so-called blast after impact.
However the continuous lightning strikes from the orb still doesn't happen, colliding with the world without hitting an enemy don't spawn particles and says this: http://image.noelshack.com/fichiers/2016/05/1454319929-razenkrauft20160201104422-00.jpg , colliding with an enemy that gets gibbed still sends the orb to another direction, none of the explosion sprites (both orb impact and blast) show-up, when the blast happens the particle effect that should appear on the enemy appears instead at the origin point of the blast, and when I'm too close to the impact I get targeted by the blast, even though the code should avoid that.
Here's the code in weapons.qc once again, as I've added some more stuff in addition to yours: http://pastebin.com/EAV4PayU
#1985 posted by Spike on 2016/02/01 11:40:44
local entity bfgexpl;
bfgexpl.movetype = MOVETYPE_NONE;
that's an assignment to world.
remember that world is equivelent to null or nothing (and that locals default to nothing, or at least whatever 0 means), thus assignments to its fields are considered a bug - and this case is certainly no exception.
Did Some Modifications
#1986 posted by aDaya on 2016/02/01 14:11:15
Notably for both touch and explosion functions, where I looked at the rocket launcher's touch and explosion functions.
http://pastebin.com/KDRyZmG3
The explosion itself now spawns the particles (and the error messages don't show up this time), but the sprites still don't show up.
Only One Think
#1987 posted by Preach on 2016/02/01 21:27:27
No, you can only have one think. Just one. When you set the second think, it replaces the first one. The first one will never happen. There is no queue. You can only have one think. The only think which is coming out of your code is SUB_Remove because the others have been replaced before they have a chance to happen. An entity can only have one think, and it is always going to be the one you assigned most recently. Only one.
SUB_
#1988 posted by ijed on 2016/02/01 22:02:13
One think to rule them, one think to find them,
one think to bring them and in the dark places bind them.
So With That
#1989 posted by aDaya on 2016/02/01 22:52:12
I removed the thinks except for bfgshot1 which commands the orb's animation. I tried to call bfg_ball_think directly on each frame of the orb's sprite but still no dice.
The reason I'm not hiring a coder is because time zones are a complete bitch and I want to have complete control on the mod.
Timing
#1990 posted by Preach on 2016/02/01 23:04:59
When you changed it to only call bfgshot1, did you also change it so that the only nextthink line is:
bfgsphere.nextthink = time + 0.1;
If you left the line
bfgsphere.nextthink = time + 5;
in then it'll only kick in 5 seconds later, and it'll collide with a wall first!
The Only Remaining Next.think And Think Fork Remaining Is
#1991 posted by aDaya on 2016/02/02 00:02:42
bfgsphere.nextthink = time + 0.1;
bfgsphere.think = bfgshot1;
But by replacing some code in bfg_ball_think:
org = self.origin + '0 0 16';
head = findradius(self.origin, 250);
The continuous lightning now works on the enemies, but myself as well.
Normally "if(head != self)" should avoid that, but it gets ignored, somehow.
(Also the sprites still don't spawn, and the blast sound effect happens at the orb's impact, not at the enemies targeted, as wanted)
Issues With Bfg_ball_think
#1992 posted by Preach on 2016/02/04 00:49:04
So there's a bit of explanation to do with the magic entity self which may explain why this code didn't work:
local entity lightcont;
org = lightcont.origin + '0 0 16';
but your modification did, and why if(self != head) is failing to protect you.
self is a variable which stores an entity, but which entity it stores changes as the engine checks different things. When the player is launching attacks, then self is the player. But when other entities are running their think functions, then they become the new self. So we need to always remember who is calling a function to reason about self.
During bfg_ball_think what is self? The ball of death, not the player! Aside: how about lightcont? Well, you never assign anything to it in your function, so it is always equal to the world entity. This is why that wasn't working before you modified it.
Anyway, back to self. The problem is that we want to get back to the player who fired it, but if the ball is self then where is the player? Luckily, all the way back when we created the ball we had a line
bfgsphere.owner = self;
At that time self was the player and bfgsphere was the ball, so now that self is the ball, self.owner is the player we stored! So we change the check to
if(head != self.owner)
and the player will be unharmed.
Can you post a current BFG_Blast and related functions? This had issues in the old incarnation but you may have fixed or changed them...
This Is All Rather Interesting!
#1993 posted by Qmaster on 2016/02/04 04:15:21
Back to the IT_BFG9500 issue with messing up the inventory. The way the IT_'s work is by turning bit values on or off (0 or 1) in the single float variable self.items.
So a player with no items has a self.items of 00000000000000000000000 in binary (23 slots {mantissa for you super nerds} because of the way quake stores memory, the other bits are for exponent and a bit for positive/negative) QuakeC sees it as a float of 0 or whatever number the IT_'s add to unless you use the bitwise operator & to see if bit IT_something is turned on.
If you have the axe, shotgun and supershotgun self.items, in binary is 00010000000000011000000 and float is 4099.
This is the conversion of the number 4099 into binary. 4099 = 4096 + 1 + 2 (axe + shotgun + dbshotgun). If you subtract the supershotgun from self.items (4099 - 2) then the binary of self.items is 00010000000000001000000
We turned off one bit. The problem is that 16777216 needs 25 bits to store it. It is too large. So it causes your bits to get all wrong and shifted when you try to add it using the bitwise | operator, hence the inventory loses stuff and gains stuff. I wouldn't even use 8388608 either since it needs 24 bits. I ran into that same problem. If you use 65536 instead, it should work fine, so long as you remove the calls that the megahealth uses in items.qc
Also,
#1994 posted by Qmaster on 2016/02/04 04:24:07
Note that by using the set of all integer values that equal powers of 2, the sum of any n values is inherently unique from any other sum of n values.
Two Things Fixed At Once
#1995 posted by aDaya on 2016/02/04 10:10:38
First, the continuous lightning now works properly (even though it should spawn at the center of the sphere) :
http://image.noelshack.com/fichiers/2016/05/1454576771-schlossherr20160204095929-00.jpg
And the BFG doesn't mess with the inventory (I think that was because I assignated it with the Mega Health slot, as previously stated by Preach):
http://image.noelshack.com/fichiers/2016/05/1454576771-schlossherr20160204100351-00.jpg
I'm really happy it functions properly now. All there is to fix now is spawning the explosion and blast sprites properly and make the lightning start from the center of the sphere.
Forgot To Put It In The Code
#1996 posted by aDaya on 2016/02/04 10:11:22
Daya
Good work man :)
Lightning Start Pos
#1998 posted by Qmaster on 2016/02/04 16:08:43
Maybe this line should be changed:
org = self.origin + '0 0 16';
To: org = self.origin;
That Did It!
#1999 posted by aDaya on 2016/02/04 18:20:05
One last thing I forgot to mention before, aside from the sprites problem, how do I make the sphere not change direction when it hits a monster that gets gibbed?
Pass Thru Bullets
#2000 posted by Qmaster on 2016/02/05 03:27:22
You should check out the nail piercer code from the AD mod just release, it should help you to see how the nails think/touch when the player has the piercer effect on.
Where Is It Exactly?
#2001 posted by aDaya on 2016/02/05 19:11:45
I found nailpiercer but only for the powerup duration, not the actual code itself. W_FireSpikes only has codes for firing offsets and nailguns switching.
#2002 posted by necros on 2016/02/05 19:47:44
dunno about that code, but the easiest way to me would be to create a new .entity field and store .owner there instead.
then, every time it hits something and you go to do your damage, temporarily swap the entity back into .owner before you call t_damage. then set .owner to be the monster you just hit, making it non solid to the nail.
Yes
#2003 posted by ijed on 2016/02/05 22:07:01
I think that's how Supa handled it in the RMQ code. You need to add it to each thing you want to pass through - grenades probably and rockets maybe.
Also a flag for breakables - this should happen with stained glass but not crumbling bricks for example.
We also made nails go through zombies, but not gib them. Which was fun, but also pretty pointless, with hindsight.
|
|
You must be logged in to post in this thread.
|
Website copyright © 2002-2025 John Fitzgibbons. All posts are copyright their respective authors.
|
|