|
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. |
|
|
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.
#2004 posted by necros on 2016/02/06 01:45:10
i did that for the fast zombies in ruins! it lets you kill dozens with well placed quad shotgun blasts. :D
i did limit shells and nails to only penetrate once. and nails turn ballistic after hitting the first zombie.
Items2
Someone mentioned the items2 field, which can be used but carefully, as the values you place into it reflect runes showing up in the hud.
[ Also it will have to be floated in a safe place , IE: .float items2; ]
32 = Resist
64 = Strength
128 = Haste
256 = Regen
I believe values < 32 and above 256 up to the max limit would be ok to store some new stuff, but I thought I remembered someone saying something weird happens to the hud if you do that, not sure...
Bfg
@Daya
Note you could also give that bfg ball a purple glow that may look pretty good since its purple already.
When it spawns, make its .effects field = EF_RED | EF_BLUE;
By the looks you are using Darkplaces engine is why I suggest it, if not it wont work.
Also looks like your beams from the orb pass through the targets they zap which is ok, but you could also pickup the end of the traceline where it contacts their hitbox using trace_endpos, then use that as the end point for the beam when you call the effect. I have done that with the Thunderbolt and spawned spark effects there. Not sure if you are already doing that, I didnt look at your code yet, but thought I would mention it.
Thanks Teknoskillz
#2007 posted by aDaya on 2016/02/06 09:59:34
But right now I'd like to focus on that sprites spawning problem and I can't find a damn solution about it. It shouldn't be that hard!
Speaking of which, how was Quoth able to make the explosion particles blue? I wanted to do that but it only made the vanilla explosion particles. And that EXPLOSION2 alternative make the impact look like water splashes.
And I plan for this mod to be playable on most clients (quakespasm, fitzquake and DP for starters) so making DP-only code wouldn't be a good idea.
The Endpoint Is Near?
#2008 posted by Preach on 2016/02/06 17:20:20
In BFG_Blast, it's important to remember that self is still the projectile, not the extra sprite you've spawned at the end of the lightning. This has an impact in two places
1) Where you have the following code...
WriteCoord (MSG_BROADCAST, self.origin_x);
WriteCoord (MSG_BROADCAST, self.origin_y);
WriteCoord (MSG_BROADCAST, self.origin_z);
...it is making sparks at the origin of self, i.e. the projectile, not the endpoint of the lightning. Change this to use org, the vector that you pass to the function.
WriteCoord (MSG_BROADCAST, org_x);
WriteCoord (MSG_BROADCAST, org_y);
WriteCoord (MSG_BROADCAST, org_z);
2) The following line of code is very subtle in its effect:
bfgblast1();
This is actually triggering a think function on self, when you want it to trigger on the newent you've created. Try something like
newent.nextthink = time + 0.01;
newent.think = bfgblast1;
This should improve things.
Quoth uses TE_EXPLOSION2 for the plasma effects, but where you use colour 246 we use 35. Bear in mind that there is a particle limit, and firing several explosions at the same time may well exceed it (you can also hit it if you gib enough monsters in a single second). An alternative would be to go down the lines of a canned mdl animation in the vein of
https://tomeofpreach.wordpress.com/2012/11/21/embers/
Obviously for the particles to be appropriate for a BFG it would need more than just a palette swap, but let me know if that would interest you...
The Explosion Particle For The Blast Now Appears
#2009 posted by aDaya on 2016/02/06 18:49:48
And the Blast sprites appears now, thanks to "setmodel (newent, "progs/bfgblst.spr");" (it was self instead of newent). Thing is, they appear at the target's foot. This maybe points to the origin. Another thing is that when the blast sprite shows up, it skips the first frame and plays it at the end of the animation. Does it has something to do with "newent.nextthink = time + 0.01;"?
The explosion sprite itself still doesn't appear though. I tried
self.nextthink = time + 0.01;
self.think = bfgexpl1;
Similarly to what you suggested for BFG_Blast, but no dice (tried both with self and bfgexpl).
Sprite Animation
Fimg comes in handy working with Sprites [ http://www.insideqc.com/frikbot/projects.php ]
But the issue you have might be because when the ent spawns, the frame by default is 0. So try starting it at frame 1 in the macro code. Otherwise open it up in Fimg, there could be an extra frame in there or the sprite file could be corrupted.
The Sprite File Wasn't Corrupted Or Anything
#2011 posted by aDaya on 2016/02/06 21:45:20
But I changed the animation cycle so that it starts at the last frame and cycles back to the beginning:
void() bfgblast1 = [4, bfgblast2] {};
void() bfgblast2 = [0, bfgblast3] {};
void() bfgblast3 = [1, bfgblast4] {};
void() bfgblast4 = [2, bfgblast5] {};
void() bfgblast5 = [3, SUB_Remove] {};
And the sprite animates properly now. Kind of wierd since the vanilla explosion sprite doesn't have that problem.
Again, Why Would The Blast Sprite Show Up Properly But Not The
#2012 posted by aDaya on 2016/02/07 00:57:40
explosion one? I can't find any issues.
Experiment
#2013 posted by Preach on 2016/02/07 01:07:25
Reset your code to start the frames from 0, then try swapping the filenames, renaming A to B and B to A. If it's still the one at the centre of the explosion which is skipping the first frame then we know the problem is in the code. If it starts being the the sprite on the blasts which is out-of-order then we know it's a sprite file issue.
#2014 posted by Shambler on 2016/02/07 22:56:26
A Quake C Exercise [EDIT]
Posted by Teknoskillz [73.142.34.180] on 2016/02/07 22:38:53
We seem to have alot of good QC coders here, so wanted to see if any are up to collaborating on a new modification for the gibs, where (and heres where its kinda gross :o) ) we give the gibs a .touch field and check for an impact against a solid where we look for vlen (self.velocity) > a certain value, and if its moving very fast and hits say the bsp, we do 1 of 3 things:
1) Make it stick partially in the wall or the ceiling. (sort of like the nails stick in walls mod)
(I believe I have played a Doom mod out there that does this)
2) Same as 1, but make it slide down and or maybe fall off the wall with a seperate think.
3) Create a "splat" effect , either using a new sprite which is sorta a flattened image of the original gib, or perhaps use a decal?
I have no knowledge of decals, not really sure if its possible to use QC for that, as it may be an engine only effect.
Some Answers
#2015 posted by Preach on 2016/02/08 00:01:33
1) Make it stick partially in the wall or the ceiling. (sort of like the nails stick in walls mod)
This is easy. Make this the .touch function of a gib
void() gib_touch =
{
��if(vlen(self.velocity) > 300 && other = world)
��{
����self.velocity = '0 0 0';
����self.movetype = MOVETYPE_NONE;
����self.avelocity = '0 0 0'
��}
}
2) Same as 1, but make it slide down and or maybe fall off the wall with a seperate think.
This will be a bit harder, and I don't think the request is fully specified yet. For example, what happens if the gib hits a ceiling? How about angled surfaces? Sloped up or down?
Regardless of the answers to these questions, there are some concerns which always apply. There's no simple way of determining the facing of the surface we collided with. We could try and traceline backwards but this may be inaccurate in corners. There's also a bug with MOVETYPE_BOUNCE entities moving down slopes just get stuck.
However, in the simple case where we have determined that we've hit a proper wall, one which is not sloped but perfectly vertical, you could probably simulate sliding down the wall quite well by setting self.velocity = '0 0 0' and self.gravity = 0.4.
3) Create a "splat" effect , either using a new sprite which is sorta a flattened image of the original gib, or perhaps use a decal?
Gonna pass on this, there's no actual decal support in normal engines, and there are loads of pitfalls in using sprites.
Preach
#2016 posted by necros on 2016/02/08 03:05:12
if(vlen(self.velocity) > 300 && other = world)
^_^;
|
|
You must be logged in to post in this thread.
|
Website copyright © 2002-2025 John Fitzgibbons. All posts are copyright their respective authors.
|
|