Terraincast
terraincast(world_position, terrain_entity, height_values=None, return_normals=False)
Uses the X and Z of world_position to look up the corresponding Y on a terrain mesh.
Parameters
| Name | Type | Default | Description | 
|---|---|---|---|
| world_position | Vec3 | — | Position in world space. | 
| terrain_entity | Entity | — | Entity using a Terrainmodel. | 
| height_values | list | None | Raw height map data; if Noneit’s taken from model. | 
| return_normals | bool | False | If True, also return surface normal at that point. | 
Example
from ursina import *
from ursina.terraincast import terraincast
app = Ursina()
terrain = Entity(
    model=Terrain('heightmap_1', skip=8),
    scale=(40,5,20),
    texture='heightmap_1'
)
player = Entity(model='sphere', scale=.2, origin_y=-.5, color=color.azure)
def update():
    move = Vec3(held_keys['d'] - held_keys['a'], 0, held_keys['w'] - held_keys['s']).normalized()
    player.position += move * time.dt * 4
    y = terraincast(player.world_position, terrain, terrain.model.height_values)
    if y is not None:
        player.y = y
EditorCamera()
app.run()