【问题标题】:convert hsl to hsb将 hsl 转换为 hsb
【发布时间】:2012-08-02 22:13:32
【问题描述】:

将 HSL 转换为 HSB 的公式是什么?我只能找到可以轻松将 RGB 移植到 HSL 的代码。根据this stack overflow answer,我可以使用以下公式将 hsb 转换为 hsl:

(b - s) / 2

但我想另辟蹊径,(b+s) * 2 返回的值与 photoshop 的转换明显不同,例如:

?rgbtohsb(100,100,100) 年代:0 小时:0 乙:200 而 Photoshop 返回 0,0,39

这是我基于 easyrgb.com 网站的 rgb 到 hsl 代码的代码(这是用 Brightscript 编写的,Roku Digital Video Player 的基本类似语言):

function RGBtoHSB(r as integer, g as integer, b as integer) as object
hue=0.0
var_R = ( R / 255 )
?"var_R=";var_r
var_G = ( G / 255 )
?"var_g=";var_g
var_B = ( B / 255 )
?"var_b=";var_b
var_Min = min([ var_R, var_G, var_B ])    'Min. value of RGB
?"var_min=";var_min
var_Max = max([ var_R, var_G, var_B ])    'Max. value of RGB
?"var_max=";var_max
del_Max = var_Max - var_Min             'Delta RGB value
?"del_max=";del_max



LUM = ( var_Max + var_Min ) / 2
?"LUM=";LUM
if ( del_Max = 0 )                     'This is a gray, no chroma...
?"del_max=0"
   HUE = 0                                'HSL results from 0 to 1
   SAT = 0
else                                    'Chromatic data...
?"del_max";del_max
   if ( LUM < 0.5 ) then 
        SAT = del_Max / ( var_Max + var_Min )
        ?"Lum < 0.5 so SAt=";sat
   else           
   ?"LUM > 0.5, LUM=";LUM
        SAT = del_Max / ( 2 - var_Max - var_Min )
        ?"SAT=";SAT

       del_R = ( ( ( var_Max - var_R ) / 6 ) + ( del_Max / 2 ) ) / del_Max
       ?"del_r=";del_r
       del_G = ( ( ( var_Max - var_G ) / 6 ) + ( del_Max / 2 ) ) / del_Max
       ?"del_g=";del_g
       del_B = ( ( ( var_Max - var_B ) / 6 ) + ( del_Max / 2 ) ) / del_Max
       ?"del_b=";del_b


       if var_R = var_Max THEN
           HUE = del_B - del_G
           ?"var_r=var_max, so HUE=";hue
       else if ( var_G = var_Max ) then 
           HUE = ( 1 / 3 ) + del_R - del_B
           ?"var_g=var_max so HUE=";hue
       else if ( var_B = var_Max ) then 
           HUE = ( 2 / 3 ) + del_G - del_R
           ?"var_b=var_max so HUE=";hue
       end if



       if ( HUE < 0 ) then 
           HUE = HUE + 1
           ?"hue < 0 so hue=";hue
       end if
       if ( HUE > 1 ) then 
           HUE = HUE - 1
           ?"hue > 1 so hue=";hue
       end if

    end if
end if


?"sleeping"
sleep(5000)

bri=0.0
bri=(lum+sat) *2
?"hue=";HUE;" SAT=";sat;" LUM=";lum;" bri=";bri 

return {h:int(hue*255),s:int(sat*255),l:int(lum*255),b:int(bri*255)}
end function

【问题讨论】:

    标签: rgb hsl hsb


    【解决方案1】:

    我编写了一些函数,用于直接从 HSV 转换 HSL 并返回。 但是,它假定 S、L、B 和 V 值的范围是从 0 到 1,而不是从 0 到 100。此外,这些函数使用 C# 而不是 BrightScript。

    https://gist.github.com/4085710

    代码已发布到公共领域。

    【讨论】:

      【解决方案2】:

      This Answer

      相关

      两者的色调相同,所以让我们看看数学:

      var SL = {s:0, l:0},
          SB = {s:0, b:0};
      
      function sb2sl(){
        var l = (2 - SB.s / 100) * SB.b / 2;              // Lightness range 0-100
        SL.s = Math.round( SB.s * SB.b / (l<50 ? l * 2 : 200 - l * 2) ) |0;
        SL.l = Math.round( l );
      }
      function sl2sb(){
        var t = SL.s * (SL.l<50 ? SL.l : 100-SL.l) / 100; // Temp value
        SB.s = Math.round( 200 * t / (SL.l+t) ) |0;
        SB.b = Math.round( t+SL.l );
      }
      // Above, the "|0" prevents the NaN while dividing by 0
      

      另见:http://code.stephenmorley.org/javascript/colour-handling-and-processing/

      【讨论】:

        猜你喜欢
        • 2011-03-26
        • 2013-03-18
        • 1970-01-01
        • 2011-05-05
        • 2021-06-29
        • 2015-03-11
        • 2016-08-11
        • 1970-01-01
        • 2014-09-21
        相关资源
        最近更新 更多