init
This commit is contained in:
94
lib/engine/rs_color.cpp
Normal file
94
lib/engine/rs_color.cpp
Normal file
@@ -0,0 +1,94 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** This file is part of the LibreCAD project, a 2D CAD program
|
||||
**
|
||||
** Copyright (C) 2020 A. Stebich (librecad@mail.lordofbikes.de)
|
||||
** Copyright (C) 2010 R. van Twisk (librecad@rvt.dds.nl)
|
||||
** Copyright (C) 2001-2003 RibbonSoft. All rights reserved.
|
||||
**
|
||||
**
|
||||
** This file may be distributed and/or modified under the terms of the
|
||||
** GNU General Public License version 2 as published by the Free Software
|
||||
** Foundation and appearing in the file gpl-2.0.txt included in the
|
||||
** packaging of this file.
|
||||
**
|
||||
** This program is distributed in the hope that it will be useful,
|
||||
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
** GNU General Public License for more details.
|
||||
**
|
||||
** You should have received a copy of the GNU General Public License
|
||||
** along with this program; if not, write to the Free Software
|
||||
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||
**
|
||||
** This copyright notice MUST APPEAR in all copies of the script!
|
||||
**
|
||||
**********************************************************************/
|
||||
|
||||
|
||||
#include <iostream>
|
||||
#include <cmath>
|
||||
#include "rs_color.h"
|
||||
|
||||
//This method is used for plugins
|
||||
int RS_Color::toIntColor(void) const {
|
||||
if (isByLayer())
|
||||
return -1;
|
||||
if (isByBlock())
|
||||
return -2;
|
||||
// int tmp1 = red() << 16;
|
||||
// int tmp2 = green() << 8;
|
||||
// int tmp3 = tmp1+tmp2+blue();
|
||||
int cd = (red() << 16) + (green() << 8) + blue();
|
||||
return cd;
|
||||
|
||||
}
|
||||
|
||||
//This method is used for plugins
|
||||
void RS_Color::fromIntColor(int co) {
|
||||
if (co == -1)
|
||||
setFlags(RS2::FlagByLayer);
|
||||
else if (co == -2)
|
||||
setFlags(RS2::FlagByBlock);
|
||||
else {
|
||||
setRed((co >> 16) & 0xFF);
|
||||
setGreen((co >> 8) & 0xFF);
|
||||
setBlue(co & 0xFF);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* Color distance
|
||||
*
|
||||
* Calculate distance between two RGB colors using low-cost approximation of
|
||||
* human eye response by Thiadmer Riemersma. Formula explanation found here:
|
||||
* https://www.compuphase.com/cmetric.htm
|
||||
*
|
||||
* @author Thiadmer Riemersma
|
||||
* @author Jeremy Ruhland
|
||||
*
|
||||
* @param c Color to perform comparison against
|
||||
*
|
||||
* @return Distance between colors in percent, value ranging from 0 (identical)
|
||||
* to 100 (maximum difference)
|
||||
*/
|
||||
int RS_Color::colorDistance(const RS_Color& c) const {
|
||||
|
||||
int myRed {red()};
|
||||
int otherRed {c.red()};
|
||||
int redMean {(myRed + otherRed) / 2};
|
||||
|
||||
// Convert difference value to percentage using maximum color difference (764.834 / 100)
|
||||
return std::lround( std::sqrt( std::pow(otherRed - myRed, 2) * (512 + redMean) / 256
|
||||
+ std::pow(c.green() - green(), 2) * 4
|
||||
+ std::pow(c.blue() - blue(), 2) * (767 - redMean) / 256)
|
||||
/ 7.64834);
|
||||
}
|
||||
|
||||
std::ostream& operator << (std::ostream& os, const RS_Color& c) {
|
||||
os << " color: " << c.name().toLatin1().data()
|
||||
<< " flags: " << (c.getFlag(RS2::FlagByLayer) ? "RS2::FlagByLayer " : "")
|
||||
<< (c.getFlag(RS2::FlagByBlock) ? "RS2::FlagByBlock " : "");
|
||||
return os;
|
||||
}
|
||||
Reference in New Issue
Block a user