Page 1 of 1

How can i detect unit is fully underwater?

Posted: 21 Dec 2010, 18:09
by slogic
I could use GetUnitDefHeight() & unit position. But i do not know where is the center of unit. Engine somehow can detect a unit can't shoot when being under water.

Re: How can i detect unit is fully underwater?

Posted: 21 Dec 2010, 20:08
by hoijui
as much as i know, the shooting ability depends on some position of the weapon being underwater or not (don't know the name if the point).

Re: How can i detect unit is fully underwater?

Posted: 22 Dec 2010, 01:07
by aegis
yep, hoijui is right (it was actually possible to shoot from the water with units underwater that couldn't be seen)

you can get a unit's full 3d position in lua

Re: How can i detect unit is fully underwater?

Posted: 22 Dec 2010, 12:05
by slogic
There is no place for lua in C++ AI API.

I don't get one thing. Why BA's sonar station (armsonar) is floating & underwater metal maker (armuwmmm) is placed at the bottom without typical differences in their .fbi files? They both do not have waterline tag set (waterline = 0) and thus for both "floater"= false? Is it hardcoded in engine for building when its "sonarDistance" <> 0? I suspect this because for floating metal maker (armfmkr) there is "waterline" tag set which is logical and provoke no questions.

Re: How can i detect unit is fully underwater?

Posted: 24 Dec 2010, 00:12
by Kloot
But i do not know where is the center of unit
It's safe to consider pos.y the lowest point on a unit's model.
I could use GetUnitDefHeight() & unit position
You would still not be able to detect submarines (I assume that was the point of this question) reliably. Eg. for BA's armsubk, pos.y + height > 0 because its waterline is too small. Even the engine does not know if a unit is intended to be a submarine or a regular ship (game devs can only give it a hint in that regard, see MoveData::subMarine).
Why BA's sonar station (armsonar) is floating & underwater metal maker (armuwmmm) is placed at the bottom without typical differences in their .fbi
They are both placed at the bottom, armsonar can just be built in shallower water (minWaterDepth=10) than armuwmmm (minWaterDepth=15) so it will stick out above the surface more often.

Re: How can i detect unit is fully underwater?

Posted: 24 Dec 2010, 11:37
by slogic
Kloot wrote:It's safe to consider pos.y the lowest point on a unit's model.
I thought it is the center of the model usually.
Kloot wrote:You would still not be able to detect submarines
Yeah, i already decided to use different algorithms for units with movedef & without. Results are fine at least for BA. The only faulty detected units are Seaplane Platforms because they are both floating and underwater.

I discovered one more reliable way. Any unit has a hit sphere. For now i don't know if GetUnitDefRadius() gives me hit sphere or smth another (can you clear up it?). So, gamedev designs a unit according to its gameplay purposes. If unit is intended to be submarine its hit sphere should not be visible outside the water. So, checking hit sphere it a sensible way to go.
Kloot wrote:They are both placed at the bottom...
Just checked this. You're right! I was under deep influence by OTA!

Re: How can i detect unit is fully underwater?

Posted: 24 Dec 2010, 15:07
by Kloot
I discovered one more reliable way. Any unit has a hit sphere. For now i don't know if GetUnitDefRadius() gives me hit sphere or smth another (can you clear up it?). So, gamedev designs a unit according to its gameplay purposes. If unit is intended to be submarine its hit sphere should not be visible outside the water. So, checking hit sphere it a sensible way to go.
That won't always work either. GetUnitDefRadius returns the radius of the model, which is auto-calculated by Spring for some model types and set manually by the modeller for others (units that do not have a defined custom collision primitive use this radius to scale their hitspheres). As an example of what to expect, see:
subs1.png
(1.09 MiB) Downloaded 3 times

Re: How can i detect unit is fully underwater?

Posted: 27 Dec 2010, 12:01
by knorke
maybe GetUnitDefHeight() ?

Re: How can i detect unit is fully underwater?

Posted: 27 Dec 2010, 14:14
by slogic
Re-read the first post.