This example demonstrates a simple use of operator overloading with the [] (array indexing) operator. We create an object class (hexRGB_doc) whose only purpose is to provide an easy way to convert web-style hexadecimal color specifications to three-element RGB vectors.

The hexRGB_doc object definition and operator overloading code listed in this section is contained in the procedure file hexrgb_doc__define.pro, and is located in the examples/doc/objects subdirectory of the IDL distribution. To view the file in an IDL editor window, enter .EDIT hexrgb_doc__define.pro at the IDL command line.

The following code, located in hexrgb_doc__define.pro, defines the hexRGB_doc object and the overloaded [] (array indexing) operator method.

 

FUNCTION hexrgb_doc::_overloadBracketsRightSide, isRange, sub1
 
   ; Check to see that the input is a single, six-character string.
   ; If not, generate an error.
   IF (N_ELEMENTS(sub1) NE 1 || $
      SIZE(sub1, /TYPE) NE 7 || $
      STRLEN(sub1) NE 6 ) $
      THEN BEGIN
 
      MESSAGE, 'Input must be a single, six-character string'
 
   ENDIF ELSE BEGIN
 
   ; Read the input string, using the 'z' format code
   ; to convert from hexadecimal to floating-point values.
   READS, sub1, red, green, blue, FORMAT='(z2,z2,z2)'
 
   ; Create the return RGB array, converting to integer type.
   retval = FIX([red, green, blue])
 
   ENDELSE
 
   RETURN, retval
 
END
 
PRO hexrgb_doc__define
 
   STRUCT = { hexrgb_doc, $
   INHERITS IDL_Object }
 
END

The following code snippet creates a hexRGB_doc object and uses it to convert a hexadecimal color value to a three-element RGB vector.

c = hexrgb_doc()
PRINT, c['FF2C9D']

You could use this method to supply color values to IDL routines or keywords that expect a three-element RGB vector. For example:

p = PLOT(INDGEN(10), COLOR=c['FF00CC'])