X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fsixth%2Fe3d%2Frenderer%2Fraster%2FRenderAggregator.java;h=d6da472c9da4d78ad08942e2cfd51e607114e149;hb=a3ff3683bd0a025061667b26b6fcf56fe20f0afc;hp=048bb53b67da5557ec37852aac9243563baff71f;hpb=03447008b8ee26a6463d2cd03005dc26464863db;p=sixth-3d.git diff --git a/src/main/java/eu/svjatoslav/sixth/e3d/renderer/raster/RenderAggregator.java b/src/main/java/eu/svjatoslav/sixth/e3d/renderer/raster/RenderAggregator.java index 048bb53..d6da472 100644 --- a/src/main/java/eu/svjatoslav/sixth/e3d/renderer/raster/RenderAggregator.java +++ b/src/main/java/eu/svjatoslav/sixth/e3d/renderer/raster/RenderAggregator.java @@ -1,12 +1,7 @@ /* - * Sixth 3D engine. Copyright ©2012-2016, Svjatoslav Agejenko, svjatoslav@svjatoslav.eu - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of version 3 of the GNU Lesser General Public License - * or later as published by the Free Software Foundation. - * + * Sixth 3D engine. Author: Svjatoslav Agejenko. + * This project is released under Creative Commons Zero (CC0) license. */ - package eu.svjatoslav.sixth.e3d.renderer.raster; import eu.svjatoslav.sixth.e3d.gui.RenderingContext; @@ -14,21 +9,16 @@ import eu.svjatoslav.sixth.e3d.renderer.raster.shapes.AbstractCoordinateShape; import java.io.Serializable; import java.util.ArrayList; -import java.util.Collections; import java.util.Comparator; public class RenderAggregator { - ArrayList shapes = new ArrayList<>(); - ShapesComparator comparator = new ShapesComparator(); + private final ArrayList shapes = new ArrayList<>(); + private final ShapesZIndexComparator comparator = new ShapesZIndexComparator(); public void paint(final RenderingContext renderBuffer) { - - Collections.sort(shapes, comparator); - - for (final AbstractCoordinateShape shape : shapes) - shape.paint(renderBuffer); - + shapes.sort(comparator); + shapes.forEach(shape -> shape.paint(renderBuffer)); } public void queueShapeForRendering(final AbstractCoordinateShape shape) { @@ -39,7 +29,7 @@ public class RenderAggregator { shapes.clear(); } - static class ShapesComparator implements Comparator, Serializable { + static class ShapesZIndexComparator implements Comparator, Serializable { @Override public int compare(final AbstractCoordinateShape o1, final AbstractCoordinateShape o2) {