~ubuntu-branches/ubuntu/wily/oolite/wily-proposed

« back to all changes in this revision

Viewing changes to tools/planettool/FloatPixMap/FPMQuantize.c

  • Committer: Package Import Robot
  • Author(s): Nicolas Boulenguez
  • Date: 2011-12-22 00:22:39 UTC
  • mfrom: (1.2.2)
  • Revision ID: package-import@ubuntu.com-20111222002239-pr3upeupp4jw1psp
Tags: 1.76-1
* New upstream.
* watch: scan upstream stable releases instead of dev snapshots.
* control: use default gobjc instead of explicit 4.6.
* rules: use dpkg-dev build flags.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 *  FPMQuantize.c
 
3
 *  planettool
 
4
 *
 
5
 *  Created by Jens Ayton on 2009-10-01.
 
6
 *  Copyright 2009 Jens Ayton. All rights reserved.
 
7
 *
 
8
 */
 
9
 
 
10
#include "FPMQuantize.h"
 
11
#include "FPMImageOperations.h"
 
12
 
 
13
 
 
14
static float QuantizeComponentClip(float v, float srcToStepsFactor, float srcToStepsOffset, float stepsToTargetFactor, float stepMax, float targetMin)
 
15
{
 
16
        v = v * srcToStepsFactor - srcToStepsOffset;
 
17
        v = fmaxf(0.0f, fminf(v, stepMax));
 
18
        v = roundf(v);
 
19
        
 
20
        v = v * stepsToTargetFactor + targetMin;
 
21
        
 
22
        return v;
 
23
}
 
24
 
 
25
 
 
26
static float QuantizeComponent(float v, float srcToStepsFactor, float srcToStepsOffset, float stepsToTargetFactor, float targetMin)
 
27
{
 
28
        v = v * srcToStepsFactor - srcToStepsOffset;
 
29
        v = roundf(v);
 
30
        
 
31
        v = v * stepsToTargetFactor + targetMin;
 
32
        
 
33
        return v;
 
34
}
 
35
 
 
36
 
 
37
void FPMQuantize(FloatPixMapRef pm, float srcMin, float srcMax, float targetMin, float targetMax, unsigned steps, FPMQuantizeFlags options)
 
38
{
 
39
        if (pm == NULL)  return;
 
40
        
 
41
        float srcScale = srcMax - srcMin;
 
42
        float targetScale = targetMax - targetMin;
 
43
        float stepMax = steps - 1;
 
44
        float srcToStepsFactor = stepMax / srcScale;
 
45
        float srcToStepsOffset = srcToStepsFactor * srcMin;
 
46
        bool clip = options & kFMPQuantizeClip;
 
47
        float stepsToTargetFactor = targetScale / stepMax;
 
48
        
 
49
        // FIXME: implement dithering and jitter.
 
50
        if (clip)
 
51
        {
 
52
                FPM_FOR_EACH_PIXEL(pm, true)
 
53
                        pixel->r = QuantizeComponentClip(pixel->r, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, stepMax, targetMin);
 
54
                        pixel->g = QuantizeComponentClip(pixel->g, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, stepMax, targetMin);
 
55
                        pixel->b = QuantizeComponentClip(pixel->b, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, stepMax, targetMin);
 
56
                        pixel->a = QuantizeComponentClip(pixel->a, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, stepMax, targetMin);
 
57
                FPM_END_FOR_EACH_PIXEL
 
58
        }
 
59
        else
 
60
        {
 
61
                FPM_FOR_EACH_PIXEL(pm, true)
 
62
                        pixel->r = QuantizeComponent(pixel->r, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, targetMin);
 
63
                        pixel->g = QuantizeComponent(pixel->g, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, targetMin);
 
64
                        pixel->b = QuantizeComponent(pixel->b, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, targetMin);
 
65
                        pixel->a = QuantizeComponent(pixel->a, srcToStepsFactor, srcToStepsOffset, stepsToTargetFactor, targetMin);
 
66
                FPM_END_FOR_EACH_PIXEL
 
67
        }
 
68
}