|
#15558
#15567 posted by metlslime on 2015/11/18 01:17:32
qbsp is supposed to calculate the physics bounds of each brush model. The engine fix for this bug would be to ignore the bounds in the .bsp and calculate your own. The tools fix is to calculate bounds correctly in qbsp. The mapper fix is to add a visible brush at opposite corners, hopefully inside other geometry so you don't see them.
Skip That
#15568 posted by Preach on 2015/11/18 01:18:13
No, I want the effect of clip for what I have in mind. Visibility isn't a problem because I can turn that off with QC, but I want attacks and traces to pass through and only large entities to be blocked.
Prog Hacks
#15569 posted by Preach on 2015/11/18 01:20:32
Hi DW, I have a collection of posts on my site which answer several of your questions
https://tomeofpreach.wordpress.com/category/map-hacks/
In particular, the following post is a guide to which functions you can/should use:
https://tomeofpreach.wordpress.com/2012/11/18/mid-map-entity-spawning/
and this one deals with building triggers:
https://tomeofpreach.wordpress.com/2013/05/13/build-your-own-trigger/
Which Function 2015
#15570 posted by Preach on 2015/11/18 01:28:17
Revisiting that first post, it actually doesn't say as much as I thought it did about which functions you can use.
In a technical sense any QC function can be used. However, if the function takes parameters they will end up uninitialised, which rarely works well, so usually those functions should be avoided.
Which ones are useful is a bit more of a different matter - it's really down to what you're trying to accomplish. The following post has a bit of a guide on how I go about locating a useful function in the code and turning it into a functioning hack:
https://tomeofpreach.wordpress.com/2014/10/07/nightmare-skill-detection/
#15571 posted by necros on 2015/11/18 02:28:49
sorry, what i said is not entirely correct. the engine only calculates collision within the bounding box.
so as metl is saying, it can be either side's fault.
the engine is a little lazy on how it decides to calculate collision, but the tool is just wrong in calculating the bounding box.
CAGE FIGHT!
#15572 posted by metlslime on 2015/11/18 04:13:50
i don't think it's lazy to trust the data coming from the map compiler. It just turns out to be wrong.
#15573 posted by ericw on 2015/11/18 04:45:52
I can take a shot at fixing this in tyrutils-ericw, or at least add it to the todo list. It might be something that is easy to fix, given a test case.
Dynamic Light Maphack
#15574 posted by Text_Fish on 2015/11/18 11:06:34
Is there a maphack I can do to turn on a dynamic light (much like the power-up glow or weapon flashing) attached to the player, that gets triggered during play and lasts until triggered again or until the end of the map?
I'm mapping for Quoth btw. I know there's a torch powerup available but I'd prefer a pool of light to a spotlight, and I don't want the player to be able to turn it off himself.
Prog Hacks
#15575 posted by DeeDoubleU on 2015/11/18 11:20:30
I found your site while searching for info, Preach. Read most of the map hacks articles. I especially liked sad story of info_notnull that thought it is a real shambler 8)
Great info, even though at least half of it is too advanced for me at the moment. Another thing that makes my life harder is editor behavior.
For example, I tried to recreate activated door from Dynamic Entity Spawning and it didn't work (as I described in 2nd question). Well technically it worked, but not in a way it supposed to - activator-button opened door and activated trigger ignored me.
Today I opened my test map and same setup works as it should without me changing anything.
Few other things happened.
All entities with info_notnull and InitTrigger classnames had their position and size reset. Remember I wrote about suspicious "-64 0 0" origin? Well, now it is correct since entity crawled to the center of the world over the night.
As for what I'm trying to accomplish, I had that weird idea of trigger_push that pushes player only while he is facing specific direction. Realized that movement and view direction both use 'angle'. Got confused and tried to make something simpler.
So far I can recreate trigger_push behavior and trigger_multiple with angle, but not mixed together.
Some Combo
#15576 posted by Preach on 2015/11/19 00:07:19
I think that might be a difficult combo to create. One of the barriers is that the "movedir" field is used by both type of entities to determine the direction of travel/activation. The bigger one is that the code which decides if you are facing the correct way to activate a trigger doesn't really depend on any other properties of the entity - it's hard-coded to call multi_trigger.
So if my heart was set on it, I'd probably accept I need to just have a conventional "facing trigger" activating some kind of hacked entity which pushes the player, and can be toggled on and off. I've never seen anyone create a trigger which can be switched on and off an arbitrary number of times before, the "spawn a trigger" was a state-of-the-art trick, but only good for one shot. But now I wonder if there might be a way...
The idea would be to create a moving trigger! I think the door functions are the best bet for this. An important detail is that we get actual instant teleportation if we make set the speed high enough, which will probably save us worries about movetype. Then you have a position far outside the map for the trigger to sit idle, and a target position for it to jump to when triggered. Use the door TOGGLE spawnflag value (32) so it doesn't auto-return and it might just work.
This is just a theoretical plan right now, but if it works then it's a really huge hack idea with a wide number of applications. So when I get a chance tomorrow I'll try to see if it can be made to work.
#15577 posted by necros on 2015/11/19 01:08:27
hmm, will a trigger generate a touch if it teleports over an entity? (eg: with setorigin) i think you need force retouch?
Some Combo
#15578 posted by DeeDoubleU on 2015/11/19 10:38:02
"movedir". Yeah, that's what confused me too.
Maybe it still possible if we accept that this trick will always push and trigger using same direction?
I tried to activate different variations of pushing entity and failed. Maybe I'm doing something wrong (still a noob), but it looks like push trigger only works directly and does nothing when triggered by anything except for player.
#15579 posted by khreathor on 2015/11/19 13:44:48
It's good to take a look at QC sources to figure out why something is not working.
For example "counter trigger" won't message "Only 3 more to go..." etc. when the activator is not player...
if (activator.classname == "player" && (self.spawnflags & SPAWNFLAG_NOMESSAGE) == 0)
Now I'm looking for some workaround, so monster killing each other can "fire" message in counter.
Toggleable Trigger_push
#15580 posted by Preach on 2015/11/20 01:00:21
Hey DeeDoubleU, this one's for you.
https://tomeofpreach.wordpress.com/2015/11/19/toggleable-trigger_push/
It gets you a trigger_push hack which can be turned on and off an arbitrary number of times. You'll still have to do a bit of the heavy lifting here, useing a conventional "facing detector" trigger to turn it on. You may have to play around with the best way to make this work, some suggestions to try:
* Get rid of the TOGGLE spawnflag, so the trigger naturally returns to "closed" after a short time, and only constant retriggers from the facing detector will keep it in place
* Keep the TOGGLE, but have a trigger_relay which resets it at the same rate that the facing detector is reactivated
* Keep the TOGGLE, and have a pair of overlapping, opposite facing detectors. One triggers to turn the pusher on, and the other facing turns it back off.
To Khreathor
#15581 posted by Preach on 2015/11/20 01:11:24
You're next in the queue! I like this hack so much I'm going to use it to fix your problem too! But it's bedtime now so it may take a little while until I get a chance.
TextFish: Have you tried a slient, rapidfire https://tomeofpreach.wordpress.com/quoth/tutorial/info_trap/ targeting the player through the floor? That sounds pretty hacky to me! There's probably a way to create a follow spot in just regular quake using an info_notnull, the effects flags, and the ShalHome function.
It's also interesting that both of you have asked a question which the aside in https://tomeofpreach.wordpress.com/2015/11/18/selective-clipping/ is very relevant to. Who does the spotlight follow if there are no players connected? In coop, which one of the players do you want to give the "3 more to go..." message to?
Preach
#15582 posted by khreathor on 2015/11/20 04:02:25
Thanks for your help! I already tried few combinations with "enemy" key. I finally got it working. Problem was I forgot to set "wait" ;)
So I have connected enemies to info_notnull, which triggers counter every time enemy dies with "enemy" key set to 1, so it always blames player ;D
Here is an example:
{
"classname" "info_notnull"
"angles" "-0 0 -0"
"target" "counter"
"targetname" "count_enemies"
"use" "multi_trigger"
"enemy" "1"
"wait" "0.01"
"origin" "400 472 0"
}
Thanks Preach.
#15583 posted by Text_Fish on 2015/11/20 14:15:37
My idea isn't worth abandoning Quoth for and it sounds like the info_trap would be very reliant on the player remaining as low as possible in the map (limiting the use of bridges and multi-story buildings etc.), so I think I'll need to put it on the back-burner until I can think of another solution!
@Preach And Others
#15584 posted by DeeDoubleU on 2015/11/20 16:44:58
I feel like I'm missing some fundamentals. Some details that no one ever mentions because it's basic stuff.
Finally figured out that I need to add keys in text editor and compile with .bat file, since editor "fixes" non-standard entities on map save/open and build.
Is there easier way to do this - some set of handy utils or hack-friendly editor?
Preach, maaaan they should teach about you in school.
Togglable push trigger works, though I can't implement your suggestions properly.
I can't make push-door go down on its own. It's either constantly going on and off dropping player a bit during each 'off' phasse or never goes down.
If We Talk About Basics
#15585 posted by khreathor on 2015/11/20 16:56:43
http://quakewiki.org/wiki/Map_based_hacks
But you must remember those are hacks, so you just exploit existing functions. That means: if you want to make some complex stuff, you need to write your own scripts in QC.
#15586 posted by metlslime on 2015/11/20 18:23:59
some editors don't "fix" entities like that, so you might try other editors -- or talk to the developers here if it's trenchbroom or jackhammer.
What Do You Mean, Fix
#15587 posted by SleepwalkR on 2015/11/20 18:41:57
You mean that the editor clears out any properties that weren't in the .def or .fgd file? I don't think TrenchBroom does that, and if it does, it shouldn't and I will fix it.
It Doesn't As Far As I Know...
#15588 posted by ijed on 2015/11/20 20:01:27
I tend to prototype stuff without adding it to my fgd.
But I'm still on the last TB1 and only put stuff in TB2 to test.
If/when I map again I'll update to all the latest tech.
It's GtkRadiant.
#15589 posted by DeeDoubleU on 2015/11/20 20:02:24
It doesn't remove any keys or values, but if I create trigger that has actual volume and then change it's class to info_notnull - load/save/build would clear brush info from that entity and add origin instead.
Was wondering how you guys do it and hoped someone knows another way except making all hack related stuff last [in notepad] and never modify and save map in editor again.
#15590 posted by metlslime on 2015/11/20 20:49:53
oh yeah, there is the problem of trying to use info_notnull as a brush entity and a point entity in the same map. If you only want brush entities you can just change it in the .def file, but if you want both you can't.
Probably the best solution with the tools we have is to create a info_notnull2 which allows brushes, then add to your batch file some kind of step that does a search and replace with info_notnull2 to info_notnull.
#15591 posted by negke on 2015/11/20 20:55:16
Radiant only supports an entity classname to be either point- or brush-based. By default the definitions make info_notnull a point entity, so the editor converts it once you rename it.
There's no solution, only a workaround: I changed the def file so that info_notnull defaults to being a brush-based entity which then works for trigger volumes and such. It's still possible to make point-based info_notnulls by creating some point entity and renaming the classname afterwards; however, it will not show up in the editor views and can only be accessed/edited from the entity list ("L"). Pretty awkward.
|
|
You must be logged in to post in this thread.
|
Website copyright © 2002-2025 John Fitzgibbons. All posts are copyright their respective authors.
|
|