这个公式对我来说很简单;为什么你认为它“对于 XSLT 来说太复杂了”?
看起来您最初的问题是您不知道如何在 XSLT 1.0 中将十六进制数转换为十进制数。这是一个简单的模板来做到这一点;它接受两位十六进制数并返回等效的十进制数。
<!--* Given a two-digit hex string, return the equivalent number in decimal. *-->
<xsl:template name="hex_to_dec">
<xsl:param name="raw-hex" select="'00'"/>
<!--* a list of hex digits, in numerical order *-->
<xsl:variable name="hex-digits" select="'0123456789ABCDEF'"/>
<!--* strip space and uppercase a-f *-->
<xsl:variable name="xy"
select="normalize-space(translate($raw-hex,'abcdef','ABCDEF'))"/>
<xsl:choose>
<xsl:when test="translate($xy,$hex-digits,'') != ''">
<xsl:message><xsl:value-of select="$raw-hex"
/> is not a legal hexadecimal string</xsl:message>
</xsl:when>
<xsl:when test="string-length($xy) < 2">
<xsl:message>Hex string too short</xsl:message>
</xsl:when>
<xsl:when test="string-length($xy) > 2">
<xsl:message>Hex string too long</xsl:message>
</xsl:when>
<xsl:otherwise>
<xsl:variable name="X" select="substring($xy,1,1)"/>
<xsl:variable name="Y" select="substring($xy,2,1)"/>
<xsl:variable name="Xval"
select="string-length(substring-before($hex-digits,$X))"/>
<xsl:variable name="Yval"
select="string-length(substring-before($hex-digits,$Y))"/>
<xsl:value-of select="16 * $Xval + $Yval"/>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
如果我是你,我会首先编写一个模板,命名rgb_to_hsl
为接受 0 255 之间的三个十进制数字作为参数 R、G 和 B,并计算一个 HSL 字符串。然后我会编写第二个模板来接受 RGB 十六进制字符串,解析出红色、绿色和蓝色的十六进制值,使用上面给出的模板将它们转换为小数,然后调用rgb_to_hsl
.