News | Forum | People | FAQ | Links | Search | Register | Log in
Mapping Help
This is the place to ask about mapping problems, techniques, and bug fixing, and pretty much anything else you want to do in the level editor.

For questions about coding, check out the Coding Help thread: https://www.celephais.net/board/view_thread.php?id=60097
First | Previous | Next | Last
Iris Doors 
How do they work?

Rotating? If so, screw it :)

I've seen them in Quake but can't remember where... 
Bah 
Looks like it does work by rotating objects. Has anyone seen a non-rotating version? 
Iris 
I wonder if you can cheat. If you had two pairs of doors, one opening vertically and the other opening horizontally directly behind them, you'd end up with a square hole as you opened them. If you extended this idea to four pairs (and presumably made the doors fairly thin) you could make an octagon which might look quite iris like. 
Yeah 
that's kind of what I was thinking...

Will post any experiments that work. 
Iris Doors... 
don't need rotating, each slice just moves in a straight line. I think one of the IKBlue levels has this. 
That Sound About Right 
With pie slice floor texture.

I think it can't work vertically though, only horizontally. 
Iris Example 
And For Not QOOLE Users 
Re 9743 
that's not a real iris though. a true iris has pie shapes that rotate outwards.

http://www.youtube.com/watch?v=rskukxKo5UI

but yeah, what preach said works pretty good and looks really cool when opening and has the benefit of working as a vertical door. a lot of sci fi use doors like that. 
Sweet 
yeah you guys were right, it was just the spaces in the texture names. Awesome now I can finish these maps. Yay! Now here's the situation I'm in. I'm using the Nexiuz textures, the originals are 2x the size of the recent Q1 conversion ones, so I want to keep with the originals since otherwise my texturing will be messed up everywhere. I guess my question is, what would be the best way to replace the spaces in the names of the textures in the original wads with _'s, or, is there a Nexiuz texture wad available for Quake with all the textures in the original sizes? 
 
just run them through irfanview to shrink them, it's free :) 
Search/replace 
Wordpad. Or, if the map file is too large for it, a text editor like Notepad++ for example. 
All Your Bases Are Belong To Notepad++ 
 
Alright 
fixed the texture names, now I just need to convert (some of) the original nexiuz textures to the Q1 palette in their original sizes. What's the best program to do this? 
Or 
if anyone wants to do me the favour of converting these textures you'll be rewarded with a couple new Q1SPs, heh. 
Texture Conversion Tool 
TY 
now go invent some other weird creepy sneaky Q1SP stuff :) 
Weird Question 
what is the formula to calculate the maximum distance a sound can be heard?

i don't think volume plays any part in it, just attenuation.

i have some looping sounds that may start when the player is beyond hearing range. if this happens, the engine doesn't register the sound as playing so i need to continuously check if the player is entering hearing range, but the check is done on multiple types of entities with different attenuation values, so i can't just use a flat range. 
You're 
On a higher level than me. But from that question my advice would be change engine. 
 
ask LordHavoc, Spike, mh or metlslime?

The problem where Quake stops playing sounds when the player is out of range (and continues them weirdly when he returns), is, er, a problem. 
 
whoah, we made a good show here. 
 
what is the formula to calculate the maximum distance a sound can be heard?

I never figured this out, in the end i just experimented with different distances until i found one that seemed right. 
 
i asked on inside3d, so we'll see. :)

i just experimented with different distances

i would do that if it was only one sound, but i will have multiple sounds at multiple attenuations, and it would be unlikely that i could guesstimate all differences accurately. 
Sound Thinking 
We can pick atten to lie between 0 and 4. The engine now defines:

nom_atten = atten / 1000

dist = nom_atten * length(sound.origin - player.origin);

So the crucial thing here is to notice how the attenuation affects the distance.
Attenuation 2 samples are effectively twice as far away as attenuation 1 sounds.
Attenuation 0 sounds are always treated as distance 0 away.

The next thing you need to know is that the volume is multiplied by
( 1 - dist) * rscale in the right ear and (1 - dist) * lscale in the left ear.

rscale is equal to 1 + v_right*normalise(sound.origin - player.origin)
lscale is equal to 1 - v_right*normalise(sound.origin - player.origin)

Don't worry too much about what rscale and lscale mean, just be aware that they are never negative and sum to 2.

We need to compute when both the left and right ear go to zero volume, as in that case the sound is not played.
We know that lscale and rscale are never both equal to 0. So the only case we need to think about is

1 - dist <= 0

this implies that
dist >= 1
so
nom_atten * length(sound.origin - player.origin) >= 1

atten * length(sound.origin - player.origin) >= 1000

It is best to keep the inequality in this form, so that you don't have to worry about dividing by 0 if either the attenuation or the length go to zero.

In real terms, this means a sound with attenuation 1 is audible 1000 units away, attenuation 2 is 500 units away, etc. 
You Are A Quake Hero 
 
First | Previous | Next | Last
You must be logged in to post in this thread.
Website copyright © 2002-2025 John Fitzgibbons. All posts are copyright their respective authors.