normalize function

Image normalize(
  1. Image src,
  2. int minValue,
  3. int maxValue
)

Linearly normalize the colors of the image. All color values will be mapped to the range minValue, maxValue inclusive.

Implementation

Image normalize(Image src, int minValue, int maxValue) {
  final A = minValue < maxValue ? minValue : maxValue;
  final B = minValue < maxValue ? maxValue : minValue;

  final mM = minMax(src);
  final m = mM[0];
  final M = mM[1];

  final fm = m.toDouble();
  final fM = M.toDouble();

  if (m == M) {
    return fill(src, minValue);
  }

  if (m != A || M != B) {
    final p = src.getBytes();
    for (var i = 0, len = p.length; i < len; i += 4) {
      p[i] = ((p[i] - fm) / (fM - fm) * (B - A) + A).toInt();
      p[i + 1] = ((p[i + 1] - fm) / (fM - fm) * (B - A) + A).toInt();
      p[i + 2] = ((p[i + 2] - fm) / (fM - fm) * (B - A) + A).toInt();
      p[i + 3] = ((p[i + 3] - fm) / (fM - fm) * (B - A) + A).toInt();
    }
  }

  return src;
}