/*
* 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.Point;
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 distance to the center of visible portion of the image.
*
* Tiles with the closest distance to the center come first.
*/
public class DistanceToCenterTilePrioritizer implements TileLoadingPrioritizer
{
@Override
public void sortTilesByPriority(List<Tile> tilesToSort, BufferedVirtualSlideImage image, Rectangle imageBounds)
{
Collections.sort(tilesToSort, (tile1, tile2) ->
{
Point imageCenter = getCenter(imageBounds);
Point tile1Center = getCenter(tile1.getBounds(image));
Point tile2Center = getCenter(tile2.getBounds(image));
return (int)(tile1Center.distanceSq(imageCenter) - tile2Center.distanceSq(imageCenter));
});
}
private Point getCenter(Rectangle bounds)
{
return new Point(bounds.x + bounds.width / 2,
bounds.y + bounds.height / 2);
}
}