LensShadingMap

public final class LensShadingMap
extends Object

java.lang.Object
   ↳ android.hardware.camera2.params.LensShadingMap


Immutable class for describing a 4 x N x M lens shading map of floats.

Summary

Constants

float MINIMUM_GAIN_FACTOR

The smallest gain factor in this map.

Public methods

void copyGainFactors(float[] destination, int offset)

Copy all gain factors in row-major order from this lens shading map into the destination.

boolean equals(Object obj)

Check if this LensShadingMap is equal to another LensShadingMap.

int getColumnCount()

Get the number of columns in this map.

float getGainFactor(int colorChannel, int column, int row)

Get a single color channel gain factor from this lens shading map by its row and column.

int getGainFactorCount()

Get the total number of gain factors in this map.

RggbChannelVector getGainFactorVector(int column, int row)

Get a gain factor vector from this lens shading map by its row and column.

int getRowCount()

Get the number of rows in this map.

int hashCode()

Returns a hash code value for the object.

String toString()

Return the LensShadingMap as a string representation.

Inherited methods

Constants

MINIMUM_GAIN_FACTOR

Added in API level 21
public static final float MINIMUM_GAIN_FACTOR

The smallest gain factor in this map.

All values in this map will be at least this large.

Constant Value: 1.0

Public methods

copyGainFactors

Added in API level 21
public void copyGainFactors (float[] destination, 
                int offset)

Copy all gain factors in row-major order from this lens shading map into the destination.

Each gain factor will be >= MINIMUM_GAIN_FACTOR.

Parameters
destination float: an array big enough to hold at least RggbChannelVector#COUNT elements after the offset

offset int: a non-negative offset into the array

Throws
NullPointerException If destination was null
IllegalArgumentException If offset was negative
ArrayIndexOutOfBoundsException If there's not enough room to write the elements at the specified destination and offset.

equals

Added in API level 21
public boolean equals (Object obj)

Check if this LensShadingMap is equal to another LensShadingMap.

Two lens shading maps are equal if and only if they have the same rows/columns, and all of their elements are equal.

Parameters
obj Object: the reference object with which to compare.

Returns
boolean true if the objects were equal, false otherwise

getColumnCount

Added in API level 21
public int getColumnCount ()

Get the number of columns in this map.

Returns
int

getGainFactor

Added in API level 21
public float getGainFactor (int colorChannel, 
                int column, 
                int row)

Get a single color channel gain factor from this lens shading map by its row and column.

The rows must be within the range [0, getRowCount()), the column must be within the range [0, getColumnCount()), and the color channel must be within the range [0, android.hardware.camera2.params.RggbChannelVector.COUNT RggbChannelVector.COUNT).

The channel order is [R, Geven, Godd, B], where Geven is the green channel for the even rows of a Bayer pattern, and Godd is the odd rows.

Parameters
colorChannel int: color channel from [R, Geven, Godd, B]

column int: within the range [0, getColumnCount())

row int: within the range [0, getRowCount())

Returns
float a gain factor >= .MINIMUM_GAIN_FACTOR

Throws
IllegalArgumentException if any of the parameters was out of range

getGainFactorCount

Added in API level 21
public int getGainFactorCount ()

Get the total number of gain factors in this map.

A single gain factor contains exactly one color channel. Use with copyGainFactors(float, int) to allocate a large-enough array.

Returns
int

getGainFactorVector

Added in API level 21
public RggbChannelVector getGainFactorVector (int column, 
                int row)

Get a gain factor vector from this lens shading map by its row and column.

The rows must be within the range [0, getRowCount()), the column must be within the range [0, getColumnCount()).

Parameters
column int: within the range [0, getColumnCount())

row int: within the range [0, getRowCount())

Returns
RggbChannelVector an RggbChannelVector where each gain factor >= .MINIMUM_GAIN_FACTOR

Throws
IllegalArgumentException if any of the parameters was out of range

getRowCount

Added in API level 21
public int getRowCount ()

Get the number of rows in this map.

Returns
int

hashCode

Added in API level 21
public int hashCode ()

Returns a hash code value for the object. This method is supported for the benefit of hash tables such as those provided by HashMap.

The general contract of hashCode is:

  • Whenever it is invoked on the same object more than once during an execution of a Java application, the hashCode method must consistently return the same integer, provided no information used in equals comparisons on the object is modified. This integer need not remain consistent from one execution of an application to another execution of the same application.
  • If two objects are equal according to the equals method, then calling the hashCode method on each of the two objects must produce the same integer result.
  • It is not required that if two objects are unequal according to the equals method, then calling the hashCode method on each of the two objects must produce distinct integer results. However, the programmer should be aware that producing distinct integer results for unequal objects may improve the performance of hash tables.

Returns
int a hash code value for this object.

toString

Added in API level 21
public String toString ()

Return the LensShadingMap as a string representation.

"LensShadingMap{R:([%f, %f, ... %f], ... [%f, %f, ... %f]), G_even:([%f, %f, ... %f], ... [%f, %f, ... %f]), G_odd:([%f, %f, ... %f], ... [%f, %f, ... %f]), B:([%f, %f, ... %f], ... [%f, %f, ... %f])}", where each %f represents one gain factor and each [%f, %f, ... %f] represents a row of the lens shading map

Returns
String string representation of LensShadingMap