1

在数据库中,我仅以 MS Access 颜色格式(BGR 的十进制格式)存储颜色:它看起来像 8689859 => brown => #c39884 ...但我需要按颜色范围进行过滤,我的意思是用户使用颜色选择器并选择例如。#ffffff 颜色。而且我想返回颜色与#ffffff 相似的所有行(颜色不完全相同,但在同一范围内 +- )。

这样的事情可能吗?

4

1 回答 1

1

我想 =- 范围应该适用于 BGR 值中的每个单独的颜色元素。在这种情况下,您需要提取这些元素,如下所示:

SELECT colour
      ,Fix([Colour]/(256*256)) as B
      ,Fix(([Colour]-Fix([Colour]/(256*256))*256*256)/256) as G
      ,[Colour]-Fix([Colour]/(256*256))*256*256-Fix(([Colour]-Fix([Colour]/(256*256))*256*256)/256)*256 as R
FROM MyColours

我建议您将它们放入单独的函数中,例如 GetR、GetB、GetG

您甚至可以制作计算字段并将它们应用到您的表中:

带有计算字段的颜色表

现在,要查找您的表格,您还需要在 BGR 元素中拆分所选颜色:

Dim selectedColour as Integer
Dim rr as Integer
Dim gg as Integer
Dim bb as Integer
selectedColour = 11124168 ' A9BDC8 - selected from the colour picker
rr = getR(selectedColour)
gg = getG(selectedColour)
bb = getB(selectedColour)

如果表中有计算字段,则查询将是:

SELECT colour 
FROM MyColours
WHERE B BETWEEN bb-4 AND bb+4 
AND G BETWEEN gg-4 AND gg+4 
AND R BETWEEN rr-4 AND rr+4 

如果您不希望计算域使用 VBA 函数:

SELECT colour 
FROM MyColours
WHERE getB(colour) BETWEEN bb-4 AND bb+4 
AND getG(Colour) BETWEEN gg-4 AND gg+4 
AND getR(Colour) BETWEEN rr-4 AND rr+4 
于 2016-03-22T01:45:17.193 回答