1 /*****************************************************************************/ 2 // Copyright 2007 Adobe Systems Incorporated 3 // All Rights Reserved. 4 // 5 // NOTICE: Adobe permits you to use, modify, and distribute this file in 6 // accordance with the terms of the Adobe license agreement accompanying it. 7 /*****************************************************************************/ 8 9 /* $Id: //mondo/dng_sdk_1_4/dng_sdk/source/dng_tone_curve.cpp#1 $ */ 10 /* $DateTime: 2012/05/30 13:28:51 $ */ 11 /* $Change: 832332 $ */ 12 /* $Author: tknoll $ */ 13 14 /*****************************************************************************/ 15 16 #include "dng_tone_curve.h" 17 18 #include "dng_assertions.h" 19 #include "dng_spline.h" 20 #include "dng_utils.h" 21 22 /******************************************************************************/ 23 24 dng_tone_curve::dng_tone_curve () 25 26 : fCoord () 27 28 { 29 30 SetNull (); 31 32 } 33 34 /******************************************************************************/ 35 36 bool dng_tone_curve::operator== (const dng_tone_curve &curve) const 37 { 38 39 return fCoord == curve.fCoord; 40 41 } 42 43 /******************************************************************************/ 44 45 void dng_tone_curve::SetNull () 46 { 47 48 fCoord.resize (2); 49 50 fCoord [0].h = 0.0; 51 fCoord [0].v = 0.0; 52 53 fCoord [1].h = 1.0; 54 fCoord [1].v = 1.0; 55 56 } 57 58 /******************************************************************************/ 59 60 bool dng_tone_curve::IsNull () const 61 { 62 63 dng_tone_curve temp; 64 65 return (*this == temp); 66 67 } 68 69 /******************************************************************************/ 70 71 void dng_tone_curve::SetInvalid () 72 { 73 74 fCoord.clear (); 75 76 } 77 78 /******************************************************************************/ 79 80 bool dng_tone_curve::IsValid () const 81 { 82 83 if (fCoord.size () < 2) 84 { 85 86 return false; 87 88 } 89 90 for (uint32 j = 0; j < fCoord.size (); j++) 91 { 92 93 if (fCoord [j] . h < 0.0 || fCoord [j] . h > 1.0 || 94 fCoord [j] . v < 0.0 || fCoord [j] . v > 1.0) 95 { 96 97 return false; 98 99 } 100 101 if (j > 0) 102 { 103 104 if (fCoord [j] . h <= fCoord [j - 1] . h) 105 { 106 107 return false; 108 109 } 110 111 } 112 113 } 114 115 return true; 116 117 } 118 119 /******************************************************************************/ 120 121 void dng_tone_curve::Solve (dng_spline_solver &solver) const 122 { 123 124 solver.Reset (); 125 126 for (uint32 index = 0; index < fCoord.size (); index++) 127 { 128 129 solver.Add (fCoord [index].h, 130 fCoord [index].v); 131 132 } 133 134 solver.Solve (); 135 136 } 137 138 /*****************************************************************************/ 139