/**
* Copyright 2014
* SMEdit https://github.com/StarMade/SMEdit
* SMTools https://github.com/StarMade/SMTools
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
**/
package jo.sm.plugins.ship.stripes;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Random;
import jo.sm.data.BlockTypes;
import jo.sm.data.CubeIterator;
import jo.sm.data.SparseMatrix;
import jo.sm.data.StarMade;
import jo.sm.mods.IBlocksPlugin;
import jo.sm.mods.IPluginCallback;
import jo.sm.ship.data.Block;
import jo.vecmath.Point3i;
import jo.vecmath.logic.MathUtils;
/**
* @Auther Jo Jaquinta for SMEdit Classic - version 1.0
* @Auther Robert Barefoot for SMEdit - version 1.1
**/
public class OmbrePlugin implements IBlocksPlugin {
public static final String NAME = "Ombre";
public static final String DESC = "Paint a pattern fading from one color to another.";
public static final String AUTH = "Jo Jaquinta";
public static final int[][] CLASSIFICATIONS
= {
{TYPE_SHIP, SUBTYPE_PAINT},
{TYPE_STATION, SUBTYPE_PAINT},
{TYPE_SHOP, SUBTYPE_PAINT},};
public Random mRND = new Random();
@Override
public String getName() {
return NAME;
}
@Override
public String getDescription() {
return DESC;
}
@Override
public String getAuthor() {
return AUTH;
}
@Override
public Object newParameterBean() {
return new OmbreParameters();
}
@Override
public void initParameterBean(SparseMatrix<Block> original, Object params,
StarMade sm, IPluginCallback cb) {
}
@Override
public int[][] getClassifications() {
return CLASSIFICATIONS;
}
@Override
public SparseMatrix<Block> modify(SparseMatrix<Block> original,
Object p, StarMade sm, IPluginCallback cb) {
OmbreParameters params;
params = (OmbreParameters) p;
Point3i lower;
Point3i upper;
if ((sm.getSelectedLower() != null) && (sm.getSelectedUpper() != null)) {
lower = sm.getSelectedLower();
upper = sm.getSelectedUpper();
} else {
lower = new Point3i();
upper = new Point3i();
original.getBounds(lower, upper);
}
cb.startTask((upper.x - lower.x + 1) * (upper.y - lower.y + 1) * (upper.z - lower.z + 1));
SparseMatrix<Block> modified;
modified = new SparseMatrix<>(original);
for (Iterator<Point3i> i = new CubeIterator(lower, upper); i.hasNext();) {
cb.workTask(1);
Point3i xyz = i.next();
Block b = modified.get(xyz);
if (b == null) {
continue;
}
if (BlockTypes.isAnyHull(b.getBlockID())) {
b = modify(xyz, b, params, lower, upper);
modified.set(xyz, b);
}
}
cb.endTask();
return modified;
}
private Block modify(Point3i xyz, Block b, OmbreParameters params, Point3i lower, Point3i upper) {
List<Double> medians;
medians = new ArrayList<>();
if (params.isXAxis()) {
double a;
a = MathUtils.interpolate(xyz.x, lower.x, upper.x, 0, 1);
medians.add(a);
}
if (params.isYAxis()) {
double a;
a = MathUtils.interpolate(xyz.y, lower.y, upper.y, 0, 1);
medians.add(a);
}
if (params.isZAxis()) {
double a;
a = MathUtils.interpolate(xyz.z, lower.z, upper.z, 0, 1);
medians.add(a);
}
double median = 0;
for (Double m : medians) {
median += m / medians.size();
}
short newColor;
if (mRND.nextDouble() < median) {
newColor = params.getColor2();
} else {
newColor = params.getColor1();
}
newColor = BlockTypes.getColoredBlock(b.getBlockID(), newColor);
b = new Block(b);
b.setBlockID(newColor);
return b;
}
}