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

org.micromanager.acqj.api.AcquisitionAPI Maven / Gradle / Ivy

/*
 * To change this license header, choose License Headers in Project Properties.
 * To change this template file, choose Tools | Templates
 * and open the template in the editor.
 */
package org.micromanager.acqj.api;

import java.util.Iterator;
import java.util.concurrent.Future;
import java.util.function.Consumer;

import mmcorej.org.json.JSONObject;
import org.micromanager.acqj.main.AcquisitionEvent;

/**
 * General interface for acquisitions
 *
 * @author henrypinkard
 */
public interface AcquisitionAPI {

   public static final int EVENT_GENERATION_HOOK = 0;
   public static final int BEFORE_HARDWARE_HOOK = 1;
   public static final int AFTER_HARDWARE_HOOK = 2;
   public static final int AFTER_CAMERA_HOOK = 3;

   /**
    * Block until acquisition finished and all resources complete.
    */
   public void waitForCompletion();

   /**
    * Signal the acquisition to complete once all events are done
    *
    */
   public void finish();

   /**
    * returns true if all acquisition events have been processed and
    * hardware control is complete. This does not, however signal that
    * all images are finished writing to disk (if DataSink is not null).
    * This occurs after events are finished, and the DataSink should
    * provide that information directly
    *
    * @return
    */
   public boolean areEventsFinished();

   /**
    * Cancel any pending events and shutdown
    */
   public void abort();

   /**
    * Abort, and provide an exception that is the reason for the abort. This
    * is useful for passing exceptions across threads
    * @param e
    */
   public void abort(Exception e);

   /**
    * Has abort been called?
    */
   public boolean isAbortRequested();

   /**
    * return if acquisition is paused (i.e. not acquiring new data but not
    * finished)
    *
    * @return
    */
   public boolean isPaused();

   /**
    * Pause or unpause
    */
   public void setPaused(boolean pause);

   /**
    * Get the summary metadata for this acquisition
    *
    * @return
    */
   public JSONObject getSummaryMetadata();

   /**
    * Returns true once any data has been acquired
    *
    * @return
    */
   public boolean anythingAcquired();

   /**
    * Add a Consumer that will receive the metadata JSONObject for each image
    * that is generated and modify it as needed. Metadata can also be modified
    * through an ImageProcessor. This method is more lightweight--it should not
    * be doing an significant computation, unlike Image Processors, which run
//    * /on their own dedicated Thread()
    */
   public void addImageMetadataProcessor(Consumer modifier);

   /**
    * Add an image processor for modifying images before saving or diverting
    * them to some other purpose
    *
    * @param p
    */
   public void addImageProcessor(TaggedImageProcessor p);

   /**
    * Add a an arbitrary piece of code (i.e. a hook) to be executed at a
    * specific time in the acquisition loop
    *
    * @param hook Code to run
    * @param type BEFORE_HARDWARE_HOOK, AFTER_HARDWARE_HOOK, AFTER_SAVE_HOOK
    */
   public void addHook(AcquisitionHook hook, int type);

   /**
    * Submit a list of acquisition events for acquisition. Acquisition engine
    * will automatically optimize over this list (i.e. implement hardware sequencing).
    * @param evt 
    */
   public Future submitEventIterator(Iterator evt);

   /**
    * Get the DataSink used by this acquisition. This could be null (since)
    * ImageProcessors allow data to be intercepted and diverted
    * @return
    */
   public DataSink getDataSink();

   /**
    * Should debug logging be printed
    */
   public boolean isDebugMode();

   /**
    * Activate debug logging
    */
   public void setDebugMode(boolean debug);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy