|
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. |
|
|
A Few Other Notes
#2631 posted by Esrael on 2018/07/26 00:08:34
Thunderbolt bugs relating to the "three beams"
I assume this bug isn't related to lightning attacks (both thunderbolt and shambler) being able to damage entities through walls? Also, hitchecks with the thunderbolt are kinda weird. (You probably know what I mean with that, but if you don't, just tell me, and I can explain in a reply.)
multiple megahealth rots down too quickly (double rot)
I had learned about this actually, when I tried to make a custom Doom-like health bonus item. My health would rot down super fast after having picked up like ten of those items! @~@ I actually thought that it was a feature, to make supercharged players less OP, or something. :D
targets not fired if the player doesn't take the item (e.g. already has max armour, touching armour should trigger a monster/something, but doesn't)
This is even more so arguable, whether it's a bug or not. I actually prefer it the current way. If I wanted to make 100 % sure about the targets being triggered when touching the item, I'd add a trigger_once brush or something.
(Also there are minor typos here and there in the list.)
@Johnny Law
Thanks. I wasn;t aware Preach had a version of his own. I'll most likely use Preach's 106 code when I dive back in. I am using FTEQCCGUI and Notepad++
#2633 posted by Tribal on 2018/07/26 00:36:39
@dumptruck
Last year muk0r put together a "clean QC source"... but the readme doesn't say if there is any bugfixes :(
http://www.quaketastic.com/files/Clean_QuakeC_Source.zip
but maybe (i said maybe because i don't know if you want these features) you should start with custents?
http://www.quaketastic.com/files/tools/windows/quakec/custents.zip
It seems to be a mix of all the cool features of the two official mission-packs, like: rotating brushes, earthquakes, particle fields, breakable walls, etc
@Tribal
Thanks for these links. I am looking at adding some of the custents features for sure.
#2635 posted by metlslime on 2018/07/26 01:04:17
I think the "same name texture" crash mentioned on that page is only in GLQuake and derived engines.
@esrael
#2636 posted by therektafire on 2018/07/26 02:04:05
I agree about the item not triggering it's targets if it hasn't been picked up, that is definitely not a bug, it makes total sense for an item to not do anything if the player touches it but can't interact with it for whatever reason, like if their ammo is full or they have full armor or they already have that type of key in their inventory. Not to mention that a vast majority of maps are designed around this mechanic one way or another, like key traps triggering when the player, you know, picks up the key or encounters that get triggered when you pick up a particular weapon or powerup like quad damage
Now if we're talking about keeping the player from picking something up if they already have enough of it that's another story, it would definitely be nice sometimes if some things like ammo or health only gave themselves to you if you actually needed that much, it would definitely help prevent wastefulness by picking them up on accident when you don't really need that much yet
@esrael
#2637 posted by therektafire on 2018/07/26 02:04:06
I agree about the item not triggering it's targets if it hasn't been picked up, that is definitely not a bug, it makes total sense for an item to not do anything if the player touches it but can't interact with it for whatever reason, like if their ammo is full or they have full armor or they already have that type of key in their inventory. Not to mention that a vast majority of maps are designed around this mechanic one way or another, like key traps triggering when the player, you know, picks up the key or encounters that get triggered when you pick up a particular weapon or powerup like quad damage
Now if we're talking about keeping the player from picking something up if they already have enough of it that's another story, it would definitely be nice sometimes if some things like ammo or health only gave themselves to you if you actually needed that much, it would definitely help prevent wastefulness by picking them up on accident when you don't really need that much yet
Cleaned Up Code
#2638 posted by Preach on 2018/07/26 14:30:45
I should mention that the changes in the cleaned up code are only to eliminate compiler warnings, there aren't any bug fixes or behaviour changes. Just wanted to set the right expectations for it.
@Preach
Thanks for the clarification. I am still very much in the copy and paste fingers crossed stage of qc. I believe c0burn wants to release a bug smashed version of the code eventually. That's a great project IMO.
#2630
#2640 posted by madfox on 2018/07/26 23:08:49
Result is that a player in fight with an Axe_ogre will get pissed. If player is shot from distance, the ogre won't walk to the player's body.
@madfox
#2641 posted by Spike on 2018/07/27 03:18:25
the point of doing it in ai_run is that:
a) self is the ogre that should do the widdle. there is absolutely no need to call find (because you can just use self). there is no need to loop etc (each monster will call the function at some point anyway).
however, you really ought to only do that logic if self.classname is actually what you expect. you don't really want scrags trying to widdle.
b) the player that its trying to urinate on is already stored inside self.enemy. This means that you don't need a seperate leakentity field - just use self.enemy! (do note that you'll want to avoid the self.enemy=world line if the ogre is meant to start widdling.)
@Spike
#2642 posted by madfox on 2018/07/28 23:30:09
Thanks for your answer. Sorry I'm such a noob at coding.
If I use the self argument, how do I make it fit in?
As it is an experimental src, so maybe it is better to show an example
of what I am trying to do.
MF_Qtest00
Heh
#2643 posted by spy on 2018/07/29 08:45:22
here's a demo of Qtest
the main problem, the "new" monsters seem too much overpowered (especially vomitus)
noticed a couple of issues, check the demo
http://quaketastic.com/files/demos/spy_MadfoxQtest_demo.rar
Queer Queen
#2644 posted by madfox on 2018/07/29 11:49:57
Just finished a nice trick to change the serpent into a quaddam.
But don't touch it, cause it lives.., a bit husling with the skin file.
Yes, the src has a MISSILE weaponcode for each monster,
wizard is also much too strong. Number code for weapons won't work. Still beta.
Thanks for the demo, I'll look at it!
@Spy
#2645 posted by madfox on 2018/07/30 03:38:13
You made your way quiet advanced on hard skill. Spy.
The missing sounds are qc depended.
I turned a bit strayed with the qtest.qc. adding the monsters,
especially the dragons, caused a lot of changes.
I assume the forced demo end had something to do with crashing,
it is still beta version, already glad it runs.
Thanks for taking your time.
Partial Cross Post
I am just getting started "cutting and pasting" QuakeC. I followed Preach's revised tutorial on monster spawning here:
https://tomeofpreach.wordpress.com/2017/10/08/teleporting-monsters-flag/
I'd like to add a small random delay automatically to each teleporting monster as you can do in Quoth. I am using custents multiple triggers to trigger these delays spawns. Similar to Quoth, it would be nice to have a little variation on the timing if the monsters all share a targetname.
I've tried a few things already, being exceedingly cautious not to mess up this code I can barely comprehend. I'm wondering if anyone would like to give me a hint of how to approach this little addition.
#2647 posted by Qmaster on 2018/07/31 21:53:23
Add a new function:
void monster_teleport_delay () {
self.think = monster_teleport_go;
self.nextthink =time + self.wait; // or self.delay if you prefer that
};
Then in your monster_teleport() function change self.use to be monster_teleport_delay; instead of monster_teleport_go.
DISCLAIMER: Untested.
@qmaster
thank you for the help... I will try this after work this evening!
@qmaster
Newb question: would this mean I need to add a wait or delay key value to the entities? I don't mind setting it manually but wanted to know if this is how this method works.
Alternative
#2650 posted by Preach on 2018/07/31 22:48:50
If you don't want to set a wait value manually, instead of using self.wait in that code you can generate a random number between 0 and 1 using random() instead.
Can you see how to adapt the code to use random to create a delay of between 0 and 1 seconds?
How about a delay between 0 and 2 seconds?
What about between 0.5 and 1 seconds?
...
#2651 posted by Preach on 2018/07/31 22:49:42
Obviously I posted that before reading the other thread.
@Preach
No worries thanks for the great tutorials. I am enjoying messing around with QC finally. Next, I am going to try and figure out a silent spawn without the tfog and audio next. I think I can do it.
//
#2653 posted by Qmaster on 2018/08/01 01:19:52
Decision Made!
After trying to implement random timings I felt it better to go with self.delay. More work but more control for the mapper. Thanks everyone!
Te_lightning, Etc
#2655 posted by c0burn on 2018/08/06 21:53:07
/*==========
te_lightning
==========*/
void(vector v1, vector v2) te_lightning =
{
WriteByte (MSG_BROADCAST, SVC_TEMPENTITY);
WriteByte (MSG_BROADCAST, TE_LIGHTNING1);
WriteEntity (MSG_BROADCAST, world);
WriteCoord (MSG_BROADCAST, v1_x);
WriteCoord (MSG_BROADCAST, v1_y);
WriteCoord (MSG_BROADCAST, v1_z);
WriteCoord (MSG_BROADCAST, v2_x);
WriteCoord (MSG_BROADCAST, v2_y);
WriteCoord (MSG_BROADCAST, v2_z);
};
Writing some TE_ helper functions has gotten me curious. WHY is there an entity parameter needed for the lightning, beam, etc? Is it safe to just write world?
|
|
You must be logged in to post in this thread.
|
Website copyright © 2002-2025 John Fitzgibbons. All posts are copyright their respective authors.
|
|