- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想显示一些图像,如本例
填充颜色由数据库中的字段决定,颜色为十六进制(例如:ClassX -> Color:#66FFFF)。现在,我想在填充上方显示所选颜色的数据(如上图所示),但我需要知道颜色是深色还是浅色,这样我就知道单词应该是白色还是黑色。有办法吗?谢了
最佳答案
建立在我的answer to a similar question之上.
您需要将十六进制代码分成 3 部分才能获得单独的红色、绿色和蓝色强度。代码的每 2 位数字代表一个十六进制(基数 16)表示法的值。我不会在这里详细介绍转换的细节,它们很容易查找。
获得各个颜色的强度后,您可以确定颜色的整体强度并选择相应的文本。
if (red*0.299 + green*0.587 + blue*0.114) > 186 use #000000 else use #ffffff
186 的阈值是基于理论的,但可以根据口味进行调整。根据评论,低于 150 的阈值可能更适合您。
<小时/>编辑:上面的代码很简单,而且工作得相当好,并且似乎在 StackOverflow 上得到了很好的接受。然而,下面的评论之一表明,在某些情况下,它可能会导致不遵守 W3C 准则。在此,我得出了一种修改后的形式,该形式始终根据指南选择最高对比度。如果您不需要需要遵守 W3C 规则,那么我会坚持使用上面更简单的公式。有关此问题的有趣研究,请参阅 Contrast Ratio Math and Related Visual Issues .
W3C Recommendations (WCAG 2.0) 中给出的对比度公式为 (L1 + 0.05)/(L2 + 0.05)
,其中 L1
是最浅颜色的亮度,L2
是最浅颜色的亮度最暗的等级为 0.0-1.0。黑色的亮度为 0.0,白色的亮度为 1.0,因此替换这些值可以让您确定对比度最高的值。如果黑色的对比度大于白色的对比度,则使用黑色,否则使用白色。假设您正在测试的颜色的亮度为 L
,则测试将变为:
if (L + 0.05) / (0.0 + 0.05) > (1.0 + 0.05) / (L + 0.05) use #000000 else use #ffffff
这从代数上简化为:
if L > sqrt(1.05 * 0.05) - 0.05
或者大约:
if L > 0.179 use #000000 else use #ffffff
剩下的唯一事情就是计算L
。该公式也是 given in the guidelines看起来像是从 sRGB 到线性 RGB 的转换,然后是 ITU-R recommendation BT.709亮度。
for each c in r,g,b:
c = c / 255.0
if c <= 0.04045 then c = c/12.92 else c = ((c+0.055)/1.055) ^ 2.4
L = 0.2126 * r + 0.7152 * g + 0.0722 * b
阈值 0.179 不应更改,因为它与 W3C 准则相关。如果您发现结果不符合您的喜好,请尝试上面更简单的公式。
关于colors - 如何根据背景颜色决定字体颜色为白色或黑色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3942878/
这是一道函数依赖题。 我知道当 x->yz 然后 x->y 和 x->z 时。但是上面的依赖关系可能吗? 最佳答案 If xy determines z can x determine z and y
我有一个奇怪的问题。 Line 61: $this->_currentRoute = Default_Model_Routes::getInstance()->getCurrentRoute(); .
我正在开发一种工具来比较两个波形文件的波形相似性。例如,我有一个持续时间为 1 分钟的波形文件,我使用第一个波形文件制作了另一个波形文件,但每 5 秒生成一次数据,间隔为 5 秒至 0。 现在我的软件
我遇到了一个奇怪的问题,尽管我打赌有一个巧妙的方法可以解决它。 情况是我有一个具有三列排序状态的表:完全未排序,在这种情况下我不希望出现任何图标,按升序排序,在这种情况下我想要一个向上箭头,以及按降序
Java 语言规范提供了criteria用于确定(格式良好的)执行是否满足“Java 内存模型的因果关系要求”。让我们假设执行是有限的。我试图了解是否存在多项式时间算法来证明或反驳这种情况。 真的,我
Java 语言规范提供了criteria用于确定(格式良好的)执行是否满足“Java 内存模型的因果关系要求”。让我们假设执行是有限的。我试图了解是否存在多项式时间算法来证明或反驳这种情况。 真的,我
我正在编写一个简单的Bank类,其中包含Account。我希望人员能够开设一个新的受密码保护的银行帐户,并从其帐户中提取和存入资金。账户设在银行内。银行和帐户类应提供哪些服务? 假设 p 已在银行 b
我的标题概括了这一点。我有一个将要开发的简单业务线应用程序,并且很好奇如何确定我应该针对哪个 .NET 版本。支持 Win XP SP3 会很好,但不是必需的。它将用于索引多页 tiff,因此导入一批
已锁定。这个问题及其答案是locked因为这个问题是题外话,但却具有历史意义。目前不接受新的答案或互动。 你是否真的“尝试过”(意味着在其中编程,而不仅仅是阅读有关它的文章)Erlang并决定在项目中
我正在尝试使用 ExceptionFilterAttribute 为 Web Api 实现异常处理。我已经继承了ExceptionFilterAttribute 类并覆盖了onException 方法
前一段时间在一次编程比赛中我遇到了一个令人费解的问题,此后一直困扰着我。虽然我没有逐字记住,但我会尽力重现: Jack starts at 0 on the number line and jumps
我有什么: 我有一个主要内容区域,后面跟着两个旁白: #primary,#secondary,#tertiary{float:left; width:33%;} Primary
我无法正确操作键盘。 整个 View 充满了文本字段。 当我使用通知将 View 向上移动时,上方的文本框不再可见: override func viewDidLoad() { super.v
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我在尝试获取父对象来过滤子事件时遇到问题。 在下面的示例中,我在旋转框上设置了一个事件过滤器。事件过滤器检测旋转框上的鼠标按下事件。然后,我希望父对象根据某些标准接受或忽略该事件。 问题是它似乎接受了
我使用从 std::system_error 继承的类进行错误处理,我想控制调用 what() 时返回的内容。原因:标准(C++11 和 C++1y CD 草案 - N3690,下面的 § 引用是后者
我正在用 Swift 构建一个 iOS 应用程序,它的起始页有 6 个按钮。这些按钮中的每一个都将连接到一个 TableView Controller ,其数据由 NSFetchedResultsCo
我想构建这样的东西 数据存储| mycode.py | RESTful API | mywebapp.py(Django 或 Tornado) 我检查了 Django 的 Piston,但似乎这样我就
究竟如何更改 RichTextBox 中的字体? 环顾四周给了我似乎不再有效的旧答案。我认为这就像执行 richtextbox1.Font = Font.Bold; 或类似操作一样简单。原来不是,所以
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 7 年前。 Improve this qu
我是一名优秀的程序员,十分优秀!