![]() |
ImFusion SDK 4.3
|
#include <ImFusion/US/SweepCroppingAlgorithm.h>
Algorithm for cropping, binning (downsampling), and vertical flipping of ultrasound image data, with full correction of associated tracking and geometry metadata. More...
Inheritance diagram for SweepCroppingAlgorithm:Algorithm for cropping, binning (downsampling), and vertical flipping of ultrasound image data, with full correction of associated tracking and geometry metadata.
This algorithm is designed for preprocessing ultrasound sweeps, allowing you to:
In contrast to generic image processing algorithms, this class also ensures that all relevant metadata is updated consistently:
This is especially useful when preparing ultrasound data for further processing or visualization, ensuring that both the image content and its spatial context remain consistent.
Example usage:
Public Member Functions | |
| SweepCroppingAlgorithm (SharedImageSet &sharedImageSet) | |
| SweepCroppingAlgorithm (const std::vector< SharedImageSet * > &sis) | |
| vec2i | cropLower () const |
| Get the lower-left cropping in pixels (may be negative). | |
| void | setCropLower (vec2i value) |
| Set the lower-left cropping in pixels (may be negative). | |
| vec2i | cropUpper () const |
| Get the upper-right cropping in pixels (may be negative). | |
| void | setCropUpper (vec2i value) |
| Set and get the upper-right cropping in pixels (may be negative). | |
| vec2i | binning () const |
| Get the applied binning (downsampling) factor. | |
| void | setBinning (vec2i value) |
| Set the applied binning (downsampling) factor. | |
| bool | flip () const |
| Get whether the image will be vertically flipped. | |
| void | setFlip (bool flip) |
| Set whether the image will be vertically flipped. | |
| bool | createNew () const |
| Get whether to create a new image instead of performing an in-place operation. | |
| void | setCreateNew (bool value) |
| Set whether to create a new image instead of performing an in-place operation. | |
| void | configure (const Properties *p) override |
| Configure this object instance by de-serializing the given Properties. | |
| void | configuration (Properties *p) const override |
| Serialize the current object configuration into the given Properties object. | |
| void | compute () override |
| Execute the algorithm. | |
| OwningDataList | takeOutput () override |
| Return any new Data that was created by the Algorithm during the last call to compute(). | |
Public Member Functions inherited from Algorithm | |
| Algorithm () | |
| Default constructor will registers a single "compute" action that calls compute() and returns status(). | |
| virtual void | setProgress (Progress *progress) |
| Sets a Progress interface the algorithm can use to notify observers about its computing progress. | |
| Progress * | progress () const |
| Returns the progress interface if set. | |
| virtual int | status () const |
| Indicates the status of the last call to compute(). | |
| virtual bool | survivesDataDeletion (const Data *) const |
| Indicates whether the algorithm can handle (partial) deletion of the specified data, by default this checks whether the data is in the input list. | |
| const FactoryInfo & | factoryInfo () const |
| Returns the record describing how this Algorithm was instantiated by the AlgorithmFactory. | |
| void | setFactoryInfo (const FactoryInfo &value) |
| Sets the record describing how this Algorithm was instantiated by the AlgorithmFactory. | |
| Status | runAction (const std::string &id) |
Run the action with name id if it exists. | |
| const std::vector< Action > & | actions () |
| Get a mapping from Action id to Action as registered in this algorithm. | |
Public Member Functions inherited from Configurable | |
| virtual void | configureDefaults () |
| Retrieve the properties of this object, replaces values with their defaults and sets it again. | |
| void | registerParameter (ParameterBase *param) |
| Register the given Parameter or SubProperty, so that it will be configured during configure()/configuration(). | |
| void | unregisterParameter (const ParameterBase *param) |
| Remove the given Parameter or SubProperty from the list of registered parameters. | |
| Configurable (const Configurable &rhs) | |
| Configurable (Configurable &&rhs) noexcept | |
| Configurable & | operator= (const Configurable &) |
| Configurable & | operator= (Configurable &&) noexcept |
Static Public Member Functions | |
| static Geometry::AlignedBox | cropBounds (const US::FrameGeometry &geometry) |
| Computes the axis aligned bounding box of the given ultrasound FrameGeometry in pixel coordinates. | |
| static bool | createCompatible (const DataList &data, Algorithm **a) |
Static Public Member Functions inherited from Algorithm | |
| static bool | createCompatible (const DataList &data, Algorithm **a=nullptr) |
| Factory function to check algorithm compatibility with input data and optionally instantiate it. | |
Additional Inherited Members | |
Public Types inherited from Algorithm | |
| enum | Status { Unknown = -1 , Success = 0 , Error = 1 , InvalidInput , IncompleteInput , OutOfMemoryHost , OutOfMemoryGPU , UnsupportedGPU , UnknownAction , AbortedByUser , User = 1000 } |
| Status codes. More... | |
Public Attributes inherited from Algorithm | |
| Signal | signalOutputChanged |
| Signal should be emitted by Algorithms when their output/result has changed. | |
| Signal | signalParametersChanged |
| Signal should be emitted by Algorithms when their parameter configuration has changed. | |
Public Attributes inherited from Configurable | |
| Signal | signalParametersChanged |
Emitted whenever one of the registered Parameters' or SubPropertys' signalValueChanged signal was emitted. | |
Protected Member Functions inherited from Algorithm | |
| void | loadDefaults () |
| void | registerAction (const std::string &id, const std::string &guiName, const std::function< Algorithm::Status(void)> &action) |
| Register an action to be run via runAction. | |
| template<typename D> | |
| void | registerAction (const std::string &id, const std::string &guiName, Algorithm::Status(D::*action)(void)) |
| Template version of runAction that can be used with a pointer to a member function. | |
| void | registerAction (const Action &action) |
| Register an action. | |
Protected Attributes inherited from Algorithm | |
| std::string | m_name |
| Algorithm name. | |
| Progress * | m_progress = nullptr |
| Non-owing pointer to a progress interface. May be a nullptr. | |
| FactoryInfo | m_factoryInfo = {} |
| Record describing how this algorithm was instantiated by the AlgorithmFactory. | |
| int | m_status = Status::Unknown |
| Algorithm status after last call to compute() | |
| std::vector< Action > | m_actions |
| Map of key given by the id of the action, of the available actions of this algorithm. | |
Protected Attributes inherited from Configurable | |
| std::vector< Param > | m_params |
| List of all registered Parameter and SubProperty instances. | |
|
static |
Computes the axis aligned bounding box of the given ultrasound FrameGeometry in pixel coordinates.
The resulting bounding box can be used to set the crop parameters to precisely cover the region of the FrameGeometry.
| geometry | FrameGeometry for which to compute the pixel bounds. |
| vec2i cropLower | ( | ) | const |
Get the lower-left cropping in pixels (may be negative).
This specifies how many pixels to crop from the lower-left corner of the image.
| void setCropLower | ( | vec2i | value | ) |
Set the lower-left cropping in pixels (may be negative).
This specifies how many pixels to crop from the lower-left corner of the image.
| vec2i cropUpper | ( | ) | const |
Get the upper-right cropping in pixels (may be negative).
Specifies how many pixels to crop from the upper-right corner of the image.
| void setCropUpper | ( | vec2i | value | ) |
Set and get the upper-right cropping in pixels (may be negative).
Specifies how many pixels to crop from the upper-right corner of the image.
| vec2i binning | ( | ) | const |
Get the applied binning (downsampling) factor.
Each dimension must be >= 1. A value of (1,1) means no binning.
| void setBinning | ( | vec2i | value | ) |
Set the applied binning (downsampling) factor.
Each dimension must be >= 1. A value of (1,1) means no binning.
| bool flip | ( | ) | const |
Get whether the image will be vertically flipped.
If enabled, the image is flipped along the vertical axis.
| void setFlip | ( | bool | flip | ) |
Set whether the image will be vertically flipped.
If enabled, the image is flipped along the vertical axis.
| bool createNew | ( | ) | const |
Get whether to create a new image instead of performing an in-place operation.
If true, a new image set is created; otherwise, the operation is performed in-place.
| void setCreateNew | ( | bool | value | ) |
Set whether to create a new image instead of performing an in-place operation.
If true, a new image set is created; otherwise, the operation is performed in-place.
|
overridevirtual |
Configure this object instance by de-serializing the given Properties.
The default implementation will do so automatically for all registered Parameter and SubProperty instances.
Reimplemented from Configurable.
|
overridevirtual |
Serialize the current object configuration into the given Properties object.
The default implementation will do so automatically for all registered Parameter and SubProperty instances.
Reimplemented from Configurable.
|
overridevirtual |
Execute the algorithm.
Implements Algorithm.
|
overridevirtual |