/* * This file is part of the Illarion project. * * Copyright © 2015 - Illarion e.V. * * Illarion is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Illarion 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. */ package illarion.common.graphics; import org.jetbrains.annotations.Contract; /** * This interfaces defines the file constructs that are load by the texture loader implementations. * * @param <T> the type of the texture stored in this texture atlas * @author Martin Karing >nitram@illarion.org< */ @FunctionalInterface public interface TextureAtlas<T> { /** * Get the texture assigned to a specified name. * * @param texture the name of the texture to look for * @return the texture or {@code null} in case the texture was not found in this object */ @Contract(pure = true) T getTexture(String texture); }