192 lines
5.4 KiB
Java
192 lines
5.4 KiB
Java
/*
|
||
* Copyright or © or Copr. Moribus (2013)
|
||
* Copyright or © or Copr. ProkopyL <prokopylmc@gmail.com> (2015)
|
||
* Copyright or © or Copr. Amaury Carrade <amaury@carrade.eu> (2016 – 2020)
|
||
* Copyright or © or Copr. Vlammar <valentin.jabre@gmail.com> (2019 – 2020)
|
||
*
|
||
* This software is a computer program whose purpose is to allow insertion of
|
||
* custom images in a Minecraft world.
|
||
*
|
||
* This software is governed by the CeCILL-B license under French law and
|
||
* abiding by the rules of distribution of free software. You can use,
|
||
* modify and/ or redistribute the software under the terms of the CeCILL-B
|
||
* license as circulated by CEA, CNRS and INRIA at the following URL
|
||
* "http://www.cecill.info".
|
||
*
|
||
* As a counterpart to the access to the source code and rights to copy,
|
||
* modify and redistribute granted by the license, users are provided only
|
||
* with a limited warranty and the software's author, the holder of the
|
||
* economic rights, and the successive licensors have only limited
|
||
* liability.
|
||
*
|
||
* In this respect, the user's attention is drawn to the risks associated
|
||
* with loading, using, modifying and/or developing or reproducing the
|
||
* software by the user in light of its specific status of free software,
|
||
* that may mean that it is complicated to manipulate, and that also
|
||
* therefore means that it is reserved for developers and experienced
|
||
* professionals having in-depth computer knowledge. Users are therefore
|
||
* encouraged to load and test the software's suitability as regards their
|
||
* requirements in conditions enabling the security of their systems and/or
|
||
* data to be ensured and, more generally, to use and operate it in the
|
||
* same conditions as regards security.
|
||
*
|
||
* The fact that you are presently reading this means that you have had
|
||
* knowledge of the CeCILL-B license and that you accept its terms.
|
||
*/
|
||
|
||
package fr.moribus.imageonmap.image;
|
||
|
||
import java.awt.Graphics;
|
||
import java.awt.image.BufferedImage;
|
||
|
||
/**
|
||
* This class represents an image split into pieces
|
||
*/
|
||
public class PosterImage
|
||
{
|
||
static private final int WIDTH = 128;
|
||
static private final int HEIGHT = 128;
|
||
|
||
private BufferedImage originalImage;
|
||
private BufferedImage[] cutImages;
|
||
private int lines;
|
||
private int columns;
|
||
private int cutImagesCount;
|
||
private int remainderX, remainderY;
|
||
|
||
/**
|
||
* Creates a new Poster from an entire image
|
||
* @param originalImage the original image
|
||
*/
|
||
public PosterImage(BufferedImage originalImage)
|
||
{
|
||
this.originalImage = originalImage;
|
||
calculateDimensions();
|
||
}
|
||
|
||
private void calculateDimensions()
|
||
{
|
||
int originalWidth = originalImage.getWidth();
|
||
int originalHeight = originalImage.getHeight();
|
||
|
||
columns = (int) Math.ceil(originalWidth / WIDTH);
|
||
lines = (int) Math.ceil(originalHeight / HEIGHT);
|
||
|
||
remainderX = originalWidth % WIDTH;
|
||
remainderY = originalHeight % HEIGHT;
|
||
|
||
if(remainderX > 0) columns++;
|
||
if(remainderY > 0) lines++;
|
||
|
||
cutImagesCount = columns * lines;
|
||
}
|
||
|
||
public void splitImages()
|
||
{
|
||
cutImages = new BufferedImage[cutImagesCount];
|
||
|
||
int imageX;
|
||
int imageY = remainderY == 0 ? 0 :(remainderY - HEIGHT) / 2;
|
||
for(int i = 0; i < lines; i++)
|
||
{
|
||
imageX = remainderX == 0 ? 0 :(remainderX - WIDTH) / 2;
|
||
for(int j = 0; j < columns; j++)
|
||
{
|
||
cutImages[i * columns + j] = makeSubImage(originalImage, imageX, imageY);
|
||
imageX += WIDTH;
|
||
}
|
||
imageY += HEIGHT;
|
||
}
|
||
|
||
originalImage = null;
|
||
}
|
||
|
||
/**
|
||
* Generates the subimage that intersects with the given map rectangle.
|
||
* @param x X coordinate of top-left point of the map.
|
||
* @param y Y coordinate of top-left point of the map.
|
||
* @return the requested subimage.
|
||
*/
|
||
private BufferedImage makeSubImage(BufferedImage originalImage, int x, int y)
|
||
{
|
||
BufferedImage newImage = new BufferedImage(WIDTH, HEIGHT, BufferedImage.TYPE_INT_ARGB);
|
||
|
||
Graphics graphics = newImage.getGraphics();
|
||
|
||
graphics.drawImage(originalImage, -x, -y, null);
|
||
graphics.dispose();
|
||
return newImage;
|
||
}
|
||
|
||
/**
|
||
*
|
||
* @return the split images
|
||
*/
|
||
public BufferedImage[] getImages()
|
||
{
|
||
return cutImages;
|
||
}
|
||
|
||
public BufferedImage getImageAt(int i)
|
||
{
|
||
return cutImages[i];
|
||
}
|
||
|
||
public int getColumnAt(int i)
|
||
{
|
||
return i % columns;
|
||
}
|
||
|
||
public int getLineAt(int i)
|
||
{
|
||
return i / columns;
|
||
}
|
||
|
||
/**
|
||
*
|
||
* @return the number of lines of the poster
|
||
*/
|
||
public int getLines()
|
||
{
|
||
return lines;
|
||
}
|
||
|
||
/**
|
||
*
|
||
* @return the number of columns of the poster
|
||
*/
|
||
public int getColumns()
|
||
{
|
||
return columns;
|
||
}
|
||
|
||
/**
|
||
*
|
||
* @return the number of split images
|
||
*/
|
||
public int getImagesCount()
|
||
{
|
||
return cutImagesCount;
|
||
}
|
||
|
||
public int getRemainderX()
|
||
{
|
||
return remainderX;
|
||
}
|
||
|
||
public void setRemainderX(int remainderX)
|
||
{
|
||
this.remainderX = remainderX;
|
||
}
|
||
|
||
public int getRemainderY()
|
||
{
|
||
return remainderY;
|
||
}
|
||
|
||
public void setRemainderY(int remainderY)
|
||
{
|
||
this.remainderY = remainderY;
|
||
}
|
||
}
|