diff --git a/docs/index.html b/docs/index.html index 714c6a23d..acf52603f 100644 --- a/docs/index.html +++ b/docs/index.html @@ -1164,6 +1164,9 @@
  • spawn_tree
  • +
  • + spawn_unrolled_player_rope +
  • @@ -4720,7 +4723,7 @@

    Shop functions

    add_item_to

    Search script examples for add_item_to_shop

    -

    nil add_item_to_shop(int item_uid, int shop_owner)

    +

    nil add_item_to_shop(int item_uid, int shop_owner_uid)

    Adds entity as shop item, has to be movable (haven't tested many)

    change_diceshop_prizes

    @@ -4982,8 +4985,14 @@

    spawn_tree

    Search script examples for spawn_tree

    -

    nil spawn_tree(float x, float y, LAYER layer)

    nil spawn_tree(float x, float y, LAYER layer, int height)

    +

    int spawn_tree(float x, float y, LAYER layer)

    int spawn_tree(float x, float y, LAYER layer, int height)

    Spawns and grows a tree

    +

    spawn_unrolled_player_rope

    +
    +

    Search script examples for spawn_unrolled_player_rope

    +
    +

    int spawn_unrolled_player_rope(float x, float y, LAYER layer, TEXTURE texture)

    int spawn_unrolled_player_rope(float x, float y, LAYER layer, TEXTURE texture, int max_length)

    +

    Spawns an already unrolled rope as if created by player

    String functions

    add_custom_name

    Search script examples for add_custom_name

    @@ -6520,7 +6529,7 @@

    Ai

    int whipped -How many times master has violated us +Number of times whipped by player

    Animation

    @@ -6533,6 +6542,11 @@

    Animation

    int +id + + + +int first_tile @@ -6553,6 +6567,63 @@

    Animation

    EntityDB

    +

    Used to store static common data for an ENT_TYPE. You can also clone entity types with the copy constructor to create new custom entities with different common properties. This tool can be helpful when messing with the animations. The default values are also listed in entities.json.

    + +
    +

    When cloning an entity type, remember to save it in the script for as long as you need it. Otherwise the memory will be freed immediately, which eventually leads to a crash when used or overwritten by other stuff:

    +
    +
    -- Create a special fast snake type with weird animation
    +special_snake = EntityDB:new(ENT_TYPE.MONS_SNAKE)
    +special_snake.max_speed = 1
    +special_snake.acceleration = 2
    +special_snake.animations[2].num_tiles = 1
    +
    +set_post_entity_spawn(function(snake)
    +    -- 50% chance to make snakes special
    +    if prng:random_chance(2, PRNG_CLASS.PROCEDURAL_SPAWNS) then
    +        -- Assign custom type
    +        snake.type = special_snake
    +        -- This is only really needed if types are changed during the level
    +        snake.current_animation = special_snake.animations[2]
    +    end
    +end, SPAWN_TYPE.ANY, MASK.MONSTER, ENT_TYPE.MONS_SNAKE)
    +
    +
    +

    You can also use Entity.user_data to store the custom type:

    +
    +
    -- Custom player who is buffed a bit every level
    +set_callback(function()
    +    -- Doing this to include HH
    +    for i,v in ipairs(get_entities_by_mask(MASK.PLAYER)) do
    +        local player = get_entity(v)
    +
    +        -- Create new custom type on the first level, based on the original type
    +        if not player.user_data then
    +            player.user_data = {}
    +            player.user_data.type = EntityDB:new(player.type.id)
    +        end
    +
    +        -- Set the player entity type to the custom type every level
    +        player.type = player.user_data.type
    +
    +        -- Buff the player every subsequent level
    +        if state.level_count > 0 then
    +            player.type.max_speed = player.type.max_speed * 1.1
    +            player.type.acceleration = player.type.acceleration * 1.1
    +            player.type.jump = player.type.jump * 1.1
    +        end
    +    end
    +end, ON.POST_LEVEL_GENERATION)
    +
    +
    +

    Illegal bad example, don't do this:

    +
    +
    set_callback(function()
    +    -- Nobody owns the new type and the memory is freed immediately, eventually leading to a crash
    +    players[1].type = EntityDB:new(players[1].type)
    +    players[1].type.max_speed = 2
    +end, ON.POST_LEVEL_GENERATION)
    +
    @@ -6561,6 +6632,16 @@

    EntityDB

    + + + + + + + + + + @@ -15715,6 +15796,11 @@

    Entity

    + + + + + @@ -19935,6 +20021,11 @@

    CustomMovableBehavior

    + + + + + diff --git a/docs/light.html b/docs/light.html index 16a708b7c..8f82e8a15 100644 --- a/docs/light.html +++ b/docs/light.html @@ -1164,6 +1164,9 @@
  • spawn_tree
  • +
  • + spawn_unrolled_player_rope +
  • @@ -4720,7 +4723,7 @@

    Shop functions

    add_item_to

    Search script examples for add_item_to_shop

    -

    nil add_item_to_shop(int item_uid, int shop_owner)

    +

    nil add_item_to_shop(int item_uid, int shop_owner_uid)

    Adds entity as shop item, has to be movable (haven't tested many)

    change_diceshop_prizes

    @@ -4982,8 +4985,14 @@

    spawn_tree

    Search script examples for spawn_tree

    -

    nil spawn_tree(float x, float y, LAYER layer)

    nil spawn_tree(float x, float y, LAYER layer, int height)

    +

    int spawn_tree(float x, float y, LAYER layer)

    int spawn_tree(float x, float y, LAYER layer, int height)

    Spawns and grows a tree

    +

    spawn_unrolled_player_rope

    +
    +

    Search script examples for spawn_unrolled_player_rope

    +
    +

    int spawn_unrolled_player_rope(float x, float y, LAYER layer, TEXTURE texture)

    int spawn_unrolled_player_rope(float x, float y, LAYER layer, TEXTURE texture, int max_length)

    +

    Spawns an already unrolled rope as if created by player

    String functions

    add_custom_name

    Search script examples for add_custom_name

    @@ -6520,7 +6529,7 @@

    Ai

  • - +
    Type
    EntityDBnew(EntityDB other)
    EntityDBnew(ENT_TYPE)
    ENT_TYPE id
    nilset_enable_turning(bool enabled)
    nil liberate_from_shop()
    VanillaMovableBehaviorbase_behavior
    nil set_force_state(function force_state) Set the force_state function of a CustomMovableBehavior, this will be called every frame when
    the movable is updated. If an force_state is already set it will be overridden. The signature
    of the function is bool force_state(movable, base_fun), when the function returns true the movable will
    enter this behavior. If no base behavior is set base_fun will be nil.
    int whippedHow many times master has violated usNumber of times whipped by player

    Animation

    @@ -6533,6 +6542,11 @@

    Animation

    int +id + + + +int first_tile @@ -6553,6 +6567,63 @@

    Animation

    EntityDB

    +

    Used to store static common data for an ENT_TYPE. You can also clone entity types with the copy constructor to create new custom entities with different common properties. This tool can be helpful when messing with the animations. The default values are also listed in entities.json.

    + +
    +

    When cloning an entity type, remember to save it in the script for as long as you need it. Otherwise the memory will be freed immediately, which eventually leads to a crash when used or overwritten by other stuff:

    +
    +
    -- Create a special fast snake type with weird animation
    +special_snake = EntityDB:new(ENT_TYPE.MONS_SNAKE)
    +special_snake.max_speed = 1
    +special_snake.acceleration = 2
    +special_snake.animations[2].num_tiles = 1
    +
    +set_post_entity_spawn(function(snake)
    +    -- 50% chance to make snakes special
    +    if prng:random_chance(2, PRNG_CLASS.PROCEDURAL_SPAWNS) then
    +        -- Assign custom type
    +        snake.type = special_snake
    +        -- This is only really needed if types are changed during the level
    +        snake.current_animation = special_snake.animations[2]
    +    end
    +end, SPAWN_TYPE.ANY, MASK.MONSTER, ENT_TYPE.MONS_SNAKE)
    +
    +
    +

    You can also use Entity.user_data to store the custom type:

    +
    +
    -- Custom player who is buffed a bit every level
    +set_callback(function()
    +    -- Doing this to include HH
    +    for i,v in ipairs(get_entities_by_mask(MASK.PLAYER)) do
    +        local player = get_entity(v)
    +
    +        -- Create new custom type on the first level, based on the original type
    +        if not player.user_data then
    +            player.user_data = {}
    +            player.user_data.type = EntityDB:new(player.type.id)
    +        end
    +
    +        -- Set the player entity type to the custom type every level
    +        player.type = player.user_data.type
    +
    +        -- Buff the player every subsequent level
    +        if state.level_count > 0 then
    +            player.type.max_speed = player.type.max_speed * 1.1
    +            player.type.acceleration = player.type.acceleration * 1.1
    +            player.type.jump = player.type.jump * 1.1
    +        end
    +    end
    +end, ON.POST_LEVEL_GENERATION)
    +
    +
    +

    Illegal bad example, don't do this:

    +
    +
    set_callback(function()
    +    -- Nobody owns the new type and the memory is freed immediately, eventually leading to a crash
    +    players[1].type = EntityDB:new(players[1].type)
    +    players[1].type.max_speed = 2
    +end, ON.POST_LEVEL_GENERATION)
    +
    @@ -6561,6 +6632,16 @@

    EntityDB

    + + + + + + + + + + @@ -15715,6 +15796,11 @@

    Entity

    + + + + + @@ -19935,6 +20021,11 @@

    CustomMovableBehavior

    + + + + +
    Type
    EntityDBnew(EntityDB other)
    EntityDBnew(ENT_TYPE)
    ENT_TYPE id
    nilset_enable_turning(bool enabled)
    nil liberate_from_shop()
    VanillaMovableBehaviorbase_behavior
    nil set_force_state(function force_state) Set the force_state function of a CustomMovableBehavior, this will be called every frame when
    the movable is updated. If an force_state is already set it will be overridden. The signature
    of the function is bool force_state(movable, base_fun), when the function returns true the movable will
    enter this behavior. If no base behavior is set base_fun will be nil.