All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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