org.micromanager.acqj.internal.AffineTransformUtils Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
// AUTHOR: Henry Pinkard, [email protected]
//
// COPYRIGHT: University of California, San Francisco, 2015
//
// LICENSE: This file is distributed under the BSD license.
// License text is included with the source distribution.
//
// This file 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.
//
// IN NO EVENT SHALL THE COPYRIGHT OWNER OR
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
// INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES.
//
package org.micromanager.acqj.internal;
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
import java.awt.geom.AffineTransform;
import java.awt.geom.Point2D;
import java.util.ArrayList;
import mmcorej.DoubleVector;
import org.micromanager.acqj.util.xytiling.XYStagePosition;
public class AffineTransformUtils {
public static ArrayList createPositionGrid(int imageWidth, int imageHeight,
double xCenter, double yCenter, int overlapX, int overlapY, int numRows, int numCols) {
ArrayList positions = new ArrayList();
int tileWidthMinusOverlap = imageWidth - overlapX;
int tileHeightMinusOverlap = imageHeight - overlapY;
AffineTransform transform = getAffineTransform(xCenter, yCenter);
for (int col = 0; col < numCols; col++) {
double xPixelOffset = (col - (numCols - 1) / 2.0) * tileWidthMinusOverlap;
//add in snaky behavior
if (col % 2 == 0) {
for (int row = 0; row < numRows; row++) {
double yPixelOffset = (row - (numRows - 1) / 2.0) * tileHeightMinusOverlap;
Point2D.Double pixelPos = new Point2D.Double(xPixelOffset, yPixelOffset);
Point2D.Double stagePos = new Point2D.Double();
transform.transform(pixelPos, stagePos);
AffineTransform posTransform = getAffineTransform(stagePos.x, stagePos.y);
positions.add(new XYStagePosition(stagePos, row, col));
}
} else {
for (int row = numRows - 1; row >= 0; row--) {
double yPixelOffset = (row - (numRows - 1) / 2.0) * tileHeightMinusOverlap;
Point2D.Double pixelPos = new Point2D.Double(xPixelOffset, yPixelOffset);
Point2D.Double stagePos = new Point2D.Double();
transform.transform(pixelPos, stagePos);
positions.add(new XYStagePosition(stagePos, row, col));
}
}
}
return positions;
}
public static String transformToString(AffineTransform transform) {
double[] matrix = new double[4];
transform.getMatrix(matrix);
return matrix[0] + "_" + matrix[1] + "_" + matrix[2] + "_" + matrix[3];
}
public static AffineTransform stringToTransform(String s) {
if (s.equals("Undefined")) {
return null;
}
double[] mat = new double[4];
String[] vals = s.split("_");
for (int i = 0; i < 4; i++) {
mat[i] = NumUtils.parseDouble(vals[i]);
}
return new AffineTransform(mat);
}
public static boolean isAffineTransformDefined() {
try {
DoubleVector v = Engine.getCore().getPixelSizeAffine(true);
for (int i = 0; i < v.size(); i++) {
if (v.get(i) != 0.0) {
return true;
}
}
return false;
} catch (Exception ex) {
throw new RuntimeException(ex);
}
}
public static AffineTransform getAffineTransform(double xTranslation, double yTranslation) {
try {
AffineTransform transform = doubleToAffine(Engine.getCore().getPixelSizeAffine());
//set map origin to current stage position
double[] matrix = new double[6];
transform.getMatrix(matrix);
matrix[4] = xTranslation;
matrix[5] = yTranslation;
return new AffineTransform(matrix);
} catch (Exception ex) {
throw new RuntimeException(ex);
}
}
public static final AffineTransform doubleToAffine(DoubleVector atf) {
if (atf.size() != 6) {
double[] flatMatrix = {0.0, 0.0, 0.0, 0.0, 0.0, 0.0};
return new AffineTransform(flatMatrix);
}
double[] flatMatrix = {atf.get(0), atf.get(3), atf.get(1),
atf.get(4), atf.get(2), atf.get(5)};
return new AffineTransform(flatMatrix);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy