/* * Copyright (C) 2021 Christopher J. Howard * * This file is part of Antkeeper source code. * * Antkeeper source code is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Antkeeper source code is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Antkeeper source code. If not, see . */ #include "entity/commands.hpp" #include "entity/components/model.hpp" #include "entity/components/transform.hpp" #include "entity/components/copy-transform.hpp" #include "entity/components/snap.hpp" #include "entity/components/parent.hpp" #include namespace entity { namespace command { void translate(entity::registry& registry, entity::id entity_id, const float3& translation) { if (registry.has(entity_id)) { component::transform& transform = registry.get(entity_id); transform.local.translation += translation; } } void move_to(entity::registry& registry, entity::id entity_id, const float3& position) { if (registry.has(entity_id)) { component::transform& transform = registry.get(entity_id); transform.local.translation = position; } } void warp_to(entity::registry& registry, entity::id entity_id, const float3& position) { if (registry.has(entity_id)) { component::transform& transform = registry.get(entity_id); transform.local.translation = position; transform.warp = true; } } void set_scale(entity::registry& registry, entity::id entity_id, const float3& scale) { if (registry.has(entity_id)) { component::transform& transform = registry.get(entity_id); transform.local.scale = scale; } } void set_transform(entity::registry& registry, entity::id entity_id, const math::transform& transform, bool warp) { if (registry.has(entity_id)) { component::transform& component = registry.get(entity_id); component.local = transform; component.warp = warp; } } void place(entity::registry& registry, entity::id entity_id, const float2& translation) { component::snap component; component.warp = true; component.relative = false; component.autoremove = true; component.ray.origin = {translation[0], 10000.0f, translation[1]}; component.ray.direction = {0.0f, -1.0f, 0.0f}; registry.assign_or_replace(entity_id, component); } void assign_render_layers(entity::registry& registry, entity::id entity_id, unsigned int layers) { if (registry.has(entity_id)) { component::model model = registry.get(entity_id); model.layers = layers; registry.replace(entity_id, model); // Apply to child layers registry.view().each( [&](entity::id entity_id, auto& component) { if (component.parent == entity_id) assign_render_layers(registry, entity_id, layers); }); } } void bind_transform(entity::registry& registry, entity::id source, entity::id target) { component::copy_transform copy_transform = {target}; registry.assign_or_replace(source, copy_transform); } math::transform get_local_transform(entity::registry& registry, entity::id entity_id) { if (registry.has(entity_id)) { const component::transform& component = registry.get(entity_id); return component.local; } return math::identity_transform; } math::transform get_world_transform(entity::registry& registry, entity::id entity_id) { if (registry.has(entity_id)) { const component::transform& component = registry.get(entity_id); return component.world; } return math::identity_transform; } void parent(entity::registry& registry, entity::id child, entity::id parent) { component::parent component; component.parent = parent; registry.assign_or_replace(child, component); } } // namespace command } // namespace entity