Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Find nearest color JS #2356

Closed
wants to merge 45 commits into from
Closed
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
45 commits
Select commit Hold shift + click to select a range
a1a96d5
Create HotcueColorPalette class
ferranpujolcamins Oct 27, 2019
9af324c
Add methods to store QColor in the config
ferranpujolcamins Oct 27, 2019
39d8624
Add class to store HotcueColorPalette in userconfig
ferranpujolcamins Oct 27, 2019
a25b3a8
Add tests for color config methods
ferranpujolcamins Nov 1, 2019
547a1f7
Merge branch 'master' into new_colors_impl
ferranpujolcamins Nov 1, 2019
f4c29b2
Make Cue related code use QColor
ferranpujolcamins Nov 2, 2019
ece9385
Migrate hotcue color id to RGBA in DB
ferranpujolcamins Nov 2, 2019
ae4907e
Remove PredefinedColorRepresentation
ferranpujolcamins Nov 2, 2019
4367fe3
Make UserSettings available in ControllerEngine
ferranpujolcamins Nov 3, 2019
bfe25a3
Remove PredefinedColors from controller scripts
ferranpujolcamins Nov 3, 2019
e99e1a8
Remove PredefinedColor
ferranpujolcamins Nov 3, 2019
223911e
Update midi-components library
ferranpujolcamins Nov 3, 2019
150cddf
Avoid constructing HotcueColorPaletteSettings every time its used
ferranpujolcamins Nov 3, 2019
44ffe5d
Change test names
ferranpujolcamins Nov 4, 2019
89927fe
Reorder constructor parameters
ferranpujolcamins Nov 4, 2019
91067eb
Rename member variable
ferranpujolcamins Nov 4, 2019
3233dc3
Rename some color related classes
ferranpujolcamins Nov 4, 2019
768c306
Remove cues tab on TrackInfo
ferranpujolcamins Nov 4, 2019
03b4f06
Add QColorDialog to ColorMenu
ferranpujolcamins Nov 4, 2019
a16a290
Merge branch 'master' into new_colors_impl
ferranpujolcamins Nov 11, 2019
5f22b90
Set hotcue color to the first predefined color
ferranpujolcamins Nov 11, 2019
1bc6c77
Set hotcue color CO to -1 when no hotcue is loaded
ferranpujolcamins Nov 11, 2019
fc22b25
Make hotcue skin buttons use the cue color
ferranpujolcamins Nov 11, 2019
85a3762
Pass UserSettings to Controller constructor
ferranpujolcamins Nov 11, 2019
3027abd
Format code
ferranpujolcamins Nov 11, 2019
53a0877
Rename members
ferranpujolcamins Nov 11, 2019
83892d2
Change string literal
ferranpujolcamins Nov 11, 2019
b858137
Allow skins to configure text color depending on background
ferranpujolcamins Nov 11, 2019
bde2fa8
Highlight hotcue buttons when hovered
ferranpujolcamins Nov 11, 2019
c35de30
Fix Shade hotcue buttons color
ferranpujolcamins Nov 12, 2019
7930270
Make hotcue button hover highlighting configurable
ferranpujolcamins Nov 12, 2019
efda2b1
Merge branch 'master' into new_colors_impl
ferranpujolcamins Nov 12, 2019
318025e
src/controllers/colorjsproxy: Add nearestColorMidiCode function
Holzhaus Nov 14, 2019
77b3f55
res/controllers/midi-components: Update HotcueButton to use new API
Holzhaus Nov 14, 2019
ad38a40
Roland DJ-505: Update controller script for new color API
Holzhaus Nov 14, 2019
b873ca2
src/controllers/colorjsproxy: Fix indentation in colorDistance function
Holzhaus Nov 15, 2019
1d05858
src/controllers/colorjsproxy: Add comment to colorDistance algorithm
Holzhaus Nov 15, 2019
2b61025
src/controllers: Add ColorMapper class for controller scripts
Holzhaus Nov 16, 2019
a24b22a
res/controllers/midi-components: Add support for ColorMapper class
Holzhaus Nov 16, 2019
3f42532
Roland DJ-505: Add support for ColorMapper class
Holzhaus Nov 16, 2019
efde9e4
controllers/colormapperjsproxy: Add separate getNearestValue method
Holzhaus Nov 19, 2019
b94a72f
Roland DJ-505: Switch to ControllerMapper::getNearestValue
Holzhaus Nov 19, 2019
73de6dc
midi-components: Remove default value for HotcueButton.colors
Holzhaus Nov 19, 2019
d4cda18
controllers/midi-components: Rename HotcueButton.colors to .colorMapper
Holzhaus Nov 19, 2019
c6c467b
Roland DJ-505: Rename Component.colors to .colorMapper
Holzhaus Nov 19, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
41 changes: 24 additions & 17 deletions res/controllers/Roland_DJ-505-scripts.js
Original file line number Diff line number Diff line change
Expand Up @@ -941,17 +941,24 @@ DJ505.PadColor = {
DIM_MODIFIER: 0x10,
};

DJ505.PadColorMap = [
DJ505.PadColor.OFF,
DJ505.PadColor.RED,
DJ505.PadColor.GREEN,
DJ505.PadColor.BLUE,
DJ505.PadColor.YELLOW,
DJ505.PadColor.CELESTE,
DJ505.PadColor.PURPLE,
DJ505.PadColor.APRICOT,
DJ505.PadColor.WHITE,
];
DJ505.PadColorMap = {
'#FFCC0000': DJ505.PadColor.RED,
'#FFCC4400': DJ505.PadColor.CORAL,
'#FFCC8800': DJ505.PadColor.ORANGE,
'#FFCCCC00': DJ505.PadColor.YELLOW,
'#FF88CC00': DJ505.PadColor.GREEN,
'#FF00CC00': DJ505.PadColor.APPLEGREEN,
'#FF00CC88': DJ505.PadColor.AQUAMARINE,
'#FF00CCCC': DJ505.PadColor.TURQUOISE,
'#FF0088CC': DJ505.PadColor.CELESTE,
'#FF0000CC': DJ505.PadColor.BLUE,
'#FF4400CC': DJ505.PadColor.AZURE,
'#FF8800CC': DJ505.PadColor.PURPLE,
'#FFCC00CC': DJ505.PadColor.MAGENTA,
'#FFCC0044': DJ505.PadColor.RED,
'#FFFFCCCC': DJ505.PadColor.APRICOT,
'#FFFFFFFF': DJ505.PadColor.WHITE,
};

DJ505.PadSection = function (deck, offset) {
// TODO: Add support for missing modes (flip, slicer, slicerloop)
Expand Down Expand Up @@ -1190,7 +1197,7 @@ DJ505.HotcueMode = function (deck, offset) {
this.ledControl = DJ505.PadMode.HOTCUE;
this.color = DJ505.PadColor.WHITE;

var hotcueColors = [this.color].concat(DJ505.PadColorMap.slice(1));
var hotcueColors = DJ505.PadColorMap;
this.pads = new components.ComponentContainer();
for (var i = 0; i <= 7; i++) {
this.pads[i] = new components.HotcueButton({
Expand Down Expand Up @@ -1226,7 +1233,7 @@ DJ505.CueLoopMode = function (deck, offset) {
this.ledControl = DJ505.PadMode.HOTCUE;
this.color = DJ505.PadColor.BLUE;

var cueloopColors = [this.color].concat(DJ505.PadColorMap.slice(1));
var cueloopColors = DJ505.PadColorMap;
this.PerformancePad = function(n) {
this.midi = [0x94 + offset, 0x14 + n];
this.number = n + 1;
Expand Down Expand Up @@ -1492,7 +1499,7 @@ DJ505.PitchPlayMode = function (deck, offset) {
this.color = DJ505.PadColor.GREEN;
this.cuepoint = 1;
this.range = PitchPlayRange.MID;
var pitchplayColors = [this.color].concat(DJ505.PadColorMap.slice(1));
var pitchplayColors = DJ505.PadColorMap;

this.PerformancePad = function(n) {
this.midi = [0x94 + offset, 0x14 + n];
Expand All @@ -1510,10 +1517,10 @@ DJ505.PitchPlayMode = function (deck, offset) {
mode: this,
outConnect: false,
off: DJ505.PadColor.OFF,
outputColor: function(id) {
outputColor: function(colorCode) {
// For colored hotcues (shifted only)
var color = this.colors[id];
this.send((this.mode.cuepoint === this.number) ? color : (color + DJ505.PadColor.DIM_MODIFIER));
var midiColor = color.nearestColorMidiCode(colorCode, this.colors)
this.send((this.mode.cuepoint === this.number) ? midiColor : (midiColor + DJ505.PadColor.DIM_MODIFIER));
},
unshift: function() {
this.outKey = "pitch_adjust";
Expand Down
17 changes: 7 additions & 10 deletions res/controllers/midi-components-0.0.js
Original file line number Diff line number Diff line change
Expand Up @@ -330,20 +330,17 @@
this.send(outval);
}
},
outputColor: function (id) {
var color = this.colors[id];
if (color instanceof Array) {
if (color.length !== 3) {
print("ERROR: invalid color array for id: " + id);
return;
}
outputColor: function (colorCode) {
if (this.colors !== undefined) {
var nearestColor = color.nearestColorMidiCode(colorCode, this.colors);
print("COLOR = "+nearestColor);
this.send(nearestColor);
} else {
if (this.sendRGB === undefined) {
print("ERROR: no function defined for sending RGB colors");
return;
}
this.sendRGB(color);
} else if (typeof color === 'number') {
this.send(color);
this.sendRGB(color.colorFromHexCode(colorCode));
}
},
connect: function() {
Expand Down
45 changes: 45 additions & 0 deletions src/controllers/colorjsproxy.cpp
Original file line number Diff line number Diff line change
@@ -1,6 +1,24 @@
#include <cstdint>
#include <cmath>
#include "controllers/colorjsproxy.h"
#include "preferences/hotcuecolorpalettesettings.h"

namespace {
double colorDistance(QColor a, QColor b)
{
long mean_red = ((long)a.red() + (long)b.red()) / 2;
Holzhaus marked this conversation as resolved.
Show resolved Hide resolved
long delta_red = (long)a.red() - (long)b.red();
long delta_green = (long)a.green() - (long)b.green();
long delta_blue = (long)a.blue() - (long)b.blue();
return sqrt(
(((512 + mean_red) * delta_red * delta_red) >> 8) +
(4 * delta_green * delta_green) +
(((767 - mean_red) * delta_blue * delta_blue) >> 8)
);
}
}


ColorJSProxy::ColorJSProxy(QScriptEngine* pScriptEngine,
HotcueColorPaletteSettings colorPaletteSettings)
: m_pScriptEngine(pScriptEngine),
Expand All @@ -25,6 +43,33 @@ QScriptValue ColorJSProxy::colorFromHexCode(uint colorCode) {
return jsColor;
}

QScriptValue ColorJSProxy::nearestColorMidiCode(uint colorCode, QVariantMap availableColors) {
QColor desiredColor = QColor::fromRgba(colorCode);
uint nearestColorValue = 0;
double nearestColorDistance = qInf();
QMapIterator<QString, QVariant> it(availableColors);
while (it.hasNext()) {
it.next();
QColor availableColor(it.key());
VERIFY_OR_DEBUG_ASSERT(availableColor.isValid()) {
qWarning() << "Received invalid color name from controller script:" << it.key();
continue;
}

double distance = colorDistance(desiredColor, availableColor);
if (distance < nearestColorDistance) {
nearestColorDistance = distance;
bool valueOk;
nearestColorValue = it.value().toUInt(&valueOk);
VERIFY_OR_DEBUG_ASSERT(availableColor.isValid()) {
qWarning() << "Failed to convert value to uint:" << it.value();
}
qDebug() << "Match for " << desiredColor << " -> " << availableColor << "(distance =" << distance << ", value = " << nearestColorValue << ")";
}
}
return nearestColorValue;
}

QScriptValue ColorJSProxy::makeHotcueColorPalette(QScriptEngine* pScriptEngine,
HotcueColorPaletteSettings colorPaletteSettings) {
// TODO: make sure we get notified when the palette changes
Expand Down
1 change: 1 addition & 0 deletions src/controllers/colorjsproxy.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ class ColorJSProxy final : public QObject {
// of a color. The parameter is the hexadecimal representation of the color
// i.e. 0xAARRGGBB
Q_INVOKABLE QScriptValue colorFromHexCode(uint colorCode);
Q_INVOKABLE QScriptValue nearestColorMidiCode(uint colorCode, QVariantMap availableColorCodes);

private:
QScriptValue makeHotcueColorPalette(QScriptEngine* pScriptEngine,
Expand Down