/* * Copyright (C) 2015 Patryk Strach * * This file is part of Virtual Slide Viewer. * * Virtual Slide Viewer 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. * * Virtual Slide Viewer 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 Virtual Slide Viewer. * If not, see <http://www.gnu.org/licenses/>. */ package virtualslideviewer.imageviewing; import java.awt.Rectangle; import java.util.Collections; import java.util.List; import virtualslideviewer.core.BufferedVirtualSlideImage; import virtualslideviewer.core.Tile; /** * An implementation of TileLoadingPrioritizer which sorts the tiles by their visible area. * Tiles with the largest visible come first. */ public class VisibleAreaTilePrioritizer implements TileLoadingPrioritizer { @Override public void sortTilesByPriority(List<Tile> tilesToSort, BufferedVirtualSlideImage image, Rectangle imageBounds) { Collections.sort(tilesToSort, (tile1, tile2) -> { Rectangle firstTileVisibleRegionBounds = tile1.getBounds(image).intersection(imageBounds); Rectangle secondTileVisibleRegionBounds = tile2.getBounds(image).intersection(imageBounds); int firstTileVisibleRegionArea = firstTileVisibleRegionBounds.width * firstTileVisibleRegionBounds.height; int secondTileVisibleRegionArea = secondTileVisibleRegionBounds.width * secondTileVisibleRegionBounds.height; return secondTileVisibleRegionArea - firstTileVisibleRegionArea; }); } }