Search in sources :

Example 1 with Profiler

use of net.modificationstation.stationapi.api.util.profiler.Profiler in project StationAPI by ModificationStation.

the class SpriteAtlasTexture method stitch.

public Data stitch(TexturePack resourceManager, Stream<Identifier> idStream, Profiler profiler, int mipmapLevel) {
    int p;
    profiler.push("preparing");
    Set<Identifier> set = idStream.peek(identifier -> {
        if (identifier == null) {
            throw new IllegalArgumentException("Location cannot be null!");
        }
    }).collect(Collectors.toSet());
    int i = this.maxTextureSize;
    TextureStitcher textureStitcher = new TextureStitcher(i, i, mipmapLevel);
    int j = Integer.MAX_VALUE;
    int k = 1 << mipmapLevel;
    profiler.swap("extracting_frames");
    for (Sprite.Info info2 : this.loadSprites(resourceManager, set)) {
        j = Math.min(j, Math.min(info2.getWidth(), info2.getHeight()));
        int l = Math.min(Integer.lowestOneBit(info2.getWidth()), Integer.lowestOneBit(info2.getHeight()));
        if (l < k) {
            LOGGER.warn("Texture {} with size {}x{} limits mip level from {} to {}", info2.getId(), info2.getWidth(), info2.getHeight(), MathHelper.log2(k), MathHelper.log2(l));
            k = l;
        }
        textureStitcher.add(info2);
    }
    int m = Math.min(j, k);
    int n = MathHelper.log2(m);
    if (n < mipmapLevel) {
        LOGGER.warn("{}: dropping miplevel from {} to {}, because of minimum power of two: {}", this.id, mipmapLevel, n, m);
        p = n;
    } else {
        p = mipmapLevel;
    }
    profiler.swap("register");
    textureStitcher.add(MissingSprite.getMissingInfo());
    profiler.swap("stitching");
    try {
        textureStitcher.stitch();
    } catch (TextureStitcherCannotFitException textureStitcherCannotFitException) {
        CrashReport crashReport = CrashReport.create(textureStitcherCannotFitException, "Stitching");
        CrashReportSection crashReportSection = crashReport.addElement("Stitcher");
        crashReportSection.add("Sprites", textureStitcherCannotFitException.getSprites().stream().map(info -> String.format("%s[%dx%d]", info.getId(), info.getWidth(), info.getHeight())).collect(Collectors.joining(",")));
        crashReportSection.add("Max Texture Size", i);
        throw new CrashException(crashReport);
    }
    profiler.swap("loading");
    List<Sprite> list = this.loadSprites(resourceManager, textureStitcher, p);
    profiler.pop();
    return new Data(set, textureStitcher.getWidth(), textureStitcher.getHeight(), p, list);
}
Also used : ResourceManager(net.modificationstation.stationapi.api.resource.ResourceManager) CrashReportSection(net.modificationstation.stationapi.api.util.exception.CrashReportSection) java.awt.image(java.awt.image) java.util(java.util) MODID(net.modificationstation.stationapi.api.StationAPI.MODID) java.util.stream(java.util.stream) Environment(net.fabricmc.api.Environment) LOGGER(net.modificationstation.stationapi.impl.client.texture.StationRenderImpl.LOGGER) Resource(net.modificationstation.stationapi.api.client.resource.Resource) CrashException(net.modificationstation.stationapi.api.util.exception.CrashException) Lists(com.google.common.collect.Lists) TexturePack(net.minecraft.client.resource.TexturePack) Identifier(net.modificationstation.stationapi.api.registry.Identifier) EnvType(net.fabricmc.api.EnvType) Util(net.modificationstation.stationapi.api.util.Util) CrashReport(net.modificationstation.stationapi.api.util.exception.CrashReport) ApiStatus(org.jetbrains.annotations.ApiStatus) java.util.concurrent(java.util.concurrent) javax.imageio(javax.imageio) Pair(com.mojang.datafixers.util.Pair) MathHelper(net.modificationstation.stationapi.api.util.math.MathHelper) AnimationResourceMetadata(net.modificationstation.stationapi.api.client.resource.metadata.AnimationResourceMetadata) Nullable(org.jetbrains.annotations.Nullable) java.io(java.io) Profiler(net.modificationstation.stationapi.api.util.profiler.Profiler) SpriteFinderImpl(net.modificationstation.stationapi.impl.client.render.SpriteFinderImpl) RenderSystem(net.modificationstation.stationapi.impl.client.texture.RenderSystem) CrashException(net.modificationstation.stationapi.api.util.exception.CrashException) CrashReport(net.modificationstation.stationapi.api.util.exception.CrashReport) CrashReportSection(net.modificationstation.stationapi.api.util.exception.CrashReportSection) Identifier(net.modificationstation.stationapi.api.registry.Identifier)

Aggregations

Lists (com.google.common.collect.Lists)1 Pair (com.mojang.datafixers.util.Pair)1 java.awt.image (java.awt.image)1 java.io (java.io)1 java.util (java.util)1 java.util.concurrent (java.util.concurrent)1 java.util.stream (java.util.stream)1 javax.imageio (javax.imageio)1 EnvType (net.fabricmc.api.EnvType)1 Environment (net.fabricmc.api.Environment)1 TexturePack (net.minecraft.client.resource.TexturePack)1 MODID (net.modificationstation.stationapi.api.StationAPI.MODID)1 Resource (net.modificationstation.stationapi.api.client.resource.Resource)1 AnimationResourceMetadata (net.modificationstation.stationapi.api.client.resource.metadata.AnimationResourceMetadata)1 Identifier (net.modificationstation.stationapi.api.registry.Identifier)1 ResourceManager (net.modificationstation.stationapi.api.resource.ResourceManager)1 Util (net.modificationstation.stationapi.api.util.Util)1 CrashException (net.modificationstation.stationapi.api.util.exception.CrashException)1 CrashReport (net.modificationstation.stationapi.api.util.exception.CrashReport)1 CrashReportSection (net.modificationstation.stationapi.api.util.exception.CrashReportSection)1