xslt根据背景颜色亮度更改文字
有没有办法在xsl中根据背景颜色亮度将文本颜色更改为黑色或白色?
所以在下面的例子中,基于背景颜色的亮度,两个问候都应该有白色文本。 在xsl中是否有内置函数来完成此操作?
XSL
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="html"/>
<xsl:template match="greetings">
<xsl:apply-templates select="greeting"/>
</xsl:template>
<xsl:template match="greeting">
<html>
<body>
<h1>
<span>
<xsl:attribute name="style">
background-color: <xsl:value-of select="@backcolor"/>
color: <!-- Is there a way to make color black or white based on background color brightness? -->
</xsl:attribute>
<xsl:value-of select="."/>
</span>
</h1>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
XML
<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xsl" href="colortest.xslt"?> <!--todo: change this if copying to new file-->
<!--todo: change preceding line if copying to new file-->
<greetings>
<greeting id="1" backcolor="f59595">
Hello World!
</greeting>
<greeting id="2" backcolor="ff0000">
Hola!
</greeting>
</greetings>
您必须计算出RGB背景颜色的“亮度”值,然后设置一个阈值以确定前景颜色是否需要黑色或白色(以获得最佳对比度)。 不幸的是,XSLT(和XPath)没有提供任何处理颜色的函数,而且看到你被XSLT 1.0所困住(我假设 - 因为你在浏览器中使用它),事情会变得很冗长。 ..但仍然有可能...
尝试像这样...
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="html"/>
<xsl:variable name="vHexDigits" select="'0123456789abcdef'"/>
<xsl:template match="greetings">
<html>
<body>
<xsl:apply-templates select="greeting"/>
</body>
</html>
</xsl:template>
<xsl:template match="greeting">
<xsl:variable name="vLuminance">
<xsl:call-template name="RGB2Luminance">
<xsl:with-param name="pRed" select="(string-length(substring-before($vHexDigits, substring(@backcolor,1,1))) * 16) + string-length(substring-before($vHexDigits, substring(@backcolor,2,1)))"/>
<xsl:with-param name="pGreen" select="(string-length(substring-before($vHexDigits, substring(@backcolor,3,1))) * 16) + string-length(substring-before($vHexDigits, substring(@backcolor,4,1)))"/>
<xsl:with-param name="pBlue" select="(string-length(substring-before($vHexDigits, substring(@backcolor,5,1))) * 16) + string-length(substring-before($vHexDigits, substring(@backcolor,6,1)))"/>
</xsl:call-template>
</xsl:variable>
<xsl:variable name="vForegroundColor">
<xsl:choose>
<!-- assume our black/white forground threshold is 0.5 -->
<xsl:when test="$vLuminance > 0.5">
<xsl:text>black</xsl:text>
</xsl:when>
<xsl:otherwise>
<xsl:text>white</xsl:text>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<h1>
<span style="background-color: {@backcolor}; color: {$vForegroundColor};">
<xsl:value-of select="."/>
</span>
</h1>
</xsl:template>
<xsl:template name="RGB2Luminance">
<xsl:param name="pRed"/>
<xsl:param name="pGreen"/>
<xsl:param name="pBlue"/>
<xsl:variable name="vR" select="$pRed div 255"/>
<xsl:variable name="vG" select="$pGreen div 255"/>
<xsl:variable name="vB" select="$pBlue div 255"/>
<xsl:variable name="vMax">
<xsl:choose>
<xsl:when test="$vR >= $vG and $vR >= $vB">
<xsl:value-of select="$vR"/>
</xsl:when>
<xsl:when test="$vG >= $vR and $vG >= $vB">
<xsl:value-of select="$vG"/>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$vB"/>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:variable name="vMin">
<xsl:choose>
<xsl:when test="$vR <= $vG and $vR <= $vB">
<xsl:value-of select="$vR"/>
</xsl:when>
<xsl:when test="$vG <= $vR and $vG <= $vB">
<xsl:value-of select="$vG"/>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="$vB"/>
</xsl:otherwise>
</xsl:choose>
</xsl:variable>
<xsl:value-of select="($vMax + $vMin) div 2"/>
</xsl:template>
</xsl:stylesheet>
<?xml version="1.0" encoding="utf-8"?>
<?xml-stylesheet type="text/xml" href="XSLTFile2.xslt"?>
<greetings>
<greeting id="1" backcolor="f59595">
Hello World!
</greeting>
<greeting id="2" backcolor="ff0000">
Hola!
</greeting>
</greetings>
好的,如果您想使用css来控制背景颜色,请在您的XML中使用xml-stylesheet将其指向一个执行以下操作的XSLT文件。 此代码将根据listItemColor变量选择正确的样式表,并用正确的css样式表替换XML中的xml样式表。 (尽管我仍然不知道listItemColor如何获得它的价值,也许你可以告诉我们。)
创建两个样式表,一个用于光照,另一个用于黑暗。
以下是XSLTFile2.xslt文件:
<xsl:variable name="listItemColor" select="'b'"/>
<xsl:template match="processing-instruction('xml-stylesheet')">
<xsl:choose>
<xsl:when test="listItemColor ='a'">
<xsl:processing-instruction name="xml-stylesheet">
<xsl:text>type="text/css" href="colortest.css"</xsl:text>
</xsl:processing-instruction>
</xsl:when>
<xsl:otherwise>
<xsl:processing-instruction name="xml-stylesheet">
<xsl:text>type="text/css" href="colortest2.css"</xsl:text>
</xsl:processing-instruction>
</xsl:otherwise>
</xsl:choose>
</xsl:template>
<!-- Do any other processing. -->
<!-- Identity template.-->
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
链接地址: http://www.djcxy.com/p/87039.html