[AccessD] Color Number Format

Gustav Brock gustav at cactus.dk
Sun Apr 9 09:35:08 CDT 2017


Hi Rocky

I don't think that property is for you to change.
And the #000000 format is a CSS standard and used all over (outside VBA), so you better assimilate it.

/gustav
________________________________________
Fra: AccessD <accessd-bounces at databaseadvisors.com> på vegne af Rocky Smolin <rockysmolin at bchacc.com>
Sendt: 9. april 2017 16:18:54
Til: 'Access Developers discussion and problem solving'
Emne: Re: [AccessD] Color Number Format

Gustav:

So I discovered by accident (or brilliant deduction) last night that the RGB
representation in the property sheet with # was the reverse of the &H
representation in VBA.

Why would they do that?  Some programmer's sense of humor?

I think I'm going to switch to a simpler language like Mandarin or ancient
Aramaic. :)

But your code goes in my library.  Somehow I managed 20 years of Access
development without having to fiddle with this. But in 2010 because the
property sheet is in that #nnnnnn format I probably will again.

Is there no preference switch somewhere to have access display decimal in
the property sheet like good old Access 2003?

Thank you.

Rocky


-----Original Message-----
From: AccessD [mailto:accessd-bounces at databaseadvisors.com] On Behalf Of
Gustav Brock
Sent: Sunday, April 09, 2017 2:43 AM
To: 'Access Developers discussion and problem solving'; 'Off Topic'
Subject: Re: [AccessD] Color Number Format

Hi Rocky

The #112233 format is still in RGB sequence but it's a hex representation,
not the hex value.

The hex value will be &H332211 because Red is the "small" component.

Recently, I had a lot of similar conversions to do and made these small
functions to minimise the dull work:

<code>
' Calculate discrete RGB colours from a composite colour value and ' return
one component.
' Also, by reference, return all components.
'
' Examples:
'   Simple print of the components:
'
'   SomeColor = 813466
'   RGBComponent SomeColor
'   ' Debug Print:
'   ' 154           105           12
'
'   Get one component from a colour value:
'
'   Dim SomeColor   As Long
'   Dim Green       As Integer
'   SomeColor = 13466
'   Green = RGBComponent(SomeColor, vbGreen)
'   ' Green ->  52
'
'   Get all components from a colour value:
'
'   Dim SomeColor   As Long
'   Dim Red         As Integer
'   Dim Green       As Integer
'   Dim Blue        As Integer
'   SomeColor = 813466
'   RGBComponent SomeColor, , Red, Green, Blue
'   ' Red   -> 154
'   ' Green -> 105
'   ' Green ->  12
'
' 2017-03-26. Gustav Brock, Cactus Data ApS, CPH.
'
Public Function RGBComponent( _
    ByVal RGB As Long, _
    Optional ByVal Component As Long, _
    Optional ByRef Red As Integer, _
    Optional ByRef Green As Integer, _
    Optional ByRef Blue As Integer) _
    As Integer

    Dim Color   As Long

    If RGB <= 0 Then
        ' Return Black.
        Red = 0
        Green = 0
        Blue = 0
    Else
        ' Dissolve composite RGB into discrete colours.
        Red = RGB And vbRed
        Green = (RGB And vbGreen) / &H100
        Blue = (RGB And vbBlue) / &H10000
        ' Return chosen colour component.
        Select Case Component
            Case vbRed
                Color = Red
            Case vbGreen
                Color = Green
            Case vbBlue
                Color = Blue
            Case Else
                Color = vbBlack
        End Select
    End If

    Debug.Print Red, Green, Blue

    RGBComponent = Color

End Function


' Returns the numeric RGB value from an CSS RGB hex representation.
' Will accept strings with or without a leading octothorpe.
'
' Examples:
'   Color = RGBCompound("#9A690C")
'   ' Color = 813466
'   Color = RGBCompound("9A690C")
'   ' Color = 813466
'
' 2017-03-26. Gustav Brock, Cactus Data ApS, CPH.
'
Public Function RGBCompound( _
    ByVal HexRGB As String) _
    As Long

    ' Format of RGB hex strings.
    Const RGBPrefix As String = "#"
    Const Length    As Integer = 6
    ' Format of Hex values.
    Const HexPrefix As String = "&H"

    Dim Start       As Integer
    Dim Color       As Long

    If Mid(HexRGB, 1, 1) = RGBPrefix Then
        Start = 1
    End If
    If Len(HexRGB) = Start + Length Then
        Color = RGB( _
            HexPrefix & Mid(HexRGB, Start + 1, 2), _
            HexPrefix & Mid(HexRGB, Start + 3, 2), _
            HexPrefix & Mid(HexRGB, Start + 5, 2))
    End If

    RGBCompound = Color

End Function


' Returns the CSS hex representation of a decimal RGB value ' with or
without a leading octothorpe.
'
' Example:
'   CSSValue = RGBHex(813466)
'   ' CSSValue = "#9A690C"
'   CSSValue = RGBHex(813466, True)
'   ' CSSValue = "9A690C"
'
' 2017-03-26. Gustav Brock, Cactus Data ApS, CPH.
'
Public Function RGBHex( _
    ByVal Color As Long, _
    Optional ByVal NoPrefix As Boolean) _
    As String

    ' Format of RGB hex strings.
    Const RGBPrefix As String = "#"

    Dim Red     As Integer
    Dim Green   As Integer
    Dim Blue    As Integer
    Dim HexRGB  As String

    RGBComponent Color, , Red, Green, Blue

    If Not NoPrefix Then
        ' Set prefix.
        HexRGB = RGBPrefix
    End If
    ' Assemble compound string with leading zeroes for small values.
    HexRGB = HexRGB & _
        Right("0" & Hex(Red), 2) & _
        Right("0" & Hex(Green), 2) & _
        Right("0" & Hex(Blue), 2)

    RGBHex = HexRGB

End Function
</code>

/gustav

________________________________________
Fra: AccessD <accessd-bounces at databaseadvisors.com> på vegne af Rocky Smolin
<rockysmolin at bchacc.com>
Sendt: 9. april 2017 06:18:19
Til: 'Access Developers discussion and problem solving'; 'Off Topic'
Emne: [AccessD] Color Number Format

Dear List(s):

In A2003 colors in the property sheet were entered in decimal by default
(Back Color, Border Color, etc.)

In A2010 the default is Hex (#nnnnnn).

I would like it to default to decimal but can't find where that switch is.

Does anybody know?

MTIA
Rocky Smolin

Beach Access Software

760-683-5777

 <http://www.bchacc.com> www.bchacc.com

 <http://www.e-z-mrp.com> www.e-z-mrp.com

Skype: rocky.smolin


More information about the AccessD mailing list