FUNCTION TO_HEX, D, NCHAR ;+ ; NAME: ; TO_HEX ; PURPOSE: ; Translate a non-negative decimal integer to a hexadecimal string ; ; CALLING SEQUENCE: ; HEX = TO_HEX( D, [ NCHAR ] ) ; INPUTS: ; D - non-negative decimal integer, scalar or vector. If input as a ; string, (e.g. '32') then all leading blanks are removed. ; ; OPTIONAL INPUT: ; NCHAR - number of characters in the output hexadecimal string. ; If not supplied, then the hex string will contain no ; leading zeros. ; ; OUTPUT: ; HEX - hexadecimal translation of input integer, string ; ; EXAMPLES: ; IDL> A = TO_HEX([11,16]) ==> A = ['B','10'] ; IDL> A = TO_HEX(100,3) ==> A = '064' ; ; METHOD: ; The hexadecimal format code '(Z)' is used to convert. No parameter ; checking is done. ; PROCEDURES CALLED: ; FSTRING() -- needed prior to V5.4 if formatting more than 1024 values ; REVISION HISTORY: ; Written W. Landsman November, 1990 ; Converted to IDL V5.0 W. Landsman September 1997 ; Use FSTRING() for more than 1024 values March 2000 ; No FSTRING call needed if V5.4 or later September 2002 ;- if N_elements(nchar) EQ 0 then format = '(Z)' else begin ch = strtrim( nchar, 2 ) format = '(Z' + ch + '.' + ch + ')' endelse if (N_elements(d) GT 1024) and (!VERSION.RELEASE LT '5.4') then $ return, strtrim( fstring(d, FORM = format), 2) return, strtrim( string(d, FORM = format), 2) end