Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Physics module #17

Open
StN-NL opened this issue Oct 31, 2024 · 9 comments
Open

Physics module #17

StN-NL opened this issue Oct 31, 2024 · 9 comments

Comments

@StN-NL
Copy link

StN-NL commented Oct 31, 2024

Hello, using the physics module with cliffs only works fine (a bit ugly though), but when using height instead of cliffs (terrain tool), units start to float (cliff level 0) or objects fall below the surface (higher cliff levels). This is expected?

@Frotty
Copy link
Owner

Frotty commented Oct 31, 2024

No, that is not expected. The system works on terrain height, there is no difference between cliffs and terrain tool height. Also, not sure what you mean by "ugly". Post a reproducible example.

@StN-NL
Copy link
Author

StN-NL commented Oct 31, 2024

When I say ugly I am just referencing the terraining crowd (point A): https://www.hiveworkshop.com/threads/advanced-terraining-tutorial.203428/

This is the map: https://github.com/StN-NL/sheepz

The default map is a tropical island (the one in the top left):

  1. Running the default setup you will see the sheep is floating, especially near the beach (global cliff level 0)
  2. If you then in the World Editor > Advanced > Adjust Cliff Levels > +2
  3. The sheep is no longer floating but missiles are going underground (press F to get access to missiles)

Alternatively, using only cliffs, where everything works just fine:
4. comment lines 747-749 from GameMenu.wurst
5. uncomment lines 750-750 from GameMenu.wurst
6. this will change the playable coordinates to a different "map" (the purple one in the center) which uses cliffs only

Hope this makes any sense, let me know if you need more info.

@Frotty
Copy link
Owner

Frotty commented Oct 31, 2024

It's not really feasible for me to check an entire map's unknown to me script for this specific error, there could be many side effects coming from all kinds of places.
I created a minimal example which I think is similar to what you're looking for, a unit that falls down, stays on the ground, but can jump. It seems to work fine for me on a map with smooth hills with negative and positive z values:

package Usage
import EntityManagement
import Projectile
import Heightmap
import PhysicsEntity
import ClosureKeyPresses

class TestUnitEntity extends UnitEntity
    use PhysicsModule

    construct(vec3 pos)
        super(createUnitZ(players[0], 'hfoo', pos, angle(0)), pos)
        print(GetObjectName(0))
        sleeps = false

        onKeyPress(OSKEY_B) ->
            addVel(actor.getFacingAngle().toVec(10).withZ(25))


    override function update()
        super.update()
        physicsUpdate(this)
        print(pos.toString())


init
    new TestUnitEntity(ZERO2.withHeightMap(256))

    startEntityLoop()

Only thing from a short look over your code I saw is that you call physicUpdate before update, it should be after. But that's not the cause of the problem.
Since this works, I am quite certain the problem is in your code.

So, please create a similar small example to reproduce the issue if you want me to analyze it further.

@stijn-nefkens
Copy link

stijn-nefkens commented Nov 1, 2024

If you were to run your code using my map Sheepz.w3x you will find your footman is floating near the shores.

Only modification needed to land it on the island:

new TestUnitEntity(vec2(-8000, 8000).withHeightMap(256))

This might be an issue with the map itself then, and I might try to remake it.

Maybe a by-effect of resizing the map.

EDIT: it is definitively an issue with the map file. Sorry for bothering you with this. I created a new map and it seems to work fine.

@Frotty
Copy link
Owner

Frotty commented Nov 1, 2024

No problem. Perhaps it's an issue if you change cliff level with water or something, making the height values not be correct.
Can this issue be closed then?

@StN-NL
Copy link
Author

StN-NL commented Nov 3, 2024

Unfortunately recreating the map first caused me to think it worked as I placed the island in a different position.

But when I moved it back to the topleft the same issue reappeared.

To pinpoint the issue I created maps of several sizes with cliff level 4 just to have initial height.

Then I started clicking around to see visualize the heightmap using:

package Test
import ClosureEvents
import FText
import Heightmap

function getMousePos3() returns vec3
    let x = EventData.getPlayerMouseX()
    let y = EventData.getPlayerMouseY()
    let z = vec2(x, y).getHeightMap()
    return vec3(x, y, z)


init
    FogMaskEnableOff()
    FogEnableOff()

    EventListener.add(EVENT_PLAYER_MOUSE_DOWN) ->
        let pos = getMousePos3()
        flashEffect("Abilities\\Spells\\NightElf\\TrueshotAura\\TrueshotAura.mdx", pos)
        createFText(pos.toVec2().toVec3(), pos.toString(), 10, 10, ZERO2)

Turns out that the larger the map the smaller the heightmap coverage. The surface that is not covered is for the higher Y values. It seems that the maximum area covered by the heightmap is 268,435,456 or 16,384 tiles (128x128).

To reproduce:

  1. create a new map where:
  • size 192x192 or bigger,
  • initial cliff level is 4 (anything other than 2)
  1. delete melee initialization trigger
  2. save map
  3. run with the above script
  4. click moving the screen up until Z always becomes 0.0

@Frotty
Copy link
Owner

Frotty commented Nov 4, 2024

Ok, I see, so it's due to max array size in Jass. Lua wouldn't have this problem, but it has many others 😄 .
With the 32768 max size the heightmap can only cover 181x181 tiles, and it starts in bottom right corner, so in the top part of the map the index exceeds 32768. I guess I never made such a big map that the issue would come up.
Also, the heightmap is a somewhat recent addition in order to prevent desyncs due to terrain deformations and such.
I kept it to a single array for performance’s sake, but I guess if you want to support larger sizes it would require some splitting up or reverting to using regular terrainZ instead, could add an option for that.

@StN-NL
Copy link
Author

StN-NL commented Nov 4, 2024

Ok, I will reduce the map size for full coverage, sounds like the best approach here. Feel free to close. Before I forget, thanks for Wurst ;)

@Frotty
Copy link
Owner

Frotty commented Nov 5, 2024

Well not the best but the fastest workaround I guess. I can add something if I get the time. Enjoy your Wurst.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants