MySQLでRGBをHSLに変換します
質問
私のデータベースからHSLカラー値を取得しようとしています。現在、格納されているRGB値しかありません。 RGBの列を別々に入手しましょう。赤緑青はそれぞれ0-255の数値0~255です。
ターゲット結果は、RGB値から計算された結果セット内の色相飽和照明です。私はたくさんの計算を見ましたが、それらのどれもクエリでやるのは簡単に見えないようですか?あるいは、一般的にSQLに十分に深く、SCLICTステートメントのようなものをSQLに移植する方法を知ることはできません。
私が見つけた変換の最良の例はここにあります:
function rgbToHsl(r, g, b){
r /= 255, g /= 255, b /= 255;
var max = Math.max(r, g, b), min = Math.min(r, g, b);
var h, s, l = (max + min) / 2;
if(max == min){
h = s = 0; // achromatic
}else{
var d = max - min;
s = l > 0.5 ? d / (2 - max - min) : d / (max + min);
switch(max){
case r: h = (g - b) / d + (g < b ? 6 : 0); break;
case g: h = (b - r) / d + 2; break;
case b: h = (r - g) / d + 4; break;
}
h /= 6;
}
return [h, s, l];
}
.
しかし、私はSQLでこの計算のようなことをする方法についての答えのために完全に急増しました。
それが正しく機能しない後(上記のコードサンプルは、フエの変換のためにウィキペディアで見ることができるものから正しくありません。 'VEはArthから解決され、これに着いた、私は前にR、G、BのA / 255に、それが上記のコードサンプルから追従するのが簡単です。
CASE
WHEN r>=g AND g>=b THEN ((g-b)/(r-b))*60
WHEN g>r AND r>=b THEN (2-(r-b)/(g-b))*60
WHEN g>=b AND b>r THEN (2+(b-r)/(g-r))*60
WHEN b>g AND g>r THEN (4-(g-r)/(b-r))*60
WHEN b>r AND r>=g THEN (4+(r-g)/(b-g))*60
WHEN r>=b AND b>g THEN (6-(b-g)/(r-g))*60
END h,
CASE
WHEN r=g AND g=b THEN 0
WHEN r>=g AND g>=b AND (r-b)>0.5 THEN (r-b)/(2-r-b)
WHEN r>=g AND g>=b THEN (r-b)/(r+b)
WHEN r>=g AND b>g AND (r-g)>0.5 THEN (r-g)/(2-r-g)
WHEN r>=g AND b>g THEN (r-g)/(r+g)
WHEN g>=r AND r>=b AND (g-b)>0.5 THEN (g-b)/(2-g-b)
WHEN g>=r AND r>=b THEN (g-b)/(g+b)
WHEN g>=r AND b>r AND (g-r)>0.5 THEN (g-r)/(2-g-r)
WHEN g>=r AND b>r THEN (g-r)/(g+r)
WHEN b>=r AND r>=g AND (b-g)>0.5 THEN (b-g)/(2-b-g)
WHEN b>=r AND r>=g THEN (b-g)/(b+g)
WHEN b>=r AND g>r AND (b-r)>0.5 THEN (b-r)/(2-b-r)
WHEN b>=r AND g>r THEN (b-r)/(b+r)
END s,
CASE
WHEN r=g AND g=b THEN r
WHEN r>=g AND g>=b THEN (r+b)/2
WHEN r>=g AND b>g THEN (r+g)/2
WHEN g>=r AND r>=b THEN (g+r)/2
WHEN g>=r AND b>r THEN (g+b)/2
WHEN b>=r AND r>=g THEN (b+g)/2
WHEN b>=r AND g>r THEN (b+r)/2
END l
. 解決
それは絶対的な悪夢であり、テストされていないが、私は行く:
SELECT
CASE
WHEN r=g AND g=b THEN 0
WHEN r>=g AND g>b THEN ((g-b)/(r-b))/6
WHEN r>=g AND b>=g THEN ((g-b)/(r-g)+6)/6
WHEN g>=r AND r>=b THEN ((b-r)/(g-b)+2)/6
WHEN g>=r AND b>r THEN ((b-r)/(g-r)+2)/6
WHEN b>=r AND r>=g THEN ((r-g)/(b-g)+4)/6
WHEN b>=r AND g>r THEN ((r-g)/(b-r)+4)/6
END h,
CASE
WHEN r=g AND g=b THEN 0
WHEN r>=g AND g>=b AND (r-b)>0.5*255 THEN (r-b)/(510-r-b)
WHEN r>=g AND g>=b THEN (r-b)/(r+b)
WHEN r>=g AND b>g AND (r-g)>0.5*255 THEN (r-g)/(510-r-g)
WHEN r>=g AND b>g THEN (r-g)/(r+g)
WHEN g>=r AND r>=b AND (g-b)>0.5*255 THEN (g-b)/(510-g-b)
WHEN g>=r AND r>=b THEN (g-b)/(g+b)
WHEN g>=r AND b>r AND (g-r)>0.5*255 THEN (g-r)/(510-g-r)
WHEN g>=r AND b>r THEN (g-r)/(g+r)
WHEN b>=r AND r>=g AND (b-g)>0.5*255 THEN (b-g)/(510-b-g)
WHEN b>=r AND r>=g THEN (b-g)/(b+g)
WHEN b>=r AND g>r AND (b-r)>0.5*255 THEN (b-r)/(510-b-r)
WHEN b>=r AND g>r THEN (b-r)/(b+r)
END s,
CASE
WHEN r=g AND g=b THEN r/255
WHEN r>=g AND g>=b THEN (r+b)/510
WHEN r>=g AND b>g THEN (r+g)/510
WHEN g>=r AND r>=b THEN (g+r)/510
WHEN g>=r AND b>r THEN (g+b)/510
WHEN b>=r AND r>=g THEN (b+g)/510
WHEN b>=r AND g>r THEN (b+r)/510
END l
FROM table1
.
結論として、あなたはおそらくRGB値の選択とアプリケーションレベルでの変換を実行するのが良いでしょう!
所属していません StackOverflow