Factorio-Paranoidal_mod/PickerDollies
Aleksei-bird 487a0e6e16 Добавлены все обновления от сообщества, вплоть до #148 2024-09-12 14:31:00 +03:00
..
locale/en Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
changelog.txt Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
control.lua Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
data.lua Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
info.json Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
interface.lua Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
readme.md Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
settings.lua Изменил на соответствие главному репозиторию сборки Paranoidal 2024-03-24 22:01:26 +03:00
thumbnail.png Добавлены все обновления от сообщества, вплоть до #148 2024-09-12 14:31:00 +03:00

readme.md

Picker Dollies

Hover over entities and use the Picker dolly keybinds to move entities around. Entities will keep their wire connections and settings. This allows you to build your set up spaced out and when you are finished push it all together for a nice tight build. Some entities can't be shoved around. Also respects max wire distance. Note Moving some modded entities that rely on position can cause issues. There is an API available that mod authors can use to be notified of these events.

Dollies in Action

Picker Dollies

Dollies Remote API

Whenever a player moves an entity using picker dollies an event is raised. Listening for this event will allow you to update your entities if needed.

In your mods on_load and on_init events add:

if remote.interfaces["PickerDollies"] and remote.interfaces["PickerDollies"]["dolly_moved_entity_id"] then
    script.on_event(remote.call("PickerDollies", "dolly_moved_entity_id"), your_function_to_update_the_entity)
end

The dolly moved event returns a table with the following the information:

{
    player_index = player_index, -- The index of the player who moved the entity
    moved_entity = entity, -- The entity that was moved
    start_pos = position -- The position that the entity was moved from
}

In addition a remote api to disallow moving of an entity is available:

if remote.interfaces["PickerDollies"] and remote.interfaces["PickerDollies"]["add_blacklist_name"] then
    remote.call("PickerDollies", "add_blacklist_name", "name-of-your-entity")
end