Home | History | Annotate | Download | only in svg
      1 /*
      2  Copyright (C) 2007 Eric Seidel <eric (at) webkit.org>
      3 
      4  This file is part of the WebKit project
      5 
      6  This library is free software; you can redistribute it and/or
      7  modify it under the terms of the GNU Library General Public
      8  License as published by the Free Software Foundation; either
      9  version 2 of the License, or (at your option) any later version.
     10 
     11  This library is distributed in the hope that it will be useful,
     12  but WITHOUT ANY WARRANTY; without even the implied warranty of
     13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
     14  Library General Public License for more details.
     15 
     16  You should have received a copy of the GNU Library General Public License
     17  along with this library; see the file COPYING.LIB.  If not, write to
     18  the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
     19  Boston, MA 02110-1301, USA.
     20  */
     21 
     22 #include "config.h"
     23 #if ENABLE(SVG)
     24 #include "ColorDistance.h"
     25 #include "Color.h"
     26 #include <wtf/MathExtras.h>
     27 
     28 namespace WebCore {
     29 
     30 ColorDistance::ColorDistance()
     31     : m_redDiff(0)
     32     , m_greenDiff(0)
     33     , m_blueDiff(0)
     34 {
     35 }
     36 
     37 ColorDistance::ColorDistance(const Color& fromColor, const Color& toColor)
     38     : m_redDiff(toColor.red() - fromColor.red())
     39     , m_greenDiff(toColor.green() - fromColor.green())
     40     , m_blueDiff(toColor.blue() - fromColor.blue())
     41 {
     42 }
     43 
     44 ColorDistance::ColorDistance(int redDiff, int greenDiff, int blueDiff)
     45     : m_redDiff(redDiff)
     46     , m_greenDiff(greenDiff)
     47     , m_blueDiff(blueDiff)
     48 {
     49 }
     50 
     51 static inline int clampColorValue(int v)
     52 {
     53     if (v > 255)
     54         v = 255;
     55     else if (v < 0)
     56         v = 0;
     57     return v;
     58 }
     59 
     60 ColorDistance ColorDistance::scaledDistance(float scaleFactor) const
     61 {
     62     return ColorDistance(static_cast<int>(scaleFactor * m_redDiff),
     63                          static_cast<int>(scaleFactor * m_greenDiff),
     64                          static_cast<int>(scaleFactor * m_blueDiff));
     65 }
     66 
     67 Color ColorDistance::addColorsAndClamp(const Color& first, const Color& second)
     68 {
     69     return Color(clampColorValue(first.red() + second.red()),
     70                  clampColorValue(first.green() + second.green()),
     71                  clampColorValue(first.blue() + second.blue()));
     72 }
     73 
     74 Color ColorDistance::addToColorAndClamp(const Color& color) const
     75 {
     76     return Color(clampColorValue(color.red() + m_redDiff),
     77                  clampColorValue(color.green() + m_greenDiff),
     78                  clampColorValue(color.blue() + m_blueDiff));
     79 }
     80 
     81 bool ColorDistance::isZero() const
     82 {
     83     return (m_redDiff == 0 && m_blueDiff == 0 && m_greenDiff == 0);
     84 }
     85 
     86 float ColorDistance::distance() const
     87 {
     88     // This is just a simple distance calculation, not respecting color spaces
     89     return sqrtf(m_redDiff * m_redDiff + m_blueDiff * m_blueDiff + m_greenDiff * m_greenDiff);
     90 }
     91 
     92 }
     93 
     94 #endif
     95